:root{--bg-color: #181c24;--text-color: #e6e6e6;--bg-color-darker: #0b2545;--bg-color-lighter: #23272f;--border-color: #298dff;--border-color-light: #3a3f4b;--link-color: #4fc3f7;--link-hover-color: #6edcff;--sidebar-bg: #181c24;--sidebar-text: #e6e6e6;--sidebar-hover-bg: #112d5c;--sidebar-active-bg: #1f2430;--input-bg: #23272f;--input-text: #e6e6e6;--input-border: #3a3f4b;--button-bg: #0b2545;--button-text: #e6e6e6;--button-hover-bg: #112d5c;--bubble-user-bg: #23272f;--bubble-user-text: #e6e6e6;--bubble-assistant-bg: #0b2545;--bubble-assistant-text: #e6e6e6;--code-bg: #23272f;--code-text: #e6e6e6}body,.stApp{background:var(--bg-color)!important}.user-bubble{background:var(--bubble-user-bg);color:var(--bubble-user-text);border:1px solid var(--border-color-light);border-radius:16px;padding:.7rem 1.2rem;margin-bottom:.5rem;display:inline-block;max-width:100%;word-wrap:break-word;overflow-wrap:break-word;overflow:hidden}.assistant-bubble{background:var(--bubble-assistant-bg);color:var(--bubble-assistant-text);border:1px solid var(--border-color);border-radius:16px;padding:.7rem 1.2rem;margin-bottom:.5rem;display:block;animation:fadeInUp .3s ease-out;word-wrap:break-word;max-width:100%;overflow-wrap:break-word;overflow:hidden}.assistant-bubble.streaming{border:1px solid var(--link-color);box-shadow:0 0 10px #4fc3f74d;animation:pulse-border 2s infinite,fadeInUp .3s ease-out}.thinking-bubble{background:var(--bubble-assistant-bg);color:var(--bubble-assistant-text);border:1px solid var(--border-color);border-radius:16px;padding:.7rem 1.2rem;margin-bottom:.5rem;display:inline-block;animation:thinking-pulse 1.5s infinite,fadeInUp .3s ease-out}.typing-cursor:after{content:"▋";color:var(--link-color);animation:cursor-blink 1s infinite;margin-left:2px}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-border{0%,to{border-color:#298dff;box-shadow:0 0 5px #298dff4d}50%{border-color:#4fc3f7;box-shadow:0 0 15px #4fc3f799}}@keyframes thinking-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.02)}}@keyframes cursor-blink{0%,50%{opacity:1}51%,to{opacity:0}}.chat-wrapper{max-width:960px;margin:0 auto;padding:1rem;color:var(--text-color)}.chat-list{min-height:60vh;overflow-y:auto;padding:.5rem;border:1px solid var(--border-color)22;border-radius:12px}.chat-input{display:flex;gap:.5rem;margin-top:.75rem}.chat-input textarea{flex:1;padding:.75rem 1rem;min-height:50px;max-height:200px;border-radius:10px;border:1px solid var(--border-color-light);background:var(--input-bg);color:var(--input-text);font-size:1rem;font-family:inherit;resize:none;overflow-y:auto}.chat-input button{padding:.75rem 1.5rem;min-width:80px;height:fit-content;border-radius:10px;border:1px solid var(--border-color);background:var(--button-bg);color:var(--button-text);cursor:pointer;align-self:flex-end}.sidebar{position:fixed;right:16px;top:16px;width:320px;background:var(--sidebar-bg);border:1px solid var(--border-color)22;border-radius:12px;padding:.75rem;color:var(--sidebar-text)}.logout-button{display:block;width:100%;box-sizing:border-box;padding:.6rem 1rem;margin-top:.5rem;border-radius:8px;border:1px solid var(--border-color);background:var(--button-bg);color:var(--button-text);font-size:.95rem;font-weight:500;text-align:center;cursor:pointer;transition:all .2s ease}.logout-button:active{transform:scale(.98);box-shadow:0 0 2px #4fc3f733}.typing-status{font-size:.85rem;color:#b0b0b0;opacity:.9;margin-top:.25rem;align-self:flex-end}.chat-list{display:flex;flex-direction:column}.assistant-bubble,.user-bubble{font-size:1rem;line-height:1.5}.assistant-bubble h1,.user-bubble h1{font-size:1.3rem}.assistant-bubble h2,.user-bubble h2{font-size:1.15rem}.assistant-bubble h3,.assistant-bubble h4,.assistant-bubble h5,.assistant-bubble h6,.user-bubble h3,.user-bubble h4,.user-bubble h5,.user-bubble h6{font-size:1.05rem}.assistant-bubble p,.user-bubble p{margin:.5em 0}.assistant-bubble ul,.assistant-bubble ol,.user-bubble ul,.user-bubble ol{margin:.5em 0 .5em 1.25em}.assistant-bubble code,.assistant-bubble pre,.user-bubble code,.user-bubble pre{background:var(--code-bg);color:var(--code-text);padding:.2em .4em;border-radius:4px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,Liberation Mono,monospace;font-size:.95em}.assistant-bubble pre,.user-bubble pre{padding:.6em;border-radius:6px;overflow-x:auto;line-height:1.45;margin:.6em 0}.assistant-bubble blockquote,.user-bubble blockquote{border-left:3px solid var(--border-color);margin:.6em 0;padding-left:.75em;color:#b0b0b0}.assistant-bubble a,.user-bubble a{color:var(--link-color);text-decoration:underline}.assistant-bubble *,.user-bubble *{box-sizing:border-box}.assistant-bubble ul,.assistant-bubble ol,.user-bubble ul,.user-bubble ol{list-style-position:inside}.assistant-bubble table,.user-bubble table,.assistant-bubble pre,.user-bubble pre{max-width:100%;overflow-x:auto;display:block}.hamburger{position:fixed;top:16px;right:16px;z-index:1100;width:40px;height:40px;border-radius:8px;border:1px solid var(--border-color);background:var(--button-bg);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex-direction:column;gap:5px;transition:background .2s ease,border-color .2s ease}.hamburger:hover{background:var(--button-hover-bg);border-color:var(--link-color)}.hamburger span{display:block;width:18px;height:2px;background:var(--text-color);border-radius:2px}.sidebar-overlay{position:fixed;inset:0;background:#00000059;backdrop-filter:blur(1px);z-index:1090}.sidebar-panel{position:fixed;top:0;right:-340px;width:320px;height:100dvh;background:var(--sidebar-bg);border-left:1px solid var(--border-color)22;box-shadow:-12px 0 24px #00000059;z-index:1110;display:flex;flex-direction:column;transition:right .25s ease}.sidebar-panel.open{right:0}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:12px;border-bottom:1px solid #298dff22}.sidebar-title{font-size:1rem;font-weight:600;color:var(--text-color)}.sidebar-close{background:transparent;border:1px solid var(--border-color-light);color:var(--text-color);border-radius:8px;width:32px;height:32px;cursor:pointer;transition:all .2s ease}.sidebar-close:hover{border-color:var(--link-color)}.sidebar-content{padding:12px;display:flex;flex-direction:column;gap:12px}.logout-button{display:block;width:100%;box-sizing:border-box;padding:.6rem 1rem;margin-top:.25rem;border-radius:8px;border:1px solid var(--border-color);background:var(--button-bg);color:var(--button-text);font-size:.95rem;font-weight:500;text-align:center;cursor:pointer;transition:all .2s ease}.logout-button:hover{background:var(--button-hover-bg);border-color:var(--link-color);box-shadow:0 0 4px #4fc3f74d}.logout-button:active{transform:scale(.98)}@media (min-width: 1280px){.sidebar-overlay{display:none}.sidebar-panel{right:-340px}.sidebar-panel.open{right:0}}.bubble-emoji{margin-right:.35rem}.assistant-bubble .bubble-html>:last-child,.user-bubble .bubble-html>:last-child{margin-bottom:0!important}.assistant-bubble .bubble-html p:empty,.user-bubble .bubble-html p:empty{display:none}.bubble-footer{font-size:.85rem;color:#888;margin-top:.25rem;text-align:right}.bubble-html>pre,.bubble-html pre{overflow-x:auto;line-height:1.45;margin:.6em 0}.bubble-html code{background:var(--code-bg);color:var(--code-text);padding:.2em .4em;border-radius:4px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,Liberation Mono,monospace;font-size:.95em}.bubble-html blockquote{border-left:3px solid #298dff;margin:.6em 0;padding-left:.75em;color:#b0b0b0}.bubble-html a{color:#4fc3f7;text-decoration:underline}.assistant-bubble,.user-bubble,.bubble-html{font-family:Merriweather Sans,serif}html,body,input,button,textarea{font-family:Montserrat,sans-serif}.assistant-bubble .bubble-html li:empty{display:none}.assistant-bubble .bubble-html li:empty::marker{content:""}.assistant-bubble .bubble-html ul:empty,.assistant-bubble .bubble-html ol:empty{display:none}.hamburger.left{position:fixed;top:16px;left:16px;z-index:1100;width:40px;height:40px;border-radius:8px;border:1px solid var(--border-color);background:var(--button-bg);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex-direction:column;gap:5px;transition:background .2s ease,border-color .2s ease}.hamburger.left:hover{background:var(--sidebar-hover-bg);border-color:var(--link-color)}.chat-thread-wrapper{position:relative;display:flex;align-items:stretch;gap:0;width:100%}.chat-thread-item{text-align:left;padding:10px 45px 10px 12px;border-radius:10px;border:1px solid var(--border-color-light);background:var(--bg-color-lighter);color:var(--text-color);cursor:pointer;flex:1;display:flex;flex-direction:column;position:relative}.chat-thread-edit{flex:1;padding:.5rem}.thread-edit-input{width:100%;padding:.5rem .75rem;border:2px solid var(--link-color);border-radius:6px;background:var(--bg-color-lighter);color:var(--text-color);font-size:.95rem;font-family:inherit;outline:none}.thread-edit-input:focus{border-color:var(--border-color);box-shadow:0 0 8px #298dff4d}.thread-edit-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);opacity:.6;cursor:pointer;background:transparent;border:none;color:var(--link-color);padding:.25rem .5rem;font-size:1rem;transition:opacity .2s;flex-shrink:0;z-index:10}.thread-edit-btn:hover{opacity:1}.chat-thread-item:disabled{cursor:not-allowed;opacity:.5;border-color:#2a2f38;background:#1a1e26}.chat-thread-item:disabled:hover{border-color:#2a2f38;background:#1a1e26}.new-chat-inline:disabled,.new-chat-button:disabled{cursor:not-allowed;opacity:.5;border-color:#555;background:#0a1929}.new-chat-inline:disabled:hover,.new-chat-button:disabled:hover{background:#0a1929;border-color:#555;box-shadow:none}@media (min-width: 1280px){.sidebar-overlay{display:none}}.hamburger.left,.icon-chat.left{position:fixed;top:16px;left:16px;z-index:1100;width:40px;height:40px;border-radius:8px;border:1px solid var(--border-color);background:var(--button-bg);color:var(--text-color);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .2s ease,border-color .2s ease,color .2s ease}.hamburger.left:hover,.icon-chat.left:hover{background:var(--button-hover-bg);border-color:var(--link-color)}.sidebar-panel.left{left:-340px;right:auto;border-right:1px solid var(--border-color)22;border-left:none}.sidebar-panel.left.open{left:0}@media (min-width: 1280px){.icon-chat.left{display:none}.sidebar-panel.left{left:0!important}.sidebar-panel.left .sidebar-close{display:none}.sidebar-overlay{display:none!important}.chat-wrapper{margin-left:340px}}.new-chat-inline,.new-chat-button{padding:.55rem .9rem;border-radius:8px;border:1px solid var(--border-color);background:var(--button-bg);color:var(--button-text);cursor:pointer;transition:all .2s ease}.new-chat-inline:hover,.new-chat-button:hover{background:var(--button-hover-bg);border-color:var(--link-color);box-shadow:0 0 4px #4fc3f74d}.chat-thread-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}.chat-thread-item{text-align:left;padding:10px 12px;border-radius:10px;border:1px solid var(--border-color-light);background:var(--bg-color-lighter);color:var(--text-color);cursor:pointer}.chat-thread-item.active{border-color:var(--border-color);box-shadow:0 0 6px #298dff40;background:var(--sidebar-active-bg)}.chat-thread-item .thread-title{font-weight:600;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-thread-item .thread-sub{opacity:.8;font-size:.8rem;margin-top:2px}.chat-header{display:flex;align-items:center;justify-content:center;position:relative}.chat-title{margin:0;text-align:center;width:100%}.chat-actions{display:flex;align-items:center;gap:8px}.thread-title{max-width:42vw;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:.9;font-size:.95rem}.theme-toggle{position:fixed;top:1rem;right:4rem;z-index:1001;background:none;border:none;cursor:pointer;font-size:1.5rem;padding:.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;width:44px;height:44px}.theme-toggle:hover{background-color:var(--bg-color-lighter)}.theme-switch{position:fixed;top:1.25rem;right:4.5rem;display:inline-block;width:50px;height:26px;z-index:1100}.theme-switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#ccc;transition:.4s;border-radius:26px}.slider:before{position:absolute;content:"";height:18px;width:18px;left:4px;bottom:4px;background-color:#fff;transition:.4s;border-radius:50%}input:checked+.slider{background-color:#2196f3}input:focus+.slider{box-shadow:0 0 1px #2196f3}input:checked+.slider:before{transform:translate(24px)}.slider:after{content:"☀️";font-size:12px;position:absolute;top:50%;transform:translateY(-50%);right:6px;opacity:1;transition:opacity .2s}input:checked+.slider:after{opacity:0}.slider:before{z-index:1}input:checked+.slider:before{content:"🌙";font-size:12px;color:#fff;text-align:center;line-height:18px;transform:translate(24px)}body.light-theme .slider:after{content:"🌙";opacity:0}body.light-theme input:checked+.slider:after{opacity:1}body.light-theme .slider:before{content:"☀️"}.light-theme .chat-thread-item.active{border-color:#007bff;box-shadow:0 0 8px #007bff40}body.light-theme{--bg-color: #ffffff;--text-color: #212529;--bg-color-darker: #f8f9fa;--bg-color-lighter: #e9ecef;--border-color: #dee2e6;--border-color-light: #ced4da;--link-color: #007bff;--link-hover-color: #0056b3;--sidebar-bg: #f8f9fa;--sidebar-text: #212529;--sidebar-hover-bg: #e9ecef;--sidebar-active-bg: #ffffff;--input-bg: #fff;--input-text: #212529;--input-border: #ced4da;--button-bg: #007bff;--button-text: #fff;--button-hover-bg: #0069d9;--bubble-user-bg: #e9ecef;--bubble-user-text: #212529;--bubble-assistant-bg: #f8f9fa;--bubble-assistant-text: #212529;--code-bg: #f5f5f5;--code-text: #64242b}
