*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);background-attachment:fixed;color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;overflow-x:hidden}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--primary-color:#10a37f;--primary-hover:#0d8a6b;--primary-light:#1a7f64;--secondary-color:#6b7280;--success-color:#10b981;--warning-color:#f59e0b;--error-color:#ef4444;--background-color:#fff;--surface-color:#f7f7f8;--surface-elevated:#fff;--surface-hover:#f0f0f0;--text-primary:#212121;--text-secondary:#6b7280;--text-muted:#9ca3af;--text-inverse:#fff;--border-color:#e5e7eb;--border-light:#f3f4f6;--border-radius:12px;--border-radius-sm:8px;--border-radius-lg:16px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;--shadow-glow:0 0 20px #10a37f4d;--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--transition-fast:0.15s ease-in-out;--transition-normal:0.3s ease-in-out;--transition-slow:0.5s ease-in-out;--z-dropdown:1000;--z-sticky:1020;--z-fixed:1030;--z-modal-backdrop:1040;--z-modal:1050;--z-popover:1060;--z-tooltip:1070}.container{margin:0 auto;max-width:1200px;padding:0 1rem;padding:0 var(--spacing-md)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-sm{gap:.5rem;gap:var(--spacing-sm)}.gap-md{gap:1rem;gap:var(--spacing-md)}.gap-lg{gap:1.5rem;gap:var(--spacing-lg)}.w-full{width:100%}.h-full{height:100%}.min-h-screen{min-height:100vh}.btn{align-items:center;border:none;border-radius:12px;border-radius:var(--border-radius);cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:.25rem;gap:var(--spacing-xs);justify-content:center;overflow:hidden;padding:.5rem 1rem;padding:var(--spacing-sm) var(--spacing-md);position:relative;text-decoration:none;transition:all .15s ease-in-out;transition:all var(--transition-fast)}.btn:disabled{cursor:not-allowed;opacity:.5;transform:none!important}.btn:active:not(:disabled){transform:translateY(1px)}.btn.btn-primary{background:linear-gradient(135deg,#10a37f,#1a7f64);background:linear-gradient(135deg,var(--primary-color) 0,var(--primary-light) 100%);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:#fff;color:var(--text-inverse)}.btn.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#0d8a6b,#10a37f);background:linear-gradient(135deg,var(--primary-hover) 0,var(--primary-color) 100%);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn.btn-primary:focus{box-shadow:0 0 20px #10a37f4d;box-shadow:var(--shadow-glow)}.btn.btn-secondary{background-color:#6b7280;background-color:var(--secondary-color);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:#fff;color:var(--text-inverse)}.btn.btn-secondary:hover:not(:disabled){background-color:#4b5563;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn.btn-outline{background-color:#0000;border:2px solid #10a37f;border:2px solid var(--primary-color);color:#10a37f;color:var(--primary-color)}.btn.btn-outline:hover:not(:disabled){background-color:#10a37f;background-color:var(--primary-color);color:#fff;color:var(--text-inverse);transform:translateY(-1px)}.btn.btn-ghost{background-color:#0000;border-radius:8px;border-radius:var(--border-radius-sm);color:#6b7280;color:var(--text-secondary)}.btn.btn-ghost:hover:not(:disabled){background-color:#f0f0f0;background-color:var(--surface-hover);color:#212121;color:var(--text-primary)}.btn.btn-sm{border-radius:8px;border-radius:var(--border-radius-sm);font-size:.75rem;padding:.25rem .5rem;padding:var(--spacing-xs) var(--spacing-sm)}.btn.btn-lg{border-radius:16px;border-radius:var(--border-radius-lg);font-size:1rem;padding:1rem 1.5rem;padding:var(--spacing-md) var(--spacing-lg)}.btn.btn-icon{border-radius:50%;height:40px;padding:.5rem;padding:var(--spacing-sm);width:40px}.btn.btn-icon.btn-sm{height:32px;padding:.25rem;padding:var(--spacing-xs);width:32px}.btn.btn-icon.btn-lg{height:48px;padding:1rem;padding:var(--spacing-md);width:48px}.input{background-color:#fff;background-color:var(--background-color);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;border-radius:var(--border-radius);color:#212121;color:var(--text-primary);font-size:.875rem;padding:.5rem 1rem;padding:var(--spacing-sm) var(--spacing-md);transition:border-color .2s ease-in-out;width:100%}.input:focus{border-color:#10a37f;border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a;outline:none}.input::placeholder{color:#9ca3af;color:var(--text-muted)}.card{background-color:#fff;background-color:var(--background-color);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;border-radius:var(--border-radius);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);overflow:hidden}.card.card-elevated{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;box-shadow:var(--shadow-md)}.card .card-header{background-color:#f7f7f8;background-color:var(--surface-color);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color)}.card .card-body,.card .card-footer,.card .card-header{padding:1rem;padding:var(--spacing-md)}.card .card-footer{background-color:#f7f7f8;background-color:var(--surface-color);border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color)}.spinner{animation:spin 1s linear infinite;border:2px solid #e5e7eb;border-top:2px solid #10a37f;border:2px solid var(--border-color);border-radius:50%;border-top-color:var(--primary-color);height:20px;width:20px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media(max-width:768px){.container{padding:0 .5rem;padding:0 var(--spacing-sm)}.btn{font-size:.8rem;padding:.5rem;padding:var(--spacing-sm)}.btn.btn-lg{font-size:.9rem;padding:.5rem 1rem;padding:var(--spacing-sm) var(--spacing-md)}.card .card-body,.card .card-footer,.card .card-header{padding:.5rem;padding:var(--spacing-sm)}body{font-size:14px}.input{font-size:16px}}@media(max-width:480px){.btn{font-size:.75rem;padding:.25rem .5rem;padding:var(--spacing-xs) var(--spacing-sm)}.card{border-radius:8px;border-radius:var(--border-radius-sm)}.card .card-body,.card .card-footer,.card .card-header{padding:.25rem;padding:var(--spacing-xs)}}@media(prefers-color-scheme:dark){:root{--background-color:#1a1a1a;--surface-color:#2d2d2d;--surface-elevated:#3a3a3a;--text-primary:#fff;--text-secondary:#b3b3b3;--text-muted:grey;--border-color:#404040;--border-light:#333}}.message{animation:fadeInUp .3s ease-out;display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);max-width:85%}.message.user{flex-direction:row-reverse;margin-left:auto}.message.user .message-content{background:linear-gradient(135deg,var(--primary-color) 0,var(--primary-light) 100%);box-shadow:var(--shadow-md);color:var(--text-inverse)}.message.user .message-content .message-author{color:#ffffffe6}.message.user .message-content .message-time{color:#ffffffb3}.message.assistant{margin-right:auto}.message.assistant .message-content{background:var(--surface-elevated);border:1px solid var(--border-light);box-shadow:var(--shadow-sm)}.message.assistant .message-content:hover{box-shadow:var(--shadow-md)}.message-avatar{align-items:center;background-color:var(--surface-color);border-radius:50%;color:var(--text-secondary);display:flex;flex-shrink:0;height:32px;justify-content:center;width:32px}.message.user .message-avatar{background-color:#fff3;color:#fff}.message.assistant .message-avatar{background-color:var(--primary-color);color:#fff}.message-content{border-radius:var(--border-radius);box-shadow:var(--shadow-sm);flex:1 1;padding:var(--spacing-sm) var(--spacing-md)}.message-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--spacing-xs)}.message-author{color:var(--text-secondary);font-size:.75rem;font-weight:600}.message-time{align-items:center;color:var(--text-muted);display:flex;font-size:.75rem;gap:2px}.message-body{line-height:1.6}.message-body .message-text{color:inherit;font-size:.875rem}.markdown-paragraph{font-size:.875rem;line-height:1.6;margin:0 0 var(--spacing-sm) 0}.markdown-paragraph:last-child{margin-bottom:0}.markdown-list{margin:var(--spacing-sm) 0;padding-left:var(--spacing-md)}.markdown-list .markdown-list-item{font-size:.875rem;line-height:1.5;margin-bottom:var(--spacing-xs)}.markdown-strong{font-weight:600}.markdown-emphasis{font-style:italic}.markdown-blockquote{background-color:var(--surface-color);border-left:3px solid var(--primary-color);border-radius:0 var(--border-radius) var(--border-radius) 0;font-style:italic;margin:var(--spacing-sm) 0;padding:var(--spacing-sm) var(--spacing-md)}.markdown-link{align-items:center;color:inherit;display:inline-flex;gap:2px;text-decoration:underline}.markdown-link:hover{opacity:.8}code{background-color:var(--surface-color);border-radius:3px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.8em;padding:2px 4px}pre{border-radius:var(--border-radius);margin:var(--spacing-sm) 0;overflow-x:auto}pre code{background:none;padding:0}.message-sources{border-top:1px solid #ffffff1a;margin-top:var(--spacing-sm);padding-top:var(--spacing-sm)}.message.user .message-sources{border-top-color:#fff3}.message.assistant .message-sources{border-top-color:var(--border-color)}.sources-header{margin-bottom:var(--spacing-xs)}.sources-title{color:var(--text-muted);font-size:.75rem}.message.user .sources-title{color:#ffffffb3}.sources-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.source-link{background-color:#ffffff1a;border-radius:4px;text-decoration:none;transition:background-color .2s ease-in-out}.source-link:hover{background-color:#fff3}.message.assistant .source-link{background-color:var(--surface-color)}.message.assistant .source-link:hover{background-color:var(--border-color)}.source-title{color:inherit;flex:1 1;font-weight:500;white-space:nowrap}.source-domain{color:var(--text-muted);flex-shrink:0;font-size:.7rem}.message.user .source-domain{color:#ffffffb3}.more-sources{color:var(--text-muted);font-size:.7rem;font-style:italic;padding:var(--spacing-xs) var(--spacing-sm)}.message.user .more-sources{color:#ffffffb3}@media(max-width:768px){.message{max-width:90%}.message-content{padding:var(--spacing-sm)}.message-avatar{height:28px;width:28px}.markdown-list .markdown-list-item,.markdown-paragraph{font-size:.8rem}.source-link{font-size:.7rem;padding:2px var(--spacing-xs)}}.message-list{display:flex;flex-direction:column;gap:var(--spacing-md);min-height:100%}.message-wrapper{display:flex;width:100%}.message-wrapper.user{justify-content:flex-end}.message-wrapper.assistant{justify-content:flex-start}.message-wrapper.typing{opacity:.7}.empty-messages{align-items:center;display:flex;height:100%;justify-content:center;min-height:400px;width:70%}.empty-content{max-width:500px;padding:var(--spacing-xl);text-align:center}.empty-icon{color:var(--primary-color);margin-bottom:var(--spacing-lg)}.empty-title{color:var(--text-primary);font-size:1.5rem;font-weight:600;margin-bottom:var(--spacing-md)}.empty-message{color:var(--text-secondary);font-size:1rem;line-height:1.6;margin-bottom:var(--spacing-lg)}.empty-examples{background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:var(--spacing-md);text-align:left}.examples-title{color:var(--text-primary);font-size:.875rem;font-weight:600;margin-bottom:var(--spacing-sm)}.examples-list{list-style:none;margin:0;padding:0}.examples-list li{border-bottom:1px solid var(--border-color);color:var(--text-secondary);font-size:.875rem;padding:var(--spacing-xs) 0}.examples-list li:last-child{border-bottom:none}.examples-list li:before{content:"💡";margin-right:var(--spacing-xs)}.typing-indicator{align-items:center;display:flex;gap:4px;padding:var(--spacing-sm) 0}.typing-dot{animation:typing 1.4s ease-in-out infinite;background-color:var(--text-muted);border-radius:50%;height:8px;width:8px}.typing-dot:first-child{animation-delay:-.32s}.typing-dot:nth-child(2){animation-delay:-.16s}@keyframes typing{0%,80%,to{opacity:.5;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}@media(max-width:768px){.empty-content{padding:var(--spacing-lg)}.empty-title{font-size:1.25rem}.empty-message{font-size:.875rem}.empty-examples{padding:var(--spacing-sm)}.examples-list li{font-size:.8rem}}.message-input{width:100%}.input-container{display:flex;flex-direction:column;gap:var(--spacing-xs)}.input-wrapper{align-items:flex-end;background:var(--surface-elevated);border:2px solid var(--border-light);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-sm);display:flex;gap:var(--spacing-sm);padding:var(--spacing-md);transition:all var(--transition-fast)}.input-wrapper:focus-within{border-color:var(--primary-color);box-shadow:var(--shadow-glow);transform:translateY(-1px)}.input-wrapper:hover{border-color:var(--border-color);box-shadow:var(--shadow-md)}.message-textarea{background:#0000;border:none;color:var(--text-primary);flex:1 1;font-family:inherit;font-size:.875rem;line-height:1.5;max-height:120px;min-height:20px;outline:none;padding:0;resize:none}.message-textarea::placeholder{color:var(--text-muted)}.message-textarea:disabled{cursor:not-allowed;opacity:.5}.message-textarea::-webkit-scrollbar{width:4px}.message-textarea::-webkit-scrollbar-track{background:#0000}.message-textarea::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:2px}.message-textarea::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.input-actions{align-items:center;display:flex;flex-shrink:0;gap:var(--spacing-xs)}.attach-btn{opacity:.7;padding:var(--spacing-xs)}.attach-btn:hover:not(:disabled){opacity:1}.send-btn{padding:var(--spacing-xs);transition:all .2s ease-in-out}.send-btn:disabled{cursor:not-allowed;opacity:.5}.send-btn.can-send{background-color:var(--primary-color)}.send-btn.can-send:hover:not(:disabled){background-color:var(--primary-hover);transform:scale(1.05)}.input-footer{align-items:center;color:var(--text-muted);display:flex;font-size:.75rem;justify-content:space-between;padding:0 var(--spacing-xs)}.char-count{font-weight:500}.char-count.warning{color:var(--warning-color)}.char-count.error{color:var(--error-color)}.input-hint{font-size:.7rem}@media(max-width:768px){.input-wrapper{padding:var(--spacing-xs)}.message-textarea{font-size:.8rem}.input-footer{font-size:.7rem}.attach-btn,.input-footer .input-hint{display:none}}.send-btn{overflow:hidden;position:relative}.send-btn:before{background-color:#ffffff4d;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .3s ease-in-out,height .3s ease-in-out;width:0}.send-btn:active:before{height:100px;width:100px}.message-textarea:focus{outline:none}.input-wrapper:has(.message-textarea:disabled){cursor:not-allowed;opacity:.6}.sources-list{background-color:var(--surface-color);border-top:1px solid var(--border-color);max-height:300px;overflow-y:auto}.sources-header{background-color:var(--background-color);border-bottom:1px solid var(--border-color);justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);position:-webkit-sticky;position:sticky;top:0;z-index:10}.sources-header,.sources-title{align-items:center;display:flex}.sources-title{color:var(--text-primary);font-size:.875rem;font-weight:600;gap:var(--spacing-xs)}.close-btn{opacity:.7;padding:var(--spacing-xs)}.close-btn:hover{opacity:1}.sources-content{flex-direction:column;gap:var(--spacing-sm)}.source-item,.sources-content{display:flex;padding:var(--spacing-sm)}.source-item{align-items:center;background-color:var(--background-color);border:1px solid var(--border-color);border-radius:var(--border-radius);justify-content:space-between;transition:all .2s ease-in-out}.source-item:hover{border-color:var(--primary-color);box-shadow:var(--shadow-sm)}.source-header{flex:1 1;min-width:0}.source-title{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:var(--text-primary);display:-webkit-box;font-size:.875rem;font-weight:600;line-height:1.4;margin:0 0 var(--spacing-xs) 0;overflow:hidden;text-overflow:ellipsis}.source-meta{align-items:center;color:var(--text-muted);display:flex;font-size:.75rem;gap:var(--spacing-sm)}.source-domain{font-weight:500}.source-date,.source-domain{align-items:center;display:flex;gap:2px}.source-actions{flex-shrink:0;margin-left:var(--spacing-sm)}.source-link{align-items:center;display:flex;font-size:.75rem;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm)}.source-link:hover{transform:translateY(-1px)}.sources-list::-webkit-scrollbar{width:6px}.sources-list::-webkit-scrollbar-track{background:var(--surface-color)}.sources-list::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.sources-list::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media(max-width:768px){.sources-list{max-height:250px}.sources-header{padding:var(--spacing-xs) var(--spacing-sm)}.sources-content{padding:var(--spacing-xs)}.source-item{align-items:flex-start;flex-direction:column;gap:var(--spacing-sm)}.source-header{width:100%}.source-actions{margin-left:0;width:100%}.source-actions .source-link{justify-content:center;width:100%}.source-meta{align-items:flex-start;flex-direction:column;gap:var(--spacing-xs)}}.source-item{animation:slideInUp .3s ease-out}@keyframes slideInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chat-interface{background:var(--background-color);position:relative}.chat-container,.chat-interface{display:flex;flex-direction:column;height:100%}.chat-container{background:#0000;border-radius:0;box-shadow:none;flex:1 1;min-width:0;overflow:hidden;width:100%}.chat-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#ffffffe6,#f8fafce6);border-bottom:1px solid #0000000d;border-radius:20px 20px 0 0;justify-content:space-between;padding:var(--spacing-lg);position:-webkit-sticky;position:sticky;top:0;z-index:100}.chat-header,.chat-title{align-items:center;display:flex}.chat-title{gap:var(--spacing-md)}.chat-title h2{color:var(--text-primary);font-size:1.25rem;font-weight:600;margin:0}.connection-status{align-items:center;display:flex;gap:var(--spacing-xs)}.connection-status .status-indicator{border-radius:50%;height:8px;width:8px}.connection-status .status-indicator.online{background-color:var(--success-color);box-shadow:0 0 0 2px #10b98133}.connection-status .status-indicator.offline{background-color:var(--error-color)}.connection-status .status-text{color:var(--text-secondary);font-size:.75rem;font-weight:500}.chat-actions{align-items:center;display:flex;gap:var(--spacing-sm)}.messages-container{display:flex;flex:1 1;flex-direction:column;gap:var(--spacing-md);max-height:calc(100vh - 200px);min-width:0;overflow-x:hidden;overflow-y:auto;padding:var(--spacing-md);width:100%}.messages-container::-webkit-scrollbar{width:6px}.messages-container::-webkit-scrollbar-track{background:var(--surface-color)}.messages-container::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.messages-container::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.sources-panel{background-color:var(--surface-color);border-top:1px solid var(--border-color);overflow:hidden}.input-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#ffffffe6,#f8fafce6);border-radius:0 0 20px 20px;border-top:1px solid #0000000d;padding:var(--spacing-lg)}.loading-container{height:200px}.empty-state{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:var(--spacing-lg);justify-content:center;min-height:400px;padding:var(--spacing-xl);text-align:center;width:100%}.empty-state .empty-icon{color:var(--text-muted);font-size:4rem}.empty-state .empty-title{color:var(--text-primary);font-size:1.5rem;font-weight:600}.empty-state .empty-message{color:var(--text-secondary);line-height:1.6;max-width:400px}.empty-state .empty-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-md)}@media(max-width:768px){.chat-container{height:100vh}.chat-header{padding:var(--spacing-sm) var(--spacing-md)}.chat-header .chat-title{gap:var(--spacing-sm)}.chat-header .chat-title h2{font-size:1.125rem}.chat-header .connection-status .status-text{display:none}.input-container,.messages-container{padding:var(--spacing-sm) var(--spacing-md)}.sources-panel{border:1px solid var(--border-color);border-radius:var(--border-radius);margin:0 var(--spacing-md)}}.message-enter{opacity:0;transform:translateY(20px)}.message-enter-active{opacity:1;transform:translateY(0);transition:opacity .3s ease-in-out,transform .3s ease-in-out}.chat-container:focus-within .chat-header{box-shadow:0 2px 4px #0000001a}.header{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid #ffffff1a;box-shadow:0 4px 20px #0000001a;left:0;position:fixed;right:0;top:0;transition:all .3s ease;z-index:1000}.header-content{height:70px;justify-content:space-between;margin:0 auto;max-width:1400px;padding:var(--spacing-md) var(--spacing-lg)}.header-content,.header-left{align-items:center;display:flex}.header-left{gap:var(--spacing-md)}.sidebar-toggle{align-items:center;display:flex;justify-content:center;padding:var(--spacing-xs)}@media(min-width:769px){.sidebar-toggle{display:none}}.header-title{align-items:center;display:flex;gap:var(--spacing-sm)}.header-title .header-icon{color:#fff;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));font-size:1.8rem}.header-title h1{color:#fff;font-size:1.5rem;font-weight:700;margin:0;text-shadow:0 2px 4px #0000004d}.header-title .header-subtitle{background-color:var(--surface-color);border-radius:4px;color:var(--text-muted);font-size:.75rem;font-weight:500;padding:2px 6px}.header-right{gap:var(--spacing-md)}.header-right,.header-status{align-items:center;display:flex}.header-status{gap:var(--spacing-xs)}.header-status .status-indicator{border-radius:50%;height:8px;width:8px}.header-status .status-indicator.online{background-color:var(--success-color);box-shadow:0 0 0 2px #10b98133}.header-status .status-indicator.offline{background-color:var(--error-color)}.header-status .status-indicator.connecting{animation:pulse 2s infinite;background-color:var(--warning-color)}.header-status .status-text{color:#ffffffe6;font-size:.75rem;font-weight:500;text-shadow:0 1px 2px #0000004d}@media(max-width:768px){.header-content{padding:var(--spacing-sm)}.header-title h1{font-size:1.125rem}.header-status .status-text,.header-title .header-subtitle{display:none}}.sidebar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(180deg,#f8fafc,#e2e8f0);border-right:1px solid #0000001a;box-shadow:var(--shadow-xl);display:flex;flex-direction:column;height:calc(100vh - 70px);left:0;overflow:hidden;position:fixed;top:70px;transform:translateX(-100%);transition:transform var(--transition-normal);width:250px;z-index:999}.sidebar.open{transform:translateX(0)}@media(min-width:769px){.sidebar{border-radius:0 var(--border-radius-lg) var(--border-radius-lg) 0;box-shadow:var(--shadow-md);height:auto;margin:var(--spacing-sm);margin-right:0;min-height:calc(100vh - 60px);position:static;transform:translateX(0)}}.sidebar-overlay.active{display:block}@media(min-width:769px){.sidebar-overlay{display:none!important}}.sidebar-header{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;border-bottom:1px solid #0000001a;display:flex;flex-shrink:0;justify-content:space-between;padding:var(--spacing-md);position:-webkit-sticky;position:sticky;top:0;z-index:10}.sidebar-header h2{color:var(--text-primary);font-size:1.125rem;font-weight:600;margin:0}@media(min-width:769px){.sidebar-header .btn{display:none}}.sidebar-content{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.new-session-btn{flex-shrink:0;margin:var(--spacing-md);width:calc(100% - var(--spacing-md)*2)}.sessions-list{flex:1 1;min-height:0;overflow-x:hidden;overflow-y:auto;padding:0 var(--spacing-md)}.sessions{display:flex;flex-direction:column;gap:var(--spacing-xs)}.session-item{align-items:center;background:#ffffffb3;border:1px solid #0000;border-radius:12px;cursor:pointer;display:flex;margin-bottom:var(--spacing-xs);padding:var(--spacing-md);transition:all .3s ease}.session-item:hover{background:#ffffffe6;border-color:#667eea4d;box-shadow:0 4px 12px #0000001a;transform:translateY(-1px)}.session-item.active{background:linear-gradient(135deg,#667eea1a,#764ba21a);border-color:#667eea;box-shadow:0 4px 12px #667eea33}.session-item.active .session-title{color:#667eea;font-weight:600}.session-info{flex:1 1;min-width:0}.session-title{align-items:center;color:var(--text-primary);display:flex;font-size:.875rem;font-weight:500;gap:var(--spacing-xs);margin-bottom:2px}.session-title span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.session-meta{align-items:center;color:var(--text-muted);display:flex;font-size:.75rem;justify-content:space-between}.session-count{font-weight:500}.session-date{align-items:center;display:flex;gap:2px}.sidebar-footer{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;border-top:1px solid #0000001a;flex-shrink:0;padding:var(--spacing-md)}.sidebar-stats{text-align:center}.sidebar-stats .stats-text{color:var(--text-muted);font-size:.75rem;font-weight:500}.empty-container,.loading-container{gap:var(--spacing-sm);padding:var(--spacing-xl)}.empty-container .empty-icon{margin-bottom:var(--spacing-sm)}.empty-container .empty-message{color:var(--text-primary);font-size:.875rem;font-weight:500}.empty-container .empty-submessage{color:var(--text-muted);font-size:.75rem}.sessions-list::-webkit-scrollbar{width:4px}.sessions-list::-webkit-scrollbar-track{background:#0000}.sessions-list::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:2px}.sessions-list::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media(max-width:768px){.sidebar{max-width:280px;width:100%}.sidebar-header{padding:var(--spacing-sm) var(--spacing-md)}.new-session-btn{margin:var(--spacing-sm) var(--spacing-md)}.sessions-list{padding:0 var(--spacing-sm)}}.app{background:var(--surface-color);display:flex;flex-direction:column;min-height:100vh;position:relative}.app:before{background:radial-gradient(circle at 20% 80%,#10a37f1a 0,#0000 50%),radial-gradient(circle at 80% 20%,#10a37f1a 0,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:fixed;right:0;top:0;z-index:-1}.app-content{margin-top:70px;position:relative}.app-content,.main-content{display:flex;flex:1 1;height:calc(100vh - 70px)}.main-content{background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid #fff3;border-radius:20px 20px 0 0;box-shadow:0 8px 32px #0000001a;flex-direction:column;margin:var(--spacing-sm);margin-top:0;min-width:0;overflow:hidden;transition:margin-left var(--transition-normal);width:calc(100% - 250px - var(--spacing-sm)*2)}@media(max-width:768px){.main-content{border-radius:0;height:calc(100vh - 70px);margin:0;width:100%}}.sidebar-overlay{background-color:#00000080;bottom:0;display:none;left:0;position:fixed;right:0;top:0;z-index:998}@media(max-width:768px){.sidebar-overlay.active{display:block}}.loading-container{align-items:center;display:flex;flex-direction:column;gap:var(--spacing-md);justify-content:center;min-height:200px}.loading-container .loading-text{color:var(--text-secondary);font-size:.875rem}.error-container{align-items:center;display:flex;flex-direction:column;gap:var(--spacing-md);justify-content:center;min-height:200px;text-align:center}.error-container .error-icon{color:var(--error-color);font-size:3rem}.error-container .error-title{color:var(--text-primary);font-size:1.25rem;font-weight:600}.error-container .error-message{color:var(--text-secondary);max-width:400px}.error-container .error-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.empty-container{align-items:center;display:flex;flex-direction:column;gap:var(--spacing-md);justify-content:center;min-height:300px;text-align:center}.empty-container .empty-icon{color:var(--text-muted);font-size:4rem}.empty-container .empty-title{color:var(--text-primary);font-size:1.5rem;font-weight:600}.empty-container .empty-message{color:var(--text-secondary);max-width:400px}.empty-container .empty-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-lg)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{transform:translateX(-100%)}to{transform:translateX(0)}}@keyframes slideOut{0%{transform:translateX(0)}to{transform:translateX(-100%)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes glow{0%,to{box-shadow:var(--shadow-md)}50%{box-shadow:var(--shadow-glow)}}.fade-in{animation:fadeIn .3s ease-in-out}.slide-in{animation:slideIn .3s ease-in-out}.slide-out{animation:slideOut .3s ease-in-out}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--surface-color)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}@media print{.app{background:#fff}.header,.sidebar{display:none}.main-content{margin:0}}
/*# sourceMappingURL=main.2a47dd29.css.map*/