:root,body.light-theme{--bg-dark: #ffffff;--bg-surface: #f9fafb;--bg-surface-hover: #f3f4f6;--text-main: #111827;--text-muted: #6b7280;--primary: #4d6bfe;--primary-hover: #3b56d8;--danger: #ef4444;--danger-hover: #dc2626;--border: #e5e7eb;--radius-lg: 24px;--radius-md: 12px;--radius-sm: 8px}@media(prefers-color-scheme:dark){:root:not(.light-theme){--bg-dark: #171717;--bg-surface: #212121;--bg-surface-hover: #2f2f2f;--text-main: #ececec;--text-muted: #a1a1aa;--primary: #4d6bfe;--primary-hover: #5d78ff;--border: #3f3f3f}}body.dark-theme{--bg-dark: #171717;--bg-surface: #212121;--bg-surface-hover: #2f2f2f;--text-main: #ececec;--text-muted: #a1a1aa;--primary: #4d6bfe;--primary-hover: #5d78ff;--border: #3f3f3f}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg-dark);color:var(--text-main);height:100vh;overflow:hidden;display:flex}button{cursor:pointer;font-family:inherit;border:none;background:transparent}input,textarea{font-family:inherit;outline:none}.screen{display:none;width:100%;height:100%}.screen.active{display:flex}#auth-screen{align-items:center;justify-content:center}.auth-container{background:var(--bg-surface);padding:2.5rem;border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #0000001a;width:100%;max-width:400px;border:1px solid var(--border)}.auth-container h2{margin-bottom:.5rem}.auth-container p{color:var(--text-muted);margin-bottom:1.5rem;font-size:.9rem}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.85rem;font-weight:500;margin-bottom:.25rem}.form-group input{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-dark);color:var(--text-main)}.form-group input:focus{border-color:var(--primary)}.auth-buttons{display:flex;gap:.5rem;margin-top:1.5rem}.primary-btn,.secondary-btn,.outline-btn,.danger-btn{padding:.75rem 1rem;border-radius:var(--radius-md);font-weight:500;flex:1;text-align:center;transition:all .2s}.primary-btn{background:var(--primary);color:#fff}.primary-btn:hover{background:var(--primary-hover)}.secondary-btn{background:var(--bg-surface-hover);color:var(--text-main)}.secondary-btn:hover{background:var(--border)}.outline-btn{border:1px solid var(--border);color:var(--text-main);width:100%}.outline-btn:hover{background:var(--bg-surface-hover)}.danger-btn{background:var(--danger);color:#fff}.danger-btn:hover{background:var(--danger-hover)}.divider{display:flex;align-items:center;text-align:center;color:var(--text-muted);margin:1.5rem 0;font-size:.8rem}.divider:before,.divider:after{content:"";flex:1;border-bottom:1px solid var(--border)}.divider span{padding:0 .5rem}.error-msg{color:var(--danger);font-size:.85rem;margin-top:.5rem;padding:.5rem;background:#ef44441a;border-radius:var(--radius-sm)}.hidden{display:none!important}#chat-screen{flex-direction:row}.sidebar{width:260px;background:var(--bg-surface);border-right:1px solid var(--border);display:flex;flex-direction:column;transition:transform .3s ease}.sidebar-header{padding:1rem}.new-chat-block-btn{display:flex;align-items:center;gap:.5rem;width:100%;padding:.75rem 1rem;border-radius:var(--radius-md);background:var(--bg-surface-hover);color:var(--text-main);font-weight:500;font-size:.95rem;transition:background .2s;border:1px solid var(--border)}.new-chat-block-btn:hover{background:var(--border)}.new-chat-block-btn svg{width:16px;height:16px}.sidebar-footer{padding:1rem;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;position:relative}.user-info{display:flex;flex-direction:column;font-size:.85rem;overflow:hidden}.user-info span:first-child{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}.badge{font-size:.7rem;background:var(--bg-surface-hover);padding:.15rem .5rem;border-radius:12px;width:fit-content;margin-top:.25rem;border:1px solid var(--border);color:var(--text-muted)}.settings-dropdown{position:relative}.dropdown-content{position:absolute;bottom:100%;left:0;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:0 4px 12px #0000001a;min-width:180px;z-index:10;margin-bottom:.5rem;overflow:hidden}.dropdown-content button{width:100%;text-align:left;padding:.75rem 1rem;display:flex;align-items:center;gap:.75rem;font-size:.85rem;color:var(--text-main);transition:background .2s}.dropdown-content button:hover{background:var(--bg-surface-hover)}.dropdown-content button.danger{color:var(--danger)}.dropdown-content button svg{width:14px;height:14px}.sidebar-content{flex:1;overflow-y:auto;padding:.5rem}.chat-list{list-style:none}.chat-item{padding:.1rem .5rem;margin-bottom:.1rem;border-radius:var(--radius-md);color:var(--text-main);display:flex;align-items:center;justify-content:space-between;font-size:.9rem}.chat-item-link{padding:.5rem;display:flex;align-items:center;gap:.75rem;flex:1;overflow:hidden;cursor:pointer}.chat-item:hover{background:var(--bg-surface-hover)}.chat-item.active{background:var(--bg-surface-hover);font-weight:500}.chat-item svg{width:14px;height:14px;color:var(--text-muted)}.chat-item-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.chat-delete-btn{opacity:0;transition:opacity .2s;color:var(--text-muted);display:flex;align-items:center;justify-content:center;padding:.5rem}.chat-item:hover .chat-delete-btn{opacity:1}.chat-delete-btn:hover{color:var(--danger)}.chat-delete-btn svg{width:14px;height:14px}.chat-main{flex:1;display:flex;flex-direction:column;background:var(--bg-dark);position:relative}.icon-btn,.mobile-only{color:var(--text-muted);padding:.4rem;border-radius:var(--radius-sm);display:flex;align-items:center;transition:all .2s}.icon-btn:hover,.mobile-only:hover{background:var(--bg-surface-hover);color:var(--text-main)}.icon-btn svg,.mobile-only svg{width:18px;height:18px}.mobile-only{display:none}.chat-header{padding:1rem 1.5rem;display:flex;align-items:center;border-bottom:1px solid var(--border);background:var(--bg-surface);gap:1rem}.chat-title-container{display:flex;align-items:center;gap:.5rem}.chat-title-container h2{font-size:1rem;font-weight:500;color:var(--text-main)}.messages-container{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem;scroll-behavior:smooth}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;margin:auto;color:var(--text-main);text-align:center;max-width:600px}.empty-icon{margin-bottom:1.5rem;color:var(--primary);background-color:var(--bg-surface-hover);padding:1rem;border-radius:50%}.empty-icon svg{width:32px;height:32px}.empty-state h2{font-size:1.5rem;font-weight:600;margin-bottom:.5rem}.empty-state p{color:var(--text-muted);font-size:1rem}.message{display:flex;gap:1rem;max-width:800px;margin:0 auto;width:100%}.message.user{justify-content:flex-end}.message-content.user-bubble{background:var(--bg-surface-hover);padding:.75rem 1.25rem;border-radius:var(--radius-lg);max-width:75%;flex:none}.message-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--primary);color:#fff;flex-shrink:0}.message-avatar svg{width:18px;height:18px}.message-content{flex:1;min-width:0}.message-body{line-height:1.6;font-size:.95rem;overflow-wrap:break-word}.message-body p{margin-bottom:.75rem}.message-body p:last-child{margin-bottom:0}.message-body pre{background:var(--bg-surface);padding:1rem;border-radius:var(--radius-md);overflow-x:auto;margin-bottom:.75rem;border:1px solid var(--border);font-family:monospace}.message-body code{font-family:monospace;background:var(--bg-surface);padding:.2rem .4rem;border-radius:4px}.message-actions{display:flex;gap:.5rem;margin-top:.5rem;opacity:0;transition:opacity .2s;align-items:center}.message:hover .message-actions{opacity:1}.action-btn{color:var(--text-muted);font-size:.8rem;display:flex;align-items:center;gap:.25rem;padding:.2rem .4rem;border-radius:var(--radius-sm)}.action-btn:hover{color:var(--text-main);background:var(--bg-surface-hover)}.variations-selector{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--text-muted);-webkit-user-select:none;user-select:none;margin-right:.5rem}.variations-selector button{color:var(--text-muted);display:flex;align-items:center;justify-content:center;border-radius:4px;padding:.1rem}.variations-selector button:hover:not(:disabled){background:var(--bg-surface-hover);color:var(--text-main)}.variations-selector button:disabled{opacity:.3;cursor:not-allowed}.variations-selector svg{width:14px;height:14px}.action-btn svg{width:14px;height:14px}.chat-input-area{padding:1.5rem;background:var(--bg-dark);max-width:840px;margin:0 auto;width:100%}.chat-form{display:flex;gap:.5rem;background:var(--bg-surface-hover);border:1px solid transparent;border-radius:var(--radius-lg);padding:.75rem 1rem;align-items:flex-end;transition:background .2s}.chat-form:focus-within{background:var(--bg-dark);border-color:var(--primary);box-shadow:0 0 0 4px #4d6bfe1a}.chat-form textarea{flex:1;background:transparent;border:none;resize:none;padding:.5rem 0;color:var(--text-main);max-height:200px;min-height:24px}.chat-form button#send-btn{background:var(--primary);color:#fff;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-bottom:.1rem;transition:opacity .2s}.chat-form button#send-btn:disabled{background:var(--text-muted);opacity:.5;cursor:not-allowed}.chat-actions-col{display:flex;flex-direction:row;gap:.25rem;align-items:center}.chat-form button#attach-btn,.chat-form button#search-btn{color:var(--text-muted);width:36px;height:36px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .2s,color .2s;background:transparent}.chat-form button#attach-btn:hover,.chat-form button#search-btn:hover{background:var(--bg-dark);color:var(--text-main)}.chat-form button#search-btn.active{background:#4d6bfe33;color:var(--primary)}.input-footer{text-align:center;font-size:.75rem;color:var(--text-muted);margin-top:.5rem;display:flex;justify-content:center;gap:1rem}.search-queries-badge{display:inline-flex;align-items:center;gap:.25rem;background:var(--bg-surface-hover);color:var(--text-muted);font-size:.75rem;padding:.25rem .5rem;border-radius:var(--radius-sm);margin-bottom:.5rem}.search-queries-badge svg{width:12px;height:12px}.modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100}.modal-content{background:var(--bg-surface);padding:2rem;border-radius:var(--radius-lg);width:90%;max-width:400px}.modal-content h3{margin-bottom:.5rem}.modal-content p{color:var(--text-muted);margin-bottom:1.5rem;font-size:.9rem}.modal-content input{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-dark);color:var(--text-main);margin-bottom:1.5rem}.modal-actions{display:flex;gap:1rem}.loading-dots{display:inline-block;color:var(--text-muted);font-style:italic;animation:pulse 1.5s infinite ease-in-out}@keyframes pulse{0%{opacity:.4}50%{opacity:1}to{opacity:.4}}.edit-mode textarea{width:100%;min-height:80px;background:var(--bg-dark);border:1px solid var(--border);border-radius:var(--radius-md);padding:.5rem;color:var(--text-main);margin-bottom:.5rem}.edit-actions{display:flex;gap:.5rem}.edit-actions button{padding:.4rem .8rem;border-radius:var(--radius-sm);font-size:.8rem}.btn-save{background:var(--primary);color:#fff}.btn-cancel{background:var(--bg-surface-hover);color:var(--text-main)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media(max-width:768px){.sidebar{position:absolute;left:-100%;height:100%;z-index:50}.sidebar.open{left:0}.mobile-only{display:block;background:transparent;color:var(--text-main);padding:.5rem}}
