:root{--teal:#2fd5c6;--cyan:#69f2f9;--blue:#09f;--amber:#f0a132;--coral:#ff7a59;--canvas:#07101f;--canvas-2:#0b1a30;--surface:#122036;--line:#1b3142;--bone:#f3f1e7;--muted:#8b99af}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--canvas);color:var(--bone);font-family:Inter,system-ui,sans-serif}.app{flex-direction:column;height:100vh;display:flex}.topbar{background:linear-gradient(180deg, var(--canvas-2), var(--canvas));border-bottom:1px solid var(--line);flex:0 0 62px;align-items:center;gap:18px;height:62px;padding:0 18px;display:flex}.brand{align-items:center;gap:11px;display:flex}.brand .mark{color:#06222a;background:linear-gradient(140deg, var(--cyan), var(--teal));border-radius:11px;place-items:center;width:38px;height:38px;font-family:Fredoka,sans-serif;font-size:22px;font-weight:700;display:grid;box-shadow:0 4px 14px #2fd5c659}.brand-txt{flex-direction:column;line-height:1.12;display:flex}.brand-txt strong{letter-spacing:.2px;font-family:Fredoka,sans-serif;font-size:17px}.brand-txt span{color:var(--teal);letter-spacing:1.5px;text-transform:uppercase;font-size:11px;font-weight:600}.proj{color:var(--bone);align-items:center;gap:9px;font-size:15px;font-weight:600;display:flex}.proj-badge{letter-spacing:1px;text-transform:uppercase;color:var(--cyan);background:#69f2f91a;border:1px solid #69f2f940;border-radius:999px;padding:3px 8px;font-size:10px}.spacer{flex:1}.btn{cursor:pointer;color:#06222a;border:none;border-radius:10px;align-items:center;gap:7px;padding:9px 18px;font-family:inherit;font-size:14px;font-weight:700;transition:transform .1s,filter .15s,opacity .15s;display:inline-flex}.btn span{font-size:12px}.btn:hover:not(:disabled){filter:brightness(1.06);transform:translateY(-1px)}.btn:disabled{opacity:.4;cursor:default}.btn.start{background:linear-gradient(140deg, var(--teal), #1fbfae);box-shadow:0 4px 14px #2fd5c64d}.btn.stop{background:linear-gradient(140deg, var(--coral), #ef5f3c);color:#2a0d05}.btn.ghost{color:var(--muted);border:1px solid var(--line);background:0 0}.btn.ghost:hover:not(:disabled){color:var(--bone)}.workspace{flex:1;min-height:0;display:flex}.pane-label{letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);padding:10px 14px 8px;font-size:11px;font-weight:700}.editor-pane{border-right:1px solid var(--line);flex-direction:column;flex:1;min-width:0;display:flex}.editor-host{flex:1;min-height:0}.pg-pane{background:radial-gradient(120% 80% at 70% 0%, #0c1c34, var(--canvas));flex-direction:column;min-width:0;padding:0 18px 16px;display:flex}.divider{cursor:col-resize;background:var(--canvas-2);border-left:1px solid var(--line);border-right:1px solid var(--line);touch-action:none;flex:0 0 10px;justify-content:center;align-items:center;display:flex;position:relative}.divider:hover{background:#15263f}.divider-grip{background:var(--line);border-radius:3px;width:3px;height:36px;transition:background .15s}.divider:hover .divider-grip{background:var(--cyan)}.pg{border:1px solid var(--line);border-radius:16px;flex:1;min-height:0;position:relative;overflow:hidden}.pg-canvas{width:100%;height:100%;display:block}.pg-fallback{background:var(--canvas-2);place-items:center;padding:24px;display:grid}.pg-fallback-inner{text-align:center;max-width:360px}.pg-fallback-inner strong{color:var(--cyan);margin-bottom:8px;font-family:Fredoka,sans-serif;font-size:17px;display:block}.pg-fallback-inner p{color:var(--muted);font-size:13px;line-height:1.5}.pg-cams{gap:6px;display:flex;position:absolute;top:12px;right:12px}.pg-cams button{cursor:pointer;color:var(--muted);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid var(--line);background:#07101fb3;border-radius:8px;padding:6px 11px;font-family:inherit;font-size:12px;font-weight:700}.pg-cams button.on{color:#06222a;background:var(--cyan);border-color:var(--cyan)}.pg-hud{color:var(--bone);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid var(--line);background:#07101fb8;border-radius:10px;align-items:center;gap:8px;padding:7px 12px;font-size:13px;font-weight:600;display:flex;position:absolute;bottom:12px;left:12px}.pg-hud b{color:var(--cyan);font-variant-numeric:tabular-nums}.pg-hud .dot{background:var(--cyan);width:8px;height:8px;box-shadow:0 0 8px var(--cyan);border-radius:50%}.coach{border:1px solid var(--line);background:var(--surface);border-radius:16px;align-items:center;gap:13px;margin-top:12px;padding:10px 14px 10px 10px;transition:border-color .2s,background .2s;display:flex}.coach-av{object-fit:cover;object-position:50% 18%;background:var(--canvas);border-radius:14px;flex:0 0 54px;width:54px;height:54px;box-shadow:inset 0 0 0 1px #ffffff12}.coach.win .coach-av{animation:.5s pop}@keyframes pop{0%{transform:scale(.7)}60%{transform:scale(1.12)}to{transform:scale(1)}}.bubble{flex-direction:column;gap:2px;display:flex;position:relative}.bubble-tag{letter-spacing:1px;text-transform:uppercase;color:var(--teal);font-family:Fredoka,sans-serif;font-size:11px;font-weight:700}.bubble-text{color:var(--bone);font-size:14px;font-weight:600;line-height:1.25}.coach.run{border-color:var(--blue)}.coach.run .bubble-tag{color:var(--cyan)}.coach.win{border-color:var(--teal);background:#2fd5c61f}.coach.err{border-color:var(--coral)}.coach.err .bubble-tag{color:var(--coral)}@media (width<=1024px){.pg-pane{flex-basis:460px;width:460px}}.blocklyToolboxDiv,.blocklyToolbox{min-width:196px;background:var(--canvas-2)!important;border-right:1px solid var(--line)!important;padding:12px 9px!important}.blocklyToolboxCategoryContainer:first-of-type{--cat:0,153,255;--icon:url(/icons/drivetrain.svg)}.blocklyToolboxCategoryContainer:nth-of-type(2){--cat:255,122,89;--icon:url(/icons/pen.svg)}.blocklyToolboxCategoryContainer:nth-of-type(3){--cat:47,213,198;--icon:url(/icons/sensing.svg)}.blocklyToolboxCategoryContainer:nth-of-type(4){--cat:240,161,50;--icon:url(/icons/control.svg)}.blocklyToolboxCategoryContainer:nth-of-type(5){--cat:108,75,214;--icon:url(/icons/operators.svg)}.blocklyToolboxCategory{align-items:center;transition:background .14s,transform 80ms;position:relative;background:0 0!important;border-left:0!important;border-radius:13px!important;margin:7px 4px!important;padding:8px 12px!important;display:flex!important}.blocklyToolboxCategory:hover{transform:translate(2px);background:rgba(var(--cat,140,150,170),.12)!important}.blocklyTreeSelected .blocklyToolboxCategory,.blocklyToolboxCategoryContainer[aria-selected=true] .blocklyToolboxCategory,.blocklyToolboxSelected{box-shadow:inset 0 0 0 1px rgba(var(--cat,140,150,170),.45);background:rgba(var(--cat,140,150,170),.18)!important}.blocklyToolboxCategoryLabel{letter-spacing:.2px;color:var(--bone)!important;font-family:Fredoka,sans-serif!important;font-size:15px!important;font-weight:600!important}.blocklyTreeSelected .blocklyToolboxCategoryLabel,.blocklyToolboxCategoryContainer[aria-selected=true] .blocklyToolboxCategoryLabel{color:#fff!important}.blocklyToolboxCategoryIcon{background-color:rgb(var(--cat,140,150,170));width:28px;height:28px;box-shadow:0 1px 4px rgba(var(--cat,140,150,170),.4), inset 0 0 0 1px #ffffff38;border-radius:50%;margin-right:12px;transition:transform .12s;position:relative;visibility:visible!important;display:inline-block!important}.blocklyToolboxCategory:hover .blocklyToolboxCategoryIcon,.blocklyTreeSelected .blocklyToolboxCategoryIcon,.blocklyToolboxCategoryContainer[aria-selected=true] .blocklyToolboxCategoryIcon{transform:scale(1.08)}.blocklyToolboxCategoryIcon:before{content:"";-webkit-mask:var(--icon,none) center / 17px 17px no-repeat;-webkit-mask:var(--icon,none) center / 17px 17px no-repeat;mask:var(--icon,none) center / 17px 17px no-repeat;background-color:#fff;position:absolute;inset:0}.blocklyFlyoutBackground{fill:var(--canvas)!important;fill-opacity:.96!important}.editor-wrap{width:100%;height:100%;position:relative}.be-canvas{width:100%;height:100%}.palette-toggle{z-index:6;color:var(--bone);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid var(--line);cursor:pointer;background:#07101fd1;border-radius:9px;padding:6px 11px;font-family:Fredoka,sans-serif;font-size:12px;font-weight:600;transition:color .15s,border-color .15s;position:absolute;top:8px;right:8px}.palette-toggle:hover{color:var(--cyan);border-color:var(--cyan)}.editor-wrap.collapsed .blocklyToolboxDiv,.editor-wrap.collapsed .blocklyFlyout,.editor-wrap.collapsed .blocklyFlyoutScrollbar,.be-canvas.flyout-auto-hidden .blocklyFlyout,.be-canvas.flyout-auto-hidden .blocklyFlyoutScrollbar{display:none!important}
