*{box-sizing:border-box;margin:0;padding:0}
html,body{width:100%;height:100%;overflow:hidden;background:#1c1816}
body{font-family:'IBM Plex Mono',monospace;color:#ddd8cc}

/* ── FONT SCALE ── */
:root{--fs:1}
body.fs-md{--fs:1.3}
body.fs-lg{--fs:1.65}

/* Terminal & windows scale */
body.fs-md .log-entry,body.fs-lg .log-entry{font-size:calc(12px * var(--fs))}
body.fs-md .le-time,body.fs-lg .le-time{font-size:calc(10px * var(--fs));width:calc(60px * var(--fs))}
body.fs-md .le-agent,body.fs-lg .le-agent{font-size:calc(10px * var(--fs));width:calc(88px * var(--fs))}
body.fs-md #log-cmd,body.fs-lg #log-cmd{font-size:calc(13px * var(--fs))}
body.fs-md .lf,body.fs-lg .lf{font-size:calc(9px * var(--fs))}
body.fs-md .ltb-title,body.fs-lg .ltb-title{font-size:calc(10px * var(--fs))}
body.fs-md .ltb-badge,body.fs-lg .ltb-badge{font-size:calc(9px * var(--fs))}
/* Canvas nodes scale */
body.fs-md .nh-name,body.fs-lg .nh-name{font-size:calc(18px * var(--fs))}
body.fs-md .meta,body.fs-lg .meta{font-size:calc(8px * var(--fs))}
body.fs-md .nsb,body.fs-lg .nsb{font-size:calc(8px * var(--fs))}
/* Models window scale */
body.fs-md .mt-model-row,body.fs-lg .mt-model-row,body.fs-md .mt-tok-row,body.fs-lg .mt-tok-row{font-size:calc(12px * var(--fs))}
body.fs-md .mt-agent-id,body.fs-lg .mt-agent-id{font-size:calc(12px * var(--fs))}
body.fs-md .mt-sec-hdr,body.fs-lg .mt-sec-hdr{font-size:calc(11px * var(--fs))}

#bg{position:fixed;inset:0;z-index:0;pointer-events:none}
#noise{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.055;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='f'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23f)'/%3E%3C/svg%3E");
  background-size:200px 200px}

/* ── TOOLBAR ── */
#toolbar{position:fixed;top:11px;left:50%;transform:translateX(-50%);z-index:300}
.toolbar-frame{display:inline-flex;align-items:center;gap:4px;position:relative;padding:5px 10px 26px;background:rgba(18,14,12,.96);border:1px solid rgba(255,255,255,.14);box-shadow:0 8px 22px rgba(0,0,0,.4),0 0 0 1px rgba(255,255,255,.04) inset;backdrop-filter:blur(12px);border-radius:5px}
.toolbar-main-row{display:contents}
#toolbar-models-line{position:absolute;bottom:4px;left:10px;right:10px;display:flex;align-items:center;gap:6px;overflow:hidden;opacity:.65}
#toolbar-models-line:hover{opacity:1}
.toolbar-models-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}
.toolbar-preset-btn{background:transparent;border:none;color:#6a6058;font-size:9px;letter-spacing:.06em;text-transform:uppercase;font-family:'IBM Plex Mono',monospace;cursor:pointer;padding:2px 4px;flex-shrink:0;outline:none}
.toolbar-preset-btn:hover{color:#9a9088}
.toolbar-preset-btn:focus{outline:none}
.toolbar-preset-btn.active{color:#c8b880;font-weight:500;border-bottom:1px solid rgba(200,160,64,.5);padding-bottom:1px}
.toolbar-preset-btn.premium{color:#7a6030}
.toolbar-preset-btn.premium:hover{color:#c8a040}
.toolbar-preset-btn.premium.active{color:#c8a040;font-weight:500;border-bottom:1px solid #c8a040;padding-bottom:1px}
#toolbar-models-strip{display:flex;align-items:center;gap:8px;overflow-x:auto;overflow-y:hidden;min-width:0;padding-bottom:2px}
#toolbar-models-strip::-webkit-scrollbar{height:3px}
#toolbar-models-strip::-webkit-scrollbar-thumb{background:rgba(255,255,255,.06);border-radius:999px}
.toolbar-model-chip{display:flex;align-items:center;gap:5px;flex:0 0 auto}
.toolbar-model-chip-label{font-size:9px;color:#5a5248;letter-spacing:.06em;text-transform:uppercase;flex-shrink:0}
.toolbar-model-chip select{background:transparent;border:none;border-bottom:1px solid rgba(200,160,64,.15);color:#8a7848;font-family:'IBM Plex Mono',monospace;font-size:9px;padding:2px 4px;max-width:140px;outline:none;cursor:pointer}
.toolbar-model-chip select:focus{border-bottom-color:rgba(200,160,64,.4);color:#c8a040}
.tsep{width:1px;height:24px;background:rgba(255,255,255,.09);flex-shrink:0;margin:0 3px}
.tool-btn{display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:#b8b0a8;font-family:'IBM Plex Mono',monospace;font-size:13px;padding:4px 8px;cursor:pointer;border-radius:3px;letter-spacing:.03em;transition:.12s;white-space:nowrap;gap:0}
.tool-btn:hover{background:rgba(255,255,255,.07);color:#f0e8e0}
.tb-col{flex-direction:column;gap:3px;min-height:46px;padding:5px 12px;font-size:12px;line-height:1.15}
.tb-stop-ico{font-size:11px;color:#9a9088;line-height:1}
.tb-hist{margin-left:auto}
.tb-hist svg{opacity:.65}
.trun{background:#c8a040;border:none;color:#17120a;font-family:'IBM Plex Mono',monospace;font-weight:700;padding:7px 20px;border-radius:4px;cursor:pointer;transition:.12s;display:flex;flex-direction:column;align-items:center;gap:3px;min-width:80px;min-height:46px}
.trun:hover{background:#d8b24a}
.trun-ico{font-size:15px;line-height:1}
.trun-lbl{font-size:11px;letter-spacing:.1em;text-transform:uppercase;font-family:'IBM Plex Mono',monospace}
#stop-btn-mini.pipeline-live{background:rgba(45,108,223,.2) !important;color:#8fb8ff !important;border:1px solid rgba(82,143,255,.28) !important;box-shadow:0 0 12px rgba(45,108,223,.15)}
#stop-btn-mini.pipeline-live:hover{background:rgba(45,108,223,.3) !important}
#run-timer{display:none;padding:3px 7px;border-radius:3px;background:rgba(45,108,223,.14);border:1px solid rgba(82,143,255,.25);color:#8fb8ff;font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:.06em;white-space:nowrap;margin-left:2px}
#run-timer.live{display:inline-block}

.add-agent-menu{position:fixed;top:62px;left:50%;transform:translateX(-50%);z-index:299;width:min(910px,calc(100vw - 32px));background:rgba(17,14,12,.97);border:1px solid rgba(255,255,255,.08);border-radius:6px;box-shadow:0 18px 38px rgba(0,0,0,.42);backdrop-filter:blur(16px)}
.add-agent-menu.hidden{display:none}
.add-agent-menu-inner{padding:14px 18px 18px}
.add-input-row{display:flex;justify-content:center;gap:10px;margin-bottom:14px}
.add-input-btn{min-width:82px;height:30px;padding:0 16px;border:1px solid rgba(200,160,64,.26);background:linear-gradient(180deg,rgba(200,160,64,.16),rgba(200,160,64,.08));color:#f1e6c6;border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:grab;font-family:'IBM Plex Sans',sans-serif;font-size:13px;font-weight:600;letter-spacing:.01em;box-shadow:0 0 0 1px rgba(200,160,64,.08) inset;transition:.12s}
.add-input-btn:hover{background:linear-gradient(180deg,rgba(200,160,64,.24),rgba(200,160,64,.12));border-color:rgba(200,160,64,.42);color:#fff2cc}
.add-input-btn:active{cursor:grabbing}
.add-agent-menu-label{font-family:'IBM Plex Mono',monospace;font-size:11px;color:#8e857c;letter-spacing:.08em;text-transform:uppercase;text-align:center}
.add-agent-menu-label-bottom{margin-top:10px}
.add-agent-list{display:flex;flex-wrap:nowrap;align-items:stretch;gap:10px;overflow-x:auto;overflow-y:hidden;padding:2px 0 6px}
.add-agent-list::-webkit-scrollbar{height:4px}
.add-agent-list::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:999px}
.add-agent-card{min-width:116px;min-height:88px;padding:10px 10px 12px;border:1px dashed rgba(255,255,255,.18);border-radius:4px;background:rgba(255,255,255,.02);display:flex;flex-direction:column;justify-content:flex-start;gap:7px;cursor:grab;transition:.12s;color:#cfc7bc;flex:0 0 auto}
.add-agent-card:hover{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.26);transform:translateY(-1px)}
.add-agent-card:active{cursor:grabbing}
.add-agent-card.disabled{opacity:.38;filter:saturate(.35);cursor:not-allowed;pointer-events:auto;box-shadow:none}
.add-agent-dot{width:10px;height:10px;border-radius:2px;background:#706860}
.add-agent-name{font-family:'IBM Plex Sans',sans-serif;font-size:15px;color:#f1ece3;font-weight:600;line-height:1.1}
.add-agent-meta{font-family:'IBM Plex Mono',monospace;font-size:10px;color:#7f766d;line-height:1.35;text-transform:lowercase}
.add-agent-card.pilot .add-agent-dot{background:#c85050}
.add-agent-card.human .add-agent-dot{background:#c8a040}
.add-agent-card.research .add-agent-dot{background:#3a9a6a}
.add-agent-card.prompt .add-agent-dot{background:#c8a040}
.add-agent-card.image .add-agent-dot{background:#8a5abf}
.add-agent-card.video .add-agent-dot{background:#4a8abf}
.add-agent-card.assembly .add-agent-dot{background:#c87840}
.add-agent-card.pilot{border-style:solid;box-shadow:0 0 0 1px rgba(200,80,80,.18) inset}
.add-agent-card.human{border-style:solid;box-shadow:0 0 0 1px rgba(200,160,64,.16) inset}

/* ── PIPELINE SIDEBAR ── */
#pside{position:fixed;left:0;top:0;bottom:0;width:242px;z-index:400;background:rgba(10,8,8,.97);
  border-right:1px solid rgba(255,255,255,.08);backdrop-filter:blur(16px);display:flex;flex-direction:column;
  transform:translateX(-100%);transition:transform .2s cubic-bezier(.4,0,.2,1);box-shadow:4px 0 32px rgba(0,0,0,.7)}
#pside.open{transform:translateX(0)}
#pside-head{padding:13px 14px 11px;border-bottom:1px solid rgba(255,255,255,.06);
  display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
#pside-head h2{font-family:'IBM Plex Sans',sans-serif;font-size:13px;font-weight:600;color:#d0ccc4;letter-spacing:.1em;text-transform:uppercase}
.pside-cls{background:transparent;border:none;color:#9a9088;font-size:14px;cursor:pointer;padding:2px 5px;border-radius:2px}
.pside-cls:hover{background:rgba(255,255,255,.06);color:#ddd8cc}
#pside-body{flex:1;overflow-y:auto;padding:8px 0}
#pside-body::-webkit-scrollbar{width:3px}
#pside-body::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12)}
.ps-sec{padding:6px 14px 3px}
.ps-lbl{font-size:10px;color:#b0a898;letter-spacing:.1em;text-transform:uppercase;margin-bottom:5px}
.ps-pipe{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:4px;cursor:pointer;transition:.12s;margin-bottom:2px;border:1px solid transparent}
.ps-pipe:hover{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.1)}
.ps-pipe.on{background:rgba(200,160,64,.09);border-color:rgba(200,160,64,.25)}
.ps-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}
.ps-info{flex:1;min-width:0}
.ps-name{font-size:11px;color:#d0ccc4;font-family:'IBM Plex Sans',sans-serif;font-weight:500}
.ps-pipe.on .ps-name{color:#c8a040}
.ps-sub{font-size:9px;color:#8a8478;margin-top:1px}
.ps-del{background:transparent;border:none;color:#8a8478;font-size:9px;cursor:pointer;padding:2px 5px;border-radius:2px;opacity:0;transition:.12s}
.ps-pipe:hover .ps-del{opacity:1}
.ps-del:hover{color:#cc6060;background:rgba(138,58,58,.15)}
.ps-empty{font-size:10px;color:#9a9088;padding:8px 10px;line-height:1.6}
.ps-div{height:1px;background:rgba(255,255,255,.07);margin:8px 14px}
.ps-new{display:flex;align-items:center;gap:7px;padding:6px 10px;border-radius:3px;cursor:pointer;
  color:#9a9088;font-size:10px;transition:.12s;border:1px dashed rgba(255,255,255,.1);margin:2px 0}
.ps-new:hover{background:rgba(255,255,255,.05);color:#ddd8cc;border-color:rgba(255,255,255,.2)}
.ps-agent{display:flex;align-items:center;gap:7px;padding:5px 10px;border-radius:3px;cursor:grab;font-size:12px;color:#b0a898;transition:.12s;margin-bottom:1px}
.ps-agent:hover{background:rgba(255,255,255,.05);color:#ddd8cc}
.ps-adot{width:7px;height:7px;border-radius:2px;flex-shrink:0}
#pback{position:fixed;inset:0;z-index:399;background:rgba(0,0,0,.3);display:none}

/* ── CANVAS ── */
#wrap{position:fixed;inset:0;z-index:10;overflow:hidden}
#canvas{position:absolute;transform-origin:0 0;width:6000px;height:5000px}
#svgl{position:absolute;top:0;left:0;width:6000px;height:5000px;pointer-events:none;z-index:1}

/* ══════════════════════════════
   NODE
   ══════════════════════════════ */
.node{position:absolute;width:265px;border-radius:5px;border:1px solid rgba(255,255,255,.07);
  cursor:move;z-index:5;font-family:'IBM Plex Mono',monospace;overflow:visible;
  box-shadow:0 2px 16px rgba(0,0,0,.5)}
.node:hover{border-color:rgba(255,255,255,.16)}
.node.sel{border-color:rgba(200,160,64,.6);box-shadow:0 0 0 1px rgba(200,160,64,.3),0 4px 32px rgba(0,0,0,.6)}
.node.running{border-color:rgba(200,160,64,.4) !important;animation:nodeborderpulse 1.8s ease-in-out infinite}
@keyframes nodeborderpulse{0%,100%{border-color:rgba(200,160,64,.25);box-shadow:0 0 8px rgba(200,160,64,.08),0 2px 16px rgba(0,0,0,.5)}50%{border-color:rgba(200,160,64,.7);box-shadow:0 0 0 1px rgba(200,160,64,.15),0 0 24px rgba(200,160,64,.18),0 2px 16px rgba(0,0,0,.5)}}
.node.paused{animation:none !important;border-color:rgba(74,100,200,.35) !important;box-shadow:0 0 10px rgba(74,100,200,.08),0 2px 16px rgba(0,0,0,.5)}
.node.node-flash{animation:nodeflash .5s ease-out}
@keyframes nodeflash{0%,100%{box-shadow:0 0 0 2px rgba(200,160,64,0)}50%{box-shadow:0 0 0 3px rgba(200,160,64,.7),0 0 30px rgba(200,160,64,.3)}}
.node.awaiting-input{border-color:rgba(200,160,64,.5) !important;animation:awaitpulse 1.5s ease-in-out infinite}
@keyframes awaitpulse{0%,100%{box-shadow:0 0 0 1px rgba(200,160,64,.3),0 4px 32px rgba(0,0,0,.6)}50%{box-shadow:0 0 0 2px rgba(200,160,64,.5),0 4px 40px rgba(200,160,64,.15)}}

/* Skill frames — stacked rings around node */
.skill-frame{position:absolute;border-radius:8px;border:1px solid rgba(74,122,191,.3);pointer-events:none;z-index:-1}
.skill-frame-label{position:absolute;top:-8px;left:8px;font-size:7px;padding:0 5px;border-radius:2px;font-family:'IBM Plex Mono',monospace;letter-spacing:.06em}

.node-inner{border-radius:5px;overflow:hidden;background:#0f0d0c}

/* Header */
.nh{padding:10px 12px 7px;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(0,0,0,.35);gap:0}
.nh-left{display:flex;align-items:center;gap:8px}
.nh-icon{font-size:16px;opacity:.8;width:20px}
.nh-name{font-size:22px;font-weight:700;color:#fff;letter-spacing:.01em;font-family:'IBM Plex Sans',sans-serif}
.nh-right{display:flex;align-items:center;gap:2px}
.nh-model{width:100%;margin-top:5px}
.n-model-sel{width:100%;background:rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.07);border-radius:3px;color:#706860;font-size:14px;font-family:'IBM Plex Mono',monospace;letter-spacing:.03em;padding:2px 5px;cursor:pointer;outline:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='5' viewBox='0 0 8 5'%3E%3Cpath d='M0 0l4 5 4-5z' fill='%23706860'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 5px center}
.n-model-sel:hover{border-color:rgba(255,255,255,.15);color:#9a9088}
.n-model-sel:focus{border-color:rgba(200,160,64,.35);color:#c8a040}
.n-model-sel option{background:#1a1612;color:#9a9088;font-size:12px}
.n-free-badge{display:block;margin-top:3px;font-size:10px;color:#7a6030;letter-spacing:.04em;font-family:'IBM Plex Mono',monospace;padding:1px 4px;border-radius:2px;border:1px solid rgba(120,90,40,.25);background:rgba(120,90,40,.1)}
.nc{width:18px;height:18px;border-radius:3px;border:none;background:rgba(0,0,0,.25);
  color:rgba(255,255,255,.45);display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:8px;transition:.1s;line-height:1}
.nc:hover{background:rgba(0,0,0,.5);color:#fff}

/* IO Section — INPUT + OUTPUT on node */
.nio{display:flex;border-bottom:1px solid rgba(255,255,255,.04)}
.nio-half{flex:1;padding:5px 8px;position:relative;cursor:pointer;transition:.12s}
.nio-half:hover{background:rgba(255,255,255,.03)}
.nio-half+.nio-half{border-left:1px solid rgba(255,255,255,.04)}
.nio-lbl{font-size:12px;letter-spacing:.12em;text-transform:uppercase;margin-bottom:5px;opacity:.7}
.nio-type{font-size:19px;display:flex;align-items:center;gap:6px;color:#9a9088}
.nio-icon{font-size:20px;flex-shrink:0}
.nio-default{font-size:13px;color:#706860;margin-top:4px;font-style:italic;line-height:1.35}
.nio-expand{font-size:11px;color:#706860;cursor:pointer;margin-top:3px;letter-spacing:.06em;transition:.1s}
.nio-expand:hover{color:#706860}

/* Meta/Goal — clickable to expand */
.nmeta{padding:10px 12px 8px;border-bottom:1px solid rgba(255,255,255,.04);cursor:pointer;transition:.1s}
.nmeta:hover{background:rgba(255,255,255,.02)}
.nmeta-row{font-size:14px;color:#d4c7bc;line-height:1.4;letter-spacing:.01em;display:block}
.nmeta-row+.nmeta-row{margin-top:4px}
.nmeta-row b{color:#aa998e;font-weight:500;display:inline;margin-right:6px}
.nmeta-row .nmeta-txt{overflow:hidden;display:inline;-webkit-line-clamp:1;-webkit-box-orient:vertical}
.nmeta-row .nmeta-txt.expanded{-webkit-line-clamp:unset}
.nmeta-expand-hint{font-size:11px;color:#706860;letter-spacing:.06em;margin-top:3px}

/* Subtasks */
.nsubtasks{padding:6px 12px 6px;border-bottom:1px solid rgba(255,255,255,.04)}
.nsub{font-size:13px;color:#b6a99c;padding:2px 0}

/* Visual output */
.nvis{border-bottom:1px solid rgba(255,255,255,.04)}
.nvis-img{width:100%;height:90px;object-fit:cover;display:block}
.nvis-placeholder{height:70px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;background:#0a0808}
.nvis-placeholder svg{opacity:.12}
.nvis-placeholder span{font-size:9px;color:#2a2620;letter-spacing:.08em}
.nvis-gen{height:70px;display:flex;align-items:center;justify-content:center;background:#0a0808;font-size:11px;color:#3a3630;letter-spacing:.08em;position:relative;overflow:hidden}
.nvis-prompt{padding:6px 9px;background:#0a0808;min-height:48px}
.nvis-prompt-lbl{font-size:9px;color:#3a3630;letter-spacing:.1em;margin-bottom:3px;text-transform:uppercase}
.nvis-prompt-txt{font-size:11px;color:#706860;line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.nvis-list{padding:4px 9px}
.nvis-li{font-size:11px;color:#706860;padding:2px 0;border-bottom:1px solid rgba(255,255,255,.03);display:flex;gap:4px}
.nvis-li:last-child{border:none}
.nvis-timeline{padding:5px 9px}
.ntl-bar{height:9px;background:#0a0808;border-radius:2px;overflow:hidden;margin-bottom:2px}
.ntl-fill{height:100%;border-radius:2px;transition:width .3s}
.ntl-clips{display:flex;gap:2px;margin-top:2px}
.ntl-clip{flex:1;height:14px;border-radius:2px;display:flex;align-items:center;justify-content:center;font-size:7px;color:rgba(255,255,255,.2)}

/* Action buttons */
.nactions{display:flex;border-top:1px solid rgba(255,255,255,.04)}
.nact{flex:1;padding:5px 7px;background:#0f0d0c;display:flex;align-items:center;gap:5px;
  cursor:pointer;border:none;font-family:'IBM Plex Mono',monospace;font-size:11px;color:#706860;
  letter-spacing:.02em;border-right:1px solid rgba(255,255,255,.04);transition:.12s;text-align:left}
.nact:last-child{border-right:none}
.nact:hover{background:#141210;color:#9a9088}
.nact-ico{width:18px;height:18px;border-radius:3px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11px}
.nstatus-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-left:auto}
.nstatus-dot.idle{background:#1e1c1a;border:1.5px solid #2e2c28}
.nstatus-dot.running{background:#c8a040;animation:sdpulse .8s infinite alternate}
.nstatus-dot.done{background:#3a8a3a}
.nstatus-dot.error{background:#8a2a2a}
.nstatus-dot.paused{background:#2a3a6a}
@keyframes sdpulse{from{opacity:1}to{opacity:.3}}

/* Footer */
.nfoot{padding:5px 12px;background:rgba(0,0,0,.2);border-top:1px solid rgba(0,0,0,.3);
  display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}
.nfoot-st{font-size:12px;color:#706860;letter-spacing:.06em}
.nfoot-tok{font-size:11px;color:#c8892f;letter-spacing:.04em;font-family:'IBM Plex Mono',monospace}
.nfoot-cfg{background:transparent;border:none;font-size:12px;color:#706860;
  cursor:pointer;font-family:'IBM Plex Mono',monospace;letter-spacing:.04em;padding:2px 5px;border-radius:2px}
.nfoot-cfg:hover{background:rgba(255,255,255,.05);color:#706860}
.nfoot-out{background:transparent;border:none;font-size:11px;color:#4a7a5a;
  cursor:pointer;font-family:'IBM Plex Mono',monospace;letter-spacing:.04em;padding:2px 6px;border-radius:2px;transition:.12s}
.nfoot-out:hover{background:rgba(58,138,90,.1);color:#6aaa7a}

/* Scanline — destello de luz */
.scanline{position:absolute;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent 0%,rgba(255,220,100,0) 10%,rgba(255,235,140,.95) 45%,rgba(255,255,200,1) 50%,rgba(255,235,140,.95) 55%,rgba(255,220,100,0) 90%,transparent 100%);
  box-shadow:0 0 8px 2px rgba(255,220,80,.6),0 0 20px 4px rgba(255,200,60,.25);
  animation:scan 1.4s cubic-bezier(.4,0,.6,1) infinite;pointer-events:none;z-index:20;display:none;top:0}
@keyframes scan{0%{top:0%;opacity:0}5%{opacity:1}90%{opacity:.8}100%{top:100%;opacity:0}}
.node.running .scanline{display:block}
.node.paused .scanline{display:none}

/* Streaming text output in running text-type agent nodes */
.nvis-streaming{padding:6px 8px;min-height:60px;background:#0a0808;overflow:hidden;position:relative}
.nvis-stream-text{font-family:'IBM Plex Mono',monospace;font-size:8px;color:#5a4a30;line-height:1.5;max-height:68px;overflow:hidden;word-break:break-all;white-space:pre-wrap;display:inline}
.nvis-cursor{display:inline-block;color:#c8a040;animation:cursor-blink .7s step-end infinite;font-size:10px;line-height:1;vertical-align:text-bottom}
@keyframes cursor-blink{0%,100%{opacity:1}50%{opacity:0}}

/* Human approve */
.happrove{padding:7px 9px;background:rgba(200,160,64,.05);border-bottom:1px solid rgba(200,160,64,.1)}
.happrove-lbl{font-size:8px;color:#c8a040;letter-spacing:.07em;margin-bottom:5px;text-transform:uppercase}
.happrove-btns{display:flex;gap:4px}
.hbtn{flex:1;padding:4px 4px;border-radius:3px;border:1px solid rgba(255,255,255,.06);
  background:transparent;font-family:'IBM Plex Mono',monospace;font-size:9px;cursor:pointer;transition:.12s}
.hbtn.yes{color:#3a8a3a;border-color:rgba(58,138,58,.2)}.hbtn.yes:hover{background:rgba(58,138,58,.1)}
.hbtn.no{color:#8a3a3a;border-color:rgba(138,42,42,.2)}.hbtn.no:hover{background:rgba(138,42,42,.1)}
.hbtn.edit{color:#706860}.hbtn.edit:hover{background:rgba(255,255,255,.05)}

/* PORTS */
.port{position:absolute;width:14px;height:14px;border-radius:50%;border:2px solid rgba(255,255,255,.2);
  background:#1c1816;cursor:crosshair;z-index:20;transition:.12s}
.port:hover{border-color:#c8a040;background:#c8a04033;transform:scale(1.3)}
.port.port-active{border-color:#c8a040!important;background:#c8a04066!important;box-shadow:0 0 7px #c8a040bb;}
.port.in.port-active{transform:translateY(-50%) scale(1.4)!important;}
.port.out.port-active,.port.out-y.port-active,.port.out-n.port-active{transform:translateY(-50%) scale(1.4)!important;}
.oc-connect-port.port-active{border-color:#c8a040!important;background:#c8a04066!important;color:#c8a040!important;box-shadow:0 0 7px #c8a040bb;}
/* Invisible larger hit area via padding trick */
.port::before{content:'';position:absolute;inset:-8px;border-radius:50%;}
.port.in{left:-7px;top:50%;transform:translateY(-50%)}
.port.in:hover{transform:translateY(-50%) scale(1.3)}
.port.out{right:-7px;top:50%;transform:translateY(-50%)}
.port.out:hover{transform:translateY(-50%) scale(1.3)}
.port.out-y{right:-7px;top:32%;transform:translateY(-50%)}
.port.out-y:hover{transform:translateY(-50%) scale(1.3);border-color:#3a8a3a;background:#3a8a3a33}
.port.out-n{right:-7px;top:68%;transform:translateY(-50%)}
.port.out-n:hover{transform:translateY(-50%) scale(1.3);border-color:#8a3a3a;background:#8a3a3a33}
.plbl{position:absolute;right:14px;font-size:7px;color:#3a3630;pointer-events:none;letter-spacing:.06em}
.plbl.y{top:28%;transform:translateY(-50%)}
.plbl.n{top:64%;transform:translateY(-50%)}

/* ══════════════════════════════
   OUTPUT CARD (dropped by agent)
   ══════════════════════════════ */
.output-card{
  position:absolute;width:200px;z-index:6;
  font-family:'IBM Plex Mono',monospace;cursor:move;
  overflow:visible;
}
.oc-inner{
  border-radius:5px;border:1px solid rgba(255,255,255,.1);
  background:#0e0c0a;box-shadow:0 4px 24px rgba(0,0,0,.6);
  overflow:hidden;
  transition:border-color .15s,box-shadow .15s;
}
.output-card:hover .oc-inner{border-color:rgba(255,255,255,.2);box-shadow:0 6px 32px rgba(0,0,0,.7)}
.output-card.connectable .oc-inner{border-color:rgba(200,160,64,.4);box-shadow:0 0 0 1px rgba(200,160,64,.2),0 4px 24px rgba(0,0,0,.6)}
.synth-output-card{z-index:10}
.synth-output-card .oc-inner{
  border-color:rgba(200,120,64,.52)!important;
  box-shadow:0 0 0 1px rgba(200,120,64,.18),0 0 26px rgba(200,120,64,.18),0 6px 30px rgba(0,0,0,.72)!important;
  background:linear-gradient(180deg,rgba(28,18,10,.98),rgba(14,12,10,.98));
}
.synth-output-card .oc-header{
  background:linear-gradient(90deg,rgba(200,120,64,.18),rgba(0,0,0,.2));
  border-bottom-color:rgba(200,120,64,.22);
}
.synth-output-card .oc-from{color:#c87840}
.synth-output-card .oc-size{color:#c87840!important}
.synth-output-card .oc-expand-hint{color:#e0a060}
/* Seed input card */
.seed-input-card{width:220px}
.seed-input-card .oc-inner{border-color:rgba(200,160,64,.4)!important;box-shadow:0 0 20px rgba(200,160,64,.12),0 4px 24px rgba(0,0,0,.6)!important}
.seed-input-card .oc-header{background:rgba(58,40,0,.5);border-bottom-color:rgba(200,160,64,.15)}
.seed-input-card .oc-from{color:#c8a04088;font-size:11px}
.sic-title{font-size:8px;color:#c8a040;letter-spacing:.1em;text-transform:uppercase;margin-bottom:5px;opacity:.7}
.sic-run-btn{width:100%;margin-top:10px;padding:8px 0;background:#c8a040;border:none;border-radius:5px;color:#1a1000;font-size:12px;font-weight:800;letter-spacing:.18em;cursor:pointer;transition:background .2s,box-shadow .2s}
.sic-run-btn:hover{background:#e0b850;box-shadow:0 0 14px rgba(200,160,64,.5)}
.sic-run-btn.sic-run-stopping{background:#0d2a45;color:#4a9aef;box-shadow:0 0 12px rgba(74,154,239,.25)}
.sic-run-btn.sic-run-stopping:hover{background:#0f3357;box-shadow:0 0 18px rgba(74,154,239,.45)}

/* ── CONTEXT FILE CARD ── */
.ctx-file-card{width:206px;z-index:12;transition:left .55s cubic-bezier(.22,1,.36,1),top .55s cubic-bezier(.22,1,.36,1),transform .28s ease,filter .28s ease}
.ctx-file-card.ctx-in-flight{transform:translateY(-4px) scale(1.02);filter:drop-shadow(0 0 22px rgba(74,122,154,.22))}
.ctx-file-card.ctx-shared{transform:translateY(-7px) scale(1.03)}
.ctx-file-card .oc-inner{border-color:rgba(74,122,154,.45)!important;box-shadow:0 0 18px rgba(74,122,154,.12),0 4px 24px rgba(0,0,0,.6)!important;background:#0a0e14}
.ctx-file-hd{padding:7px 8px 6px;border-bottom:1px solid rgba(74,122,154,.15);display:flex;align-items:center;gap:7px;background:rgba(10,20,32,.6)}
.ctx-file-icon{font-size:14px;color:#4a7a9a;flex-shrink:0}
.ctx-file-titles{flex:1;min-width:0}
.ctx-file-name{font-size:10px;font-weight:600;color:#8ab8d8;letter-spacing:.04em;font-family:'IBM Plex Mono',monospace}
.ctx-file-pipe{font-size:8px;color:#4a6a8a;letter-spacing:.03em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}
.ctx-refresh{background:transparent;border:none;color:#4a6a8a;font-size:13px;cursor:pointer;padding:0 2px;line-height:1;transition:.12s;flex-shrink:0}
.ctx-refresh:hover{color:#8ab8d8;transform:rotate(30deg)}
.ctx-file-body{padding:7px 8px;display:flex;flex-direction:column;gap:6px}
.ctx-query{font-size:10px;color:#b9d4e6;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ctx-chip-row{display:flex;flex-wrap:wrap;gap:4px}
.ctx-chip{font-size:8px;color:#8ab8d8;border:1px solid rgba(74,122,154,.18);background:rgba(74,122,154,.08);padding:2px 5px;border-radius:999px;letter-spacing:.04em}
.ctx-grid{display:grid;grid-template-columns:1fr 1fr;gap:5px 8px}
.ctx-mini{display:flex;justify-content:space-between;gap:6px;align-items:baseline}
.ctx-row{display:flex;justify-content:space-between;align-items:baseline;gap:6px}
.ctx-row.compact{padding-top:2px;border-top:1px solid rgba(74,122,154,.1)}
.ctx-lbl{font-size:8px;color:#6a8aaa;letter-spacing:.06em;text-transform:uppercase;font-family:'IBM Plex Mono',monospace}
.ctx-val{font-size:9px;color:#8ab8d8;font-family:'IBM Plex Mono',monospace;font-weight:500}
.ctx-usage-row{padding:0 8px 7px;font-size:8px;color:#9ac7de;letter-spacing:.08em;text-transform:uppercase;font-family:'IBM Plex Mono',monospace}
.ctx-file-ft{padding:5px 7px;border-top:1px solid rgba(74,122,154,.1);background:rgba(0,0,0,.2)}
.ctx-edit-btn{background:transparent;border:1px solid rgba(74,122,154,.25);border-radius:3px;color:#4a8aaa;font-size:8px;font-family:'IBM Plex Mono',monospace;cursor:pointer;padding:3px 8px;width:100%;text-align:center;letter-spacing:.04em;transition:.12s}
.ctx-edit-btn:hover{background:rgba(74,122,154,.1);border-color:rgba(74,122,154,.5);color:#8ab8d8}
.ctx-empty-msg{font-size:8px;color:#3a3830;font-style:italic;font-family:'IBM Plex Mono',monospace;padding:6px 0;text-align:center;letter-spacing:.03em}

/* ── QUESTION CARD (operator) ── */
.question-card{width:392px;z-index:16}
.question-card .oc-inner{border-color:rgba(200,160,64,.58)!important;box-shadow:0 0 0 1px rgba(200,160,64,.12),0 0 34px rgba(200,160,64,.24),0 10px 34px rgba(0,0,0,.72)!important;background:linear-gradient(180deg,rgba(19,14,10,.98),rgba(10,8,6,.98))}
.qcard-hd{padding:13px 15px 11px;border-bottom:1px solid rgba(200,160,64,.22);display:flex;align-items:flex-start;gap:10px;background:linear-gradient(90deg,rgba(58,38,8,.82),rgba(20,14,8,.72))}
.qcard-icon{font-size:18px;color:#f0bc4c;flex-shrink:0;line-height:1}
.qcard-title-wrap{display:flex;flex-direction:column;gap:4px}
.qcard-title{font-size:11px;font-weight:700;color:#f0bc4c;letter-spacing:.08em;text-transform:uppercase;font-family:'IBM Plex Mono',monospace}
.qcard-subtitle{font-size:9px;color:#9c8358;letter-spacing:.04em;font-family:'IBM Plex Mono',monospace}
.qcard-body{padding:14px 15px 10px}
.qcard-q{font-size:13px;color:#e0d4be;line-height:1.7;margin-bottom:13px;font-family:'IBM Plex Mono',monospace}
.qcard-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px}
.qcard-suggest-lbl,.qcard-edit-lbl{font-size:9px;color:#8e7350;letter-spacing:.09em;text-transform:uppercase;font-family:'IBM Plex Mono',monospace}
.qcard-use-suggest{background:rgba(200,160,64,.1);border:1px solid rgba(200,160,64,.24);border-radius:999px;color:#e0b860;font-size:9px;font-family:'IBM Plex Mono',monospace;cursor:pointer;padding:4px 10px;letter-spacing:.05em;transition:.12s}
.qcard-use-suggest:hover{background:rgba(200,160,64,.18);border-color:rgba(200,160,64,.46);color:#f0c870}
.qcard-suggest{font-size:12px;color:#d8b06a;background:rgba(200,160,64,.08);border:1px solid rgba(200,160,64,.22);border-radius:8px;padding:10px 11px;line-height:1.6;font-family:'IBM Plex Mono',monospace;margin-bottom:12px;cursor:pointer;transition:.12s;word-break:break-word}
.qcard-suggest:hover{background:rgba(200,160,64,.14);border-color:rgba(200,160,64,.38);color:#f0bc4c}
.qcard-edit-lbl{margin-bottom:6px}
.qcard-input{width:100%;background:rgba(0,0,0,.46);border:1px solid rgba(200,160,64,.24);border-radius:8px;color:#e0d4be;font-size:12px;font-family:'IBM Plex Mono',monospace;padding:10px 11px;box-sizing:border-box;resize:vertical;min-height:86px;transition:.12s;line-height:1.6}
.qcard-input:focus{outline:none;border-color:rgba(240,188,76,.68);background:rgba(200,160,64,.05);box-shadow:0 0 0 3px rgba(200,160,64,.08)}
.qcard-input::placeholder{color:#5a4320}
.qcard-progress-wrap{padding:4px 15px 12px;display:flex;align-items:center;gap:12px}
.qcard-countdown{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 30% 30%,rgba(240,188,76,.24),rgba(90,58,12,.16));border:1px solid rgba(240,188,76,.32);color:#f0bc4c;font-size:15px;font-weight:700;font-family:'IBM Plex Mono',monospace;letter-spacing:.02em;box-shadow:0 0 18px rgba(200,160,64,.18);flex-shrink:0}
.qcard-countdown.editing{color:#8ab8d8;border-color:rgba(138,184,216,.35);background:radial-gradient(circle at 30% 30%,rgba(138,184,216,.2),rgba(14,24,32,.18))}
.qcard-countdown.urgent{color:#ffb27a;border-color:rgba(255,140,90,.48);box-shadow:0 0 22px rgba(255,120,70,.22)}
.qcard-progress-block{flex:1;display:flex;flex-direction:column;gap:7px}
.qcard-progress-lbl{font-size:9px;color:#9c8358;letter-spacing:.12em;text-transform:uppercase;font-family:'IBM Plex Mono',monospace}
.qcard-progress{flex:1;height:8px;background:rgba(200,160,64,.08);border-radius:999px;overflow:hidden;border:1px solid rgba(200,160,64,.08)}
.qcard-progress-bar{height:100%;background:linear-gradient(90deg,#f0bc4c,#c87840);border-radius:999px;transition:width .35s linear,background .15s ease}
.qcard-progress-bar.urgent{background:linear-gradient(90deg,#ffb25a,#d05a40)}
.qcard-ft{padding:10px 15px 14px;border-top:1px solid rgba(200,160,64,.12);display:flex;gap:8px}
.qcard-confirm{flex:1;background:rgba(200,160,64,.12);border:1px solid rgba(200,160,64,.28);border-radius:3px;color:#c8a040;font-size:10px;font-family:'IBM Plex Mono',monospace;cursor:pointer;padding:7px;letter-spacing:.05em;transition:.12s}
.qcard-confirm:hover{background:rgba(200,160,64,.22);border-color:rgba(200,160,64,.6);color:#e0c060}
.qcard-skip{background:transparent;border:1px solid rgba(255,255,255,.07);border-radius:3px;color:#706050;font-size:10px;font-family:'IBM Plex Mono',monospace;cursor:pointer;padding:7px 11px;letter-spacing:.04em;transition:.12s}
.qcard-skip:hover{border-color:rgba(255,255,255,.14);color:#706860}

/* ── CONNECTION PAYLOAD CARD ── */
.conn-payload-card{width:290px;z-index:9}
.conn-payload-card .oc-inner{border-color:rgba(200,160,64,.38)!important;box-shadow:0 0 22px rgba(200,160,64,.16),0 6px 28px rgba(0,0,0,.7)!important;background:#100d09}
.cpayload-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:8px}
.cpayload-route{font-size:9px;color:#d8d0c0;line-height:1.45;font-family:'IBM Plex Mono',monospace}
.cpayload-route span{color:#c8a040}
.cpayload-type{font-size:8px;white-space:nowrap;font-family:'IBM Plex Mono',monospace}
.cpayload-body{background:rgba(0,0,0,.28);border:1px solid rgba(255,255,255,.06);border-radius:4px;padding:8px;max-height:220px;overflow:auto}
.cpayload-pre{margin:0;font-size:9px;line-height:1.55;color:#bfb7aa;white-space:pre-wrap;word-break:break-word;font-family:'IBM Plex Mono',monospace}
.cpayload-text{font-size:9px;line-height:1.55;color:#bfb7aa;white-space:pre-wrap;word-break:break-word;font-family:'IBM Plex Mono',monospace}

/* Pilot ctx button */
.nfoot-ctx{background:transparent;border:none;font-size:8px;color:#4a7a9a;cursor:pointer;font-family:'IBM Plex Mono',monospace;letter-spacing:.04em;padding:1px 5px;border-radius:2px;transition:.12s}
.nfoot-ctx:hover{background:rgba(74,122,154,.12);color:#8ab8d8}
.sic-prompt{color:#c8a040!important;font-style:italic;font-size:15px!important;-webkit-line-clamp:4!important}
.oc-header{padding:6px 9px;border-bottom:1px solid rgba(255,255,255,.06);
  display:flex;align-items:center;justify-content:space-between;
  background:rgba(0,0,0,.3)}
.oc-from{font-size:11px;color:#3a3630;letter-spacing:.06em;display:flex;align-items:center;gap:5px}
.oc-from-dot{width:6px;height:6px;border-radius:50%}
.oc-type{font-size:11px;padding:1px 6px;border-radius:2px;letter-spacing:.04em}
.oc-type.text{background:rgba(200,160,64,.1);color:#c8a040}
.oc-type.image{background:rgba(138,90,191,.1);color:#8a5abf}
.oc-type.video{background:rgba(74,122,191,.1);color:#4a7abf}
.oc-type.json{background:rgba(58,138,58,.1);color:#3a8a3a}
.oc-type.file{background:rgba(200,120,64,.1);color:#c87840}
.oc-body{padding:8px 9px;max-height:100px;overflow:hidden;position:relative;cursor:pointer}
.oc-body:hover .oc-expand-hint{opacity:1}
.oc-preview-txt{font-size:12px;color:#706860;line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.oc-preview-img{width:100%;height:70px;object-fit:cover;border-radius:2px;display:block}
.oc-preview-video{width:100%;height:78px;object-fit:cover;border-radius:2px;display:block;background:#080a12}
.oc-preview-json{font-size:8px;color:#3a8a3a;line-height:1.4;white-space:pre;overflow:hidden;max-height:60px}
.oc-preview-image-card{display:flex;flex-direction:column;gap:6px}
.oc-preview-video-card{display:flex;flex-direction:column;gap:6px}
.oc-preview-caption{font-size:8px;color:#8a826e;line-height:1.45;font-family:'IBM Plex Mono',monospace;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.oc-expand-hint{position:absolute;bottom:4px;right:6px;font-size:7px;color:#c8a040;opacity:0;transition:.15s;background:#0e0c0a;padding:1px 4px;border-radius:2px}
.oc-footer{padding:4px 9px;border-top:1px solid rgba(255,255,255,.05);
  display:flex;align-items:center;justify-content:space-between;background:rgba(0,0,0,.2)}
.oc-size{font-size:8px;color:#3a3630;letter-spacing:.04em}
.oc-connect-port{width:13px;height:13px;border-radius:50%;border:2px solid rgba(200,160,64,.45);
  background:#1c1816;cursor:crosshair;transition:.12s;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:8px;color:rgba(200,160,64,.45)}
.oc-connect-port::before{content:'→'}
.oc-connect-port:hover{border-color:#c8a040;background:#c8a04033;color:#c8a040}
.oc-actions{display:flex;gap:4px}
.oc-btn{background:transparent;border:none;color:#3a3630;font-size:10px;cursor:pointer;padding:1px 3px;border-radius:2px;transition:.1s}
.oc-btn:hover{background:rgba(255,255,255,.06);color:#706860}

/* Drag ghost for output cards */
.oc-dragging{opacity:.7;transform:rotate(2deg)}

/* CONNECTIONS */
.cpath{fill:none;stroke:#3a3830;stroke-width:1.5;stroke-dasharray:5 4}
.cpath.active{stroke:#c8a040;stroke-width:2.5;stroke-dasharray:10 4;animation:flow 1.1s linear infinite;filter:drop-shadow(0 0 5px rgba(200,160,64,.65))}
.cpath.seed-conn{stroke:#c8a040;stroke-width:2;stroke-dasharray:8 5;animation:seed-flow 1.8s linear infinite;filter:drop-shadow(0 0 3px rgba(200,160,64,.45))}
@keyframes seed-flow{to{stroke-dashoffset:-52}}
.cpath.cy{stroke:#2a5a2a;stroke-dasharray:4 3}
.cpath.cn{stroke:#5a2a2a;stroke-dasharray:4 3}
.cpath.card-conn{stroke:#c8a04055;stroke-dasharray:3 3;stroke-width:1}
.cpath.card-conn.active{stroke:#c8a040;stroke-dasharray:none;animation:flow 1.4s linear infinite}
.cpath.ctx-conn{stroke:#4a9aaa;stroke-width:1.5;stroke-dasharray:6 3;animation:ctx-flow 2s linear infinite;filter:drop-shadow(0 0 3px rgba(74,154,170,.4))}
@keyframes ctx-flow{to{stroke-dashoffset:-27}}
@keyframes flow{to{stroke-dashoffset:-18}}
#tc{fill:none;stroke:#c8a040;stroke-width:1.5;stroke-dasharray:5 3;display:none}

/* ══════════════════════════════
   MODELS & TOKENS WINDOW
   ══════════════════════════════ */
#mtwin{position:fixed;bottom:12px;left:12px;width:360px;z-index:95;border-radius:6px;
  border:1px solid rgba(255,255,255,.1);background:rgba(10,8,8,.96);
  box-shadow:0 8px 40px rgba(0,0,0,.7);display:flex;flex-direction:column;
  overflow:hidden;backdrop-filter:blur(10px);transition:height .18s ease;
  min-width:260px;min-height:28px}
#mtwin.minimized{height:28px!important}
#mtwin.minimized #mtbody,#mtwin.minimized #mtresize{display:none}
#mttbar{height:28px;background:rgba(18,14,12,.98);border-bottom:1px solid rgba(255,255,255,.07);
  display:flex;align-items:center;cursor:move;flex-shrink:0;user-select:none}
#mtbody{flex:1;overflow-y:auto;overflow-x:hidden;min-height:0;font-family:'IBM Plex Mono',monospace}
#mtbody::-webkit-scrollbar{width:3px}
#mtbody::-webkit-scrollbar-thumb{background:rgba(255,255,255,.08);border-radius:2px}
.mt-sec-hdr{display:grid;grid-template-columns:90px 90px 1fr 60px;gap:0;
  padding:4px 10px;font-size:13px;color:#3a3630;letter-spacing:.1em;text-transform:uppercase;
  border-bottom:1px solid rgba(255,255,255,.05);background:rgba(14,10,10,.8);position:sticky;top:0}
.mt-models-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px 8px;
  border-bottom:1px solid rgba(255,255,255,.05);background:rgba(14,10,10,.84);position:sticky;top:0;z-index:2}
.mt-models-title{font-size:11px;color:#8e857c;letter-spacing:.14em;text-transform:uppercase}
.mt-preset-actions{display:flex;align-items:center;gap:8px}
.mt-preset-btn{background:rgba(58,138,58,.08);border:1px solid rgba(90,154,90,.2);color:#7db27d;
  border-radius:999px;padding:5px 12px;font-size:11px;letter-spacing:.08em;text-transform:uppercase;
  font-family:'IBM Plex Mono',monospace;cursor:pointer}
.mt-preset-btn:hover{border-color:rgba(90,154,90,.45);background:rgba(58,138,58,.14)}
.mt-preset-btn.premium{background:rgba(200,160,64,.08);border-color:rgba(200,160,64,.24);color:#c8a040}
.mt-preset-btn.premium:hover{background:rgba(200,160,64,.14);border-color:rgba(200,160,64,.45)}
.mt-tok-hdr{grid-template-columns:90px 110px 110px 60px;position:relative}
.mt-reset-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);
  background:none;border:1px solid rgba(255,255,255,.08);border-radius:2px;color:#3a3630;
  font-size:13px;padding:1px 5px;cursor:pointer;font-family:'IBM Plex Mono',monospace;line-height:1}
.mt-reset-btn:hover{color:#c8a040;border-color:rgba(200,160,64,.3)}
.mt-model-card{background:rgba(18,14,12,.72);border:1px solid rgba(255,255,255,.06);
  border-radius:8px;padding:10px 10px 12px;display:flex;flex-direction:column;gap:8px}
.mt-model-card:hover{border-color:rgba(200,160,64,.22);box-shadow:0 0 0 1px rgba(200,160,64,.08)}
.mt-model-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.mt-model-card-head{display:flex;flex-direction:column;gap:4px;min-width:0}
.mt-model-card-provider{display:flex;align-items:center;gap:6px;font-size:10px;color:#6f675d;letter-spacing:.08em;text-transform:uppercase}
.mt-model-sel{background:#0e0a08;border:1px solid rgba(200,160,64,.25);border-radius:3px;
  color:#c8a040;font-family:'IBM Plex Mono',monospace;font-size:15px;padding:3px 5px;
  cursor:pointer;outline:none;width:100%;}
.mt-model-sel:focus{border-color:rgba(200,160,64,.6);}
.mt-agent-id{color:#5a5248;font-size:16px}
.mt-agent-label{color:#d0c8b8;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mt-model-note{color:#c8a040;font-size:11px}
.mt-provider{display:flex;align-items:center;gap:4px;font-size:16px}
.mt-provider-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.mt-model-name{color:#9a9088;font-size:16px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mt-tier{font-size:14px;padding:1px 4px;border-radius:2px;text-align:center}
.mt-tier.premium{background:rgba(200,160,64,.12);color:#c8a040}
.mt-tier.balanced{background:rgba(74,130,200,.1);color:#6090c0}
.mt-tier.fast{background:rgba(58,138,58,.1);color:#5a9a5a}
.mt-model-meta{font-size:10px;color:#706860;line-height:1.5;min-height:30px}
.mt-card-actions{display:flex;justify-content:space-between;align-items:center;gap:8px}
.mt-card-reset{background:none;border:1px solid rgba(255,255,255,.08);border-radius:999px;color:#8e857c;
  padding:4px 10px;font-size:10px;font-family:'IBM Plex Mono',monospace;cursor:pointer}
.mt-card-reset:hover{color:#c8a040;border-color:rgba(200,160,64,.3)}
.mt-models-list{display:grid;grid-template-columns:1fr;gap:8px;padding:12px}
.mt-divider{height:1px;background:rgba(255,255,255,.06);margin:0}
.mt-tok-total{display:grid;grid-template-columns:90px 110px 110px 60px;padding:5px 10px;
  font-size:14px;border-bottom:1px solid rgba(255,255,255,.06);background:rgba(20,14,12,.6)}
.mt-tok-total .mt-agent-id{color:#c8a040;font-size:14px}
.mt-tok-total .mt-tok-in,.mt-tok-total .mt-tok-out{color:#c8a040}
.mt-tok-row{display:grid;grid-template-columns:90px 110px 110px 60px;padding:4px 10px;
  font-size:14px;border-bottom:1px solid rgba(255,255,255,.025);align-items:center}
.mt-tok-row:last-child{border:none}
.mt-tok-in{color:#6a8a6a;font-variant-numeric:tabular-nums}
.mt-tok-out{color:#6a7a9a;font-variant-numeric:tabular-nums}
.mt-tok-calls{color:#3a3630;font-size:13px}
.mt-tok-zero{color:#2a2826}
#mtresize{height:4px;background:transparent;cursor:ns-resize;flex-shrink:0;border-top:1px solid rgba(255,255,255,.04)}
.mt-empty{padding:16px 10px;font-size:12px;color:#2a2826;text-align:center;font-style:italic}

/* ══════════════════════════════
   LOG TERMINAL
   ══════════════════════════════ */
#logwin{position:fixed;bottom:12px;left:384px;width:680px;z-index:95;border-radius:6px;
  border:1px solid rgba(255,255,255,.1);background:rgba(10,8,8,.96);
  box-shadow:0 8px 40px rgba(0,0,0,.7);display:flex;flex-direction:column;
  overflow:hidden;backdrop-filter:blur(10px);transition:height .18s ease,border-color .3s;
  min-width:280px;min-height:28px;max-width:90vw}
#logresize-w{position:absolute;left:0;top:0;bottom:0;width:5px;cursor:ew-resize;z-index:10;border-radius:6px 0 0 6px}
#logresize-w:hover{background:rgba(200,160,64,.15)}
#logresize-t{position:absolute;top:0;left:0;right:0;height:5px;cursor:ns-resize;z-index:10}
#logresize-t:hover{background:rgba(200,160,64,.15)}
#logresize-r{position:absolute;right:0;top:0;bottom:0;width:5px;cursor:ew-resize;z-index:10;border-radius:0 6px 6px 0}
#logresize-r:hover{background:rgba(200,160,64,.15)}
#logwin.minimized{height:28px!important}
#logwin.minimized #logbody,#logwin.minimized #logfilters,#logwin.minimized #log-inputrow,#logwin.minimized #log-decision,#logwin.minimized #logresize{display:none}
/* SPOTLIGHT MODE */
#logwin.spotlight{
  left:50%!important;top:50%!important;right:auto!important;bottom:auto!important;
  transform:translate(-50%,-50%);width:640px!important;height:auto!important;
  border-radius:10px!important;border-color:rgba(200,160,64,.4)!important;
  box-shadow:0 0 0 1px rgba(200,160,64,.15),0 40px 100px rgba(0,0,0,.92)!important;
  transition:none;background:rgba(12,9,8,.99)!important}
#logwin.spotlight #logtbar,#logwin.spotlight #logfilters,#logwin.spotlight #logbody,
#logwin.spotlight #log-decision,#logwin.spotlight #logresize,#logwin.spotlight #logresize-w{display:none!important}
#logwin.spotlight #log-inputrow{border-top:none;padding:6px 4px}
#logwin.spotlight #log-cmd{font-size:16px;padding:10px 6px}
#logwin.spotlight #log-cmd-prompt{font-size:16px;color:#c8a040;padding:0 12px}
#logwin.spotlight #cmd-hints{border-radius:0;border-bottom:none;border-left:none;border-right:none;
  border-top:1px solid rgba(255,255,255,.06);max-height:320px;overflow-y:auto}
#logwin.spotlight #cmd-hints .ch-item{padding:9px 14px;font-size:11px}
/* OPERATOR WARNING STATE */
#logwin.operator-waiting{
  border-color:rgba(200,160,64,.6) !important;
  animation:logwarnborder 1.5s ease-in-out infinite;
}
@keyframes logwarnborder{0%,100%{border-color:rgba(200,160,64,.4)}50%{border-color:rgba(200,160,64,.9);box-shadow:0 0 20px rgba(200,160,64,.2)}}

/* Hazard stripe on log title bar when operator waiting */
#logtbar{height:28px;background:rgba(18,14,12,.98);border-bottom:1px solid rgba(255,255,255,.07);
  display:flex;align-items:center;cursor:move;flex-shrink:0;user-select:none;position:relative;overflow:hidden}
#logtbar.hazard::after{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(-45deg,rgba(200,160,64,.12) 0px,rgba(200,160,64,.12) 6px,rgba(0,0,0,.0) 6px,rgba(0,0,0,0) 12px);
  animation:hstripe 1.5s linear infinite;pointer-events:none;
}
@keyframes hstripe{from{background-position:0 0}to{background-position:24px 0}}
.ltb-dots{display:flex;align-items:center;gap:4px;padding:0 10px}
.ltb-dot{width:9px;height:9px;border-radius:50%;cursor:pointer;border:1px solid rgba(0,0,0,.3);transition:.1s;flex-shrink:0}
.ltb-dot:hover{filter:brightness(1.3)}
.ltb-dot.close{background:#c85050}.ltb-dot.min{background:#c8a040}.ltb-dot.max{background:#3a8a3a}
#logtbar .ltb-dot,#mttbar .ltb-dot{width:14px;height:14px;border-radius:3px;display:flex;align-items:center;justify-content:center;overflow:hidden;background:transparent}
#logtbar .ltb-dot.min,#mttbar .ltb-dot.min{background:transparent;border:1px solid #c8a040}
#logtbar .ltb-dot.max,#mttbar .ltb-dot.max{background:transparent;border:1px solid #3a8a3a}
#logtbar .ltb-dot.close,#mttbar .ltb-dot.close{background:transparent;border:1px solid #c85050}
#logtbar .ltb-dot.min::after,#mttbar .ltb-dot.min::after{content:'−';font-size:10px;color:#c8a040;line-height:1;font-family:monospace;font-weight:700;margin-top:4px}
#logtbar .ltb-dot.max::after,#mttbar .ltb-dot.max::after{content:'↵';font-size:11px;color:#3a8a3a;line-height:1;font-family:monospace;font-weight:700}
#logtbar .ltb-dot.close::after,#mttbar .ltb-dot.close::after{content:'×';font-size:10px;color:#c85050;line-height:1;font-family:monospace;font-weight:700}
.ltb-spinner{width:13px;height:13px;border-radius:50%;border:1.5px solid rgba(200,160,64,.2);border-top-color:#c8a040;flex-shrink:0;margin:0 7px 0 2px;display:none;animation:ltb-spin .8s linear infinite}
.ltb-spinner.active{display:block}
@keyframes ltb-spin{to{transform:rotate(360deg)}}
.ltb-title{flex:1;font-size:13px;color:#5a5248;letter-spacing:.1em;text-transform:uppercase;font-family:'IBM Plex Mono',monospace;transition:color .4s}
.ltb-title.loading{color:#c8a040}
.ltb-badge{font-size:12px;padding:1px 6px;border-radius:2px;margin-right:10px;cursor:pointer;
  background:rgba(200,160,64,.12);color:#c8a040;letter-spacing:.06em;font-family:'IBM Plex Mono',monospace}
.ltb-badge.active{animation:badgepulse 1s infinite alternate}
.ltb-badge.operator{background:rgba(200,160,64,.25) !important;color:#e0c050 !important;animation:badgepulse .5s infinite alternate}
@keyframes badgepulse{from{opacity:1}to{opacity:.4}}
#logfilters{display:flex;align-items:center;border-bottom:1px solid rgba(255,255,255,.05);
  background:rgba(14,10,10,.9);flex-shrink:0}
.lf{font-size:8px;letter-spacing:.07em;padding:4px 10px;color:#3a3630;cursor:pointer;
  border-bottom:1.5px solid transparent;transition:.12s;text-transform:uppercase;font-family:'IBM Plex Mono',monospace}
.lf:hover{color:#706860}.lf.on{color:#c8a040;border-bottom-color:#c8a040}
.lf-sep{width:1px;height:12px;background:rgba(255,255,255,.05)}
.lf-clear{margin-left:auto;font-size:8px;color:#3a3630;padding:0 9px;cursor:pointer;transition:.1s}
.lf-clear:hover{color:#706860}
#logbody{flex:1;overflow-y:auto;overflow-x:hidden;padding:5px 0;font-family:'IBM Plex Mono',monospace;min-height:0}
#logbody::-webkit-scrollbar{width:3px}
#logbody::-webkit-scrollbar-thumb{background:rgba(255,255,255,.08);border-radius:2px}
.log-entry{display:flex;padding:2px 0;border-bottom:1px solid rgba(255,255,255,.025);align-items:flex-start;font-size:13px;line-height:1.5}
.log-entry:last-child{border:none}
.le-time{flex-shrink:0;width:66px;padding:0 6px;color:#5a5248;font-size:12px;padding-top:1px}
.le-agent{display:none}
.le-msg{flex:1;color:#b0a898;padding-right:8px;word-break:break-word}
.log-entry.think .le-msg{color:#c8b890;font-style:italic}.log-entry.think .le-msg::before{content:'💭 '}
.log-entry.action .le-msg{color:#7ec89a}.log-entry.action .le-msg::before{content:'→ '}
.log-entry.done .le-msg{color:#5acd6a}.log-entry.done .le-msg::before{content:'✓ '}
.log-entry.error .le-msg{color:#d06060}.log-entry.error .le-msg::before{content:'✕ '}
.log-entry.warn .le-msg{color:#d4a840}.log-entry.warn .le-msg::before{content:'⚠ '}
.log-entry.system .le-msg{color:#7888b8}.log-entry.system .le-msg::before{content:'⬡ '}
.log-entry.decision .le-msg{color:#d4a840;font-weight:500}.log-entry.decision .le-msg::before{content:'◈ '}
.log-entry.operator .le-msg{color:#e8cc58;font-weight:500;font-style:italic}.log-entry.operator .le-msg::before{content:'⚠ OPERADOR: '}
.log-entry.think.typing .le-msg::after{content:'▌';animation:blink .6s infinite;color:#c8a040}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
#logresize{height:4px;background:transparent;cursor:ns-resize;flex-shrink:0;border-top:1px solid rgba(255,255,255,.04)}
#logresize:hover{background:rgba(200,160,64,.1)}
#log-decision{border-top:2px solid rgba(200,160,64,.4);background:rgba(20,16,4,.98);flex-shrink:0;padding:10px 14px;animation:logwarnborder 1.5s ease-in-out infinite}
#log-decision-msg{font-size:12px;color:#c8a040;margin-bottom:8px;font-weight:600;letter-spacing:.03em}
#log-decision-content{max-height:110px;overflow-y:auto;background:rgba(0,0,0,.35);border:1px solid rgba(200,160,64,.15);border-radius:3px;padding:7px 10px;margin-bottom:9px;font-size:11px;color:#8a7860;white-space:pre-wrap;word-break:break-word;line-height:1.5;display:none}
#log-decision-content::-webkit-scrollbar{width:3px}
#log-decision-content::-webkit-scrollbar-thumb{background:rgba(200,160,64,.2);border-radius:2px}
#log-decision-btns{display:flex;gap:8px;flex-wrap:wrap}
.log-dec-btn{border:none;border-radius:4px;padding:6px 14px;font-family:'IBM Plex Mono',monospace;font-size:11px;font-weight:600;cursor:pointer;transition:.12s;letter-spacing:.04em}
.log-dec-btn.yes{background:#1a3a1a;color:#4a9a4a;border:1px solid #3a8a3a66}
.log-dec-btn.yes:hover{background:#2a4a2a;color:#6aba6a}
.log-dec-btn.no{background:#3a1a1a;color:#9a4a4a;border:1px solid #8a3a3a66}
.log-dec-btn.no:hover{background:#4a2a2a;color:#ba6a6a}
.log-dec-btn.edit{background:#1a1a2a;color:#6090c0;border:1px solid #4a7abf44}
.log-dec-btn.edit:hover{background:#2a2a3a;color:#80aae0}
#log-inputrow{display:flex;align-items:center;border-top:1px solid rgba(255,255,255,.06);background:rgba(10,8,6,.98);flex-shrink:0;position:relative}
#log-cmd-prompt{font-size:13px;color:#3a3630;padding:0 8px;flex-shrink:0;font-family:'IBM Plex Mono',monospace}
#log-cmd{flex:1;background:transparent;border:none;color:#ddd8cc;font-family:'IBM Plex Mono',monospace;font-size:13px;padding:8px 4px;outline:none}
#log-cmd::placeholder{color:#7a7670}
#log-cmd-send{background:transparent;border:none;color:#3a3630;font-size:12px;padding:5px 10px;cursor:pointer;transition:.1s}
#log-cmd-send:hover{color:#c8a040}
#log-cmd:disabled{cursor:not-allowed}
#log-cmd-send:disabled{cursor:not-allowed;opacity:.3}
#cmd-hints{position:absolute;bottom:100%;left:0;right:0;background:rgba(12,10,8,.98);border:1px solid rgba(255,255,255,.08);border-radius:4px 4px 0 0;z-index:200}
#log-quickbtns{display:flex;gap:5px;padding:6px 10px;border-top:1px solid rgba(255,255,255,.05);background:rgba(8,6,5,.98);flex-shrink:0}
.lqb{flex:1;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);color:#b0a898;font-family:'IBM Plex Mono',monospace;font-size:10px;padding:5px 8px;border-radius:3px;cursor:pointer;transition:.12s;letter-spacing:.04em}
.lqb:hover{background:rgba(255,255,255,.09);color:#ddd8cc;border-color:rgba(255,255,255,.18)}
.lqb-import{color:#8ab8d0;border-color:rgba(74,122,191,.2)}
.lqb-import:hover{background:rgba(74,122,191,.08);color:#c0d8f0;border-color:rgba(74,122,191,.4)}
#logwin.minimized #log-quickbtns{display:none}

/* ══════════════════════════════
   AGENT BUILDER WINDOW
   ══════════════════════════════ */
#agentwin{position:fixed;bottom:12px;left:12px;width:420px;height:520px;z-index:96;
  border-radius:7px;border:1px solid rgba(200,160,64,.25);background:rgba(8,7,6,.97);
  box-shadow:0 12px 60px rgba(0,0,0,.8),0 0 0 1px rgba(200,160,64,.08);
  display:none;flex-direction:column;overflow:hidden;backdrop-filter:blur(14px);
  min-width:300px;min-height:200px;font-family:'IBM Plex Mono',monospace}
#agentwin.open{display:flex}
#agentwin.minimized #awin-body,#agentwin.minimized #awin-resize{display:none}
#agentwin.minimized{height:28px!important}
#awin-bar{height:28px;background:rgba(16,12,10,.99);border-bottom:1px solid rgba(200,160,64,.12);
  display:flex;align-items:center;cursor:move;flex-shrink:0;user-select:none}
.awin-dots{display:flex;align-items:center;gap:4px;padding:0 10px}
.awin-title{flex:1;font-size:13px;color:#c8a040;letter-spacing:.12em;text-transform:uppercase}
.awin-badge{font-size:12px;padding:1px 7px;border-radius:2px;margin-right:8px;background:rgba(200,160,64,.1);color:#c8a040;letter-spacing:.06em}
#awin-preview{flex-shrink:0;border-bottom:1px solid rgba(255,255,255,.05);background:rgba(12,10,8,.9);padding:7px 12px;display:flex;align-items:center;gap:10px}
.awp-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}
.awp-name{font-size:10px;color:#9a9088;font-family:'IBM Plex Sans',sans-serif;font-weight:500;flex:1}
.awp-chips{display:flex;gap:4px;flex-wrap:wrap}
.awp-chip{font-size:8px;padding:1px 6px;border-radius:2px;background:rgba(255,255,255,.05);color:#4a4840;letter-spacing:.04em}
.awp-chip.ok{background:rgba(58,138,58,.1);color:#3a7a3a}
#awin-body{flex:1;display:flex;flex-direction:column;min-height:0}
#awin-msgs{flex:1;overflow-y:auto;padding:10px 12px;display:flex;flex-direction:column;gap:8px}
#awin-msgs::-webkit-scrollbar{width:3px}
#awin-msgs::-webkit-scrollbar-thumb{background:rgba(255,255,255,.08)}
.amsg{max-width:88%;display:flex;flex-direction:column;gap:3px}
.amsg.ai{align-self:flex-start}.amsg.user{align-self:flex-end}
.amsg-bubble{padding:7px 10px;border-radius:5px;font-size:10px;line-height:1.55;word-break:break-word}
.amsg.ai .amsg-bubble{background:rgba(24,20,16,.9);border:1px solid rgba(255,255,255,.07);color:#b0aa9a;border-radius:2px 5px 5px 5px}
.amsg.user .amsg-bubble{background:rgba(200,160,64,.1);border:1px solid rgba(200,160,64,.2);color:#ddd8cc;border-radius:5px 2px 5px 5px}
.amsg-label{font-size:8px;color:#3a3630;letter-spacing:.06em;padding:0 2px}
.amsg.user .amsg-label{text-align:right;color:#5a5040}
.amsg-card{background:rgba(16,12,10,.95);border:1px solid rgba(200,160,64,.18);border-radius:4px;padding:10px 12px;margin-top:4px;font-size:9px;color:#706860}
.amsg-card-title{font-size:10px;color:#c8a040;font-weight:500;margin-bottom:6px;display:flex;align-items:center;gap:6px}
.amsg-card-row{display:flex;gap:6px;margin-bottom:3px;align-items:flex-start}
.amsg-card-key{color:#3a3630;width:80px;flex-shrink:0;letter-spacing:.04em}
.amsg-card-val{color:#9a9088;flex:1}
.amsg-card-divider{height:1px;background:rgba(255,255,255,.05);margin:5px 0}
.amsg-card-tags{display:flex;gap:4px;flex-wrap:wrap;margin-top:4px}
.amsg-card-tag{font-size:8px;padding:1px 6px;border-radius:2px;background:rgba(200,160,64,.08);color:#c8a040;letter-spacing:.04em}
.typing-dots{display:flex;gap:3px;padding:8px 10px;align-items:center}
.typing-dots span{width:4px;height:4px;border-radius:50%;background:#c8a040;animation:tdot .9s infinite}
.typing-dots span:nth-child(2){animation-delay:.15s}.typing-dots span:nth-child(3){animation-delay:.3s}
@keyframes tdot{0%,60%,100%{opacity:.2;transform:scale(.8)}30%{opacity:1;transform:scale(1.2)}}
#awin-chips{padding:5px 10px;border-top:1px solid rgba(255,255,255,.04);display:flex;gap:5px;flex-wrap:wrap;background:rgba(10,8,6,.9);flex-shrink:0}
.aqchip{font-size:9px;padding:3px 9px;border-radius:3px;cursor:pointer;border:1px solid rgba(255,255,255,.08);color:#706860;background:transparent;font-family:'IBM Plex Mono',monospace;letter-spacing:.03em;transition:.12s}
.aqchip:hover{background:rgba(255,255,255,.05);color:#9a9088;border-color:rgba(255,255,255,.14)}
.aqchip.gold{border-color:rgba(200,160,64,.25);color:#c8a040}.aqchip.gold:hover{background:rgba(200,160,64,.08)}
#awin-input-row{display:flex;align-items:flex-end;border-top:1px solid rgba(255,255,255,.06);background:rgba(12,10,8,.98);flex-shrink:0}
#awin-input{flex:1;background:transparent;border:none;color:#ddd8cc;font-family:'IBM Plex Mono',monospace;font-size:10px;padding:9px 12px;resize:none;outline:none;line-height:1.5;max-height:80px;overflow-y:auto}
#awin-input::placeholder{color:#2a2620}
#awin-send{background:transparent;border:none;color:#c8a040;font-size:14px;padding:8px 12px;cursor:pointer;transition:.12s;flex-shrink:0;align-self:flex-end;margin-bottom:2px}
#awin-send:hover{color:#e0c050}
#awin-savebar{padding:8px 12px;border-top:1px solid rgba(255,255,255,.06);background:rgba(10,8,6,.98);display:none;align-items:center;gap:8px;flex-shrink:0}
#awin-savebar.show{display:flex}
.awin-save-btn{flex:1;background:#c8a040;border:none;color:#1a1200;font-family:'IBM Plex Mono',monospace;font-size:13px;font-weight:600;padding:6px 12px;border-radius:3px;cursor:pointer;transition:.12s}
.awin-save-btn:hover{background:#dab848}
.awin-discard-btn{background:transparent;border:1px solid rgba(255,255,255,.08);color:#706860;font-family:'IBM Plex Mono',monospace;font-size:13px;padding:6px 10px;border-radius:3px;cursor:pointer;transition:.12s}
#awin-resize{height:4px;background:transparent;cursor:ns-resize;flex-shrink:0;border-top:1px solid rgba(255,255,255,.04)}
#awin-resize-t{position:absolute;top:0;left:0;right:0;height:5px;cursor:ns-resize;z-index:10}
#awin-resize-t:hover{background:rgba(200,160,64,.15)}
#awin-resize-r{position:absolute;right:0;top:0;bottom:0;width:5px;cursor:ew-resize;z-index:10;border-radius:0 7px 7px 0}
#awin-resize-r:hover{background:rgba(200,160,64,.15)}

/* ── EXPAND MODAL ── */
#expandwin{position:fixed;inset:0;z-index:600;background:rgba(0,0,0,.8);display:none;align-items:center;justify-content:center;backdrop-filter:blur(8px)}
#expandwin.open{display:flex}
#expandbox{width:640px;max-height:80vh;background:#161210;border:1px solid rgba(255,255,255,.12);border-radius:8px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 32px 80px rgba(0,0,0,.8)}
.exhd{padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.07);display:flex;align-items:center;gap:10px}
.exhd-title{font-family:'IBM Plex Sans',sans-serif;font-size:17px;font-weight:600;flex:1;color:#ddd8cc}
.excls{background:transparent;border:none;color:#3a3630;font-size:15px;cursor:pointer;padding:2px 5px;border-radius:2px}
.excls:hover{background:rgba(255,255,255,.06);color:#706860}
#expandcontent{flex:1;overflow-y:auto;padding:16px}
#expandcontent::-webkit-scrollbar{width:3px}
#expandcontent::-webkit-scrollbar-thumb{background:rgba(255,255,255,.08)}
.ex-textarea{width:100%;background:#0a0808;border:1px solid rgba(255,255,255,.08);border-radius:4px;padding:10px;color:#ddd8cc;font-family:'IBM Plex Mono',monospace;font-size:15px;resize:vertical;outline:none;line-height:1.6;min-height:200px}
.ex-textarea:focus{border-color:rgba(200,160,64,.4)}
.ex-savebar{padding:10px 16px;border-top:1px solid rgba(255,255,255,.07);display:flex;gap:8px;justify-content:flex-end}
.ex-save{background:#c8a040;border:none;color:#1a1200;font-family:'IBM Plex Mono',monospace;font-size:13px;font-weight:600;padding:5px 14px;border-radius:3px;cursor:pointer}
.ex-cancel{background:transparent;border:1px solid rgba(255,255,255,.08);color:#706860;font-family:'IBM Plex Mono',monospace;font-size:13px;padding:5px 10px;border-radius:3px;cursor:pointer}

/* MODAL */
#moverlay{position:fixed;inset:0;background:rgba(0,0,0,.78);z-index:500;display:none;align-items:center;justify-content:center;backdrop-filter:blur(8px)}
#moverlay.open{display:flex}
#modal{width:1160px;max-height:90vh;background:#161210;border:1px solid rgba(255,255,255,.1);border-radius:7px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 32px 80px rgba(0,0,0,.8)}
.mhd{padding:11px 15px;border-bottom:1px solid rgba(255,255,255,.07);display:flex;align-items:center;gap:9px}
.mhd-dot{width:8px;height:8px;border-radius:2px}
.mhd-title{font-family:'IBM Plex Sans',sans-serif;font-size:17px;font-weight:600;flex:1;color:#ddd8cc}
.mcls{background:transparent;border:none;color:#3a3630;font-size:18px;cursor:pointer;padding:2px 5px;border-radius:2px}
.mcls:hover{background:rgba(255,255,255,.06);color:#706860}
.mtabs{display:flex;border-bottom:1px solid rgba(255,255,255,.06)}
.mtab{padding:7px 13px;font-size:14px;font-weight:600;letter-spacing:.08em;color:#3a3630;cursor:pointer;border-bottom:2px solid transparent;transition:.12s;text-transform:uppercase}
.mtab.on{color:#c8a040;border-bottom-color:#c8a040}
.mtab:hover:not(.on){color:#706860}
.mbody{flex:1;overflow-y:auto;padding:13px 15px}
.mbody::-webkit-scrollbar{width:3px}
.mbody::-webkit-scrollbar-thumb{background:rgba(255,255,255,.08)}
.fg{margin-bottom:11px}
.fl{font-size:15px;letter-spacing:.1em;color:#3a3630;margin-bottom:5px;text-transform:uppercase;display:flex;align-items:center;justify-content:space-between}
.fi{width:100%;background:#0a0808;border:1px solid rgba(255,255,255,.07);border-radius:3px;padding:7px 10px;color:#ddd8cc;font-family:'IBM Plex Mono',monospace;font-size:16px;resize:vertical;outline:none;transition:border-color .12s;line-height:1.5}
.ai-suggest-btn{background:rgba(200,160,64,.08);border:1px solid rgba(200,160,64,.25);color:#c8a040;font-size:11px;padding:2px 7px;border-radius:3px;cursor:pointer;font-family:'IBM Plex Mono',monospace;letter-spacing:.06em;transition:.12s;white-space:nowrap}
.ai-suggest-btn:hover{background:rgba(200,160,64,.18);border-color:rgba(200,160,64,.5)}
.ai-suggest-dropdown{position:fixed;z-index:2000;background:#1a1612;border:1px solid rgba(200,160,64,.3);border-radius:5px;padding:8px;min-width:340px;max-width:500px;box-shadow:0 8px 24px rgba(0,0,0,.7)}
.ai-suggest-opt{padding:8px 10px;border-radius:3px;background:#0a0808;border:1px solid rgba(255,255,255,.07);margin-bottom:5px;cursor:pointer;font-size:12px;color:#9a9088;line-height:1.5;font-family:'IBM Plex Mono',monospace;transition:.12s}
.ai-suggest-opt:last-child{margin-bottom:0}
.ai-suggest-opt:hover{border-color:rgba(200,160,64,.35);color:#ddd8cc}
.fi:focus{border-color:rgba(200,160,64,.4)}
textarea.fi{min-height:65px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.logl{font-size:9px;padding:3px 0;border-bottom:1px solid rgba(255,255,255,.03);display:flex;gap:8px;line-height:1.4}
.lt{color:#3a3630;flex-shrink:0;font-size:8px}
.lm{color:#706860}.lm.ok{color:#3a8a3a}.lm.er{color:#8a3a3a}.lm.wn{color:#c8a040}
.tcbox{background:#0a0808;border:1px solid rgba(255,255,255,.06);border-radius:3px;padding:8px;margin-bottom:6px}
.tcrow{display:flex;align-items:center;gap:6px;margin-bottom:4px}
.tcn{font-size:10px;flex:1;color:#ddd8cc}
.tcs{font-size:8px;padding:1px 6px;border-radius:2px;letter-spacing:.04em}
.tcs.pass{background:rgba(58,138,58,.12);color:#3a8a3a}
.tcs.fail{background:rgba(138,42,42,.12);color:#8a3a3a}
.tcs.pend{background:rgba(60,56,50,.2);color:#706860}
.runtc{background:rgba(200,160,64,.12);border:none;color:#c8a040;font-family:'IBM Plex Mono',monospace;font-size:8px;font-weight:600;padding:2px 7px;border-radius:2px;cursor:pointer}
.runtc:hover{background:rgba(200,160,64,.22)}
.add-btn{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);color:#706860;font-size:11px;padding:4px 9px;border-radius:3px;cursor:pointer;font-family:'IBM Plex Mono',monospace;margin-top:4px}

/* IO type selector in modal */
.io-type-row{display:flex;gap:5px;flex-wrap:wrap;margin-top:5px}
.io-type-btn{padding:3px 9px;border-radius:3px;border:1px solid rgba(255,255,255,.08);background:transparent;color:#706860;font-family:'IBM Plex Mono',monospace;font-size:11px;cursor:pointer;transition:.12s}
.io-type-btn:hover{background:rgba(255,255,255,.05);color:#9a9088}
.io-type-btn.on{background:rgba(200,160,64,.1);border-color:rgba(200,160,64,.3);color:#c8a040}

/* MINIMAP + ZOOM */
#mm{position:fixed;right:12px;bottom:12px;width:140px;height:85px;background:rgba(12,10,9,.92);border:1px solid rgba(255,255,255,.07);border-radius:4px;z-index:90;overflow:hidden}
#mmc{width:100%;height:100%;cursor:crosshair}
#zc{position:fixed;right:164px;bottom:12px;background:rgba(12,10,9,.92);border:1px solid rgba(255,255,255,.07);border-radius:4px;padding:3px 7px;z-index:90;display:flex;align-items:center;gap:4px}
.zb{background:transparent;border:none;color:#706860;font-size:13px;cursor:pointer;line-height:1;padding:0 3px;transition:.1s}
.zb:hover{color:#ddd8cc}
#zl{font-size:9px;color:#706860;min-width:26px;text-align:center;letter-spacing:.04em}
#ctx{position:fixed;z-index:600;background:#161210;border:1px solid rgba(255,255,255,.1);border-radius:4px;padding:3px;min-width:140px;box-shadow:0 8px 32px rgba(0,0,0,.7);display:none}
.ci{padding:5px 9px;font-size:10px;color:#706860;border-radius:2px;cursor:pointer;display:flex;align-items:center;gap:6px;letter-spacing:.03em}
.ci:hover{background:rgba(255,255,255,.05);color:#ddd8cc}
.ci.red{color:#8a3a3a}.ci.red:hover{background:rgba(138,42,42,.08);color:#cc6060}
.ci-header{color:#9a8e7c;font-size:9px;letter-spacing:.1em;text-transform:uppercase;cursor:default;opacity:.6;padding-bottom:3px}
.ci-header:hover{background:transparent;color:#9a8e7c}
.csep{height:1px;background:rgba(255,255,255,.05);margin:2px 0}

/* SKILL FRAMES */
.skill-ring{position:absolute;border-radius:8px;pointer-events:none}
.skill-tag{position:absolute;top:-8px;font-size:7px;padding:1px 6px;border-radius:2px;font-family:'IBM Plex Mono',monospace;letter-spacing:.06em;background:#0d0b0a;cursor:pointer;pointer-events:all;transition:.12s}
.skill-tag:hover{filter:brightness(1.4)}

/* Footer skill button */
.nfoot-sk{background:transparent;border:none;font-size:8px;color:#4a7abf;cursor:pointer;font-family:'IBM Plex Mono',monospace;letter-spacing:.04em;padding:1px 5px;border-radius:2px;display:none;align-items:center;gap:3px;transition:.12s}
.nfoot-sk:hover{background:rgba(74,122,191,.1);color:#7aabef}

/* SKILL ADAPT PANEL */
#skillwin{position:fixed;inset:0;z-index:620;background:rgba(0,0,0,.75);display:none;align-items:center;justify-content:center;backdrop-filter:blur(8px)}
#skillwin.open{display:flex}
#skillbox{width:520px;max-height:74vh;background:#161210;border:1px solid rgba(74,122,191,.25);border-radius:8px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 32px 80px rgba(0,0,0,.85),0 0 0 1px rgba(74,122,191,.08)}
#skillbox-head{padding:11px 15px;border-bottom:1px solid rgba(255,255,255,.07);display:flex;align-items:center;gap:10px;background:rgba(0,0,0,.3);flex-shrink:0}
.skh-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.skh-title{font-family:'IBM Plex Sans',sans-serif;font-size:17px;font-weight:600;flex:1;color:#ddd8cc}
.skh-sub{font-size:13px;color:#5a5248;font-family:'IBM Plex Mono',monospace;letter-spacing:.06em}
.skcls{background:transparent;border:none;color:#3a3630;font-size:14px;cursor:pointer;padding:2px 5px;border-radius:2px}
.skcls:hover{background:rgba(255,255,255,.06);color:#706860}
#skillbox-tabs{display:flex;border-bottom:1px solid rgba(255,255,255,.06);background:rgba(0,0,0,.2);flex-shrink:0}
.sktab{padding:7px 13px;font-size:9px;letter-spacing:.07em;color:#3a3630;cursor:pointer;border-bottom:2px solid transparent;transition:.12s;text-transform:uppercase;font-family:'IBM Plex Mono',monospace;display:flex;align-items:center;gap:5px}
.sktab.on{color:#4a9aef;border-bottom-color:#4a7abf}
.sktab:hover:not(.on){color:#706860}
#skillbox-body{flex:1;overflow-y:auto;padding:14px 15px;display:flex;flex-direction:column;gap:10px}
#skillbox-body::-webkit-scrollbar{width:3px}
#skillbox-body::-webkit-scrollbar-thumb{background:rgba(255,255,255,.08)}
.sk-card{background:#0e0c0a;border:1px solid rgba(255,255,255,.07);border-radius:5px;overflow:hidden;transition:.12s}
.sk-card:hover{border-color:rgba(74,122,191,.25)}
.sk-card-head{padding:8px 11px;display:flex;align-items:center;gap:8px;border-bottom:1px solid rgba(255,255,255,.05)}
.sk-card-n{font-size:14px;color:#9a9088;font-family:'IBM Plex Sans',sans-serif;font-weight:600;flex:1}
.sk-card-tag{font-size:11px;padding:1px 6px;border-radius:2px;background:rgba(74,122,191,.1);color:#4a7abf;letter-spacing:.04em}
.sk-card-cmd{padding:8px 11px;background:#090807;font-family:'IBM Plex Mono',monospace;font-size:13px;color:#5a9a6a;letter-spacing:.02em;line-height:1.5;border-bottom:1px solid rgba(255,255,255,.04);position:relative;cursor:pointer}
.sk-card-cmd:hover .sk-copy{opacity:1}
.sk-card-cmd code{color:#7abf7a}
.sk-copy{position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:8px;color:#4a7abf;opacity:0;transition:.1s;background:#0e0c0a;padding:2px 6px;border-radius:2px;pointer-events:none}
.sk-card-desc{padding:7px 11px;font-size:13px;color:#5a5248;line-height:1.5}
#skillbox-footer{padding:10px 15px;border-top:1px solid rgba(255,255,255,.06);display:flex;gap:8px;background:rgba(0,0,0,.25);flex-shrink:0}
.sk-apply-btn{flex:1;background:rgba(74,122,191,.12);border:1px solid rgba(74,122,191,.25);color:#4a9aef;font-family:'IBM Plex Mono',monospace;font-size:13px;font-weight:600;padding:6px 12px;border-radius:4px;cursor:pointer;transition:.12s;letter-spacing:.04em}
.sk-apply-btn:hover{background:rgba(74,122,191,.22);border-color:rgba(74,122,191,.5)}
.sk-remove-btn{background:transparent;border:1px solid rgba(138,42,42,.3);color:#8a4a4a;font-family:'IBM Plex Mono',monospace;font-size:13px;padding:6px 10px;border-radius:4px;cursor:pointer;transition:.12s}
.sk-remove-btn:hover{background:rgba(138,42,42,.1);border-color:rgba(138,42,42,.6);color:#c85050}
.sk-close-btn{background:transparent;border:1px solid rgba(255,255,255,.08);color:#706860;font-family:'IBM Plex Mono',monospace;font-size:13px;padding:6px 10px;border-radius:4px;cursor:pointer;transition:.12s}
.sk-close-btn:hover{background:rgba(255,255,255,.05)}

/* Skill drag-over highlight */
.node.skill-over{border-color:rgba(74,122,191,.7) !important;box-shadow:0 0 0 2px rgba(74,122,191,.25),0 4px 32px rgba(0,0,0,.6) !important}
.node.skill-over .node-inner{outline:1px solid rgba(74,122,191,.2)}

/* Skills catalog in sidebar */
.ps-skill{display:flex;align-items:center;gap:7px;padding:5px 10px;border-radius:3px;cursor:grab;font-size:12px;color:#90b8d8;transition:.12s;margin-bottom:1px;border-left:2px solid rgba(74,122,191,.35)}
.ps-skill:hover{background:rgba(74,122,191,.08);color:#c0d8f0;border-left-color:rgba(74,122,191,.7)}
.ps-skill-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.ps-skill-desc{font-size:10px;color:#3a3630;margin-left:auto;letter-spacing:.04em}
.ps-input{display:flex;align-items:center;gap:7px;padding:5px 10px;border-radius:3px;cursor:grab;font-size:12px;color:#c8b870;transition:.12s;margin-bottom:1px;border-left:2px solid rgba(200,160,64,.35)}
.ps-input:hover{background:rgba(200,160,64,.08);color:#e8d890;border-left-color:rgba(200,160,64,.7)}
.ps-input-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.ps-input-desc{font-size:10px;color:#3a3630;margin-left:auto;letter-spacing:.04em}
.input-drag-card{width:220px}.input-drag-card .oc-body{max-height:none;overflow:visible}
.idc-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:14px 8px;color:#4a6a90;font-size:10px;border:1px dashed rgba(74,122,191,.3);border-radius:3px;margin:4px 0}
.idc-placeholder span{font-size:18px;opacity:.5}
.idc-textarea{width:100%;box-sizing:border-box;background:rgba(0,0,0,.2);border:1px solid rgba(200,160,64,.2);border-radius:3px;color:#d8c870;font-family:'IBM Plex Mono',monospace;font-size:12px;padding:6px 8px;resize:none;min-height:64px;outline:none}
.idc-textarea:focus{border-color:rgba(200,160,64,.5)}
.idc-image-wrap{display:flex;flex-direction:column;gap:6px;margin:4px 0 8px}
.idc-image-preview{width:100%;height:110px;object-fit:cover;border-radius:4px;border:1px solid rgba(74,122,191,.24);background:#081018;display:block}
.idc-image-meta{font-size:8px;color:#6a8aaa;font-family:'IBM Plex Mono',monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.idc-upload-btn{width:100%;background:rgba(74,122,191,.12);border:1px solid rgba(74,122,191,.3);border-radius:3px;color:#8ab8d8;font-size:9px;font-family:'IBM Plex Mono',monospace;cursor:pointer;padding:6px 8px;letter-spacing:.05em;transition:.12s}
.idc-upload-btn:hover{background:rgba(74,122,191,.18);border-color:rgba(74,122,191,.55);color:#b8d8f0}

/* ══════════════════════════════════════════════════════
   ONBOARDING SYSTEM
══════════════════════════════════════════════════════ */

/* dim overlay */
#ob-overlay{position:fixed;inset:0;background:rgba(10,6,4,.82);z-index:9998;opacity:0;transition:opacity .4s;pointer-events:none}
#ob-overlay.on{opacity:1;pointer-events:all}

/* LIVE badge — blue */
.ob-live-badge{background:rgba(74,122,191,.2)!important;color:#4a9aef!important;
  animation:ob-livepulse .9s infinite alternate;letter-spacing:.08em}
@keyframes ob-livepulse{from{opacity:1;box-shadow:0 0 0 0 rgba(74,122,191,0)}
  to{opacity:.7;box-shadow:0 0 8px 2px rgba(74,122,191,.35)}}

/* filters bar — LIVE tab */
.ob-live-tab{font-size:8px;letter-spacing:.1em;padding:4px 12px;color:#4a9aef;
  border-bottom:1.5px solid #4a9aef;font-family:'IBM Plex Mono',monospace;
  text-transform:uppercase;font-weight:600;animation:ob-livepulse .9s infinite alternate}
.ob-live-dot{width:6px;height:6px;border-radius:50%;background:#4a9aef;margin:0 6px;
  flex-shrink:0;animation:ob-livepulse .9s infinite alternate}
.ob-live-status{font-size:7px;color:#3a5a8a;letter-spacing:.08em;font-family:'IBM Plex Mono',monospace;
  text-transform:uppercase;align-self:center}

/* onboard content body */
#ob-body{padding:10px 14px;font-family:'IBM Plex Mono',monospace;color:#706860;
  display:flex;flex-direction:column;gap:0;min-height:0}

/* blinking cursor line */
.ob-cursor-line{height:13px;width:8px;background:#4a9aef;opacity:.9;
  animation:ob-blink .7s step-end infinite;margin-bottom:8px;border-radius:1px}
@keyframes ob-blink{0%,100%{opacity:.9}50%{opacity:0}}

/* ASCII logo */
.ob-ascii{font-size:8.5px;line-height:1.5;color:#c8a040;letter-spacing:.01em;
  margin-bottom:10px;white-space:pre;text-shadow:0 0 18px rgba(200,160,64,.45)}
.ob-ascii div{min-height:1em}
.ob-ascii div:last-child{color:#4a5a6a;font-size:8px;letter-spacing:.12em;text-shadow:none;margin-top:2px}

/* init sequence lines */
.ob-init-line{font-size:11px;line-height:1.6;letter-spacing:.02em;padding:1px 0}

/* separator */
.ob-sep{height:1px;background:linear-gradient(90deg,transparent,rgba(74,122,191,.4),transparent);
  margin:12px 0}

/* welcome text styles */
.ob-h1{font-size:14px;color:#ddd8cc;font-weight:600;letter-spacing:.04em;
  font-family:'IBM Plex Sans',sans-serif;line-height:1.4}
.ob-desc{font-size:11px;color:#706860;line-height:1.65;letter-spacing:.01em}
.ob-hint{font-size:11px;color:#c8a040;line-height:1.6;letter-spacing:.02em}
.ob-sub{font-size:10px;color:#4a5a6a;line-height:1.6;letter-spacing:.03em;font-style:italic}

/* progress dots */
.ob-progress{display:flex;gap:6px;align-items:center;margin:14px 0 4px}
.ob-prog-dot{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.1);transition:.3s}
.ob-prog-dot.active{background:#4a9aef;border-color:#4a9aef;
  box-shadow:0 0 6px rgba(74,122,191,.5)}

/* nav buttons */
.ob-btns{display:flex;gap:8px;align-items:center;margin-top:14px;padding-top:10px;
  border-top:1px solid rgba(255,255,255,.05)}
.ob-btn-skip{background:transparent;border:1px solid rgba(255,255,255,.08);color:#9a9088;
  font-family:'IBM Plex Mono',monospace;font-size:10px;padding:6px 12px;border-radius:3px;
  cursor:pointer;transition:.15s;letter-spacing:.04em}
.ob-btn-skip:hover{color:#706860;border-color:rgba(255,255,255,.18)}
.ob-btn-next{background:#4a9aef;border:none;color:#0a0e18;font-family:'IBM Plex Mono',monospace;
  font-size:10px;font-weight:700;padding:6px 16px;border-radius:3px;cursor:pointer;
  transition:.15s;letter-spacing:.06em;margin-left:auto}
.ob-btn-next:hover{background:#6ab4ff;box-shadow:0 0 16px rgba(74,154,239,.35)}

/* floating help button */
#ob-help-btn{position:fixed;bottom:108px;right:14px;width:30px;height:30px;border-radius:50%;
  background:rgba(74,122,191,.15);border:1px solid rgba(74,122,191,.3);color:#4a7abf;
  font-family:'IBM Plex Mono',monospace;font-size:13px;font-weight:700;cursor:pointer;
  z-index:9990;transition:.2s;display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 12px rgba(0,0,0,.4)}
#ob-help-btn:hover{background:rgba(74,122,191,.3);border-color:rgba(74,122,191,.6);
  color:#6aaaf0;box-shadow:0 0 16px rgba(74,122,191,.3)}

/* ── PHASE 2 additions ── */

/* spotlight ring */
#ob-spotlight{position:fixed;border:2px solid rgba(74,154,239,.85);border-radius:6px;
  z-index:9999;pointer-events:none;opacity:0;
  transition:opacity .45s,left .62s cubic-bezier(.4,0,.2,1),top .62s cubic-bezier(.4,0,.2,1),
             width .62s cubic-bezier(.4,0,.2,1),height .62s cubic-bezier(.4,0,.2,1);
  box-shadow:0 0 0 4px rgba(74,154,239,.12),0 0 28px rgba(74,154,239,.35)}
#ob-spotlight.on{opacity:1}

/* section title inside terminal */
.ob-section-title{font-size:9px;color:#4a9aef;letter-spacing:.18em;text-transform:uppercase;
  font-family:'IBM Plex Mono',monospace;padding-bottom:5px;
  border-bottom:1px solid rgba(74,122,191,.25);margin-bottom:2px}

/* progress done dot */
.ob-prog-dot.done{background:rgba(90,154,90,.7);border-color:rgba(90,154,90,.5);
  box-shadow:0 0 4px rgba(90,154,90,.3)}

/* overlay transition (background changes smoothly via JS, opacity via CSS) */
#ob-overlay{transition:opacity .4s,background .5s}

/* connection draw animation (Phase 4) */
.cpath-draw{stroke-dasharray:2000;stroke-dashoffset:2000;
  animation:ob-drawConn .85s cubic-bezier(.4,0,.2,1) forwards}
@keyframes ob-drawConn{to{stroke-dashoffset:0}}

/* ══════════════════════════════
   SEED NODE
   ══════════════════════════════ */
.node[data-type="seed"] .port.in{display:none}
.node[data-type="seed"] .node-inner{border:1px solid rgba(200,160,64,.35);box-shadow:0 0 24px rgba(200,160,64,.12)}
.node[data-type="seed"]:hover .node-inner{border-color:rgba(200,160,64,.6)}
.node[data-type="seed"] .nactions{display:none}
.nvis-seed{padding:8px 10px}
.nvis-seed-lbl{font-size:7px;color:#c8a04066;letter-spacing:.1em;text-transform:uppercase;margin-bottom:4px}
.nvis-seed-txt{font-size:10px;color:#c8a040;line-height:1.5;font-style:italic;word-break:break-word}

/* ══════════════════════════════
   PILOT NODE
   ══════════════════════════════ */
.node[data-type="pilot"]{width:320px;border-color:rgba(200,80,80,.24);box-shadow:0 8px 34px rgba(0,0,0,.55),0 0 0 1px rgba(200,80,80,.08)}
.node[data-type="pilot"] .node-inner{border:1px solid rgba(200,80,80,.24);background:#0d0909}
.node[data-type="pilot"] .nh{padding:14px 14px 8px}
.node[data-type="pilot"] .nh-name{font-size:20px;font-weight:600}
.node[data-type="pilot"] .nh-icon{font-size:15px;opacity:.82;width:auto}
.node[data-type="pilot"] .nc{width:28px;height:28px;font-size:11px;border-radius:6px;background:rgba(0,0,0,.24)}
.node[data-type="pilot"] .nh-model{margin-top:10px}
.node[data-type="pilot"] .n-model-sel{height:34px;padding:5px 28px 5px 10px;font-size:13px;border-radius:4px;background-color:rgba(0,0,0,.35)}
.node[data-type="pilot"] .port.in{left:-10px;width:18px;height:18px}
.node[data-type="pilot"] .port.out-y,.node[data-type="pilot"] .port.out-n{right:-10px;width:18px;height:18px}
.node[data-type="pilot"] .port.out-y{top:44%}
.node[data-type="pilot"] .port.out-n{top:64%}
.node[data-type="pilot"] .plbl{right:-42px;font-size:10px}
.pilot-io{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid rgba(255,255,255,.04);border-bottom:1px solid rgba(255,255,255,.05)}
.pilot-io-half{padding:11px 14px 12px;min-height:86px;cursor:pointer;transition:.12s}
.pilot-io-half:hover{background:rgba(255,255,255,.03)}
.pilot-io-half+.pilot-io-half{border-left:1px solid rgba(255,255,255,.05)}
.pilot-io-label{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#2f6b35;margin-bottom:8px}
.pilot-io-label-out{color:#c8a040}
.pilot-io-type{display:flex;align-items:center;gap:8px;font-size:18px;color:#f3f0ea;line-height:1.1}
.pilot-io-icon{font-size:20px;color:#4da25a}
.pilot-io-text{font-size:12px;color:#b6a99c;margin-top:7px;line-height:1.35}
.pilot-io-default{font-size:11px;color:#6d625b;font-style:italic;line-height:1.35;margin-top:5px}
.pilot-io-chip{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;margin-top:9px;border:1px solid rgba(200,160,64,.75);color:#f4eee2;background:rgba(200,160,64,.08);font-family:"IBM Plex Sans",sans-serif;font-size:11px}
.node[data-type="pilot"] .nmeta{padding:12px 14px 10px}
.node[data-type="pilot"] .nmeta-row{font-size:14px;line-height:1.4;color:#d4c7bc;display:block}
.node[data-type="pilot"] .nmeta-row+.nmeta-row{margin-top:4px}
.node[data-type="pilot"] .nmeta-row b{display:inline;color:#aa998e;margin-right:6px}
.node[data-type="pilot"] .nmeta-row .nmeta-txt{-webkit-line-clamp:2;display:inline}
.node[data-type="pilot"] .nmeta-expand-hint{margin-top:7px}
.pilot-report-snippet{padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.05);font-size:12px;color:#8f8378;line-height:1.45;cursor:pointer;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.pilot-report-snippet:hover{background:rgba(255,255,255,.02)}
.pilot-cycle-row{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid rgba(255,255,255,.05);flex-wrap:wrap;color:#a99a8e}
.pilot-cycle-label,.pilot-cycle-repeat{font-size:13px;color:#9f8f84}
.pilot-cycle-badge{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:26px;padding:0 10px;background:#f0ece6;color:#2a2220;border:1px solid #c6beb5;font-family:"IBM Plex Sans",sans-serif;font-size:14px;font-weight:600}
.pilot-loop-select,.pilot-loop-input{height:26px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);color:#d4c7bc;font-family:"IBM Plex Mono",monospace;font-size:12px;border-radius:3px;padding:0 8px}
.pilot-loop-input{width:62px}
.pilot-task-wrap{padding:10px 14px 12px;border-bottom:1px solid rgba(255,255,255,.05)}
.pilot-task-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px;color:#cdbfb3;font-size:13px}
.pilot-history-link{background:none;border:none;padding:0;color:#22a9d6;cursor:pointer;font-family:"IBM Plex Sans",sans-serif;font-size:12px;text-decoration:underline;text-underline-offset:2px}
.pilot-task-list{display:flex;flex-direction:column;gap:6px;min-height:88px}
.pilot-task-item{font-size:12px;line-height:1.35;color:#8b8077;display:flex;align-items:center;gap:7px}
.pilot-task-item.active{color:#d6cdc3}
.pilot-task-item.waiting{color:#c8a040}
.pilot-actions{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid rgba(255,255,255,.05)}
.pilot-action-btn{min-height:58px;border:none;display:flex;align-items:center;gap:10px;padding:10px 14px;font-family:'IBM Plex Mono',monospace;font-size:11px;cursor:pointer;transition:.12s;color:#f5eee4}
.pilot-report-label{display:flex;flex-direction:column;gap:2px;flex:1}
.pilot-report-title{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.8);font-family:'IBM Plex Mono',monospace}
.pilot-report-state{font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.45);font-family:'IBM Plex Mono',monospace}
.pilot-report-btn{background:#4d4032}
.pilot-context-btn{background:#184d1f}
.pilot-report-btn:hover{background:#5a4a3b}
.pilot-context-btn:hover{background:#1d5b25}
.pilot-action-ico{width:22px;height:22px;border-radius:4px;background:rgba(0,0,0,.22);display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0}
.pilot-action-state{margin-left:auto;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.7)}
.pilot-bottom-bar{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;border-top:1px solid rgba(0,0,0,.35);background:rgba(0,0,0,.26);font-family:"IBM Plex Mono",monospace}
.pilot-bottom-status{font-size:11px;letter-spacing:.08em;color:#8a8478;text-transform:uppercase}
.pilot-bottom-tokens{font-size:11px;color:#c8892f;letter-spacing:.04em}
/* ── PILOT LOG CARD (terminal pegado abajo del piloto) ── */
.pilot-log-card{position:absolute;top:calc(100% + 5px);left:0;right:0;min-width:230px;background:#060504;border:1px solid rgba(200,160,64,.22);border-radius:4px;box-shadow:0 6px 28px rgba(0,0,0,.8),0 0 0 1px rgba(200,160,64,.08) inset;z-index:8;overflow:hidden;font-family:'IBM Plex Mono',monospace;cursor:pointer}
.pilot-log-card:hover{border-color:rgba(200,160,64,.45)}
.plc-bar{display:flex;align-items:center;gap:6px;padding:5px 9px;background:rgba(200,160,64,.06);border-bottom:1px solid rgba(200,160,64,.1);flex-shrink:0}
.plc-dot{width:6px;height:6px;border-radius:50%;background:#c8a040;animation:sdpulse .9s infinite alternate;flex-shrink:0}
.node.paused .plc-dot{animation:none;background:#2a3a6a}
.plc-title{font-size:10px;color:#c8a04066;letter-spacing:.1em;text-transform:uppercase;flex:1}
.plc-close{font-size:12px;color:#3a3630;cursor:pointer;padding:1px 4px;border-radius:2px;transition:.1s;line-height:1}
.plc-close:hover{color:#cc6060;background:rgba(138,42,42,.15)}
.plc-body{padding:8px 10px;max-height:150px;overflow-y:auto;display:flex;flex-direction:column;gap:3px}
.plc-body::-webkit-scrollbar{width:3px}
.plc-body::-webkit-scrollbar-thumb{background:rgba(200,160,64,.18)}
.plc-line{display:flex;gap:8px;font-size:11px;line-height:1.6;color:#7a7060;word-break:break-word}
.plc-prompt{color:#c8a04044;flex-shrink:0;user-select:none}
.plc-text{color:#9a8e7c}
.plc-line.plc-new .plc-text{color:#c8b870}
.plc-empty{font-size:11px;color:#3a3630;font-style:italic;padding:4px 0}

/* ══════════════════════════════
   ASSEMBLY CARD VIS
   ══════════════════════════════ */
.asm-state-row{display:flex;align-items:center;justify-content:space-between;padding:4px 0 5px}
.asm-state-badge{font-size:8px;letter-spacing:.09em;padding:2px 7px;border-radius:2px;font-family:'IBM Plex Mono',monospace;text-transform:uppercase}
.asm-pendiente{background:rgba(200,120,64,.1);color:#c87840}
.asm-en_progreso{background:rgba(200,160,64,.14);color:#c8a040;animation:sdpulse .9s infinite alternate}
.asm-completado{background:rgba(58,138,90,.15);color:#3a8a5a}
.asm-count{font-size:9px;color:#706860;font-family:'IBM Plex Mono',monospace;letter-spacing:.04em}
.asm-assets{max-height:72px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}
.asm-assets::-webkit-scrollbar{width:2px}
.asm-assets::-webkit-scrollbar-thumb{background:rgba(200,120,64,.18)}
.asm-asset-item{display:flex;align-items:center;gap:5px;padding:1px 0;font-size:9px;font-family:'IBM Plex Mono',monospace}
.asm-asset-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0}
.asm-pending .asm-asset-dot{background:#2a2820}
.asm-done .asm-asset-dot{background:#3a8a5a}
.asm-pending .asm-asset-name{color:#3a3630}
.asm-done .asm-asset-name{color:#3a8a5a}
.asm-waiting{font-size:9px;color:#3a3630;font-style:italic;padding:3px 0}
.asm-dl-row{display:flex;justify-content:center;padding-top:6px;border-top:1px solid rgba(255,255,255,.05);margin-top:4px}
.asm-dl-btn{background:rgba(200,120,64,.12);border:1px solid rgba(200,120,64,.3);color:#c87840;font-family:'IBM Plex Mono',monospace;font-size:9px;letter-spacing:.06em;padding:4px 12px;border-radius:2px;cursor:pointer;transition:.12s}
.asm-dl-btn:hover{background:rgba(200,120,64,.22);border-color:rgba(200,120,64,.5)}

/* ══════════════════════════════
   WAITLIST OVERLAY
   ══════════════════════════════ */
#waitlist-overlay{
  position:fixed;inset:0;z-index:9999;
  background:rgba(12,10,8,.96);
  display:flex;align-items:center;justify-content:center;
}
#waitlist-box{
  width:340px;padding:32px 28px 28px;
  background:#1c1816;border:1px solid rgba(200,160,64,.2);border-radius:4px;
  display:flex;flex-direction:column;align-items:center;gap:14px;
}
#waitlist-icon{font-size:32px;color:#c8a040;line-height:1}
#waitlist-title{font-family:'IBM Plex Mono',monospace;font-size:14px;font-weight:500;color:#ddd8cc;text-align:center}
#waitlist-sub{font-family:'IBM Plex Mono',monospace;font-size:10px;color:#7a746c;text-align:center;line-height:1.6}
#waitlist-email{
  width:100%;padding:8px 10px;
  background:#0e0c0a;border:1px solid rgba(200,160,64,.2);border-radius:2px;
  font-family:'IBM Plex Mono',monospace;font-size:11px;color:#ddd8cc;outline:none;
}
#waitlist-email:focus{border-color:rgba(200,160,64,.5)}
#waitlist-send{
  width:100%;padding:9px;
  background:rgba(200,160,64,.12);border:1px solid rgba(200,160,64,.35);
  color:#c8a040;font-family:'IBM Plex Mono',monospace;font-size:11px;
  border-radius:2px;cursor:pointer;transition:.12s;
}
#waitlist-send:hover{background:rgba(200,160,64,.22)}
#waitlist-msg{font-family:'IBM Plex Mono',monospace;font-size:9px;color:#3a8a3a;text-align:center;min-height:14px}

/* ══════════════════════════════
   BESTPOINTS WALLET OVERLAY
   ══════════════════════════════ */
#bp-overlay{
  position:fixed;inset:0;z-index:900;
  background:rgba(12,10,8,.7);
  display:flex;align-items:center;justify-content:center;
}
#bp-box{
  width:360px;
  background:#1c1816;border:1px solid rgba(200,160,64,.2);border-radius:4px;
  font-family:'IBM Plex Mono',monospace;overflow:hidden;
}
#bp-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 14px;border-bottom:1px solid rgba(255,255,255,.06);
  font-size:11px;color:#9a9088;
}
#bp-title{color:#c8a040;font-size:11px}
.bp-cls{background:none;border:none;color:#5a5450;cursor:pointer;font-size:13px;padding:0 2px}
.bp-cls:hover{color:#9a9088}
#bp-body{padding:18px 16px;display:flex;flex-direction:column;gap:14px}
#bp-balance-row{display:flex;align-items:baseline;gap:8px}
#bp-balance{font-size:28px;font-weight:500;color:#c8a040;letter-spacing:-.02em}
#bp-balance-label{font-size:10px;color:#7a746c}
#bp-tokens-row{font-size:9px;color:#5a5450;margin-top:-8px}
.bp-divider{height:1px;background:rgba(255,255,255,.05)}
.bp-sec-lbl{font-size:9px;color:#5a5450;letter-spacing:.08em;text-transform:uppercase;margin-bottom:6px}
#bp-code-row,#bp-email-row{display:flex;gap:6px}
#bp-code-input,#bp-email-input{
  flex:1;padding:6px 8px;
  background:#0e0c0a;border:1px solid rgba(255,255,255,.08);border-radius:2px;
  font-family:'IBM Plex Mono',monospace;font-size:10px;color:#ddd8cc;outline:none;
}
#bp-code-input:focus,#bp-email-input:focus{border-color:rgba(200,160,64,.4)}
#bp-code-btn,#bp-email-btn{
  padding:6px 10px;
  background:rgba(200,160,64,.1);border:1px solid rgba(200,160,64,.25);
  color:#c8a040;font-family:'IBM Plex Mono',monospace;font-size:9px;
  border-radius:2px;cursor:pointer;white-space:nowrap;
}
#bp-code-btn:hover,#bp-email-btn:hover{background:rgba(200,160,64,.2)}
#bp-code-msg,#bp-email-msg{font-size:9px;min-height:13px;margin-top:4px;color:#3a8a3a}
#bp-hash-row{display:flex;align-items:center;gap:8px}
.bp-hash-lbl{font-size:9px;color:#3a3630}
.bp-hash-val{font-size:8px;color:#3a3630;word-break:break-all}
.bp-tier-badge{font-size:8px;letter-spacing:.1em;padding:2px 5px;border-radius:2px;margin-left:auto}
.bp-tier-badge.free{background:rgba(255,255,255,.04);color:#4a4440;border:1px solid rgba(255,255,255,.06)}
.bp-tier-badge.premium{background:rgba(200,160,64,.12);color:#c8a040;border:1px solid rgba(200,160,64,.3)}
/* Ledger */
#bp-ledger-section{display:flex;flex-direction:column;gap:6px}
#bp-ledger-list{display:flex;flex-direction:column;gap:3px;max-height:160px;overflow-y:auto}
.bp-ledger-empty{font-size:9px;color:#3a3630;font-style:italic;padding:4px 0}
.bp-ledger-row{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;padding:5px 7px;background:rgba(255,255,255,.025);border-radius:2px}
.bp-le-info{display:flex;flex-direction:column;gap:1px;min-width:0}
.bp-le-label{font-size:9px;color:#9a9088}
.bp-le-reason{font-size:8px;color:#4a4440;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}
.bp-le-right{display:flex;flex-direction:column;align-items:flex-end;gap:1px;flex-shrink:0}
.bp-le-amount{font-size:9px;font-weight:600}
.bp-le-amount.pos{color:#3a8a3a}
.bp-le-amount.neg{color:#8a3a3a}
.bp-le-date{font-size:7px;color:#3a3630}

/* ══════════════════════════════
   CREATING PIPELINE OVERLAY
   ══════════════════════════════ */
#creating-overlay{
  position:absolute;inset:0;display:none;
  align-items:center;justify-content:center;
  background:rgba(28,24,22,.82);z-index:50;
  backdrop-filter:blur(6px);pointer-events:none}
.co-inner{display:flex;flex-direction:column;align-items:center;gap:20px}
.co-badge{padding:8px 15px;border-radius:999px;border:1px solid rgba(200,160,64,.24);background:rgba(200,160,64,.08);font-family:'IBM Plex Mono',monospace;font-size:13px;color:#c8a040;letter-spacing:.12em;text-transform:uppercase}
.co-rings{position:relative;width:88px;height:88px}
.co-ring{position:absolute;border-radius:50%;border:1.5px solid transparent;animation:co-spin linear infinite}
.co-r1{inset:0;border-top-color:#c8a040;animation-duration:1.4s}
.co-r2{inset:8px;border-right-color:rgba(200,160,64,.5);animation-duration:2s;animation-direction:reverse}
.co-r3{inset:16px;border-bottom-color:rgba(200,160,64,.25);animation-duration:2.8s}
@keyframes co-spin{to{transform:rotate(360deg)}}
.co-label{font-family:'IBM Plex Mono',monospace;font-size:22px;color:#c8a040;letter-spacing:.09em;text-transform:uppercase;text-align:center;line-height:1.4}
.co-sub{font-family:'IBM Plex Mono',monospace;font-size:16px;color:rgba(216,208,192,.84);letter-spacing:.04em;text-align:center;line-height:1.65;max-width:680px}
.co-timehint{font-family:'IBM Plex Mono',monospace;font-size:14px;color:rgba(216,208,192,.82);line-height:1.75;text-align:center;max-width:660px;padding:10px 14px;border:1px solid rgba(200,160,64,.12);background:rgba(200,160,64,.05);border-radius:4px}
.co-prompt{font-family:'IBM Plex Mono',monospace;font-size:15px;color:rgba(200,160,64,.78);max-width:660px;text-align:center;line-height:1.85}
.co-inner.architect .co-r1{border-top-color:#c85050}
.co-inner.architect .co-r2{border-right-color:rgba(200,80,80,.55)}
.co-inner.architect .co-r3{border-bottom-color:rgba(200,80,80,.28)}
.co-inner.architect .co-badge{border-color:rgba(200,80,80,.28);background:rgba(200,80,80,.08);color:#d87878}

.add-agent-card{position:relative}
.add-agent-card.disabled::after{content:attr(data-disabled-reason);position:absolute;left:8px;right:8px;bottom:-28px;padding:4px 6px;border-radius:3px;background:rgba(8,7,6,.96);border:1px solid rgba(255,255,255,.08);color:#d7d0c6;font-family:'IBM Plex Mono',monospace;font-size:10px;line-height:1.25;opacity:0;transform:translateY(-2px);pointer-events:none;transition:.12s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;z-index:3}
.add-agent-card.disabled:hover::after{opacity:1;transform:translateY(0)}

/* ── RUNTIME AGENT CARDS ── */
.runtime-agent-card{width:190px;z-index:6}
.runtime-agent-card .rt-inner{background:#0d0b09;border:1px solid rgba(200,160,64,.28);border-radius:5px;overflow:hidden;box-shadow:0 0 18px rgba(200,160,64,.08),0 2px 12px rgba(0,0,0,.5)}
.rt-head{display:flex;align-items:center;gap:6px;padding:8px 10px 6px;border-bottom:1px solid rgba(255,255,255,.06)}
.rt-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.rt-name{flex:1;font-family:'IBM Plex Sans',sans-serif;font-size:12px;font-weight:600;color:#cfc7bc;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rt-agid{font-family:'IBM Plex Mono',monospace;font-size:10px;color:#3a3630;letter-spacing:.04em}
.rt-pulse{width:7px;height:7px;border-radius:50%;background:#c8a040;flex-shrink:0;animation:rtpulse 1.2s ease-in-out infinite}
@keyframes rtpulse{0%,100%{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.1)}}
.rt-action{padding:7px 10px 8px;font-family:'IBM Plex Mono',monospace;font-size:11px;color:#8a7a6a;line-height:1.4;min-height:28px;word-break:break-word}
.node.ctx-usage-target .node-inner,.runtime-agent-card.ctx-usage-target .rt-inner{box-shadow:0 0 0 1px rgba(74,122,154,.18),0 0 20px rgba(74,122,154,.1),0 2px 14px rgba(0,0,0,.56)}
.node.ctx-usage-read .node-inner,.runtime-agent-card.ctx-usage-read .rt-inner{animation:ctxreadpulse 1.1s ease-in-out 2}
.node.ctx-usage-write .node-inner,.runtime-agent-card.ctx-usage-write .rt-inner{animation:ctxwritepulse 1.1s ease-in-out 2}
@keyframes ctxreadpulse{0%,100%{box-shadow:0 0 0 1px rgba(74,122,154,.1),0 2px 12px rgba(0,0,0,.5)}50%{box-shadow:0 0 0 1px rgba(74,154,170,.35),0 0 22px rgba(74,154,170,.24),0 2px 14px rgba(0,0,0,.56)}}
@keyframes ctxwritepulse{0%,100%{box-shadow:0 0 0 1px rgba(210,166,78,.12),0 2px 12px rgba(0,0,0,.5)}50%{box-shadow:0 0 0 1px rgba(210,166,78,.45),0 0 24px rgba(210,166,78,.28),0 2px 14px rgba(0,0,0,.56)}}

/* ── IO MODAL ── */
#io-modal{position:fixed;inset:0;z-index:600;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.6);backdrop-filter:blur(6px)}
#io-modal.open{display:flex}
#io-modal-box{background:#131110;border:1px solid rgba(255,255,255,.1);border-radius:6px;width:340px;box-shadow:0 20px 60px rgba(0,0,0,.7);overflow:hidden;font-family:'IBM Plex Mono',monospace}
.iomod-head{display:flex;align-items:center;justify-content:space-between;padding:11px 14px 10px;border-bottom:1px solid rgba(255,255,255,.07)}
.iomod-title-row{display:flex;align-items:center;gap:10px}
.iomod-dir{font-size:14px;font-weight:700;letter-spacing:.14em;text-transform:uppercase}
.iomod-type-badge{font-size:15px;color:#706860}
.iomod-cls{background:transparent;border:none;color:#3a3630;cursor:pointer;font-size:18px;padding:2px 4px;border-radius:2px;transition:.12s;line-height:1}
.iomod-cls:hover{color:#cfc7bc;background:rgba(255,255,255,.05)}
.iomod-body{padding:14px}
.iomod-field{margin-bottom:10px}
.iomod-fl{font-size:13px;color:#706860;letter-spacing:.1em;text-transform:uppercase;margin-bottom:5px}
.iomod-fi{width:100%;background:#0d0b0a;border:1px solid rgba(255,255,255,.08);color:#cfc7bc;font-family:'IBM Plex Mono',monospace;font-size:15px;padding:6px 8px;border-radius:3px;box-sizing:border-box;outline:none;transition:.12s}
.iomod-fi:focus{border-color:rgba(200,160,64,.4);background:#0f0d0b}
.iomod-conn{margin-top:12px;padding:10px 12px;background:#0a0908;border:1px solid rgba(255,255,255,.06);border-radius:4px}
.iomod-conn-lbl{font-size:13px;color:#504840;letter-spacing:.1em;text-transform:uppercase;margin-bottom:7px}
.iomod-conn-src{display:flex;align-items:center;gap:7px;font-size:15px;color:#cfc7bc}
.iomod-conn-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.iomod-conn-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.iomod-conn-arrow{color:#3a3630}
.iomod-conn-type{font-size:14px}
.iomod-conn-desc{font-size:12px;color:#504840;margin-top:5px;line-height:1.4}
.iomod-conn-empty{font-size:13px;color:#3a3630;font-style:italic;padding:8px 0 2px}
