:root{--ink: #1a1a1a;--side-bg: #f9f9f9;--side-border: #f3f3f3;--item-selected: #e4e4e4;--item-hover: #efefef;--user-bubble: #f3f3f3;--input-border: #dfdfdf;--code-bg: #f7f7f5;--muted: #00000073;--muted-step: #6b6b6b}*{box-sizing:border-box}html,body{height:100%;margin:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:16px;color:var(--ink);background:#fff;-webkit-font-smoothing:antialiased}#app{height:100vh}.app{height:100vh;display:flex;background:#fff}.side{width:260px;flex:none;background:var(--side-bg);border-right:1px solid var(--side-border);padding:12px;display:flex;flex-direction:column;min-height:0}.sidecard{flex:1;min-height:0;display:flex;flex-direction:column}.me{margin-top:auto}.brand{font-weight:700;font-size:16px;color:var(--ink);padding:6px 8px 14px}.new{display:flex;align-items:center;gap:8px;background:transparent;color:var(--ink);border:none;border-radius:8px;padding:9px 12px;font-size:14px;cursor:pointer;width:100%;text-align:left;font-family:inherit;margin-bottom:8px}.new:hover{background:var(--item-hover)}.chats-scroll{flex:1;overflow:auto;min-height:0}.chats-scroll::-webkit-scrollbar{width:0}.grp{font-size:12px;color:#8a8a8a;margin:14px 8px 4px;font-weight:600}.item{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:8px;color:var(--ink);cursor:pointer;font-size:14px;margin-bottom:2px}.item .item-title{flex:1 1 auto;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item:hover{background:var(--item-hover)}.item.active{background:var(--item-selected)}.item .dot{flex:0 0 auto;width:7px;height:7px;border-radius:50%;background:#19c37d;animation:dotPulse 1.1s ease-in-out infinite}@keyframes dotPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.75)}}.me{padding:10px 8px 2px;color:#9a9a9a;font-size:12px}.main{flex:1;min-width:0;display:flex;flex-direction:column;position:relative;padding:20px}.empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px}.empty-title{font-size:32px;font-weight:400;color:#1a1a1add}.empty .inbox{width:100%;max-width:768px}.conv{flex:1;overflow:auto;min-height:0}.conv::-webkit-scrollbar{width:0}.conv-inner{max-width:1200px;margin:0 auto;padding:0 32px 16px}.user-row{display:flex;justify-content:flex-end;margin-bottom:16px}.ask{background:var(--user-bubble);border-radius:18px;padding:12px 16px;font-size:16px;color:var(--ink);line-height:1.4;max-width:70%;white-space:pre-wrap;word-break:break-word}.ans{margin-bottom:16px}.steps{margin-bottom:6px}.step{display:flex;align-items:center;gap:6px;padding:4px;color:var(--muted-step);cursor:pointer;border-radius:6px;font-size:13.5px;line-height:1.4}.step:hover .label,.step:hover .chev{color:var(--ink)}.chev{color:#aaa;transition:transform .15s;font-size:13px;width:10px;display:inline-block;flex:none}.step.open .chev{transform:rotate(90deg)}.step .label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.step .err-tag{color:#b42318;margin-left:4px}.step.pulse .label{animation:pulse 1.2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.45}}.detail{margin:2px 0 10px 18px}pre.code{background:var(--code-bg);border-radius:8px;padding:10px 12px;margin:4px 0;font-family:SF Mono,Menlo,Consolas,monospace;font-size:12px;line-height:1.5;overflow:auto;color:#333;white-space:pre-wrap;word-break:break-word}.res{color:var(--muted-step);font-size:12.5px;margin-top:3px}.answer{font-size:16px;line-height:1.6;color:var(--ink)}.answer p{margin:0 0 10px}.answer p:last-child{margin-bottom:0}.answer h1,.answer h2,.answer h3,.answer h4{margin:14px 0 8px;font-weight:600}.answer h1{font-size:24px}.answer h2{font-size:20px}.answer h3{font-size:18px}.answer ul,.answer ol{margin:0 0 10px;padding-left:24px}.answer li{margin-bottom:4px}.answer table{border-collapse:collapse;width:auto;margin:10px 0;font-size:14px;border:1px solid #e5e5e5;border-radius:6px}.answer th,.answer td{padding:6px 10px;text-align:left;border:1px solid #e5e5e5}.answer th{font-weight:600}.answer a{color:#1a73e8;text-decoration:underline}.answer code{background:#f2f2f2;border-radius:4px;padding:1px 5px;font-family:SF Mono,Menlo,Consolas,monospace;font-size:14px}.answer pre{background:#f6f8fa;border:1px solid #ededed;border-radius:8px;padding:12px;overflow:auto}.answer pre code{background:none;padding:0}.answer blockquote{margin:0 0 10px;padding:8px 12px;background:#f9f9f9;border-left:4px solid #ddd}.actions{display:flex;gap:2px;margin-top:6px}.act{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border:none;background:transparent;border-radius:8px;cursor:pointer;color:var(--muted);padding:0}.act:hover{background:#f2f2f2}.act.on{color:#1a1a1a}.act svg{width:18px;height:18px;display:block}.clarify{background:var(--code-bg);border-radius:12px;padding:13px 14px;margin-top:12px;font-size:15px;color:var(--ink)}.clarify-opts{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.opt{display:inline-block;background:#fff;border-radius:20px;padding:7px 14px;cursor:pointer;color:var(--ink);border:1px solid var(--input-border);font-size:14px}.opt:hover{background:#f0f0f0}.inbar{padding:8px 32px 0}.inbox{max-width:768px;margin:0 auto;display:flex;align-items:flex-end;gap:12px;background:#fff;border:1px solid var(--input-border);border-radius:40px;padding:8px 16px}.inbox textarea{flex:1;border:none;outline:none;font-size:18px;background:transparent;resize:none;font-family:inherit;color:var(--ink);line-height:1.4;padding:8px 0;max-height:220px}.inbox textarea::placeholder{color:#00000073}.send{width:42px;height:42px;border-radius:24px;background:#d1d1d1;border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex:none;transition:background .15s}.send.active{background:#1a1a1a}.send:disabled{cursor:default}.send.loading{background:#1a1a1a;opacity:1}.send svg{width:22px;height:22px;color:#fff;display:block}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:send-spin .7s linear infinite}@keyframes send-spin{to{transform:rotate(360deg)}}.gate{height:100vh;display:flex;align-items:center;justify-content:center;background:#fff}.gate-card{width:360px;display:flex;flex-direction:column;gap:12px}.gate-title{font-weight:600;font-size:20px;color:var(--ink);margin-bottom:4px}.gate input{border:1px solid var(--input-border);border-radius:12px;padding:11px 14px;font-size:15px;outline:none;font-family:inherit;color:var(--ink);background:#fff}.gate button{background:#1a1a1a;color:#fff;border:none;border-radius:12px;padding:11px 14px;font-weight:500;font-size:15px;cursor:pointer}.gate .err{color:#b42318;font-size:13px}
