:root{color:#171a1f;background:#f6f7f2;font-family:Avenir Next,Segoe UI,Helvetica Neue,sans-serif;font-size:15px;line-height:1.45}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:linear-gradient(90deg,rgba(30,63,87,.05) 1px,transparent 1px),linear-gradient(rgba(30,63,87,.04) 1px,transparent 1px),#f6f7f2;background-size:28px 28px}button,input,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.56}body.is-resizing-grid,body.is-resizing-grid *{cursor:col-resize!important;-webkit-user-select:none;user-select:none}.app-shell{width:min(1540px,calc(100vw - 32px));margin:0 auto;padding:24px 0 40px}.topbar{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;padding:10px 2px 20px}.topbar-actions{display:grid;justify-items:end;gap:8px}.view-nav{display:flex;gap:6px}.view-nav a{min-height:30px;padding:6px 10px;border:1px solid #c8cec9;border-radius:999px;background:#fff;color:#30363d;font-size:12px;font-weight:760;text-decoration:none}.view-nav a.active{border-color:#94b6c4;background:#eef7fa;color:#1d4354}.eyebrow{margin:0 0 5px;color:#53615a;font-family:IBM Plex Mono,SFMono-Regular,Consolas,monospace;font-size:12px;font-weight:700;letter-spacing:0;text-transform:uppercase}h1,h2,h3,p{margin:0}h1{font-size:30px;font-weight:760;letter-spacing:0}h2{font-size:17px;font-weight:760;letter-spacing:0}.runtime-strip{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.runtime-pill{display:inline-flex;align-items:center;min-height:30px;padding:6px 10px;border:1px solid #c8cec9;border-radius:999px;background:#fff;color:#30363d;font-family:IBM Plex Mono,SFMono-Regular,Consolas,monospace;font-size:12px}.runtime-pill.ok{border-color:#a6c4ae;background:#eaf5ed;color:#24623b}.runtime-pill.bad{border-color:#e8b3ac;background:#fff0ee;color:#8e3026}.workspace{display:grid;grid-template-columns:minmax(340px,380px) minmax(0,1fr);gap:16px;align-items:start;transition:grid-template-columns .16s ease}.workspace.config-collapsed{grid-template-columns:56px minmax(0,1fr)}.config-panel,.flow-panel,.log-panel,.metrics-panel,.raw-panel,.history-panel,.history-json-panel{border:1px solid #d6dbd7;border-radius:8px;background:#ffffffe6;box-shadow:0 16px 40px #202b3214}.config-panel{position:sticky;top:16px;display:grid;gap:13px;padding:16px;overflow:hidden;transition:padding .16s ease}.flow-panel{display:grid;gap:14px;padding:16px}.panel-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.panel-actions{display:flex;align-items:center;gap:8px}.config-body{display:grid;gap:13px;min-width:0}.workspace.config-collapsed .config-panel{justify-items:center;padding:10px 8px}.workspace.config-collapsed .config-panel h2,.workspace.config-collapsed .config-body,.workspace.config-collapsed #generate-keys{display:none}.workspace.config-collapsed .panel-head{justify-content:center}.log-cap,.report-status{color:#65736b;font-family:IBM Plex Mono,SFMono-Regular,Consolas,monospace;font-size:11px;font-weight:700}label{display:grid;gap:6px;color:#52605a;font-size:13px;font-weight:700}[hidden]{display:none!important}.field-group{display:grid;gap:8px}.assist-panel{display:grid;gap:5px;padding:9px 10px;border:1px solid #d9dfda;border-radius:8px;background:#f6f8f4;color:#52605a}.assist-panel span{font-size:11px;font-weight:760;text-transform:uppercase}.assist-panel code{overflow-wrap:anywhere;white-space:pre-wrap;color:#171a1f;font-family:IBM Plex Mono,SFMono-Regular,Consolas,monospace;font-size:11px;font-weight:650;line-height:1.45}input,textarea{width:100%;border:1px solid #c7cec8;border-radius:8px;background:#fbfcfa;color:#171a1f;outline:none}input{height:38px;padding:0 10px}textarea{min-height:210px;max-height:360px;padding:10px;resize:vertical;font-family:IBM Plex Mono,SFMono-Regular,Consolas,monospace;font-size:12px;line-height:1.45}input:focus,textarea:focus{border-color:#2b6f8f;box-shadow:0 0 0 3px #2b6f8f29}.button-row{display:grid;grid-template-columns:1fr 104px;gap:8px}.primary-button,.secondary-button,.danger-button,.icon-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:38px;border-radius:8px;border:1px solid transparent;font-weight:760}.compact-button{min-height:34px;padding:6px 10px}.primary-button{background:#1f6d55;color:#fff}.secondary-button{border-color:#d4b05c;background:#fff8df;color:#6d5415}.danger-button{border-color:#e0b6ad;background:#fff4f1;color:#8d3122}.icon-button{width:38px;min-width:38px;border-color:#cfd6d1;background:#fff;color:#30363d}.primary-button svg,.secondary-button svg,.danger-button svg,.icon-button svg{width:17px;height:17px}.summary-band{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,.8fr);gap:12px}.summary-band>div{min-width:0;padding:12px;border:1px solid #dce1dd;border-radius:8px;background:#f8faf6}.summary-band strong{display:block;margin-top:4px;overflow-wrap:anywhere;font-family:IBM Plex Mono,SFMono-Regular,Consolas,monospace;font-size:13px;font-weight:650}.metric-label{color:#65736b;font-size:12px;font-weight:760;text-transform:uppercase}.main-grid{display:grid;grid-template-columns:minmax(240px,var(--learning-panel-width, 360px)) 10px minmax(260px,var(--run-log-width, 1.2fr)) 10px minmax(260px,var(--rpc-log-width, 1fr));gap:10px;align-items:stretch}.learning-panel{grid-column:1;display:grid;align-content:start;gap:10px;min-width:0}.grid-resizer{position:relative;align-self:stretch;min-height:360px;border-radius:999px;cursor:col-resize}.grid-resizer:before{content:"";position:absolute;top:12px;right:4px;bottom:12px;left:4px;border-left:1px solid #cfd6d1}.grid-resizer:hover:before,.grid-resizer:focus-visible:before{border-color:#2b6f8f;box-shadow:0 0 0 3px #2b6f8f1f}.resizable-panel{resize:vertical;overflow:auto;min-width:240px;min-height:150px;max-width:100%}.lesson-card.resizable-panel{resize:both}.lesson-card{display:grid;gap:8px;padding:12px;border:1px solid #dce1dd;border-radius:8px;background:#fbfcfa}.active-lesson{border-color:#abc8d3;background:#f0f8fa}.lesson-kicker{color:#65736b;font-family:IBM Plex Mono,SFMono-Regular,Consolas,monospace;font-size:11px;font-weight:760;text-transform:uppercase}.lesson-card h2{font-size:15px}.lesson-card p,.lesson-card dd{color:#4d5a55;font-size:12px;line-height:1.5}.lesson-card code{overflow-wrap:anywhere;color:#1d4354;font-family:IBM Plex Mono,SFMono-Regular,Consolas,monospace;font-size:11px;font-weight:650}.lesson-card dl{display:grid;gap:8px;margin:0}.lesson-card dt{margin-bottom:2px;color:#52605a;font-size:11px;font-weight:760;text-transform:uppercase}.lesson-card dd{margin:0}.stepper{display:grid;align-content:start;gap:7px}.step{display:grid;grid-template-columns:12px minmax(0,1fr) auto;gap:8px;align-items:start;min-height:34px;padding:8px;border:1px solid #dce1dd;border-radius:8px;background:#fff}.step span{width:10px;height:10px;border-radius:50%;background:#a9b2ad}.step p,.step time{min-width:0}.step time{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.step p{font-size:13px;font-weight:700}.step small{display:block;margin-top:3px;color:#647168;font-size:11px;font-weight:560;line-height:1.35}.step time{color:#647168;font-family:IBM Plex Mono,SFMono-Regular,Consolas,monospace;font-size:11px}.step.running{border-color:#79abc0;background:#eef8fb}.step.running span{background:#2b6f8f}.step.success{border-color:#9fc9ac;background:#eff8f1}.step.success span{background:#1f6d55}.step.failed{border-color:#e8b3ac;background:#fff0ee}.step.failed span{background:#b33a2d}.step.skipped{opacity:.62}.log-panel{display:grid;grid-template-rows:auto minmax(360px,1fr);min-width:0;min-height:360px;padding:14px}.run-log-panel{grid-column:3}.rpc-log-panel{grid-column:5}.logs{display:grid;align-content:start;gap:10px;min-height:0;max-height:none;margin-top:12px;overflow:auto;padding-right:4px}.empty-log{padding:34px;border:1px dashed #cfd6d1;border-radius:8px;color:#647168;text-align:center}.log-entry{border:1px solid #dce1dd;border-radius:8px;background:#fff}.log-entry header{display:grid;grid-template-columns:86px minmax(0,1fr);gap:10px;padding:10px 12px}.log-entry span{color:#65736b;font-family:IBM Plex Mono,SFMono-Regular,Consolas,monospace;font-size:12px}.log-entry strong{min-width:0;overflow-wrap:anywhere;font-size:13px}.log-entry pre,.raw-panel pre,.history-json-panel pre{margin:0;overflow:auto;border-top:1px solid #e5e9e6;background:#f8faf6;color:#273039;font-family:IBM Plex Mono,SFMono-Regular,Consolas,monospace;font-size:12px;line-height:1.45;white-space:pre-wrap}.log-entry pre{max-height:240px;padding:10px 12px}.log-entry.success{border-color:#b5d2bd}.log-entry.error{border-color:#efbdb6}.metrics-panel{grid-column:1 / -1;display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));align-content:start;gap:8px;padding:12px}.metric-tile{display:grid;gap:4px;min-height:66px;padding:11px;border:1px solid #dce1dd;border-radius:8px;background:#fbfcfa}.metric-tile span{color:#65736b;font-size:12px;font-weight:760}.metric-tile strong{font-family:IBM Plex Mono,SFMono-Regular,Consolas,monospace;font-size:18px}.raw-panel{padding:14px}.raw-panel pre,.history-json-panel pre{max-height:360px;margin-top:12px;padding:12px;border:1px solid #e1e5e2;border-radius:8px}.history-view{display:grid}.history-panel{display:grid;gap:18px;padding:18px;background:linear-gradient(135deg,rgba(31,109,85,.08),transparent 34%),#ffffffeb}.history-trend-panel{display:grid;gap:12px;padding:14px;border:1px solid #dce1dd;border-radius:8px;background:#fbfcfa}.history-trend{min-width:0;overflow-x:auto}.trend-chart{display:block;width:100%;min-width:640px;height:auto}.trend-grid line{stroke:#e1e7e3;stroke-width:1}.trend-grid text,.trend-labels text{fill:#65736b;font-family:IBM Plex Mono,SFMono-Regular,Consolas,monospace;font-size:11px;font-weight:700}.trend-line{fill:none;stroke:#1f6d55;stroke-linecap:round;stroke-linejoin:round;stroke-width:3}.trend-point circle{fill:#fff;stroke:#4f6d63;stroke-width:3}.trend-point.ok circle{stroke:#1f6d55}.trend-point.bad circle{stroke:#b33a2d}.trend-legend{display:flex;flex-wrap:wrap;gap:10px 16px;color:#65736b;font-size:12px;font-weight:700}.trend-legend span{display:inline-flex;align-items:center;gap:6px}.legend-dot{width:9px;height:9px;border-radius:999px;background:#4f6d63}.legend-dot.ok{background:#1f6d55}.legend-dot.bad{background:#b33a2d}.history-grid{display:grid;grid-template-columns:minmax(300px,.45fr) minmax(0,1fr);gap:18px;align-items:start}.history-list{display:grid;align-content:start;gap:10px}.history-item{display:grid;gap:8px;width:100%;padding:14px;border:1px solid #dce1dd;border-radius:8px;background:linear-gradient(180deg,#fff,#f7faf7);color:#171a1f;text-align:left;transition:border-color .14s ease,box-shadow .14s ease,transform .14s ease}.history-item.active,.history-item:hover{border-color:#79a7b7;background:#f3fbfc;box-shadow:0 12px 24px #1f43541a;transform:translateY(-1px)}.history-item-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.history-item strong{font-size:15px}.history-duration{color:#1d4354;font-family:IBM Plex Mono,SFMono-Regular,Consolas,monospace;font-size:24px;font-weight:760;line-height:1}.history-meta-line,.history-item code{overflow-wrap:anywhere;color:#65736b;font-size:12px}.history-json-panel{display:grid;gap:14px;min-width:0;padding:16px}.history-json-panel pre{max-height:320px}.status-badge{display:inline-flex;align-items:center;min-height:24px;padding:4px 8px;border:1px solid #c8cec9;border-radius:999px;background:#fff;color:#4f5c56;font-family:IBM Plex Mono,SFMono-Regular,Consolas,monospace;font-size:10px;font-weight:760;text-transform:uppercase;white-space:nowrap}.history-item-top .status-badge,.history-title-block .status-badge{flex:none}.history-title-block .status-badge{justify-self:start}.status-badge.ok{border-color:#9fc9ac;background:#eff8f1;color:#1f6d55}.status-badge.bad{border-color:#efbdb6;background:#fff0ee;color:#9b342a}.history-summary{display:grid;gap:14px}.history-overview,.duration-board{display:grid;gap:14px;padding:14px;border:1px solid #dce1dd;border-radius:8px;background:#fbfcfa}.history-title-block{display:grid;gap:7px}.history-title-block h3{font-size:22px;font-weight:760}.history-title-block code{overflow-wrap:anywhere;color:#65736b;font-family:IBM Plex Mono,SFMono-Regular,Consolas,monospace;font-size:12px}.history-stat-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.history-stat-grid div{display:grid;gap:4px;min-height:74px;padding:10px;border:1px solid #e1e5e2;border-radius:8px;background:#fff}.history-stat-grid span,.duration-board-head span,.duration-row-main span{color:#65736b;font-size:12px;font-weight:700}.history-stat-grid strong{align-self:end;color:#1d4354;font-family:IBM Plex Mono,SFMono-Regular,Consolas,monospace;font-size:18px}.history-error{padding:10px 12px;border:1px solid #efbdb6;border-radius:8px;background:#fff0ee;color:#8e3026;font-size:13px;font-weight:700}.duration-board-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px}.duration-board-head h3{font-size:16px}.duration-list{display:grid;gap:8px}.duration-row{display:grid;grid-template-columns:minmax(160px,.9fr) minmax(180px,1fr) 76px;align-items:center;gap:12px;padding:10px;border:1px solid #e5e9e6;border-radius:8px;background:#fff}.duration-row.failed{border-color:#efbdb6}.duration-row-main{display:grid;gap:2px;min-width:0}.duration-row-main strong,.duration-row-main span{overflow-wrap:anywhere}.duration-track{height:10px;overflow:hidden;border-radius:999px;background:#e6ebe8}.duration-track span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#2b6f8f,#1f6d55)}.duration-row.failed .duration-track span{background:linear-gradient(90deg,#b33a2d,#d67545)}.duration-row time{color:#1d4354;font-family:IBM Plex Mono,SFMono-Regular,Consolas,monospace;font-size:13px;font-weight:760;text-align:right}@media(max-width:1180px){.workspace,.main-grid,.summary-band,.history-grid{grid-template-columns:1fr}.learning-panel,.run-log-panel,.rpc-log-panel,.metrics-panel{grid-column:auto}.grid-resizer{display:none}.workspace.config-collapsed{grid-template-columns:56px minmax(0,1fr)}.config-panel{position:static}.metrics-panel{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:720px){.app-shell{width:min(100vw - 20px,1540px);padding-top:14px}.topbar{align-items:flex-start;flex-direction:column}h1{font-size:24px}.button-row,.metrics-panel,.history-stat-grid,.duration-row{grid-template-columns:1fr}.duration-row time{text-align:left}.step{grid-template-columns:12px minmax(0,1fr)}.step time{grid-column:2}.log-entry header{grid-template-columns:1fr}}
