:root{color:#17202a;background:#eef3f5;font-family:Inter,Noto Sans TC,Microsoft JhengHei,system-ui,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;height:100vh;overflow:hidden}button,textarea{font:inherit}button{cursor:pointer}.app-shell{display:flex;height:100vh;overflow:hidden;background:linear-gradient(135deg,#e1efede6,#f5f7f2f2),#eef3f5}.conversation-panel{flex:0 0 auto;width:260px;overflow:hidden;transition:width .25s ease}.conversation-panel.collapsed{width:0}.conversation-panel-inner{width:260px;height:100%;display:flex;flex-direction:column;gap:28px;padding:28px 20px;border-right:1px solid rgba(31,55,64,.12);background:#fafcfac2;overflow-y:auto;overflow-x:hidden}.brand-block{display:flex;align-items:center;gap:12px}.brand-mark{flex-shrink:0;display:flex;align-items:center}.brand-mark img{width:52px;height:auto;object-fit:contain}.eyebrow{margin:0 0 4px;color:#4f6871;font-size:12px;font-weight:700;letter-spacing:0;text-transform:uppercase}h1,h2{margin:0;letter-spacing:0}h1{font-size:15px;line-height:1.4}h2{font-size:24px}.thread-list{display:grid;grid-template-columns:minmax(0,1fr);gap:8px;overflow:hidden}.new-thread-btn{display:flex;align-items:center;justify-content:center;width:100%;min-height:40px;padding:0 12px;border:1px dashed rgba(23,107,93,.4);border-radius:8px;color:#176b5d;background:#176b5d0d;font-size:13px;font-weight:600}.new-thread-btn:hover{background:#176b5d1f;border-color:#176b5d}.thread-rename-input{flex:1;min-width:0;padding:2px 4px;border:1px solid rgba(23,107,93,.4);border-radius:4px;font:inherit;font-size:14px;color:#17202a;background:#fff;outline:none}.thread-item{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;min-height:48px;padding:10px 12px;border:1px solid transparent;border-radius:8px;color:#26353b;background:transparent;text-align:left;cursor:pointer}.thread-item:hover,.thread-item.active{border-color:#176b5d2e;background:#fff}.thread-item span{flex:1 1 0;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.thread-item small{color:#6b7c82;white-space:nowrap}.chat-window{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;overflow:hidden;padding:24px}.chat-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 4px 22px;flex-shrink:0}.chat-header-title{flex:1 1 auto;min-width:0;overflow:hidden;padding-right:8px}.chat-header-title h2{overflow:hidden;text-overflow:ellipsis}.chat-header-right{display:flex;align-items:center;gap:12px}.panel-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid rgba(31,55,64,.12);border-radius:8px;background:#fff;color:#26353b;font-size:16px;flex-shrink:0}.panel-toggle:hover,.panel-toggle.active{border-color:#176b5d59;color:#176b5d;background:#176b5d0f}.status-pill{display:inline-flex;align-items:center;min-height:32px;padding:0 12px;border:1px solid rgba(23,107,93,.18);border-radius:999px;color:#176b5d;background:#fff;font-size:14px;font-weight:700}.message-list{display:flex;flex-direction:column;gap:16px;flex:1 1 auto;overflow-y:auto;padding:20px 20px 28px}.welcome-message{display:flex;align-items:center;justify-content:center;flex:1;padding:40px 20px;text-align:center;color:#4f6871;font-size:15px;line-height:1.7}.welcome-message p{margin:0;max-width:360px;font-size:20px;font-weight:500;line-height:1.8;color:#26353b}.message-row{display:flex;align-items:flex-start;gap:10px;max-width:78%}.message-row.user{align-self:flex-end;flex-direction:row-reverse}.avatar{display:grid;flex:0 0 34px;width:34px;height:34px;place-items:center;border-radius:8px;color:#fff;background:#176b5d;font-size:13px;font-weight:800}.user .avatar{background:#176b5d}.message-bubble{min-width:0;padding:12px 14px 10px;border:1px solid rgba(31,55,64,.08);border-radius:8px;background:#fff;box-shadow:0 14px 32px #1f374014}.user .message-bubble{color:#fff;background:#176b5d}.message-bubble p{margin:0;line-height:1.65;overflow-wrap:anywhere}.message-bubble time{display:block;margin-top:6px;color:#6c7b82;font-size:12px}.user .message-bubble time{color:#ffffffb8}.thinking{display:flex;gap:5px;min-width:58px}.thinking span{width:7px;height:7px;border-radius:50%;background:#6b7c82;animation:pulse 1s infinite ease-in-out}.thinking span:nth-child(2){animation-delay:.16s}.thinking span:nth-child(3){animation-delay:.32s}.map-container{width:440px;max-width:100%;height:320px;border-radius:8px;overflow:hidden}.suggestions{display:flex;gap:8px;overflow-x:auto;padding:0 0 12px;flex-shrink:0}.suggestions button{flex:0 0 auto;min-height:36px;padding:0 12px;border:1px solid rgba(31,55,64,.12);border-radius:999px;color:#26353b;background:#ffffffd1}.suggestions button:hover{border-color:#176b5d59;color:#176b5d}.composer{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;padding:12px;border:1px solid rgba(31,55,64,.12);border-radius:8px;background:#fff;box-shadow:0 18px 42px #1f37401a;flex-shrink:0}.composer textarea{width:100%;min-height:48px;max-height:140px;resize:none;overflow-y:auto;padding:12px 2px;border:0;outline:0;color:#17202a;background:transparent;line-height:1.5}.composer button{align-self:end;min-width:82px;height:48px;border:0;border-radius:8px;color:#fff;background:#176b5d;font-weight:800}.composer button:disabled{cursor:not-allowed;opacity:.48}.right-panel{flex:0 0 auto;width:0;overflow:hidden;transition:width .25s ease}.right-panel.open{width:280px}.right-panel-inner{width:280px;height:100%;display:flex;flex-direction:column;border-left:1px solid rgba(31,55,64,.12);background:#fafcfac2}.right-panel-tabs{display:flex;flex-shrink:0;border-bottom:1px solid rgba(31,55,64,.12);padding:12px 12px 0;gap:4px}.right-panel-tabs button{flex:1;padding:8px 4px 10px;border:0;border-bottom:2px solid transparent;background:transparent;color:#6b7c82;font-weight:600;font-size:12px;cursor:pointer}.right-panel-tabs button.active{color:#176b5d;border-bottom-color:#176b5d}.right-panel-content{flex:1 1 auto;overflow-y:auto;padding:16px 12px}.file-list{display:flex;flex-direction:column;gap:8px}.empty-hint{color:#6b7c82;font-size:13px;text-align:center;margin:24px 0}@keyframes pulse{0%,80%,to{opacity:.35;transform:translateY(0)}40%{opacity:1;transform:translateY(-3px)}}@media(max-width:760px){.conversation-panel,.right-panel{width:0!important}.chat-window{padding:18px 14px}.chat-header{align-items:flex-start}h2{font-size:21px}.message-row{max-width:92%}.composer{grid-template-columns:1fr}.composer button{width:100%}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent;border-radius:999px}::-webkit-scrollbar-thumb{background:#176b5d47;border-radius:999px}::-webkit-scrollbar-thumb:hover{background:#176b5d85}*{scrollbar-width:thin;scrollbar-color:rgba(23,107,93,.28) transparent}.streaming-bubble{min-width:260px;max-width:680px}.todo-section{margin-bottom:10px}.todo-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.todo-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#4f6871}.todo-progress{font-size:12px;font-weight:700;color:#176b5d;background:#176b5d1a;padding:2px 8px;border-radius:999px}.todo-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.todo-item{display:flex;align-items:flex-start;gap:8px;font-size:13px;line-height:1.5;color:#6b7c82}.todo-item.todo-done{color:#176b5d;text-decoration:line-through;opacity:.7}.todo-item.todo-current{color:#17202a;font-weight:600}.todo-icon{flex-shrink:0;width:16px;font-size:12px;margin-top:1px;color:inherit;display:flex;align-items:center;justify-content:center}.todo-spinner{width:14px;height:14px;animation:todo-spin .9s linear infinite;display:block}@keyframes todo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.todo-text{flex:1 1 0;min-width:0}.streaming-content{margin-top:8px;padding-top:8px;border-top:1px solid rgba(31,55,64,.08)}.streaming-content p{margin:0;font-size:13px;line-height:1.6;color:#4f6871;overflow-wrap:anywhere;white-space:pre-wrap}.markdown-content{line-height:1.7;overflow-wrap:anywhere}.markdown-content h1,.markdown-content h2,.markdown-content h3,.markdown-content h4{margin:.75em 0 .3em;font-size:15px;line-height:1.4}.markdown-content h1:first-child,.markdown-content h2:first-child,.markdown-content h3:first-child{margin-top:0}.markdown-content p{margin:.4em 0}.markdown-content ul,.markdown-content ol{margin:.4em 0;padding-left:1.4em}.markdown-content li{margin:.2em 0}.markdown-content a{color:#176b5d;text-decoration:underline;word-break:break-all}.markdown-content a:hover{color:#0f4a3f}.markdown-content strong{font-weight:700}.markdown-content code{background:#176b5d14;border-radius:4px;padding:0 4px;font-size:.9em}.markdown-content hr{border:none;border-top:1px solid rgba(31,55,64,.12);margin:.8em 0}.rag-sources{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin-top:10px;padding-top:10px;border-top:1px solid rgba(31,55,64,.08)}.rag-label{font-size:12px;font-weight:700;color:#4f6871;flex-shrink:0}.rag-source-btn{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border:1px solid rgba(23,107,93,.35);border-radius:999px;background:#176b5d0f;color:#176b5d;font-size:12px;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s;max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rag-source-btn:hover{background:#176b5d24;border-color:#176b5d}.rag-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#17202a73;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.rag-modal{width:100%;max-width:560px;max-height:70vh;display:flex;flex-direction:column;background:#fff;border-radius:12px;box-shadow:0 24px 64px #17202a2e;overflow:hidden}.rag-modal-header{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid rgba(31,55,64,.1);flex-shrink:0}.rag-modal-title{flex:1 1 0;min-width:0;font-size:14px;font-weight:700;color:#17202a;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rag-modal-close{flex-shrink:0;width:30px;height:30px;border:0;border-radius:6px;background:transparent;color:#6b7c82;font-size:14px;cursor:pointer}.rag-modal-close:hover{background:#1f374014;color:#17202a}.rag-modal-body{flex:1 1 auto;overflow-y:auto;padding:20px}.rag-modal-body p{margin:0;font-size:14px;line-height:1.75;color:#26353b;white-space:pre-wrap;overflow-wrap:anywhere}.generated-file-list{display:flex;flex-direction:column;gap:6px}.generated-file-item{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:8px;background:#fff;border:1px solid #d9e4e2;cursor:pointer;transition:background .15s,border-color .15s;-webkit-user-select:none;user-select:none}.generated-file-item:hover{background:#eef7f5;border-color:#176b5d}.generated-file-icon{font-size:18px;flex-shrink:0}.generated-file-name{flex:1;font-size:13px;color:#26353b;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.generated-file-action{font-size:12px;color:#176b5d;flex-shrink:0;font-weight:500}.image-preview-modal{max-width:80vw;max-height:90vh;width:auto}.image-preview-body{display:flex;justify-content:center;align-items:center;padding:16px;background:#f5f7f6;border-radius:0 0 12px 12px}.preview-image{max-width:100%;max-height:70vh;object-fit:contain;border-radius:4px}.login-page{display:flex;justify-content:center;align-items:center;height:100vh;background:linear-gradient(135deg,#e1efede6,#f5f7f2f2),#eef3f5}.login-card{width:100%;max-width:360px;padding:32px 28px;background:#fff;border-radius:12px;border:1px solid rgba(31,55,64,.12);box-shadow:0 12px 32px #17202a1f}.login-logo{display:flex;justify-content:center;margin-bottom:12px}.login-logo img{height:56px}.login-title{margin:0 0 24px;font-size:16px;font-weight:700;text-align:center;color:#17202a}.login-form{display:flex;flex-direction:column}.login-label{margin-bottom:6px;font-size:13px;font-weight:600;color:#4f6871}.login-input{min-height:44px;padding:0 12px;margin-bottom:16px;border:1px solid rgba(31,55,64,.18);border-radius:8px;color:#17202a;background:#fff;outline:none}.login-input:focus{border-color:#176b5d}.login-error{margin:-6px 0 12px;font-size:13px;color:#c0392b}.login-submit{min-height:46px;border:0;border-radius:8px;color:#fff;background:#176b5d;font-weight:800}.login-submit:disabled{cursor:not-allowed;opacity:.48}
