@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";.node-palette-container{-webkit-user-select:none;user-select:none;box-sizing:border-box;background:linear-gradient(#f1f5f9 0% 100%);border-right:1px solid #cbd5e1;flex-direction:column;width:260px;height:100vh;display:flex}.np-header{padding:16px 16px 8px}.np-title-row{align-items:center;gap:8px;margin-bottom:12px;display:flex}.np-icon-box{background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:8px;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.np-title{letter-spacing:.05em;color:#0f172a;margin:0;font-size:14px;font-weight:700}.np-search{box-sizing:border-box;color:#0f172a;background:#f8fafc;border:1px solid #cbd5e1;border-radius:8px;width:100%;padding:8px 12px;font-size:12px;transition:border-color .2s}.np-search:focus{border-color:#6366f1;outline:none}.np-content{flex:1;padding:0 8px 16px;overflow-y:auto}.np-category-btn{cursor:pointer;border:none;border-radius:8px;align-items:center;gap:8px;width:100%;padding:8px 12px;font-size:12px;font-weight:600;transition:background .2s;display:flex}.np-category-count{opacity:.4;margin-left:auto;font-size:10px}.np-list{flex-direction:column;gap:2px;margin-top:2px;margin-left:8px;display:flex}.np-item{cursor:grab;border-radius:8px;align-items:center;gap:8px;padding:8px 12px;transition:background .2s;display:flex}.np-item:active{cursor:grabbing}.np-item-dot{border-radius:50%;width:6px;height:6px}.np-item-text{flex:1;min-width:0}.np-item-label{color:#0f172a;font-size:12px;font-weight:500}.np-item-desc{color:#334155;white-space:nowrap;text-overflow:ellipsis;font-size:10px;overflow:hidden}.console-container{background:#f8fafc;border-top:1px solid #cbd5e1;flex-direction:column;transition:height .3s;display:flex}.console-header{cursor:pointer;-webkit-user-select:none;user-select:none;flex-shrink:0;justify-content:space-between;align-items:center;height:36px;padding:0 16px;display:flex}.console-header-left{align-items:center;gap:8px;display:flex}.console-label{letter-spacing:.05em;color:#334155;font-size:12px;font-weight:600}.console-badge{padding:2px, 6px;color:#6366f1;background:#6366f120;border-radius:9999px;font-size:10px;font-weight:500}.console-clear-btn{cursor:pointer;color:#334155;background:0 0;border:none;border-radius:4px;padding:2px 8px;font-size:10px;transition:color .2s}.console-clear-btn:hover{color:#0f172a}.console-chevron{color:#334155;width:12px;height:12px;transition:transform .2s}.console-output{font-family:var(--font-mono,"Courier New", monospace);flex:1;padding:8px 16px;overflow-y:auto}.console-empty{text-align:center;color:#334155;padding:16px 0;font-size:11px}.console-entry{border-radius:4px;align-items:flex-start;gap:8px;padding:2px 8px;font-size:11px;display:flex}.console-entry-icon{text-align:center;opacity:.6;flex-shrink:0;width:12px;margin-top:2px}.console-entry-msg{word-break:break-all;flex:1}.console-entry-time{color:#334155;flex-shrink:0;margin-top:2px;font-size:9px}.ctx-backdrop{z-index:999;position:fixed;inset:0}.ctx-menu{z-index:1000;background:linear-gradient(#fff 0%,#f1f5f9) 100%;border:1px solid #cbd5e1;border-radius:12px;width:240px;max-height:360px;position:fixed;overflow:hidden;box-shadow:0 8px 32px #00000026,0 0 1px #6366f133}.ctx-search-wrap{border-bottom:1px solid #cbd5e1;padding:8px}.ctx-search{color:#0f172a;box-sizing:border-box;background:#f8fafc;border:1px solid #cbd5e1;border-radius:8px;outline:none;width:100%;padding:6px 12px;font-size:12px}.ctx-list{max-height:290px;overflow-y:auto}.ctx-item{text-align:left;cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;width:100%;padding:8px 12px;transition:background .15s;display:flex}.ctx-item-label{color:#0f172a;font-size:12px;font-weight:500}.ctx-item-desc{color:#334155;white-space:nowrap;text-overflow:ellipsis;font-size:10px;overflow:hidden}.ctx-item-bar{border-radius:9999px;width:4px;height:20px}.tutorial-overlay{z-index:2000;-webkit-backdrop-filter:blur(6px);background:#fff9;justify-content:center;align-items:center;animation:.3s ease-out tutFadeIn;display:flex;position:fixed;inset:0}.tutorial-card{background:linear-gradient(#fff 0%,#f1f5f9 100%);border:1px solid #cbd5e1;border-radius:16px;width:440px;max-width:90vw;animation:.4s cubic-bezier(.34,1.56,.64,1) tutSlideUp;overflow:hidden;box-shadow:0 24px 64px #000000b3,0 0 1px #6366f14d}.tutorial-header{align-items:center;gap:12px;padding:24px 28px 0;display:flex}.tutorial-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;display:flex}.tutorial-step-label{letter-spacing:.12em;text-transform:uppercase;color:#6366f1;font-size:10px;font-weight:700}.tutorial-title{color:#0f172a;margin-top:2px;font-size:18px;font-weight:700}.tutorial-body{padding:16px 28px 24px}.tutorial-text{color:#334155;font-size:13px;line-height:1.7}.tutorial-text strong{color:#0f172a;font-weight:600}.tutorial-highlight{border-radius:6px;padding:2px 8px;font-family:Inter,sans-serif;font-size:11px;font-weight:600;display:inline-block}.tutorial-waiting{background:#6366f114;border:1px solid #6366f126;border-radius:10px;align-items:center;gap:10px;margin-top:16px;padding:10px 14px;display:flex}.tutorial-waiting-dot{background:#6366f1;border-radius:50%;width:8px;height:8px;animation:1.5s ease-in-out infinite tutPulse}.tutorial-waiting-text{color:#6366f1;font-size:11px;font-weight:500}.tutorial-footer{justify-content:space-between;align-items:center;padding:0 28px 24px;display:flex}.tutorial-btn{letter-spacing:.04em;cursor:pointer;border:none;border-radius:10px;padding:10px 24px;font-size:12px;font-weight:700;transition:all .2s}.tutorial-btn-primary{color:#6366f1;background:#6366f126;border:1px solid #6366f14d}.tutorial-btn-primary:hover{background:#6366f140;transform:translateY(-1px);box-shadow:0 4px 12px #6366f133}.tutorial-btn-success{color:#10b981;background:#10b98126;border:1px solid #10b9814d}.tutorial-btn-success:hover{background:#10b98140;transform:translateY(-1px);box-shadow:0 4px 12px #10b98133}.tutorial-btn-skip{color:#334155;background:0 0;border:none;font-size:11px;font-weight:500}.tutorial-btn-skip:hover{color:#334155}.tutorial-progress{gap:6px;padding:0 28px 20px;display:flex}.tutorial-dot{border-radius:50%;width:6px;height:6px;transition:all .3s}.tutorial-checkmark{color:#10b981;align-items:center;gap:8px;margin-top:12px;font-size:11px;font-weight:500;animation:.3s ease-out tutFadeIn;display:flex}@keyframes tutFadeIn{0%{opacity:0}to{opacity:1}}@keyframes tutSlideUp{0%{opacity:0;transform:translateY(20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes tutPulse{0%,to{opacity:.4;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}:root{--bg-dark:#f8fafc;--bg-panel:#fff;--bg-card:#f1f5f9;--border-dim:#e2e8f0;--text-primary:#0f172a;--text-muted:#334155;--accent:#6366f1}*{box-sizing:border-box;margin:0;padding:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}html,body,#root{background-color:var(--bg-dark);width:100vw;height:100vh;color:var(--text-primary);-webkit-user-select:none;user-select:none;overflow:hidden}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#64748b33;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#64748b66}.hidden{display:none!important}@keyframes flowForward{0%{stroke-dashoffset:20px}to{stroke-dashoffset:0}}@keyframes flowLoop{0%{stroke-dashoffset:30px}to{stroke-dashoffset:0}}@keyframes pulseGlow{0%,to{opacity:.8;stroke-width:2.5px;filter:drop-shadow(0 0 2px)}50%{opacity:1;stroke-width:3.5px;filter:drop-shadow(0 0 4px)}}@keyframes nodeAppear{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.wire-exec{stroke-dasharray:8 4;animation:.6s linear infinite flowForward}.wire-loop{stroke-dasharray:4 4 12 4;animation:.8s linear infinite flowLoop}.wire-active{animation:1.5s ease-in-out infinite pulseGlow}.node-enter{animation:.3s cubic-bezier(.34,1.56,.64,1) forwards nodeAppear}.nodrag{cursor:default}
