.app-layout{width:100%;height:100dvh;display:flex;overflow:hidden}.sidebar{background:#fafafa;border-right:1px solid #00000014;flex-direction:column;width:260px;min-width:260px;height:100dvh;transition:transform .2s;display:flex;overflow:hidden}.sidebar-header{align-items:center;gap:10px;padding:20px 16px 12px;display:flex}.sidebar-header .sidebar-logo{filter:brightness(0);width:28px;height:28px}.sidebar-header .sidebar-title{letter-spacing:-.04em;color:#1b252d;white-space:nowrap;font-family:Tinos,serif;font-size:16px;font-weight:400}.sidebar-actions{flex-direction:column;gap:4px;padding:8px 12px;display:flex}.sidebar-btn{color:#1b252d;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:10px;align-items:center;gap:10px;width:100%;padding:10px 12px;font-family:Inter,sans-serif;font-size:14px;font-weight:500;transition:background .15s;display:flex}.sidebar-btn:hover{background:#0000000d}.sidebar-btn.active{background:#00000014}.sidebar-btn.disabled{opacity:.35;cursor:not-allowed}.sidebar-btn.disabled:hover{background:0 0}.sidebar-btn .btn-icon.spinning{animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sidebar-btn .btn-icon{flex-shrink:0;width:18px;height:18px}.sidebar-divider{background:#00000014;height:1px;margin:8px 16px}.sidebar-section-label{text-transform:uppercase;letter-spacing:.05em;color:#00000059;padding:12px 16px 6px;font-size:11px;font-weight:600}.sidebar-recents{flex:1;padding:0 12px 16px;overflow-y:auto}.sidebar-recents::-webkit-scrollbar{width:3px}.sidebar-recents::-webkit-scrollbar-track{background:0 0}.sidebar-recents::-webkit-scrollbar-thumb{background:#0000001a;border-radius:2px}.recent-item{color:#0009;cursor:pointer;white-space:nowrap;text-overflow:ellipsis;text-align:left;background:0 0;border:none;border-radius:8px;width:100%;padding:8px 12px;font-family:Inter,sans-serif;font-size:13px;text-decoration:none;transition:background .15s;display:block;overflow:hidden}.recent-item:hover{color:#1b252d;background:#0000000d}.recent-item.active{color:#1b252d;background:#00000014}@media (width<=768px){.sidebar{z-index:100;position:fixed;top:0;left:0;transform:translate(-100%);box-shadow:4px 0 24px #0000001a}.sidebar.open{transform:translate(0)}.sidebar-overlay{z-index:99;background:#0000004d;position:fixed;inset:0}}.chat-container{flex-direction:column;flex:1;min-width:0;max-width:100%;height:100dvh;padding:20px 0;display:flex;overflow:hidden}.chat-header{color:#1b252d;letter-spacing:-.01em;box-sizing:border-box;background:#fff;border:.63px solid #e5e7eb;border-radius:0;align-items:center;width:100%;height:56.6px;padding:0 16px;font-size:16px;font-weight:500;display:flex;box-shadow:0 4px 24px #00000014,0 1px 4px #0000000a}.chat-header .header-content{align-items:center;gap:11.99px;height:31.99px;display:flex}.chat-header .header-title{letter-spacing:-.04em;color:#1b252d;white-space:nowrap;height:20px;font-family:Tinos,serif;font-size:20px;font-style:normal;font-weight:400;line-height:20px}.chat-body{box-sizing:border-box;background:#fff;border:1px solid #0000001a;border-top:none;border-radius:0;flex-direction:column;flex:1;width:100%;display:flex;overflow:hidden;box-shadow:0 4px 24px #00000014,0 1px 4px #0000000a}.chat-header .logo{filter:brightness(0);width:31.99px;height:31.99px;transition:transform .3s}.chat-header .logo.spinning{animation:1.2s linear infinite spin}.chat-messages{background:#fff;flex-direction:column;flex:1;gap:12px;padding:20px 24px;display:flex;overflow-y:auto}.chat-messages::-webkit-scrollbar{width:4px}.chat-messages::-webkit-scrollbar-track{background:0 0}.chat-messages::-webkit-scrollbar-thumb{background:#00000026;border-radius:2px}.message{word-wrap:break-word;border-radius:12px;max-width:85%;padding:12px 16px;font-size:14px;line-height:1.6}.message.user{color:#1b252d;background:#ffee97;border-bottom-right-radius:4px;align-self:flex-end;font-weight:450}.message.bot{color:#1b252d;background:#f5f5f5;border:1px solid #0000000f;border-bottom-left-radius:4px;align-self:flex-start}.message.bot a{color:#2563eb;font-weight:500;text-decoration:none}.message.bot a:hover{text-decoration:underline}.chat-input{box-sizing:border-box;background:#fff;border-top:.63px solid #e5e7eb;justify-content:center;align-items:center;width:100%;padding:16px 24px;display:flex}.chat-input-inner{box-sizing:border-box;background:#f5f5f5;border-radius:14px;flex-direction:column;flex:1;min-width:0;padding:12px 16px;display:flex}.chat-input .left-btn{cursor:pointer;box-sizing:border-box;background:#f5f5f5;border:none;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;padding:14px;display:flex}.chat-input .left-btn:hover{background:#ebebeb}.chat-input textarea{color:#1b252d;box-sizing:border-box;letter-spacing:0;resize:none;background:0 0;border:none;outline:none;width:100%;min-height:24px;max-height:200px;padding:0;font-family:Inter,sans-serif;font-size:16px;font-style:normal;font-weight:400;line-height:24px;overflow-y:hidden}.chat-input textarea::placeholder{color:#00000059}.chat-input .send-btn{opacity:.5;color:#fff;cursor:pointer;box-sizing:border-box;background:#1b252d;border:none;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;padding:0;font-size:14px;font-weight:500;transition:opacity .2s;display:flex}.chat-input .send-btn:hover{opacity:.7}.chat-input .send-btn:disabled{opacity:.3;cursor:not-allowed}.progress-steps{font-size:13px;line-height:2}.progress-steps .step{color:#0006;transition:color .3s}.progress-steps .step.active{color:#1b252d}.progress-steps .step.done{color:#16a34a}.progress-steps .step:before{content:"○ ";color:#0003}.progress-steps .step.active:before{content:"◉ ";color:#1b252d}.progress-steps .step.done:before{content:"✓ ";color:#16a34a}.download-btn{color:#fff;letter-spacing:-.01em;background:#1b252d;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;padding:14px 20px;font-size:14px;font-weight:600;text-decoration:underline;transition:all .2s;display:flex}.download-btn:hover{background:#2a3a48;transform:translateY(-1px)}.streaming-cursor{vertical-align:text-bottom;background:#1b252d;width:2px;height:1em;margin-left:2px;animation:.8s step-end infinite blink;display:inline-block}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.chat-input-row{align-items:flex-end;gap:10px;width:100%;max-width:768px;display:flex}.attachment-strip{flex-wrap:wrap;gap:8px;width:100%;margin-bottom:8px;display:flex}.attachment-chip{color:#1b252d;background:#fffc;border-radius:10px;align-items:center;gap:6px;max-width:200px;padding:6px 10px;font-size:12px;display:flex;position:relative}.attachment-thumb{object-fit:cover;border-radius:6px;flex-shrink:0;width:36px;height:36px}.attachment-icon{flex-shrink:0;font-size:18px}.attachment-name{text-overflow:ellipsis;white-space:nowrap;max-width:100px;overflow:hidden}.attachment-size{color:#0006;flex-shrink:0;font-size:11px}.attachment-remove{cursor:pointer;color:#0006;background:0 0;border:none;flex-shrink:0;padding:0 2px;font-size:16px;line-height:1}.attachment-remove:hover{color:#dc2626}.attachment-error{color:#dc2626;width:100%;margin-top:2px;font-size:12px}.message-attachments{flex-wrap:wrap;gap:4px;margin-bottom:6px;display:flex}.message-attachment-chip{color:#0009;background:#0000000f;border-radius:6px;align-items:center;gap:3px;padding:2px 8px;font-size:11px;display:inline-flex}.chat-input .send-btn.stop-btn{opacity:.8;background:#dc2626}.chat-input .send-btn.stop-btn:hover{opacity:1}@media (width<=768px){body{align-items:stretch;position:fixed;inset:0}.chat-container{border-radius:0;max-width:100%;height:100dvh;padding:0}.chat-header{padding:0 12px;padding-top:env(safe-area-inset-top);border-radius:0}.chat-body{border-left:none;border-right:none;border-radius:0}.chat-messages{padding:16px 12px}.message{max-width:90%}.chat-input{padding:12px;padding-bottom:calc(12px + env(safe-area-inset-bottom))}.chat-input-row{gap:8px}.chat-input-inner{border-radius:12px;padding:10px 12px}.chat-input .left-btn{border-radius:12px;width:42px;height:42px;padding:11px}.chat-input textarea{min-height:22px;font-size:16px}.chat-input .send-btn{border-radius:12px;width:42px;height:42px}}.message.bot.markdown-body{color:#1b252d;font-size:14px;line-height:1.6}.markdown-body>:first-child{margin-top:0}.markdown-body>:last-child{margin-bottom:0}.markdown-body p{margin:0 0 10px}.markdown-body p:last-child{margin-bottom:0}.markdown-body h1,.markdown-body h2,.markdown-body h3,.markdown-body h4,.markdown-body h5,.markdown-body h6{margin:16px 0 8px;font-weight:600;line-height:1.3}.markdown-body h1{font-size:1.4em}.markdown-body h2{font-size:1.25em}.markdown-body h3{font-size:1.1em}.markdown-body code:not(pre code){background:#0000000f;border-radius:4px;padding:2px 6px;font-family:SF Mono,Fira Code,Fira Mono,Menlo,Consolas,monospace;font-size:.9em}.markdown-body pre{color:#e5e7eb;background:#1b252d;border-radius:8px;margin:10px 0;padding:14px 16px;font-size:13px;line-height:1.5;overflow-x:auto}.markdown-body pre code{font-size:inherit;color:inherit;background:0 0;border-radius:0;padding:0;font-family:SF Mono,Fira Code,Fira Mono,Menlo,Consolas,monospace}.markdown-body pre .hljs{color:#e5e7eb;background:0 0}.markdown-body pre .hljs-keyword{color:#c792ea}.markdown-body pre .hljs-string{color:#c3e88d}.markdown-body pre .hljs-number{color:#f78c6c}.markdown-body pre .hljs-comment{color:#697098;font-style:italic}.markdown-body pre .hljs-function,.markdown-body pre .hljs-title{color:#82aaff}.markdown-body pre .hljs-built_in,.markdown-body pre .hljs-attr{color:#ffcb6b}.markdown-body pre .hljs-params{color:#e5e7eb}.markdown-body pre .hljs-literal{color:#f78c6c}.markdown-body pre .hljs-type{color:#ffcb6b}.markdown-body pre .hljs-variable{color:#f07178}.markdown-body pre .hljs-selector-class{color:#ffcb6b}.markdown-body pre .hljs-selector-tag,.markdown-body pre .hljs-tag,.markdown-body pre .hljs-name{color:#f07178}.markdown-body pre .hljs-attribute{color:#ffcb6b}.markdown-body pre::-webkit-scrollbar{height:4px}.markdown-body pre::-webkit-scrollbar-track{background:0 0}.markdown-body pre::-webkit-scrollbar-thumb{background:#fff3;border-radius:2px}.markdown-body table{border-collapse:collapse;width:100%;margin:10px 0;font-size:13px}.markdown-body th,.markdown-body td{text-align:left;border:1px solid #0000001a;padding:8px 12px}.markdown-body th{background:#0000000a;font-weight:600}.markdown-body tr:nth-child(2n){background:#00000005}.markdown-body blockquote{color:#555;border-left:3px solid #00000026;margin:10px 0;padding:4px 16px}.markdown-body blockquote p{margin:4px 0}.markdown-body ul,.markdown-body ol{margin:6px 0;padding-left:24px}.markdown-body li,.markdown-body li>p,.markdown-body ul ul,.markdown-body ol ol,.markdown-body ul ol,.markdown-body ol ul{margin:2px 0}.markdown-body hr{border:none;border-top:1px solid #0000001a;margin:14px 0}.markdown-body a{color:#2563eb;font-weight:500;text-decoration:none}.markdown-body a:hover{text-decoration:underline}.markdown-body strong{font-weight:600}.markdown-body em{font-style:italic}.markdown-body input[type=checkbox]{vertical-align:middle;margin-right:6px}.markdown-body img{border-radius:6px;max-width:100%}pre code.hljs{padding:1em;display:block;overflow-x:auto}code.hljs{padding:3px 5px}.hljs{color:#24292e;background:#fff}.hljs-doctag,.hljs-keyword,.hljs-meta .hljs-keyword,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_{color:#d73a49}.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_{color:#6f42c1}.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-variable,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id{color:#005cc5}.hljs-regexp,.hljs-string,.hljs-meta .hljs-string{color:#032f62}.hljs-built_in,.hljs-symbol{color:#e36209}.hljs-comment,.hljs-code,.hljs-formula{color:#6a737d}.hljs-name,.hljs-quote,.hljs-selector-tag,.hljs-selector-pseudo{color:#22863a}.hljs-subst{color:#24292e}.hljs-section{color:#005cc5;font-weight:700}.hljs-bullet{color:#735c0f}.hljs-emphasis{color:#24292e;font-style:italic}.hljs-strong{color:#24292e;font-weight:700}.hljs-addition{color:#22863a;background-color:#f0fff4}.hljs-deletion{color:#b31d28;background-color:#ffeef0}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{background:#f5f5f5;justify-content:center;align-items:center;height:100dvh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,sans-serif;display:flex;overflow:hidden}#root{justify-content:center;align-items:center;width:100%;height:100%;display:flex}
