@import url(https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;0,9..40,800;1,9..40,400&family=Space+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap);:root{--accent:#0d9488;--accent-hover:#0f766e;--accent-light:#0d95881f;--accent-glow:#0d958840;--accent-neon:#0d958899;--accent2:#22d3ee;--accent2-light:#22d3ee1f;--accent3:#fbbf24;--accent3-light:#fbbf241f;--bg-deep:#fff;--bg-base:#f4f6fb;--glass-bg:#fffc;--glass-bg-hover:#ffffffeb;--glass-bg-active:#f0f4fff2;--glass-border:#0023661a;--glass-border-hover:#00236633;--glass-blur:18px;--sidebar-bg:#f0f4ffeb;--sidebar-surface:#dce6ff8c;--sidebar-border:#00236617;--sidebar-text:#002366e6;--sidebar-muted:#00236680;--sidebar-hover:#0d95880f;--sidebar-active:#0d95881a;--chat-bg:#0000;--chat-surface:#f0f4ff99;--chat-border:#00236614;--text-primary:#002366;--text-secondary:#002366a6;--text-muted:#00236666;--text-inverse:#fff;--user-msg-bg:#0d958812;--user-msg-border:#0d95882e;--ai-msg-bg:#0023660a;--ai-msg-border:#00236617;--success:#059669;--success-light:#0596691a;--warning:#d97706;--warning-light:#d977061a;--error:#dc2626;--error-light:#dc26261a;--surface-1:#f0f4ffcc;--surface-2:#dce6ff99;--surface-3:#c8d7ff80;--border:#0023661a;--border-strong:#00236633;--shadow-sm:0 2px 8px #00236614;--shadow-md:0 4px 20px #0023661a,0 0 1px #0d958814;--shadow-lg:0 8px 32px #0023661f,0 0 2px #0d95881a;--shadow-xl:0 16px 48px #00236626,0 0 4px #0d95881f;--shadow-glow:0 0 20px #0d958826,0 0 60px #0d95880f;--shadow-glow-cyan:0 0 20px #0023661f,0 0 60px #0023660d;--radius-sm:8px;--radius-md:12px;--radius-lg:20px;--radius-xl:28px;--radius-full:9999px;--transition-fast:150ms cubic-bezier(0.4,0,0.2,1);--transition-base:250ms cubic-bezier(0.4,0,0.2,1);--transition-slow:400ms cubic-bezier(0.22,1,0.36,1);--transition-spring:500ms cubic-bezier(0.34,1.56,0.64,1);--primary-color:var(--accent);--secondary-color:var(--surface-2);--text-color:var(--text-primary);--light-text-color:var(--text-secondary);--border-color:var(--border);--hover-color:var(--surface-3);--error-color:var(--error)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{height:100%;scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#fff;background:var(--bg-deep);color:#002366;color:var(--text-primary);color-scheme:light;font-family:DM Sans,Segoe UI,system-ui,-apple-system,sans-serif;font-size:15px;line-height:1.6}#root,body{height:100%;overflow:hidden}code,kbd,pre{font-family:JetBrains Mono,Fira Code,Cascadia Code,monospace}::-webkit-scrollbar{height:4px;width:4px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#00236626;border-radius:9999px;border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:#0023664d}::selection{background:#00236633;color:#002366}:focus-visible{outline:2px solid #0d9488;outline:2px solid var(--accent);outline-offset:2px}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes spin{to{transform:rotate(1turn)}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}@keyframes aurora{0%{transform:translate(0) rotate(0deg) scale(1)}33%{transform:translate(30px,-40px) rotate(120deg) scale(1.1)}66%{transform:translate(-20px,30px) rotate(240deg) scale(.95)}to{transform:translate(0) rotate(1turn) scale(1)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes glowPulse{0%,to{box-shadow:0 0 20px #ec48991f}50%{box-shadow:0 0 40px #ec489940,0 0 80px #ec489914}}@keyframes borderGlow{0%,to{border-color:#ec489926}50%{border-color:#ec489966}}@keyframes gradientShift{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}.app{background:var(--bg-deep);display:flex;height:100%;isolation:isolate;overflow:hidden;position:relative;width:100%}.app:after,.app:before{border-radius:50%;content:"";filter:blur(120px);opacity:.5;pointer-events:none;position:absolute;will-change:transform;z-index:0}.app:before{animation:aurora 25s ease-in-out infinite;background:radial-gradient(circle,#ec48991f 0,#0000 70%);height:600px;left:-10%;top:-15%;width:600px}.app:after{animation:aurora 30s ease-in-out infinite reverse;background:radial-gradient(circle,#0023660f 0,#0000 70%);bottom:-10%;height:500px;right:-5%;width:500px}.aurora-blob{animation:aurora 20s ease-in-out 5s infinite;background:radial-gradient(circle,#0023660d 0,#0000 70%);border-radius:50%;filter:blur(100px);height:450px;left:50%;opacity:.3;pointer-events:none;position:absolute;top:40%;width:450px;z-index:0}.app>:not(.aurora-blob){position:relative;z-index:1}@media (max-width:768px){.app{flex-direction:row;position:relative}.app:before{height:350px;width:350px}.app:after{height:300px;width:300px}}.sidebar-wrapper{position:relative}.sidebar{backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));background:var(--sidebar-bg);border:1px solid var(--sidebar-border);border-left:none;border-radius:0 var(--radius-xl) var(--radius-xl) 0;box-shadow:var(--shadow-lg),inset 0 0 0 1px #ffffff08;color:var(--sidebar-text);display:flex;flex-direction:column;flex-shrink:0;height:calc(100% - 24px);left:0;margin:12px 0 12px 12px;overflow:hidden;position:absolute;top:0;transition:transform var(--transition-slow),opacity var(--transition-slow);width:280px;z-index:100}.sidebar-wrapper.closed .sidebar{margin:0 0 12px;min-width:0;opacity:0;pointer-events:none;transform:translateX(-100%);width:0}.sidebar-toggle-bar{align-items:center;background:#0000;border-radius:var(--radius-md);bottom:12px;cursor:pointer;display:flex;justify-content:center;left:292px;position:absolute;top:12px;transition:left var(--transition-slow),all var(--transition-fast);width:8px;z-index:150}.sidebar-wrapper.closed .sidebar-toggle-bar{left:12px}.sidebar-toggle-bar:hover{background:#0d958814}.sidebar-toggle-handle{position:relative;transform:rotate(90deg)}.sidebar-toggle-handle,.sidebar-toggle-handle:after,.sidebar-toggle-handle:before{background:#0d958880;border-radius:2px;height:2px;transition:all var(--transition-fast);width:20px}.sidebar-toggle-handle:after,.sidebar-toggle-handle:before{content:"";left:0;position:absolute}.sidebar-toggle-handle:before{top:-6px}.sidebar-toggle-handle:after{top:6px}.sidebar-toggle-bar:hover .sidebar-toggle-handle,.sidebar-toggle-bar:hover .sidebar-toggle-handle:after,.sidebar-toggle-bar:hover .sidebar-toggle-handle:before{background:#0d9588cc}.sidebar-header{align-items:center;background:#0000;border-bottom:1px solid var(--sidebar-border);display:flex;flex-shrink:0;justify-content:space-between;overflow:hidden;padding:0 12px 0 0;position:relative}.logo-container{align-items:center;display:flex;justify-content:center;padding:20px 16px 18px;width:100%}.sparf-logo{filter:drop-shadow(0 2px 12px rgba(13,149,136,.2));height:auto;max-width:160px;object-fit:contain;opacity:.92;transition:all var(--transition-base);width:100%}.sparf-logo:hover{filter:drop-shadow(0 4px 20px rgba(13,149,136,.35));opacity:1;transform:scale(1.02)}.new-chat-btn{align-items:center;animation:gradientShift 4s ease infinite;background:linear-gradient(135deg,#0d9488,#002366);background-size:200% 200%;border:none;border-radius:var(--radius-lg);box-shadow:0 4px 20px #0d95884d;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-family:Space Grotesk,sans-serif;font-size:.875rem;font-weight:700;gap:8px;justify-content:center;letter-spacing:.03em;margin:14px 14px 10px;padding:12px 16px;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.new-chat-btn:hover{box-shadow:0 8px 30px #0d958866,var(--shadow-glow);transform:translateY(-2px) scale(1.01)}.new-chat-btn:active{transform:translateY(0) scale(.99)}.conversations-section-label{color:var(--sidebar-muted);flex-shrink:0;font-family:Space Grotesk,sans-serif;font-size:.6rem;font-weight:700;letter-spacing:.14em;padding:12px 16px 6px;text-transform:uppercase}.conversations-list{flex:1 1;overflow-y:auto;padding:4px 10px 10px}.conversations-list::-webkit-scrollbar{width:3px}.conversations-list::-webkit-scrollbar-thumb{background:#0d958826;border-radius:var(--radius-full)}.conversation-item{align-items:center;background:#0000;border:1px solid #0000;border-radius:var(--radius-md);cursor:pointer;display:flex;justify-content:space-between;margin-bottom:3px;min-width:0;padding:10px 14px;position:relative;transition:all var(--transition-fast)}.conversation-item:hover{background:var(--sidebar-hover);border-color:#0d95881a;transform:translateX(3px)}.conversation-item.active{background:var(--sidebar-active);border-color:#0d958840;box-shadow:0 0 20px #0d95880f}.conversation-item.active:before{background:var(--accent);border-radius:var(--radius-full);box-shadow:0 0 8px var(--accent-neon);content:"";height:60%;left:0;position:absolute;top:50%;transform:translateY(-50%);width:3px}.conversation-item.active .conversation-title{color:var(--accent)}.conversation-info{display:flex;flex:1 1;flex-direction:column;min-width:0;overflow:hidden}.conversation-title{color:var(--sidebar-text);font-size:.84rem;font-weight:500;line-height:1.4;overflow:hidden;text-overflow:ellipsis;transition:color var(--transition-fast);white-space:nowrap}.conversation-date{color:var(--sidebar-muted);font-size:.68rem;line-height:1.3;margin-top:3px}.conversation-actions{display:flex;flex-shrink:0;gap:2px;margin-left:6px;opacity:0;transition:opacity var(--transition-fast)}.conversation-item:hover .conversation-actions{opacity:1}.conversation-actions button{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--sidebar-muted);cursor:pointer;display:flex;font-size:.8rem;justify-content:center;padding:5px;transition:all var(--transition-fast)}.conversation-actions button:hover{background:#0d95881f;color:var(--accent)}.edit-title-form{width:100%}.edit-title-form input{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0d95880f;border:1px solid #0d95884d;border-radius:var(--radius-sm);color:var(--sidebar-text);font-family:inherit;font-size:.84rem;outline:none;padding:7px 12px;width:100%}.edit-title-form input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #0d95881a,0 0 12px #0d95881a}.sidebar-footer{background:#0000;border-top:1px solid var(--sidebar-border);flex-shrink:0;padding:12px 14px 16px}.settings-btn{align-items:center;background:#0d95880a;border:1px solid #0d95881f;border-radius:var(--radius-md);color:var(--sidebar-muted);cursor:pointer;display:flex;font-family:inherit;font-size:.875rem;font-weight:500;gap:8px;justify-content:center;letter-spacing:.01em;padding:11px 14px;transition:all var(--transition-fast);width:100%}.settings-btn:hover{background:#0d95881a;border-color:#0d95884d;box-shadow:0 0 16px #0d958814;color:var(--accent)}.close-sidebar-btn{align-items:center;background:#0023660a;border:1px solid var(--sidebar-border);border-radius:var(--radius-sm);color:var(--sidebar-muted);cursor:pointer;display:flex;flex-shrink:0;font-size:1rem;justify-content:center;padding:6px;transition:all var(--transition-fast);z-index:2}.close-sidebar-btn:hover{background:#f8717114;border-color:#f8717133;color:var(--error)}.open-sidebar-btn{align-items:center;backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);color:var(--text-secondary);cursor:pointer;display:flex;font-size:1.05rem;justify-content:center;left:16px;padding:10px 12px;position:absolute;top:22px;transition:all var(--transition-fast);z-index:150}.open-sidebar-btn:hover{background:var(--glass-bg-hover);border-color:#0d95884d;box-shadow:var(--shadow-lg),0 0 16px #0d95881a;color:var(--accent);transform:scale(1.05)}@media (max-width:768px){.sidebar{border-radius:0 var(--radius-xl) var(--radius-xl) 0;box-shadow:var(--shadow-xl),40px 0 80px #0006;height:100vh;left:0;margin:0;max-width:320px;position:fixed;top:0;transform:translateX(0);width:85%}.sidebar.closed{min-width:0;min-width:auto;transform:translateX(-100%);width:85%}.open-sidebar-btn{display:flex}}.modal-overlay{align-items:center;animation:fadeIn .18s ease-out;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#0f0f1e80;bottom:0;display:flex;justify-content:center;left:0;padding:16px;position:fixed;right:0;top:0;z-index:2000}.modal-container{animation:modalSlideUp .25s cubic-bezier(.34,1.56,.64,1);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl),0 0 30px #f8717114;max-width:420px;overflow:hidden;width:100%}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(16px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{background:#0000001a;border-bottom:1px solid var(--border);justify-content:space-between;padding:18px 22px 14px}.modal-header,.modal-title{align-items:center;display:flex}.modal-title{color:var(--error);font-family:Space Grotesk,sans-serif;font-size:1rem;font-weight:700;gap:8px;letter-spacing:-.01em}.modal-icon{color:var(--error);font-size:20px}.modal-close-btn{align-items:center;background:#ffffff0a;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;font-size:1rem;justify-content:center;padding:5px;transition:all var(--transition-fast)}.modal-close-btn:hover{background:#f8717114;border-color:#f8717133;color:var(--error)}.modal-content{padding:18px 22px}.modal-content p{color:var(--text-secondary);font-size:.9rem;line-height:1.6;margin:0}.modal-actions{border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end;padding:14px 22px 18px}.modal-cancel-btn{background:#00000026;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:500;padding:9px 18px;transition:all var(--transition-fast)}.modal-cancel-btn:hover{background:#ffffff0d;border-color:var(--border-strong)}.modal-confirm-btn{background:var(--error);border:none;border-radius:var(--radius-md);box-shadow:0 4px 12px #f8717140;color:#fff;cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:600;padding:9px 18px;transition:all var(--transition-fast)}.modal-confirm-btn:hover{background:#ef4444;box-shadow:0 6px 16px #f8717159;transform:translateY(-1px)}.chat-message{animation:fadeUp .3s ease-out;clear:both;display:flex;gap:12px;padding:10px 0;width:100%}.streaming-content{display:inline-block;position:relative;width:100%}.typing-indicator{align-items:center;display:inline-flex;gap:4px;height:18px;margin-left:4px}.typing-indicator .dot{animation:typingBounce 1.2s ease-in-out infinite;background:var(--accent);border-radius:50%;display:inline-block;height:5px;opacity:.5;width:5px}.typing-indicator .dot:first-child{animation-delay:0s}.typing-indicator .dot:nth-child(2){animation-delay:.18s}.typing-indicator .dot:nth-child(3){animation-delay:.36s}@keyframes typingBounce{0%,60%,to{opacity:.4;transform:translateY(0)}30%{opacity:1;transform:translateY(-5px)}}.cursor-blink{display:none}.message-avatar{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-md);display:flex;flex-shrink:0;height:32px;justify-content:center;margin-top:4px;overflow:hidden;width:32px}.chat-message.user .message-avatar{background:#0d95881f;border:1px solid #0d958840}.chat-message.assistant .message-avatar{background:#22d3ee14;border:1px solid #22d3ee26}.user-avatar{height:18px;object-fit:contain;width:18px}.assistant-avatar{height:20px;object-fit:contain;width:20px}.message-content{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:var(--radius-lg);flex:1 1;max-width:85%;min-width:0;padding:14px 18px;position:relative}.chat-message.user .message-content{background:#0d958814;border:1px solid #0d95882e;border-radius:var(--radius-lg) var(--radius-sm) var(--radius-lg) var(--radius-lg)}.chat-message.assistant .message-content{background:var(--ai-msg-bg);border:1px solid var(--ai-msg-border);border-radius:var(--radius-sm) var(--radius-lg) var(--radius-lg) var(--radius-lg);box-shadow:0 2px 16px #00236614}.chat-message.system .message-content{background:#8c8cb40a;border:1px solid #8c8cb41a;border-radius:var(--radius-lg);max-width:100%}.message-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:6px}.message-header-left,.message-header-right{align-items:center;display:flex;gap:4px}.reasoning-summary-toggle{background:#0d958814;border:1px solid #0d958826;border-radius:var(--radius-full);color:var(--accent);cursor:pointer;font-family:Space Grotesk,sans-serif;font-size:.72rem;font-weight:600;padding:3px 10px;transition:all var(--transition-fast)}.reasoning-summary-toggle:hover{background:#0d958826;border-color:var(--accent);box-shadow:0 0 10px #0d95881a}.reasoning-summary-inline{background:#0d95880a;border-left:2px solid var(--accent);border-radius:0 var(--radius-md) var(--radius-md) 0;color:var(--text-secondary);font-size:.82rem;margin-bottom:10px;padding:8px 14px}.reasoning-summary-title{color:var(--accent);font-family:Space Grotesk,sans-serif;font-size:.72rem;font-weight:700;letter-spacing:.06em;margin-bottom:4px;text-transform:uppercase}.tts-button{align-items:center;background:#0000;border:none;border-radius:var(--radius-full);color:var(--text-muted);cursor:pointer;display:flex;font-size:.85rem;height:24px;justify-content:center;padding:3px;transition:all var(--transition-fast);width:24px}.tts-button:hover{background:#0d958814;color:var(--accent)}.tts-button.speaking{animation:glowPulse 2s ease-in-out infinite;background:var(--accent-light);color:var(--accent)}.tts-button:disabled{cursor:not-allowed;opacity:.4}.loading-icon{animation:spin .8s linear infinite}.message-timestamp{color:var(--text-muted);font-size:.68rem;letter-spacing:.01em}.message-role{color:var(--text-secondary);font-family:Space Grotesk,sans-serif;font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.chat-message.user .message-role{color:var(--accent)}.chat-message.assistant .message-role{color:var(--accent2)}.message-body{color:var(--text-primary);font-size:.93rem;line-height:1.7}.message-body p{margin-bottom:14px;margin-top:0}.message-body p:last-child{margin-bottom:0}.message-body pre{border-radius:var(--radius-md);margin:14px 0;overflow-x:auto}.message-body code{background:#0023660f;border:1px solid #0023661f;border-radius:5px;color:#002366;font-family:JetBrains Mono,Fira Code,monospace;font-size:.82em;padding:2px 7px}.message-body pre code{background:#0000;border:none;border-radius:0;color:inherit;padding:0}.message-body a{border-bottom:1px solid #0d958833;color:var(--accent);text-decoration:none;transition:all var(--transition-fast)}.message-body a:hover{border-bottom-color:var(--accent);text-shadow:0 0 8px #0d958833}.message-body ol,.message-body ul{margin:12px 0;padding-left:22px}.message-body li{margin-bottom:5px}.message-body blockquote{background:#0d95880a;border-left:3px solid var(--accent);border-radius:0 var(--radius-md) var(--radius-md) 0;color:var(--text-secondary);margin:14px 0;padding:10px 16px}.message-body h1,.message-body h2,.message-body h3,.message-body h4,.message-body h5,.message-body h6{color:var(--text-primary);font-family:Space Grotesk,sans-serif;font-weight:700;line-height:1.3;margin:18px 0 8px}.message-body table{border-collapse:collapse;font-size:.875rem;margin:14px 0;width:100%}.message-body td,.message-body th{border:1px solid var(--border);padding:9px 14px;text-align:left}.message-body th{background:#0d95880f;font-family:Space Grotesk,sans-serif;font-weight:600}.message-body tr:nth-child(2n) td{background:#0023660a}.message-tokens{color:var(--text-muted);font-size:.76rem;margin-top:8px}.token-content{line-height:1.6;word-break:break-word}.error-content{align-items:center;color:var(--error);display:flex;font-size:.9rem;gap:8px}.error-content svg{flex-shrink:0}.message-with-image{display:flex;flex-direction:column;gap:12px}.image-container{border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);max-width:480px;overflow:hidden}.uploaded-image{display:block;max-height:380px;max-width:480px;object-fit:contain;width:100%}.image-description{margin-top:8px}.file-notification{align-items:center;color:var(--text-muted);display:flex;font-size:.875rem;font-style:italic;gap:8px}.request-json{border-top:1px solid var(--border);margin-top:10px;padding-top:8px;position:relative;z-index:5}.request-json-header{align-items:center;color:var(--accent);cursor:pointer;display:flex;font-family:Space Grotesk,sans-serif;font-size:.78rem;font-weight:600;gap:6px;padding:4px 0;transition:opacity var(--transition-fast)}.request-json-header:hover{opacity:.7}.request-json-content{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#00236608;border:1px solid var(--border);border-radius:var(--radius-md);margin-top:8px;max-height:300px;overflow:auto;position:relative;width:100%}.request-json-content pre{color:var(--text-primary);font-family:JetBrains Mono,Fira Code,monospace;font-size:.78rem;margin:0;overflow-wrap:break-word;padding:12px;white-space:pre-wrap;width:100%;word-break:break-word}.api-details-section{padding:8px}.api-details-section h5{color:var(--accent);font-family:Space Grotesk,sans-serif;font-size:.78rem;font-weight:700;letter-spacing:.05em;margin:10px 0 4px;text-transform:uppercase}.api-details-section p{color:var(--text-secondary);font-size:.84rem;margin:2px 0}.settings-panel{align-items:stretch;animation:fadeInScale .3s cubic-bezier(.34,1.56,.64,1);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-xl);box-shadow:0 0 0 100vmax #00236659,var(--shadow-xl),var(--shadow-glow);display:flex;flex-direction:column;inset:0;justify-content:flex-start;margin:auto;max-height:85vh;max-width:480px;overflow:hidden;padding:0;position:fixed;width:100%;z-index:1000}.settings-header{align-items:center;background:#0023660a;border-bottom:1px solid var(--border);display:flex;flex-shrink:0;justify-content:space-between;padding:18px 24px}.settings-header h3{color:var(--text-primary);font-family:Space Grotesk,sans-serif;font-size:1.05rem;font-weight:700;letter-spacing:-.01em;margin:0}.close-btn{background:#0023660a;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:1rem;justify-content:center;padding:6px;transition:all var(--transition-fast)}.close-btn:hover{background:#f871711a;border-color:#f8717133;color:var(--error)}.settings-content{flex:1 1;overflow-y:auto;padding:24px}.settings-content section{margin-bottom:28px}.settings-content h4{border-bottom:1px solid var(--border);color:var(--text-muted);font-family:Space Grotesk,sans-serif;font-size:.68rem;font-weight:700;letter-spacing:.1em;margin-bottom:14px;margin-top:0;padding-bottom:8px;text-transform:uppercase}.setting-group{margin-bottom:16px}.setting-group label{color:var(--text-primary);display:block;font-size:.875rem;font-weight:500;margin-bottom:6px}.setting-group input[type=password],.setting-group input[type=text],.setting-group select,.setting-group textarea{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#00236608;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);color-scheme:light;font-family:inherit;font-size:.875rem;padding:10px 14px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);width:100%}.setting-group select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239898b8' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;cursor:pointer;padding-right:34px}.setting-group input[type=password]:focus,.setting-group input[type=text]:focus,.setting-group select:focus,.setting-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #0d95881a,0 0 12px #0d958814;outline:none}.system-prompt-textarea{background:#00236608;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);color-scheme:light;font-family:inherit;font-size:.875rem;line-height:1.5;padding:10px 14px;resize:vertical;width:100%}.system-prompt-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #0d95881a;outline:none}.setting-help-text{color:var(--text-muted);font-size:.78rem;font-style:italic;line-height:1.4;margin-top:5px}.radio-group{display:flex;gap:16px}.radio-group label{align-items:center;cursor:pointer;display:flex;font-weight:400;gap:6px}.api-key-form{display:flex;gap:8px}.api-key-form input{flex:1 1}.api-key-form button{background:linear-gradient(135deg,var(--accent),#99f6e4);border:none;border-radius:var(--radius-md);box-shadow:0 4px 12px #0d958833;color:#fff;cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:600;padding:10px 16px;transition:all var(--transition-fast);white-space:nowrap}.api-key-form button:hover{box-shadow:0 6px 16px #0d95884d;transform:translateY(-1px)}.api-key-form button:disabled{background:#00236614;box-shadow:none;cursor:not-allowed;transform:none}.api-key-status{animation:fadeIn .2s ease-out;border-radius:var(--radius-md);font-size:.82rem;margin-top:8px;padding:8px 12px}.api-key-status.success{background:#34d3990f;border:1px solid #34d39933;color:var(--success)}.api-key-status.error{background:#f871710f;border:1px solid #f8717133;color:var(--error)}.api-key-help{color:var(--text-muted);font-size:.78rem;line-height:1.5;margin-top:10px}.api-key-help p{margin-bottom:4px}.api-key-help a{color:var(--accent);text-decoration:none}.api-key-help a:hover{text-decoration:underline;text-shadow:0 0 8px #0d958833}.current-api-key{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.api-key-badge{align-items:center;background:#34d3990f;border:1px solid #34d39933;border-radius:var(--radius-md);color:var(--text-primary);display:flex;font-size:.875rem;gap:8px;padding:9px 14px}.api-key-icon{font-size:1rem}.remove-api-key-btn{background:#0023660a;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;font-family:inherit;font-size:.875rem;padding:8px 14px;transition:all var(--transition-fast)}.remove-api-key-btn:hover{background:#f8717114;border-color:#f8717133;color:var(--error)}.danger-zone{background:#f8717108;border:1px solid #f8717126;border-radius:var(--radius-lg);margin-bottom:24px;padding:16px}.danger-zone h4{border-bottom-color:#f8717126!important;color:var(--error)!important}.danger-label{color:var(--error)!important;font-weight:600}.danger-description{color:var(--text-secondary);font-size:.82rem;line-height:1.5;margin-bottom:12px}.danger-description p{margin-bottom:4px}.danger-btn{background:#dc26260a;border:1px solid #dc262640;border-radius:var(--radius-md);color:var(--error);cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:500;margin-right:8px;padding:8px 14px;transition:all var(--transition-fast)}.danger-btn:hover{background:#f8717114;box-shadow:0 0 12px #f871711a}.danger-btn.confirm{background:var(--error);color:#fff}.cancel-btn{background:#0023660a;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;font-family:inherit;font-size:.875rem;padding:8px 14px;transition:all var(--transition-fast)}.cancel-btn:hover{background:#00236614}.settings-reset{border-top:1px solid var(--border);margin-top:20px;padding-top:20px}.settings-reset h4{border-bottom-color:#0d958826!important;color:var(--accent)!important}.reset-btn{align-items:center;background:#0d95880f;border:1px solid #0d958833;border-radius:var(--radius-md);color:var(--accent);cursor:pointer;display:inline-flex;font-family:inherit;font-size:.875rem;font-weight:500;gap:6px;margin-right:8px;padding:8px 14px;transition:all var(--transition-fast)}.reset-btn:hover{background:#0d95881f;box-shadow:0 0 12px #0d958814}.reset-btn.confirm{background:var(--accent);color:#fff}.reset-icon{font-size:.9rem}.setting-group input[type=range]{-webkit-appearance:none;appearance:none;background:var(--border);border-radius:var(--radius-full);cursor:pointer;height:4px;margin:8px 0 4px;outline:none;width:100%}.setting-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:var(--accent);border-radius:50%;box-shadow:0 0 0 3px #0d958826,0 0 8px #0d958833;cursor:pointer;height:18px;width:18px}.setting-group input[type=range]::-moz-range-thumb{background:var(--accent);border:none;border-radius:50%;cursor:pointer;height:18px;width:18px}.range-labels{color:var(--text-muted);display:flex;font-size:.72rem;justify-content:space-between;margin-top:2px}.setting-description{color:var(--text-muted);font-size:.78rem;line-height:1.4;margin-top:5px}.voice-test-container{align-items:flex-start;display:flex;flex-direction:column;gap:8px;margin-top:10px}.voice-test-button{align-items:center;background:#0023660a;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;display:inline-flex;font-family:inherit;font-size:.875rem;gap:8px;padding:8px 14px;transition:all var(--transition-fast)}.voice-test-button:hover:not(:disabled){background:#0d958814;border-color:#0d958833;color:var(--accent)}.voice-test-button:disabled{cursor:not-allowed;opacity:.5}.voice-test-error{background:#f871710f;border:1px solid #f8717133;border-radius:var(--radius-md);color:var(--error);font-size:.82rem;max-width:100%;padding:8px 12px}.toggle-label{align-items:center;cursor:pointer;display:flex;justify-content:space-between;-webkit-user-select:none;user-select:none}.toggle-switch{display:inline-block;flex-shrink:0;height:22px;position:relative;width:40px}.toggle-switch input{height:0;opacity:0;width:0}.toggle-slider{background:#00236626;border-radius:var(--radius-full);bottom:0;cursor:pointer;left:0;position:absolute;right:0;top:0;transition:background var(--transition-base)}.toggle-slider:before{background:#fff;border-radius:50%;bottom:3px;box-shadow:0 1px 4px #0000004d;content:"";height:16px;left:3px;position:absolute;transition:transform var(--transition-base);width:16px}input:checked+.toggle-slider{background:var(--accent);box-shadow:0 0 12px #0d958833}input:disabled+.toggle-slider{background:var(--border);cursor:not-allowed}input:checked+.toggle-slider:before{transform:translateX(18px)}@media (max-width:768px){.settings-panel{border-radius:0;margin:0;max-height:100%;max-width:100%}}.file-uploader{background:#0000;display:flex;flex-direction:column;height:100%;overflow:hidden}.file-uploader-header{align-items:center;background:#0000001a;border-bottom:1px solid var(--border);display:flex;flex-shrink:0;justify-content:space-between;padding:14px 18px}.file-uploader-header h3{color:var(--text-primary);font-family:Space Grotesk,sans-serif;font-size:.9rem;font-weight:700;margin:0}.close-uploader-btn{align-items:center;background:#ffffff0a;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;font-size:1rem;justify-content:center;padding:4px;transition:all var(--transition-fast)}.close-uploader-btn:hover{background:#f8717114;border-color:#f8717133;color:var(--error)}.file-uploader-content{flex:1 1;overflow-y:auto;padding:16px}.dropzone{background:#0d958808;border:2px dashed #0d958833;border-radius:var(--radius-lg);cursor:pointer;margin-bottom:14px;padding:28px 18px;text-align:center;transition:all var(--transition-fast)}.dropzone.active,.dropzone:hover{background:#0d95880f;border-color:var(--accent);box-shadow:0 0 20px #0d958814}.dropzone-content{align-items:center;display:flex;flex-direction:column;gap:10px}.upload-icon{color:var(--text-muted);font-size:1.8rem;margin-bottom:4px}.dropzone.active .upload-icon,.dropzone:hover .upload-icon{color:var(--accent)}.dropzone-title{color:var(--text-primary);font-family:Space Grotesk,sans-serif;font-size:.95rem;font-weight:600;margin:0}.format-container{background:#00000026;border-radius:var(--radius-md);margin-top:4px;padding:10px 12px;width:100%}.formats-title{color:var(--text-muted);display:flex;font-size:.78rem;justify-content:center}.dropzone.active .dropzone-icon,.dropzone:hover .dropzone-icon{color:var(--accent)}.dropzone p{color:var(--text-secondary);font-size:.875rem;margin:0}.dropzone .file-types{font-size:.75rem}.dropzone .file-types,.file-limit{color:var(--text-muted);margin-top:6px}.file-limit{font-size:.72rem;font-style:italic}.upload-error{background:#f871710f;border:1px solid #f8717133;border-radius:var(--radius-md);color:var(--error);font-size:.82rem;margin-bottom:12px;padding:9px 14px}.current-files h4,.selected-files h4{color:var(--text-muted);font-family:Space Grotesk,sans-serif;font-size:.68rem;font-weight:700;letter-spacing:.08em;margin:0 0 8px;text-transform:uppercase}.file-entry{align-items:center;background:#0000001f;border:1px solid var(--border);border-radius:var(--radius-md);display:flex;justify-content:space-between;margin-bottom:6px;padding:9px 12px;transition:all var(--transition-fast)}.file-entry:hover{background:#0d95880d;border-color:#0d958826}.file-entry-info{align-items:center;display:flex;gap:8px;min-width:0;overflow:hidden}.file-icon{color:var(--accent);flex-shrink:0;font-size:.9rem}.file-name{color:var(--text-primary);font-size:.82rem;font-weight:500;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-size{font-size:.72rem}.file-size,.remove-file-btn{color:var(--text-muted);flex-shrink:0}.remove-file-btn{align-items:center;background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;display:flex;justify-content:center;padding:4px;transition:all var(--transition-fast)}.remove-file-btn:hover{background:#f8717114;color:var(--error)}.processing-status{background:#34d3990f;border:1px solid #34d39933;border-radius:var(--radius-md);margin-top:10px;padding:10px 14px}.processing-status p{color:var(--success);font-size:.82rem;font-weight:500;margin:0 0 8px}.progress-bar{background:#ffffff0f;height:4px;overflow:hidden}.progress-bar,.progress-fill{border-radius:var(--radius-full)}.progress-fill{background:linear-gradient(90deg,var(--accent),var(--accent2));box-shadow:0 0 8px #0d95884d;height:100%;transition:width .3s ease}.file-uploader-actions{background:#0000001a;border-top:1px solid var(--border);display:flex;flex-shrink:0;gap:8px;justify-content:flex-end;padding:12px 16px}.upload-btn{background:linear-gradient(135deg,var(--accent),#99f6e4);border:none;border-radius:var(--radius-md);box-shadow:0 4px 12px #0d958840;color:#fff;cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:600;padding:9px 18px;transition:all var(--transition-fast)}.upload-btn:hover{box-shadow:0 6px 16px #0d958859;transform:translateY(-1px)}.upload-btn:disabled{background:#ffffff14;box-shadow:none;cursor:not-allowed;transform:none}.cancel-upload-btn{background:#00000026;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;font-family:inherit;font-size:.875rem;padding:9px 18px;transition:all var(--transition-fast)}.cancel-upload-btn:hover{background:#ffffff0d;border-color:var(--border-strong)}.progress-text{color:var(--text-muted);font-size:.72rem;margin:4px 0 0;text-align:center}@media (max-width:768px){.file-uploader{max-height:80vh}}.chat-container{background:#0000;color:var(--text-primary);flex:1 1;flex-direction:column;min-width:0}.chat-container,.chat-main-layout{display:flex;min-height:0;overflow:hidden;position:relative}.chat-main-layout{flex:1 1;gap:0}.chat-content-area{display:flex;flex:1 1;flex-direction:column;min-height:0;overflow:hidden}.chat-header{align-items:center;backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));background:var(--surface-1);border:1px solid var(--border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);display:flex;flex-shrink:0;gap:12px;height:56px;justify-content:space-between;margin:10px 16px 0;padding:0 24px;position:relative}.header-logo{filter:drop-shadow(0 1px 6px rgba(13,149,136,.2));flex-shrink:0;height:28px;object-fit:contain;width:auto}.chat-header:after{display:none}.chat-title-container{align-items:center;display:flex;flex:1 1;gap:10px;min-width:0}.hamburger-btn{align-items:center;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;display:flex;flex-shrink:0;font-size:1rem;justify-content:center;margin-left:auto;padding:6px;transition:all var(--transition-fast)}.hamburger-btn:hover{background:#0d958814;border-color:#0d95884d;color:var(--accent)}.gear-settings-btn{align-items:center;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;display:flex;font-size:1.05rem;justify-content:center;margin-left:8px;padding:6px;transition:all var(--transition-fast)}.gear-settings-btn:hover{background:#0d958814;border-color:#0d95884d;box-shadow:var(--shadow-md);color:var(--accent)}.gear-settings-btn svg{height:20px;width:20px}.chat-header h2{color:var(--text-primary);font-size:.92rem;margin:0;overflow:hidden;text-overflow:ellipsis}.chat-header h2,.generate-title-btn{font-family:Space Grotesk,sans-serif;font-weight:600;white-space:nowrap}.generate-title-btn{background:#0d958814;border:1px solid #0d958833;border-radius:var(--radius-full);color:var(--accent);cursor:pointer;flex-shrink:0;font-size:.72rem;letter-spacing:.02em;padding:4px 12px;transition:all var(--transition-fast)}.generate-title-btn:hover{background:#0d958826;border-color:var(--accent);box-shadow:0 0 12px #0d95881a}.generate-title-btn:disabled{cursor:not-allowed;opacity:.4}.new-chat-header-btn{align-items:center;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;display:flex;flex-shrink:0;font-size:1rem;justify-content:center;padding:6px;transition:all var(--transition-fast)}.new-chat-header-btn:hover{background:#0d958814;border-color:#0d95884d;color:var(--accent)}.chat-header-actions{align-items:center;display:flex;flex-shrink:0;gap:8px}.model-indicator{align-items:center;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;display:inline-flex;font-family:Space Grotesk,sans-serif;font-size:.78rem;font-weight:600;letter-spacing:.02em;padding:6px 12px;transition:all var(--transition-fast);white-space:nowrap}.model-indicator:hover{background:#0d958814;border-color:#0d95884d;box-shadow:var(--shadow-md);color:var(--accent)}.api-response-btn,.auto-tts-btn{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;font-family:inherit;font-size:.9rem;gap:5px;padding:6px 8px;transition:all var(--transition-fast)}.api-response-btn:hover,.auto-tts-btn:hover{background:#0d958814;color:var(--accent)}.api-response-btn.active,.auto-tts-btn.active,.document-buttons-dropdown button.active,.image-button-container button.active{background:var(--accent-light);color:var(--accent)}.btn-label{font-size:.8rem;font-weight:500}.chat-messages{display:flex;flex:1 1;flex-direction:column;min-height:0;overflow-y:auto;padding:20px 0 8px;position:relative}.chat-messages:before{background:url(/static/media/Sparf-Logo.b809b69310302502f348.webp) 50%/contain no-repeat;content:"";height:130px;left:55%;opacity:.04;pointer-events:none;position:fixed;top:50%;transform:translate(-50%,-50%);width:320px;z-index:0}.chat-messages-content{flex:1 1;margin:0 auto;max-width:800px;min-height:0;padding:0 24px}.chat-messages-content,.messages-container{display:flex;flex-direction:column;width:100%}.messages-container{flex:1 1;gap:6px}.empty-chat{align-items:center;animation:fadeUp .5s ease-out;color:var(--text-secondary);display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:40px 24px;text-align:center}.empty-chat-logo{animation:float 6s ease-in-out infinite;filter:drop-shadow(0 4px 24px rgba(13,149,136,.3));height:auto;margin-bottom:20px;max-width:260px;width:100%}.empty-chat h3{color:var(--text-primary);font-family:Space Grotesk,sans-serif;font-size:2.2rem;font-weight:800;letter-spacing:-.03em;line-height:1.15;margin-bottom:12px}.api-key-notice{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:var(--radius-xl);margin-top:32px;max-width:440px;padding:22px 28px;transition:all var(--transition-base)}.api-key-notice.warning{background:#fbbf240f;border:1px solid #fbbf2433}.api-key-notice.success{background:#34d3990f;border:1px solid #34d39933}.api-key-status-text{color:var(--success);font-weight:700;margin-bottom:8px}.api-key-notice p{color:var(--text-secondary);font-size:.9rem;margin-bottom:14px}.primary-btn{background:linear-gradient(135deg,var(--accent),#99f6e4);border:none;border-radius:var(--radius-md);box-shadow:0 4px 16px #0d958840;color:#fff;cursor:pointer;font-family:Space Grotesk,sans-serif;font-size:.875rem;font-weight:600;padding:10px 22px;transition:all var(--transition-fast)}.primary-btn:hover{box-shadow:0 6px 24px #0d958859,var(--shadow-glow);transform:translateY(-2px)}.security-warning{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#f871710d;border:1px solid #f8717126;border-radius:var(--radius-lg);color:var(--text-secondary);font-size:.78rem;line-height:1.6;margin-bottom:20px;margin-top:18px;max-width:560px;padding:14px 18px}.security-warning strong{color:var(--error);font-weight:700}.loading-message{display:flex;justify-content:center;padding:20px}.loading-dots{align-items:center;display:flex;gap:8px}.loading-dots span{animation:loadingBounce 1.2s ease-in-out infinite both;background:var(--accent);border-radius:50%;height:8px;opacity:.3;width:8px}.loading-dots span:first-child{animation-delay:-.32s}.loading-dots span:nth-child(2){animation-delay:-.16s}@keyframes loadingBounce{0%,80%,to{opacity:.3;transform:scale(.6)}40%{opacity:1;transform:scale(1)}}.error-message{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#f871710f;border:1px solid #f8717133;border-left:3px solid var(--error);border-radius:var(--radius-md);color:var(--error);font-size:.875rem;margin:12px 0;padding:14px 18px}.api-response{backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);margin:16px 0;max-height:700px;overflow-x:auto;overflow-y:auto;padding:20px}.api-response-header{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;margin-bottom:14px;padding-bottom:10px}.api-response-header h4{color:var(--accent);font-size:.9rem;font-weight:600;margin:0}.prompt-actions .action-button{background:none;border:none;color:var(--text-muted);cursor:pointer;margin-left:10px;padding:0;transition:color var(--transition-fast)}.prompt-actions .action-button:hover{color:var(--accent)}.close-btn{align-items:center;background:none;border:none;color:var(--text-muted);cursor:pointer;display:flex;font-size:1.1rem;transition:color var(--transition-fast)}.close-btn:hover{color:var(--text-primary)}.api-response-content{display:flex;flex-direction:column;gap:14px}.api-response-section{margin-bottom:8px}.api-response-section h5{color:var(--text-primary);font-size:.85rem;font-weight:600;margin:0 0 6px}.api-response-section p{color:var(--text-secondary);font-size:.875rem;margin:3px 0}.api-response pre{background:#0023660a;border:1px solid var(--border);border-radius:var(--radius-md);font-size:.82rem;margin:0;overflow-x:auto;padding:12px 14px;white-space:pre-wrap}.chat-input-outer{background:#0000;border-top:none;flex-shrink:0;padding:0 16px 12px;position:relative;width:100%}.chat-input-outer:before{display:none}.chat-input-container{align-items:flex-end;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);box-sizing:border-box;display:flex;flex-direction:row;gap:10px;margin:0 auto;max-width:840px;padding:12px 16px;position:relative;transition:all var(--transition-fast);width:100%}.chat-input-container:focus-within{border-color:#0d95884d;box-shadow:var(--shadow-lg)}.chat-input-container.dragging{background:#0d958814;border-color:#0d95884d}.file-drop-overlay{align-items:center;background:#0d95880f;border:2px dashed var(--accent);border-radius:var(--radius-xl);display:flex;flex-direction:column;height:100%;justify-content:center;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:100}.file-drop-overlay svg{color:var(--accent);margin-bottom:8px}.file-drop-overlay p{color:var(--accent);font-size:.9rem;font-weight:600;margin:0}.file-drop-overlay .dropzone-hint{color:var(--text-muted);font-size:.78rem;margin-top:6px;max-width:80%;text-align:center}.chat-input-actions{align-items:center;display:flex;flex-direction:row;flex-shrink:0;gap:2px}.chat-input-actions button{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;font-size:1rem;justify-content:center;padding:8px;transition:all var(--transition-fast)}.chat-input-actions button.active,.chat-input-actions button:hover{background:#0d95881a;color:var(--accent)}.message-input{background:#0000;border:none;border-radius:var(--radius-lg);color:var(--text-primary);flex:1 1;font-family:inherit;font-size:.95rem;line-height:1.5;max-height:200px;min-height:42px;padding:10px 14px;resize:none;transition:background var(--transition-fast)}.message-input::placeholder{color:var(--text-muted)}.message-input:focus{background:#00236605;outline:none}.message-input:disabled{cursor:not-allowed;opacity:.4}.send-button{align-items:center;background:linear-gradient(135deg,var(--accent),#99f6e4);border:none;border-radius:var(--radius-md);box-shadow:0 4px 16px #0d95884d;color:#fff;cursor:pointer;display:flex;flex-shrink:0;height:42px;justify-content:center;transition:all var(--transition-fast);width:42px}.send-button:hover{box-shadow:0 6px 24px #0d958866,var(--shadow-glow);transform:translateY(-2px) scale(1.05)}.send-button:disabled{background:#00236614;box-shadow:none;cursor:not-allowed;transform:none}.interrupt-button{align-items:center;background:linear-gradient(135deg,var(--error),#ef4444);border:none;border-radius:var(--radius-md);box-shadow:0 4px 16px #f871714d;color:#fff;cursor:pointer;display:flex;flex-shrink:0;height:42px;justify-content:center;transition:all var(--transition-fast);width:42px}.interrupt-button:hover{box-shadow:0 6px 20px #f8717166;transform:translateY(-2px)}.image-gen-panel{backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-xl);bottom:80px;box-shadow:var(--shadow-xl);padding:18px;position:absolute;right:16px;width:300px;z-index:5}.image-gen-panel h3{color:var(--text-primary);font-family:Space Grotesk,sans-serif;font-size:.95rem;font-weight:600;margin-bottom:12px;margin-top:0}.image-gen-panel textarea{background:#00236608;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:inherit;font-size:.875rem;margin-bottom:12px;padding:10px 12px;resize:none;transition:border-color var(--transition-fast);width:100%}.image-gen-panel textarea:focus{border-color:var(--accent);box-shadow:0 0 12px #0d95881a;outline:none}.image-gen-actions{display:flex;gap:8px;justify-content:flex-end}.image-gen-actions button{border-radius:var(--radius-md);cursor:pointer;font-family:inherit;font-size:.85rem;font-weight:500;padding:8px 16px}.image-gen-actions button:first-child{background:none;border:1px solid var(--border);color:var(--text-secondary)}.image-gen-actions .primary-btn{background:linear-gradient(135deg,var(--accent),#99f6e4);border:none;color:#fff}.image-gen-actions .primary-btn:disabled{background:#00236614;cursor:not-allowed}.context-files{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#00236608;border-top:1px solid var(--border);padding:8px 16px}.context-files h4{color:var(--text-muted);font-family:Space Grotesk,sans-serif;font-size:.72rem;font-weight:700;letter-spacing:.08em;margin:0;text-transform:uppercase}.file-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.file-item{background:#0d95880f;border:1px solid #0d958826;border-radius:var(--radius-full);color:var(--text-secondary);font-size:.78rem;gap:5px;padding:4px 12px}.file-item,.file-item button{align-items:center;display:flex}.file-item button{background:none;border:none;color:var(--text-muted);cursor:pointer;justify-content:center;padding:1px;transition:color var(--transition-fast)}.file-item button:hover{color:var(--error)}.disclaimer-banner{background:#0000;color:var(--text-muted);font-size:.72rem;padding:6px 16px;text-align:center}.disclaimer-banner p{font-style:italic;margin:0}.ai-accuracy-disclaimer{flex-shrink:0;margin:2px auto;max-width:90%;padding:4px 16px;text-align:center;width:100%}.ai-accuracy-disclaimer p{color:var(--text-muted);font-size:.7rem;font-style:italic;margin:0;opacity:.7}.copyright-footer{background:#0000;border-top:none;color:var(--text-muted);font-size:.68rem;opacity:.6;padding:6px 16px 8px;text-align:center}.copyright-footer p{margin:0}.document-buttons-dropdown{display:inline-block;position:relative}.document-type-selector{backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);bottom:100%;box-shadow:var(--shadow-xl);display:flex;flex-direction:column;gap:2px;margin-bottom:8px;min-width:140px;padding:8px;position:absolute;right:0;z-index:10}.document-type-selector button{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;display:flex;font-family:inherit;font-size:.875rem;gap:8px;padding:9px 14px;text-align:left;transition:all var(--transition-fast);width:100%}.document-type-selector button:hover{background:#0d958814}.document-type-selector button.active{background:var(--accent-light);color:var(--accent)}.document-mode-indicator{align-items:center;animation:fadeUp .2s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0d95880f;border:1px solid #0d958826;border-radius:var(--radius-md);display:flex;justify-content:space-between;margin-bottom:8px;padding:8px 14px}.document-mode-info{gap:8px}.document-icon,.document-mode-info{align-items:center;display:flex}.pdf-mode .document-icon{color:#fb923c}.word-mode .document-icon{color:#60a5fa}.excel-mode .document-icon{color:#34d399}.image-mode .document-icon{color:var(--accent)}.document-name{color:var(--text-primary);font-size:.82rem;font-weight:600;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.exit-document-mode-btn{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;justify-content:center;padding:4px;transition:all var(--transition-fast)}.exit-document-mode-btn:hover{background:#f871711a;color:var(--error)}.document-uploader-container,.pdf-uploader-container{border:1px solid var(--glass-border);bottom:100%;margin-bottom:12px;max-height:500px;max-width:90vw;overflow-y:auto;padding:18px;z-index:50}.document-uploader-container,.pdf-uploader-container{backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));background:var(--glass-bg);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);position:absolute;right:16px;width:360px}.pdf-uploader-container{border:1px solid var(--glass-border);bottom:90px;max-height:400px;overflow:hidden;z-index:1000}.pdf-mode-indicator{background:#34d3990f;border:1px solid #34d39933;border-radius:var(--radius-md);justify-content:space-between;margin-bottom:10px;padding:9px 14px}.pdf-icon,.pdf-mode-indicator,.pdf-mode-info{align-items:center;display:flex}.pdf-icon{color:var(--success);margin-right:8px}.pdf-name{color:var(--text-primary);font-weight:500;max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.exit-pdf-mode-btn{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;justify-content:center;padding:4px;transition:all var(--transition-fast)}.exit-pdf-mode-btn:hover{background:#f871711a;color:var(--error)}.chat-input-actions .action-button.active{background:var(--accent-light);border-radius:var(--radius-sm);color:var(--accent)}@media (max-width:768px){.chat-header{margin:8px 10px 0;padding:0 16px 0 52px}.chat-input-outer{padding:0 8px 10px}.chat-input-container{border-radius:var(--radius-lg);padding:10px 12px}.chat-messages-content{padding:0 12px}}
/*# sourceMappingURL=main.7baa2e84.css.map*/