@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--color-bg-primary:#0a0a0f;--color-bg-secondary:#12121a;--color-bg-tertiary:#1a1a24;--color-bg-glass:#1a1a2499;--color-bg-glass-hover:#242434b3;--color-accent-primary:#6366f1;--color-accent-secondary:#8b5cf6;--color-accent-tertiary:#a78bfa;--color-accent-gradient:linear-gradient(135deg,#6366f1 0%,#8b5cf6 50%,#a78bfa 100%);--color-accent-glow:#6366f166;--color-text-primary:#f4f4f5;--color-text-secondary:#a1a1aa;--color-text-muted:#71717a;--color-text-inverse:#0a0a0f;--color-success:#22c55e;--color-warning:#f59e0b;--color-error:#ef4444;--color-info:#3b82f6;--color-border:#ffffff14;--color-border-hover:#ffffff26;--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 4px 16px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-glow:0 0 40px var(--color-accent-glow);--sidebar-width:280px;--header-height:64px;--input-height:56px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--transition-fast:.15s cubic-bezier(.4,0,.2,1);--transition-normal:.25s cubic-bezier(.4,0,.2,1);--transition-slow:.4s cubic-bezier(.4,0,.2,1);--font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-size-xs:.75rem;--font-size-sm:.875rem;--font-size-md:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:2rem}[data-theme=light]{--color-bg-primary:#f8fafc;--color-bg-secondary:#fff;--color-bg-tertiary:#f1f5f9;--color-bg-glass:#ffffffb3;--color-bg-glass-hover:#ffffffe6;--color-text-primary:#0f172a;--color-text-secondary:#475569;--color-text-muted:#94a3b8;--color-text-inverse:#fff;--color-border:#00000014;--color-border-hover:#00000026;--shadow-sm:0 2px 8px #0000000d;--shadow-md:0 4px 16px #00000014;--shadow-lg:0 8px 32px #0000001a}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-family);font-size:var(--font-size-md);color:var(--color-text-primary);background:var(--color-bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;line-height:1.6}#root{flex-direction:column;min-height:100vh;display:flex}.app-background{z-index:-1;background:var(--color-bg-primary);position:fixed;inset:0;overflow:hidden}.app-background:before{content:"";background:radial-gradient(circle,var(--color-accent-primary)0%,transparent 70%);opacity:.15;width:600px;height:600px;animation:20s ease-in-out infinite float;position:absolute;top:-200px;right:-200px}.app-background:after{content:"";background:radial-gradient(circle,var(--color-accent-secondary)0%,transparent 70%);opacity:.1;width:500px;height:500px;animation:25s ease-in-out infinite reverse float;position:absolute;bottom:-150px;left:-150px}@keyframes float{0%,to{transform:translate(0)rotate(0)}25%{transform:translate(50px,50px)rotate(5deg)}50%{transform:translateY(100px)rotate(0)}75%{transform:translate(-50px,50px)rotate(-5deg)}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border-hover);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}a{color:var(--color-accent-tertiary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-accent-primary)}button{font-family:inherit;font-size:inherit;cursor:pointer;color:inherit;background:0 0;border:none}button:disabled{cursor:not-allowed;opacity:.5}input,textarea{font-family:inherit;font-size:inherit;color:inherit;background:0 0;border:none;outline:none}input::placeholder,textarea::placeholder{color:var(--color-text-muted)}.glass{background:var(--color-bg-glass);-webkit-backdrop-filter:blur(20px);border:1px solid var(--color-border)}.glass-hover:hover{background:var(--color-bg-glass-hover);border-color:var(--color-border-hover)}.gradient-text{background:var(--color-accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.btn-primary{background:var(--color-accent-gradient);color:#fff;border-radius:var(--radius-md);transition:all var(--transition-normal);box-shadow:var(--shadow-sm);justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-weight:600;display:inline-flex}.btn-primary:hover:not(:disabled){box-shadow:var(--shadow-glow);transform:translateY(-2px)}.btn-secondary{background:var(--color-bg-glass);color:var(--color-text-primary);border-radius:var(--radius-md);border:1px solid var(--color-border);transition:all var(--transition-normal);justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-weight:500;display:inline-flex}.btn-secondary:hover:not(:disabled){background:var(--color-bg-glass-hover);border-color:var(--color-border-hover)}.btn-icon{border-radius:var(--radius-md);width:40px;height:40px;color:var(--color-text-secondary);transition:all var(--transition-fast);background:0 0;justify-content:center;align-items:center;display:flex}.btn-icon:hover:not(:disabled){background:var(--color-bg-glass);color:var(--color-text-primary)}.loading-dots{gap:4px;display:flex}.loading-dots span{background:var(--color-accent-primary);border-radius:50%;width:8px;height:8px;animation:1.4s ease-in-out infinite both bounce}.loading-dots span:first-child{animation-delay:-.32s}.loading-dots span:nth-child(2){animation-delay:-.16s}.loading-dots span:nth-child(3){animation-delay:0s}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn var(--transition-normal)forwards}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.slide-in{animation:slideIn var(--transition-normal)forwards}.auth-page{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex;position:relative}.auth-container{background:var(--color-bg-glass);-webkit-backdrop-filter:blur(24px);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:420px;box-shadow:var(--shadow-lg);padding:40px}.auth-header{text-align:center;margin-bottom:32px}.auth-logo{font-size:var(--font-size-2xl);align-items:center;gap:12px;margin-bottom:24px;font-weight:700;display:inline-flex}.auth-logo-img{object-fit:contain;width:48px;height:48px;animation:2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}.auth-title{font-size:var(--font-size-2xl);color:var(--color-text-primary);margin-bottom:8px;font-weight:700}.auth-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.auth-form{flex-direction:column;gap:16px;display:flex}.auth-error{border-radius:var(--radius-md);color:var(--color-error);font-size:var(--font-size-sm);text-align:center;background:#ef44441a;border:1px solid #ef44444d;padding:12px 16px}.input-group{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-fast);align-items:center;display:flex;position:relative}.input-group:focus-within{border-color:var(--color-accent-primary);box-shadow:0 0 0 3px var(--color-accent-glow)}.input-icon{width:48px;height:48px;color:var(--color-text-muted);flex-shrink:0;justify-content:center;align-items:center;display:flex}.input-group input{height:48px;font-size:var(--font-size-md);flex:1;padding:0 16px 0 0}.input-action{width:48px;height:48px;color:var(--color-text-muted);transition:color var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.input-action:hover{color:var(--color-text-primary)}.auth-submit{width:100%;height:48px;margin-top:8px}.auth-divider{align-items:center;gap:16px;margin:24px 0;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--color-border);flex:1;height:1px}.auth-divider span{font-size:var(--font-size-sm);color:var(--color-text-muted);white-space:nowrap}.auth-google{width:100%;height:48px}.auth-footer{text-align:center;font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:24px}.auth-footer a{font-weight:600}@media (max-width:480px){.auth-container{padding:24px}.auth-logo,.auth-title{font-size:var(--font-size-xl)}}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;animation:fadeIn var(--transition-fast)forwards;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);flex-direction:column;width:95%;max-width:900px;max-height:85vh;animation:.3s ease-out slideUp;display:flex;overflow:hidden;box-shadow:20px 20px 60px #00000080}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{border-bottom:1px solid var(--color-border);background:var(--color-bg-secondary);flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-body{flex-direction:column;flex:1;gap:32px;padding:24px;display:flex;overflow-y:auto}.settings-section{flex-direction:column;display:flex}.section-header{color:var(--color-text-primary);align-items:center;gap:12px;margin-bottom:8px;display:flex}.section-header h3{font-size:var(--font-size-lg);font-weight:600}.section-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:16px;line-height:1.5}.section-description a{color:var(--color-accent-tertiary);font-weight:500;text-decoration:none}.section-description a:hover{text-decoration:underline}.api-key-input{gap:12px;display:flex}.api-key-input input{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-text-primary);flex:1;padding:12px 16px;font-family:monospace}.api-key-input input:focus{border-color:var(--color-accent-primary);box-shadow:0 0 0 3px var(--color-accent-glow);outline:none}.status-badge{border-radius:var(--radius-full);font-size:var(--font-size-xs);align-items:center;gap:6px;margin-top:12px;padding:6px 12px;font-weight:500;display:inline-flex}.status-badge.success{color:var(--color-success);background:#22c55e1a}.status-badge.warning{color:var(--color-warning);background:#f59e0b1a}.models-filter-bar{gap:12px;margin-bottom:20px;display:flex}.search-input-wrapper{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-fast);flex:2;align-items:center;padding:0 16px;display:flex;position:relative}.search-input-wrapper:focus-within{border-color:var(--color-accent-primary);box-shadow:0 0 0 3px var(--color-accent-glow)}.search-input-wrapper input{color:var(--color-text-primary);font-size:var(--font-size-sm);background:0 0;border:none;outline:none;flex:1;padding:12px}.search-input-wrapper svg{color:var(--color-text-muted)}.provider-select-wrapper{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-fast);flex:1;align-items:center;padding:0 16px;display:flex;position:relative}.provider-select-wrapper:focus-within{border-color:var(--color-accent-primary)}.provider-select-wrapper svg{color:var(--color-text-muted);pointer-events:none}.provider-select{color:var(--color-text-primary);font-size:var(--font-size-sm);cursor:pointer;appearance:none;background:0 0;border:none;outline:none;flex:1;padding:12px 8px}.provider-select option{background:var(--color-bg-secondary);color:var(--color-text-primary)}.clear-search{color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-sm);padding:4px}.models-grid-header{color:var(--color-text-muted);margin-bottom:12px;font-size:12px}.models-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.model-option{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-normal);text-align:left;flex-direction:column;min-width:0;padding:16px;display:flex}.model-option:hover{border-color:var(--color-border-hover);background:var(--color-bg-glass-hover);transform:translateY(-2px)}.model-option.selected{border-color:var(--color-accent-primary);box-shadow:0 0 0 1px var(--color-accent-primary);background:#6366f114}.model-option-header{justify-content:space-between;align-items:flex-start;width:100%;margin-bottom:8px;display:flex}.model-option-header .model-name{font-weight:600;font-size:var(--font-size-sm);color:var(--color-text-primary);word-break:break-word;line-height:1.4}.selected-icon{color:var(--color-accent-primary)}.model-option-footer{justify-content:space-between;align-items:center;width:100%;display:flex}.model-info-left{align-items:center;gap:8px;display:flex}.model-provider{text-transform:uppercase;color:var(--color-text-muted);border-radius:var(--radius-sm);background:#ffffff0d;padding:2px 6px;font-size:10px;font-weight:700}.model-context{color:var(--color-text-muted);font-size:11px}.model-capabilities{gap:6px;display:flex}.capability-tag{width:22px;height:22px;color:var(--color-text-muted);transition:all var(--transition-fast);background:#ffffff0d;border-radius:4px;justify-content:center;align-items:center;display:flex}.capability-tag.vision{color:#3b82f6;background:#3b82f61a}.capability-tag.tools{color:#8b5cf6;background:#8b5cf61a}.model-option:hover .capability-tag{transform:scale(1.1)}.no-models-found{color:var(--color-text-secondary);text-align:center;background:var(--color-bg-tertiary);border-radius:var(--radius-xl);border:1px dashed var(--color-border);flex-direction:column;grid-column:1/-1;align-items:center;gap:16px;padding:48px;display:flex}.btn-link{color:var(--color-accent-primary);cursor:pointer;font-size:var(--font-size-sm);background:0 0;border:none;text-decoration:underline}@media (max-width:640px){.modal-content{border-radius:0;max-width:100%;height:100vh;max-height:100vh;margin:0}.models-filter-bar{flex-direction:column}.models-grid{grid-template-columns:1fr}}.api-key-input-container{flex-direction:column;gap:12px;display:flex}.save-option{align-items:center;display:flex}.checkbox-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;display:flex}.checkbox-label input{accent-color:var(--color-accent-primary);cursor:pointer;width:16px;height:16px}.saved-keys-list{border-top:1px solid var(--color-border);flex-direction:column;gap:8px;margin-top:16px;padding-top:16px;display:flex}.saved-keys-list h4{font-size:var(--font-size-sm);color:var(--color-text-primary);margin-bottom:8px}.saved-key-item{background:var(--color-bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--color-border);transition:all var(--transition-fast);justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.saved-key-item:hover{border-color:var(--color-border-hover);background:var(--color-bg-glass-hover)}.saved-key-item.active{border-color:var(--color-accent-primary);box-shadow:0 0 0 1px var(--color-accent-primary);background:#6366f114}.active-badge{background:var(--color-accent-primary);color:#fff;text-transform:uppercase;letter-spacing:.5px;border-radius:4px;margin-left:8px;padding:2px 6px;font-size:10px;font-weight:700}.key-info{flex-direction:column;gap:2px;display:flex}.key-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);font-weight:500}.key-mask{font-family:monospace;font-size:var(--font-size-sm);color:var(--color-text-primary)}.key-actions{align-items:center;gap:8px;display:flex}.btn-small{background:var(--color-accent-primary);color:#fff;border-radius:var(--radius-sm);font-size:var(--font-size-xs);cursor:pointer;border:none;padding:4px 10px;font-weight:500;transition:background .2s}.btn-small:hover{background:var(--color-accent-secondary)}.btn-icon-small{color:var(--color-text-muted);border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;transition:all .2s;display:flex}.btn-icon-small:hover{color:var(--color-danger);background:#ef44441a}.tools-modal{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:900px;height:85vh;box-shadow:var(--shadow-2xl);flex-direction:column;display:flex;overflow:hidden}.modal-header{border-bottom:1px solid var(--color-border);background:var(--color-bg-secondary);z-index:10;flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-title{align-items:center;gap:12px;display:flex}.modal-title h2{font-size:var(--font-size-lg);font-weight:600}.modal-title svg{color:var(--color-accent-primary)}.modal-body{flex:1;padding:24px;overflow-y:auto}.tools-actions{background:var(--color-bg-tertiary);border-radius:var(--radius-lg);border:1px solid var(--color-border);justify-content:space-between;align-items:center;gap:24px;margin-bottom:32px;padding:16px 20px;display:flex}.tools-hint{font-size:var(--font-size-sm);color:var(--color-text-secondary);flex:1;align-items:center;gap:10px;line-height:1.5;display:flex}.tools-hint svg{color:var(--color-accent-tertiary);flex-shrink:0}.action-buttons{flex-shrink:0;gap:12px;display:flex}.tools-grid{grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:20px;display:grid}.tool-card{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-fast);flex-direction:column;display:flex;overflow:hidden}.tool-card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-md);transform:translateY(-2px)}.tool-card.system-tool{border-left:3px solid var(--color-border-hover)}.tool-card.custom-tool{border-left:3px solid var(--color-accent-primary);background:var(--color-bg-tertiary)}.tool-header{border-bottom:1px solid var(--color-border-light);justify-content:space-between;align-items:flex-start;padding:16px;display:flex}.tool-info{flex:1}.tool-title-row{align-items:center;gap:8px;margin-bottom:4px;display:flex}.tool-info h4{font-size:var(--font-size-md);color:var(--color-text-primary);font-weight:600}.badge-custom{background:var(--color-accent-primary);color:#fff;text-transform:uppercase;letter-spacing:.5px;border-radius:4px;padding:2px 6px;font-size:.65rem;font-weight:700}.tool-slug{color:var(--color-text-muted);background:var(--color-bg-secondary);border-radius:4px;padding:2px 6px;font-family:monospace;font-size:.75rem;display:inline-block}.slug-row{align-items:center;gap:8px;display:flex}.btn-config-mini{background:var(--color-bg-tertiary);width:24px;height:24px;color:var(--color-text-secondary);border:1px solid var(--color-border);cursor:pointer;border-radius:4px;justify-content:center;align-items:center;transition:all .2s;display:flex}.btn-config-mini:hover{background:var(--color-accent-primary);color:#fff;border-color:var(--color-accent-primary)}.config-form{flex-direction:column;gap:20px;width:100%;max-width:500px;margin:0 auto;display:flex}.config-alert{border-radius:var(--radius-md);color:var(--color-success);font-size:var(--font-size-sm);background:#22c55e1a;border:1px solid #22c55e33;align-items:center;gap:12px;padding:12px 16px;display:flex}.form-actions{justify-content:flex-end;align-items:center;gap:16px;margin-top:20px;display:flex}.status-msg{font-size:var(--font-size-sm);color:var(--color-text-muted)}.tool-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);flex:1;padding:16px;line-height:1.5}.tool-params-preview{background:var(--color-bg-secondary);border-top:1px solid var(--color-border);font-size:var(--font-size-xs);padding:12px 16px}.tool-params-preview strong{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:.7rem;display:block}.tool-params-preview ul{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.tool-params-preview li{color:var(--color-text-tertiary);line-height:1.4}.param-name{color:var(--color-text-primary);font-family:monospace;font-weight:500}.param-type{color:var(--color-accent-tertiary);margin-left:4px}.param-req{color:var(--color-error);margin-left:2px;font-weight:700}.param-desc{color:var(--color-text-muted)}.no-params{color:var(--color-text-muted);font-style:italic}.tool-footer-actions{border-top:1px solid var(--color-border);background:var(--color-bg-secondary);justify-content:flex-end;gap:12px;padding:12px 16px;display:flex}.btn-text{font-size:var(--font-size-xs);color:var(--color-text-secondary);cursor:pointer;border-radius:var(--radius-sm);align-items:center;gap:6px;padding:4px 8px;font-weight:500;transition:all .2s;display:flex}.btn-text:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.btn-text.danger{color:var(--color-text-muted)}.btn-text.danger:hover{color:var(--color-error);background:#ff00000d}.view-header{align-items:center;gap:16px;margin-bottom:24px;display:flex}.btn-back{background:var(--color-bg-glass);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;padding:8px 16px;transition:all .2s}.btn-back:hover{background:var(--color-bg-glass-hover);color:var(--color-text-primary);transform:translate(-2px)}.templates-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;display:grid}.template-card{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);padding:24px}.template-card:hover{border-color:var(--color-accent-primary);box-shadow:var(--shadow-lg);transform:translateY(-4px)}@media (max-width:768px){.tools-actions{flex-direction:column;align-items:flex-start;gap:16px}.action-buttons{justify-content:stretch;width:100%}.action-buttons button{flex:1;justify-content:center}.tools-grid{grid-template-columns:1fr}}.sidebar{width:var(--sidebar-width);background:var(--color-bg-secondary);border-right:1px solid var(--color-border);z-index:100;height:100vh;transition:transform var(--transition-normal);flex-direction:column;display:flex;position:fixed;top:0;left:0}.sidebar.closed{transform:translate(-100%)}.sidebar-toggle-btn{z-index:99;background:var(--color-bg-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-md);width:40px;height:40px;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex;position:fixed;top:16px;left:16px}.sidebar-toggle-btn:hover{background:var(--color-bg-glass-hover);color:var(--color-text-primary)}.sidebar-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:16px;display:flex}.sidebar-logo{font-size:var(--font-size-lg);align-items:center;gap:10px;font-weight:700;display:flex}.sidebar-logo-img{object-fit:contain;width:28px;height:28px}.new-chat-btn{background:var(--color-accent-gradient);color:#fff;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-normal);justify-content:center;align-items:center;gap:8px;margin:16px;padding:12px;font-weight:600;display:flex}.new-chat-btn:hover{box-shadow:var(--shadow-glow);transform:translateY(-2px)}.tools-btn{background:var(--color-bg-tertiary);border:1px solid var(--color-border);color:var(--color-text-secondary);font-size:var(--font-size-sm);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;gap:8px;margin:0 16px 16px;padding:12px;display:flex}.tools-btn:hover{background:var(--color-bg-glass-hover);color:var(--color-accent-tertiary);border-color:var(--color-border-hover)}.conversations-list{flex:1;padding:0 8px;overflow-y:auto}.conversations-header{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;padding:12px 8px;font-weight:600}.no-conversations{color:var(--color-text-muted);text-align:center;flex-direction:column;align-items:center;gap:12px;padding:40px 16px;display:flex}.conversation-item{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);color:var(--color-text-secondary);align-items:center;gap:12px;margin-bottom:4px;padding:12px;display:flex}.conversation-item:hover{background:var(--color-bg-glass);color:var(--color-text-primary)}.conversation-item.active{background:var(--color-bg-glass);color:var(--color-text-primary);border:1px solid var(--color-border)}.conversation-title{text-overflow:ellipsis;white-space:nowrap;font-size:var(--font-size-sm);flex:1;overflow:hidden}.delete-btn{opacity:0;color:var(--color-text-muted);border-radius:var(--radius-sm);transition:all var(--transition-fast);padding:4px}.conversation-item:hover .delete-btn{opacity:1}.delete-btn:hover{color:var(--color-error);background:#ef44441a}.sidebar-footer{border-top:1px solid var(--color-border);align-items:center;gap:12px;padding:16px;display:flex}.user-info{flex:1;align-items:center;gap:12px;min-width:0;display:flex}.user-avatar{background:var(--color-accent-gradient);width:36px;height:36px;font-weight:600;font-size:var(--font-size-sm);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex;overflow:hidden}.user-avatar img{object-fit:cover;width:100%;height:100%}.user-details{flex-direction:column;min-width:0;display:flex}.user-name{font-weight:500;font-size:var(--font-size-sm);color:var(--color-text-primary);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.user-email{font-size:var(--font-size-xs);color:var(--color-text-muted);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.logout-btn:hover{color:var(--color-error)!important}.model-selector-container{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-normal);align-items:center;gap:12px;margin:0 16px 16px;padding:10px 14px;display:flex}.model-selector-container:hover{background:var(--color-bg-glass-hover);border-color:var(--color-accent-tertiary);transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.model-selector-icon{width:32px;height:32px;color:var(--color-accent-tertiary);border-radius:var(--radius-sm);background:#a78bfa1a;flex-shrink:0;justify-content:center;align-items:center;display:flex}.model-selector-info{flex-direction:column;flex:1;min-width:0;display:flex}.model-label{text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);margin-bottom:2px;font-size:10px;font-weight:600}.model-name{color:var(--color-text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:500;overflow:hidden}.warning-dot{background:var(--color-error);width:8px;height:8px;box-shadow:0 0 8px var(--color-error);border-radius:50%;flex-shrink:0;animation:2s ease-in-out infinite pulse}.theme-toggle-btn{color:var(--color-text-muted)!important}.theme-toggle-btn:hover{background:var(--color-bg-glass-hover);color:var(--color-accent-tertiary)!important}.settings-btn:hover{color:var(--color-accent-primary)!important}@media (max-width:768px){.sidebar{width:100%;max-width:300px}}.viz-modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2000;animation:fadeIn var(--transition-fast)forwards;background:#000c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.viz-modal-content{background:var(--color-bg-glass);border:1px solid var(--color-border);border-radius:var(--radius-xl);flex-direction:column;width:95vw;max-width:1400px;height:95vh;max-height:90vh;animation:.3s ease-out slideUp;display:flex;overflow:hidden;box-shadow:0 25px 50px -12px #0009}.viz-modal-expanded{border-radius:0!important;width:100vw!important;height:100vh!important;margin:0!important}.viz-modal-header{border-bottom:1px solid var(--color-border);background:var(--color-bg-secondary);color:var(--color-text-primary);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.viz-modal-header h3{font-size:var(--font-size-lg);margin:0;font-weight:600}.viz-modal-actions{align-items:center;gap:8px;display:flex}.viz-btn{border-radius:var(--radius-md);width:36px;height:36px;color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-fast);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff1a;border:none;justify-content:center;align-items:center;display:flex}.viz-btn:hover{background:#fff3;transform:scale(1.05)}.viz-btn-close:hover{color:var(--color-error);background:#ef444433}.viz-modal-body.expanded{padding:8px}@media (max-width:768px){.viz-modal-content{border-radius:0;width:100vw;height:100vh}.viz-modal-header{padding:12px 16px}.viz-modal-body{padding:16px}}.viz-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex;position:relative}.viz-actions{gap:4px;display:flex}.viz-inline-btn{border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);background:#ffffff1a;border:none;justify-content:center;align-items:center;width:28px;height:28px;padding:4px;display:flex}.viz-inline-btn:hover{color:var(--color-text-primary);background:#fff3;transform:scale(1.1)}.data-chart{background:var(--color-bg-glass);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-sizing:border-box;flex-direction:column;gap:24px;width:100%;margin:24px 0;padding:32px;display:flex;overflow:hidden;box-shadow:0 10px 40px #0000004d}.chart-title{font-size:var(--font-size-xl);color:var(--color-text-primary);letter-spacing:-.02em;margin:0;font-weight:700}.chart-container{width:100%;height:500px;min-height:450px}.recharts-cartesian-grid-horizontal line,.recharts-cartesian-grid-vertical line{stroke:#ffffff0d}.recharts-legend-item-text{color:var(--color-text-secondary)!important;font-size:13px!important;font-weight:500!important}.data-chart-empty{min-height:200px;color:var(--color-text-muted);justify-content:center;align-items:center;font-style:italic;display:flex}.data-table-container{border-radius:var(--radius-lg);border:1px solid var(--color-border);background:var(--color-bg-glass);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-sizing:border-box;width:100%;margin:20px 0;overflow-x:auto;box-shadow:0 4px 24px #0003}.data-table{border-collapse:separate;border-spacing:0;width:100%;font-size:var(--font-size-sm);color:var(--color-text-primary)}.data-table th{background:linear-gradient(to bottom,var(--color-bg-tertiary),var(--color-bg-secondary));color:var(--color-text-primary);text-align:left;text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--color-border);white-space:nowrap;padding:16px 20px;font-weight:600}.data-table td{transition:background var(--transition-fast);background:0 0;border-bottom:1px solid #ffffff0d;padding:14px 20px}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover td{background:#ffffff0d}.data-table-container::-webkit-scrollbar{height:8px}.data-table-container::-webkit-scrollbar-track{background:0 0}.data-table-container::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:10px}.data-table-container::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.message-bubble{gap:16px;max-width:1100px;margin:0 auto 24px;padding:0 16px;display:flex}.message-bubble.user{flex-direction:row-reverse}.viz-modal-body{background:var(--color-bg-glass);flex-direction:column;flex:1;justify-content:flex-start;align-items:center;padding:0;display:flex;overflow:auto}.bubble-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.message-bubble.user .bubble-avatar{background:var(--color-bg-tertiary);color:var(--color-text-secondary)}.message-bubble.assistant .bubble-avatar{background:0 0;justify-content:center;align-items:center;display:flex}.bubble-content{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.message-bubble.user .bubble-content{align-items:flex-end}.message-bubble.assistant .bubble-content{align-items:stretch}.bubble-text{border-radius:var(--radius-lg);font-size:var(--font-size-md);align-self:flex-start;padding:16px 20px;line-height:1.7}.message-bubble.user .bubble-text{background:var(--color-accent-gradient);color:#fff;border-bottom-right-radius:4px;align-self:flex-end}.message-bubble.assistant .bubble-text{background:var(--color-bg-glass);border:1px solid var(--color-border);border-bottom-left-radius:4px;margin-bottom:8px}.visualizations-container{flex-direction:column;gap:20px;width:100%;margin-top:8px;display:flex}.bubble-text p{margin-bottom:12px}.bubble-text p:last-child{margin-bottom:0}.bubble-text strong{font-weight:600}.bubble-text code{background:#0000004d;border-radius:4px;padding:2px 6px;font-family:Fira Code,monospace;font-size:.9em}.bubble-text pre{border-radius:var(--radius-md);background:#0006;margin:12px 0;padding:16px;overflow-x:auto}.bubble-text pre code{background:0 0;padding:0}.bubble-text ul,.bubble-text ol{margin:12px 0;padding-left:24px}.bubble-text li{margin-bottom:6px}.bubble-text table{border-collapse:collapse;border-radius:var(--radius-md);border:1px solid var(--color-border);width:100%;margin:16px 0;font-size:.9em;overflow:hidden}.bubble-text th{background:var(--color-bg-tertiary);color:var(--color-text-primary);text-align:left;border-bottom:1px solid var(--color-border);padding:10px 14px;font-weight:600}.bubble-text td{border-bottom:1px solid #ffffff0d;padding:10px 14px}.bubble-text table tbody tr:nth-child(2n) td{background:#ffffff05}.bubble-text table tbody tr:hover td{background:#ffffff12}.bubble-text tr:last-child td{border-bottom:none}.message-attachments{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.attachment-file{border-radius:var(--radius-md);overflow:hidden}.attachment-image{border-radius:var(--radius-md);max-width:300px;overflow:hidden}.attachment-image img{width:100%;height:auto;display:block}.attachment-doc{background:var(--color-bg-glass);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-sm);align-items:center;gap:8px;padding:12px 16px;display:flex}.bubble-text img{border-radius:var(--radius-md);border:1px solid var(--color-border);max-width:100%;height:auto;box-shadow:var(--shadow-sm);margin:12px 0}.mermaid-modal-scroll-container{box-sizing:border-box;background:#ffffff08;flex:1;justify-content:center;align-items:flex-start;width:100%;height:100%;padding:60px;display:flex;overflow:auto}.full-screen-mermaid-content.fit-screen svg{display:block;width:auto!important;max-width:100%!important;height:auto!important;max-height:100%!important}.full-screen-mermaid-content.zoomed svg{display:block;width:100%!important;max-width:none!important;height:auto!important;max-height:none!important}@media (max-width:768px){.message-bubble{padding:0}.bubble-avatar{width:32px;height:32px}.bubble-text{padding:12px 16px}}.visualization-image-container{border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-md);max-width:600px;transition:transform var(--transition-normal);margin-top:12px;position:relative;overflow:hidden}.visualization-image-container:hover{border-color:var(--color-accent-primary);transform:scale(1.02)}.visualization-image{width:100%;height:auto;display:block}.image-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;font-size:var(--font-size-xs);opacity:0;transition:opacity var(--transition-normal);background:linear-gradient(#0000,#000c);padding:12px 20px;position:absolute;bottom:0;left:0;right:0}.visualization-image-container:hover .image-overlay{opacity:1}.image-prompt{white-space:nowrap;text-overflow:ellipsis;font-weight:500;display:block;overflow:hidden}.mermaid-diagram-container{background:var(--color-bg-glass);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-sizing:border-box;flex-direction:column;justify-content:flex-start;align-items:center;width:100%;max-width:100%;height:auto;min-height:200px;margin-top:8px;padding:2px;display:flex;overflow:visible}.mermaid-diagram-svg-wrapper{scrollbar-width:thin;scrollbar-color:var(--color-border)transparent;box-sizing:border-box;width:100%;max-width:100%;min-height:inherit;flex-direction:column;justify-content:flex-start;align-items:center;padding:24px;display:flex;overflow:auto}.mermaid-diagram-svg-wrapper::-webkit-scrollbar{height:6px}.mermaid-diagram-svg-wrapper::-webkit-scrollbar-track{background:0 0}.mermaid-diagram-svg-wrapper::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.mermaid-diagram-svg-wrapper>div{flex-direction:column;justify-content:flex-start;align-items:center;width:auto;max-width:100%;margin:0 auto;display:flex}.mermaid-diagram-container svg{flex-shrink:0;max-width:100%;max-height:65vh;margin:auto;display:block;height:auto!important}.mermaid-diagram-container svg text{white-space:normal!important}.mermaid-diagram-container svg .mainTitle,.mermaid-diagram-container svg .titleText,.mermaid-diagram-container svg .headerText,.mermaid-diagram-container svg .sectionTitle,.mermaid-diagram-container svg .legendText{font-size:.82em!important}.mermaid-quadrant-wrapper .mermaid-diagram-container svg text,.mermaid-quadrant-wrapper .mermaid-diagram-container svg .quadrant-label,.mermaid-quadrant-wrapper .mermaid-diagram-container svg .quadrant-point-text,.mermaid-quadrant-wrapper .mermaid-diagram-container svg .axis-label,.mermaid-quadrant-wrapper .mermaid-diagram-container svg .titleText,.mermaid-quadrant-wrapper .mermaid-diagram-container svg .label,.mermaid-quadrant-wrapper .mermaid-diagram-container svg tspan{font-size:7.5px!important}.mermaid-quadrant-wrapper .mermaid-diagram-container svg .mainTitle{font-size:10px!important}.mermaid-diagram-wrapper{flex-direction:column;gap:8px;width:100%;display:flex;position:relative}.mermaid-actions{opacity:0;background:var(--color-bg-glass);border:1px solid var(--color-border);border-radius:var(--radius-md);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10;align-self:flex-end;gap:6px;padding:4px;transition:opacity .3s;display:flex}.mermaid-diagram-wrapper:hover .mermaid-actions{opacity:1}.viz-inline-btn{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;justify-content:center;align-items:center;padding:6px 8px;transition:all .2s;display:flex}.viz-inline-btn:hover:not(:disabled){background:var(--color-accent-primary);color:#fff;border-color:var(--color-accent-primary)}.full-screen-mermaid{justify-content:center;width:100%;height:auto;display:flex;overflow:auto}.full-screen-mermaid svg{max-width:none;max-height:none}@media (max-width:768px){.mermaid-diagram-container{padding:10px}}g.error-text,text.error-text,.error-text,.error-icon{opacity:0!important;visibility:hidden!important;display:none!important}.thinking-container{border:1px solid var(--color-border);border-radius:var(--radius-md);background:#0000001a;margin:8px 0 16px;font-size:.9em}.thinking-header{width:100%;color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;justify-content:space-between;align-items:center;padding:8px 12px;transition:background .2s;display:flex}.thinking-header:hover{background:#ffffff0d}.thinking-title{align-items:center;gap:8px;font-weight:500;display:flex}.thinking-body{border-top:1px solid var(--color-border);background:#0003;max-height:300px;padding:12px;overflow-y:auto}.thought-step{gap:10px;margin-bottom:12px;display:flex}.thought-step:last-child{margin-bottom:0}.thought-icon{width:20px;color:var(--color-text-tertiary);flex-shrink:0;justify-content:center;padding-top:2px;display:flex}.thought-content{min-width:0;color:var(--color-text-secondary);flex:1}.thought-message{margin-bottom:4px}.thought-details,.thought-result{color:var(--color-text-tertiary);white-space:pre-wrap;word-break:break-all;background:#0000004d;border-radius:4px;margin-top:4px;padding:6px;font-family:Fira Code,monospace;font-size:.85em}.spin{animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.chat-window{min-height:100vh;transition:margin-left var(--transition-normal);flex-direction:column;flex:1;margin-left:0;display:flex}.chat-window.with-sidebar{margin-left:var(--sidebar-width)}.mobile-menu-btn{z-index:50;background:var(--color-bg-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-md);width:40px;height:40px;color:var(--color-text-secondary);cursor:pointer;justify-content:center;align-items:center;display:flex;position:fixed;top:16px;left:16px}.chat-welcome{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;max-width:600px;margin:0 auto;padding:40px;display:flex}.welcome-icon{background:var(--color-bg-glass);border:1px solid var(--color-border);border-radius:var(--radius-xl);justify-content:center;align-items:center;width:100px;height:100px;margin-bottom:24px;padding:15px;animation:2s ease-in-out infinite pulse;display:flex}.welcome-logo-img{object-fit:contain;width:100%;height:100%}.avatar-logo-img{object-fit:contain;width:22px;height:22px}.chat-welcome h1{font-size:var(--font-size-3xl);margin-bottom:12px;font-weight:700}.chat-welcome p{color:var(--color-text-secondary);margin-bottom:32px}.quick-actions{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.quick-actions button{background:var(--color-bg-glass);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-secondary);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast);padding:12px 20px}.quick-actions button:hover{background:var(--color-bg-glass-hover);color:var(--color-text-primary);border-color:var(--color-border-hover)}.messages-container{flex:1;padding:24px 24px 120px;overflow-y:auto}.input-container{background:linear-gradient(to top,var(--color-bg-primary)60%,transparent);transition:margin-left var(--transition-normal);margin-left:0;padding:16px 24px 24px;position:fixed;bottom:0;left:0;right:0}.chat-window.with-sidebar~.input-container,.chat-window.with-sidebar .input-container{margin-left:var(--sidebar-width)}.attachments-preview{flex-wrap:wrap;gap:8px;max-width:800px;margin-bottom:12px;margin-left:auto;margin-right:auto;display:flex}.attachment-item{background:var(--color-bg-glass);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-text-secondary);align-items:center;gap:8px;padding:8px 12px;display:flex}.attachment-item button{color:var(--color-text-muted);cursor:pointer;padding:2px;display:flex}.attachment-item button:hover{color:var(--color-error)}.input-wrapper{background:var(--color-bg-glass);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--color-border);border-radius:var(--radius-lg);max-width:800px;transition:all var(--transition-fast);align-items:flex-end;gap:12px;margin:0 auto;padding:10px 16px;display:flex}.send-btn,.attach-btn{border-radius:var(--radius-full);justify-content:center;align-items:center;width:36px;height:36px;display:flex}.input-wrapper:focus-within{border-color:var(--color-accent-primary);box-shadow:0 0 0 3px var(--color-accent-glow)}.input-wrapper textarea{resize:none;min-height:24px;max-height:200px;font-size:var(--font-size-md);color:var(--color-text-primary);background:0 0;border:none;outline:none;flex:1;padding:8px 0;line-height:1.5}.attach-btn{color:var(--color-text-muted)}.attach-btn:hover,.send-btn{color:var(--color-accent-primary)}.send-btn:disabled{color:var(--color-text-muted)}.send-btn:not(:disabled):hover{background:var(--color-accent-primary);color:#fff}.send-btn.stop-btn{color:#ef4444;background:#ef44441a}.send-btn.stop-btn:hover{color:#fff;background:#ef4444}.input-wrapper textarea:disabled{opacity:.6;cursor:not-allowed}@media (max-width:768px){.chat-window.with-sidebar{margin-left:0}.input-container{margin-left:0!important}.messages-container{padding:16px}}.chat-page{background:var(--color-bg-primary);min-height:100vh;color:var(--color-text-primary);display:flex;position:relative}.chat-loading{background:var(--color-bg-primary);justify-content:center;align-items:center;min-height:100vh;display:flex}@media (max-width:768px){.chat-page{flex-direction:column}}.floating-theme-toggle{z-index:1000;background:var(--color-bg-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-full);width:44px;height:44px;color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-md);justify-content:center;align-items:center;display:flex;position:fixed;top:20px;right:20px}.floating-theme-toggle:hover{background:var(--color-bg-glass-hover);box-shadow:var(--shadow-lg);border-color:var(--color-accent-primary);color:var(--color-accent-tertiary);transform:translateY(-2px)}
