*{margin:0;padding:0;box-sizing:border-box}body{overflow:hidden;font-family:SF Pro Display,-apple-system,BlinkMacSystemFont,sans-serif;background:#252535}#app{width:100vw;height:100vh;position:relative}#canvas{display:block;width:100%;height:100%}.status-bar{position:fixed;top:8px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:12px;padding:4px 10px;background:#0000004d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.06);border-radius:8px;color:#ffffff80;font-size:10px;letter-spacing:.5px;text-transform:uppercase;animation:fadeIn 1s ease .5s both;z-index:15}.ollama-status{padding:2px 8px;border-radius:6px;font-size:10px}.ollama-status.online{background:#99ff9926;color:#9f9}.ollama-status.offline{background:#ff999926;color:#f99}.chat-input-wrapper{position:fixed;bottom:0;left:0;right:0;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding-bottom:20px;gap:6px;z-index:25;animation:fadeIn .6s ease 1s both}.chat-input-form{display:flex;align-items:center;gap:0;background:#0000008c;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.1);border-radius:14px;overflow:hidden;transition:border-color .3s ease,box-shadow .3s ease}.chat-input-wrapper.active .chat-input-form{border-color:#fff3;box-shadow:0 4px 24px #0006}.chat-input{width:420px;padding:12px 16px;background:transparent;border:none;outline:none;color:#ffffffe6;font-family:SF Pro Display,-apple-system,BlinkMacSystemFont,sans-serif;font-size:13px;letter-spacing:.2px}.chat-input::placeholder{color:#ffffff40}.chat-input:disabled{opacity:.5;cursor:not-allowed}.chat-send{padding:12px 18px;background:transparent;border:none;border-left:1px solid rgba(255,255,255,.08);color:#ffffff4d;font-family:SF Pro Display,-apple-system,BlinkMacSystemFont,sans-serif;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;cursor:pointer;transition:color .2s ease,background .2s ease}.chat-send:not(:disabled):hover{color:#fffc;background:#ffffff0d}.chat-send:disabled{cursor:not-allowed}.chat-input-hint{font-size:10px;color:#fff3;letter-spacing:.3px;transition:color .3s ease}.chat-input-wrapper.active .chat-input-hint{color:#ffffff59}.chat-input-wrapper.paused .chat-input-hint{color:#ffb46480}.chat-pause{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:none;border-right:1px solid rgba(255,255,255,.08);cursor:pointer;transition:background .2s ease;flex-shrink:0}.chat-pause:hover{background:#ffffff0d}.pause-icon{font-size:10px;color:#fff6;letter-spacing:-2px;transition:color .2s ease}.chat-pause:hover .pause-icon{color:#ffffffb3}.chat-input-wrapper.paused .pause-icon{color:#ffb464b3;letter-spacing:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.agent-name-label{position:absolute;transform:translate(-50%,-100%);display:flex;flex-direction:column;align-items:center;gap:1px;pointer-events:none;text-shadow:0 1px 4px rgba(0,0,0,.8);z-index:5}.agent-label-name{font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.agent-label-role{font-size:9px;font-weight:400;letter-spacing:.3px;opacity:.6;color:#ffffff80!important}.speech-bubble{position:absolute;transform:translate(-50%,-100%);max-width:260px;padding:10px 14px;background:#fffffff2;color:#1a1a2e;font-family:SF Pro Display,-apple-system,BlinkMacSystemFont,sans-serif;font-size:13px;line-height:1.4;border-radius:14px;pointer-events:none;animation:bubblePop .35s cubic-bezier(.34,1.56,.64,1) both;filter:drop-shadow(0 4px 12px rgba(0,0,0,.3));z-index:10}.speech-bubble.agent-bubble{border-left:3px solid #fff}.speech-bubble:after{content:"";position:absolute;bottom:-8px;left:50%;transform:translate(-50%);width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-top:10px solid rgba(255,255,255,.95)}.bubble-agent-name{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.bubble-text{font-size:13px;line-height:1.4}.speech-bubble.loading .bubble-text{animation:loadingDots 1s ease-in-out infinite}@keyframes loadingDots{0%,to{opacity:.3}50%{opacity:1}}@keyframes bubblePop{0%{opacity:0;transform:translate(-50%,-100%) scale(.5)}to{opacity:1;transform:translate(-50%,-100%) scale(1)}}.speech-bubble-hide{animation:bubbleFade .3s ease forwards}@keyframes bubbleFade{to{opacity:0;transform:translate(-50%,-100%) scale(.8) translateY(10px)}}.chat-log{position:fixed;top:16px;right:16px;width:320px;max-height:50vh;display:flex;flex-direction:column;background:#00000080;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.08);border-radius:14px;overflow:hidden;opacity:0;transform:translateY(-8px);transition:opacity .4s ease,transform .4s ease;pointer-events:none;z-index:20}.chat-log.visible{opacity:1;transform:translateY(0);pointer-events:auto}.chat-log-header{padding:10px 14px;font-size:10px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;color:#fff6;border-bottom:1px solid rgba(255,255,255,.06)}.chat-log-messages{flex:1;overflow-y:auto;padding:8px 0;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}.chat-log-messages::-webkit-scrollbar{width:4px}.chat-log-messages::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.chat-log-msg{padding:6px 14px;animation:chatMsgIn .3s ease both}.chat-log-name-line{display:flex;align-items:baseline;gap:6px;margin-bottom:2px}.chat-log-name{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.chat-log-role{font-size:9px;color:#ffffff4d;font-weight:400}.chat-log-text{font-size:12px;line-height:1.4;color:#ffffffbf}@keyframes chatMsgIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.plan-panel{position:fixed;top:16px;left:16px;width:300px;max-height:calc(100vh - 80px);display:flex;flex-direction:column;background:#0000008c;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.08);border-radius:16px;overflow:hidden;opacity:0;transform:translate(-12px);transition:opacity .6s ease,transform .6s ease;z-index:20}.plan-panel.visible{opacity:1;transform:translate(0)}.plan-header{padding:16px 18px 12px;border-bottom:1px solid rgba(255,255,255,.06)}.plan-title{font-size:13px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:#ffffffb3}.plan-subtitle{font-size:11px;color:#ffffff4d;margin-top:4px;transition:color .4s ease}.plan-subtitle.highlight{color:#ffffffb3;font-weight:600}.plan-sections{flex:1;overflow-y:auto;padding:8px 0;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}.plan-sections::-webkit-scrollbar{width:4px}.plan-sections::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.plan-section{padding:10px 18px;transition:all .3s ease}.plan-section.pending{opacity:.3}.plan-section.active{opacity:1;background:#ffffff08}.plan-section.done{opacity:1}.plan-section-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.plan-section-icon{font-size:12px;width:20px;text-align:center}.plan-section-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:#fff6}.plan-section.active .plan-section-label{color:#fffc}.plan-section.active .plan-section-label:after{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:#9bf;margin-left:8px;animation:pulse 1.2s ease-in-out infinite}.plan-section.done .plan-section-label{color:#fff9}.plan-section-content{font-size:12px;line-height:1.5;color:#ffffffb3;padding-left:28px;white-space:pre-line;animation:planContentIn .4s ease both}.plan-section.pending .plan-section-content{display:none}@keyframes planContentIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:.4;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}
