@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";.custom-tooltip{position:fixed;background-color:#2d3748;color:#f7fafc;padding:8px 12px;border-radius:8px;font-size:13px;font-weight:500;z-index:1000;opacity:0;visibility:hidden;transform:translateY(10px) translate(-50%);transition:opacity .2s ease,transform .2s ease,visibility .2s;pointer-events:none;white-space:nowrap;box-shadow:0 4px 12px #0003}.custom-tooltip.visible{opacity:1;visibility:visible;transform:translateY(0) translate(-50%)}:root{--toolbar-gradient-start: var(--surface-1);--toolbar-gradient-end: var(--surface-1);--capsule-bg-color: color-mix(in srgb, var(--primary-500) 6%, var(--bg-0));--capsule-border-color: color-mix(in srgb, var(--primary-500) 18%, transparent);--capsule-divider-glow: color-mix(in srgb, var(--primary-500) 30%, transparent);--toolbar-icon-color: var(--text);--button-hover-glow: var(--focus-ring);--toolbar-shadow-color: color-mix(in srgb, var(--text) 12%, transparent)}.toolbar{display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;height:72px;background:var(--toolbar-bg);box-shadow:var(--shadow-1);border-bottom-left-radius:0;border-bottom-right-radius:0;position:relative;overflow:hidden;z-index:10}.toolbar .toolbar-alive-canvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:1}.toolbar>.toolbar-left,.toolbar>.toolbar-control-capsule{position:relative;z-index:2}.toolbar:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.quantum-bg{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1;overflow:hidden}.quantum-bg{display:none!important}.wave-layer{position:absolute;top:0;left:0;width:100%;height:100%}.wave-layer{display:none!important}.wave{position:absolute;width:250%;height:100%;background:linear-gradient(90deg,transparent 0%,var(--primary-a04) 20%,var(--primary-a08) 40%,var(--primary-a12) 50%,var(--primary-a08) 60%,var(--primary-a04) 80%,transparent 100%);animation:waveFlow 15s infinite ease-in-out}.wave{display:none!important}.path-1{animation-delay:0s;stroke:var(--primary-500);stroke-opacity:.6}.path-2{animation-delay:-5s;stroke-width:1.3;stroke:var(--primary-600);stroke-opacity:.5}.wave-3{top:65%;animation-delay:-10s;height:35%;background:linear-gradient(90deg,transparent 0%,var(--primary-a04) 20%,var(--primary-a08) 40%,var(--primary-a12) 50%,var(--primary-a08) 60%,var(--primary-a04) 80%,transparent 100%)}@keyframes waveFlow{0%{transform:translate(-50%)}25%{transform:translate(-25%)}50%{transform:translate(0)}75%{transform:translate(25%)}to{transform:translate(50%)}}.particle-system{position:absolute;top:0;left:0;width:100%;height:100%}.particle-system{display:none!important}.particle{position:absolute;color:var(--primary-a30);font-size:10px;font-weight:700;animation:particleFloat 20s infinite ease-in-out;text-shadow:0 0 3px var(--primary-a30);z-index:2}.particle-1{top:12%;left:8%;animation-delay:0s;animation-duration:24s}.particle-2{top:35%;left:22%;animation-delay:-2.3s;animation-duration:28s;color:color-mix(in srgb,var(--text) 30%,transparent)}.particle-3{top:18%;left:42%;animation-delay:-4.7s;animation-duration:26s}.particle-4{top:55%;left:15%;animation-delay:-1.8s;animation-duration:30s;color:var(--primary-a30)}.particle-5{top:28%;left:68%;animation-delay:-3.9s;animation-duration:25s}.particle-6{top:45%;left:35%;animation-delay:-6.1s;animation-duration:29s;color:var(--primary-a30)}.particle-7{top:8%;left:75%;animation-delay:-.7s;animation-duration:27s}.particle-8{top:62%;left:55%;animation-delay:-5.4s;animation-duration:23s;color:color-mix(in srgb,var(--text) 25%,transparent)}.particle-9{top:38%;left:88%;animation-delay:-2.9s;animation-duration:31s}.particle-10{top:22%;left:95%;animation-delay:-4.2s;animation-duration:22s;color:var(--primary-a30)}.particle-11{top:58%;left:3%;animation-delay:-1.1s;animation-duration:32s}.particle-12{top:15%;left:58%;animation-delay:-3.6s;animation-duration:24s;color:var(--primary-a30)}.particle-13{top:48%;left:78%;animation-delay:-5.8s;animation-duration:28s}.particle-14{top:32%;left:28%;animation-delay:-.4s;animation-duration:26s;color:color-mix(in srgb,var(--text) 20%,transparent)}.particle-15{top:68%;left:48%;animation-delay:-4.9s;animation-duration:30s}.particle-16{top:25%;left:12%;animation-delay:-2.1s;animation-duration:26s;color:var(--primary-a30)}.particle-17{top:42%;left:82%;animation-delay:-3.2s;animation-duration:29s}.particle-18{top:5%;left:45%;animation-delay:-1.4s;animation-duration:25s;color:color-mix(in srgb,var(--text) 30%,transparent)}.particle-19{top:72%;left:25%;animation-delay:-4.5s;animation-duration:31s;color:var(--primary-a30)}.particle-20{top:50%;left:65%;animation-delay:-.9s;animation-duration:27s}@keyframes particleFloat{0%,to{transform:translateY(0) rotate(0) scale(.8);opacity:.2}25%{transform:translateY(-10px) rotate(90deg) scale(1.1);opacity:.5}50%{transform:translateY(-5px) rotate(180deg) scale(.9);opacity:.3}75%{transform:translateY(-12px) rotate(270deg) scale(1.15);opacity:.6}}.data-streams{position:absolute;top:0;left:0;width:100%;height:100%}.stream{position:absolute;display:flex;align-items:center;gap:8px;opacity:0;animation:streamFlow 25s infinite ease-in-out}.nodal-network{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:3;overflow:visible}.wandering-node{position:absolute;font-size:16px;color:var(--primary-500);text-shadow:0 0 8px var(--primary-a30);filter:drop-shadow(0 0 6px var(--primary-a30));transition:opacity .3s ease;will-change:transform,opacity;pointer-events:none}.connection-canvas{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:2}.connection-canvas line{stroke-linecap:round;will-change:stroke-opacity}@keyframes connectionFade{0%,to{opacity:0}50%{opacity:.6}}.circuit-overlay{position:absolute;top:0;left:0;width:100%;height:100%}.circuit-overlay{display:none!important}.circuit-path{fill:none;stroke:#4a90e266;stroke-width:1.5;stroke-linecap:round;filter:drop-shadow(0 0 2px rgba(74,144,226,.3));animation:circuitFlow 10s infinite ease-in-out}.connection-node{fill:#4a90e2b3;filter:drop-shadow(0 0 3px rgba(74,144,226,.5));animation:nodePulse 5s infinite ease-in-out}.node-intersection{fill:#ffffffe6;filter:drop-shadow(0 0 6px rgba(74,144,226,.8));animation:intersectionPulse 3s infinite ease-in-out}@keyframes circuitFlow{0%,to{opacity:.3;stroke-width:1}50%{opacity:.8;stroke-width:1.8}}@keyframes intersectionPulse{0%,to{r:4;fill-opacity:.9}50%{r:6;fill-opacity:.6}}.quantum-bg *,.particle-system *,.data-streams *,.circuit-overlay *{will-change:transform,opacity;backface-visibility:hidden}.quantum-bg:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background-image:radial-gradient(circle at 25% 25%,rgba(74,144,226,.015) 1px,transparent 1px),radial-gradient(circle at 75% 75%,rgba(255,255,255,.008) 1px,transparent 1px),radial-gradient(circle at 50% 50%,rgba(0,91,154,.012) 1px,transparent 1px);background-size:50px 50px,70px 70px,90px 90px;background-position:0 0,25px 25px,50px 50px;animation:patternShift 25s infinite linear;pointer-events:none;opacity:.6}@keyframes patternShift{0%{background-position:0 0,25px 25px,50px 50px}to{background-position:50px 50px,75px 75px,100px 100px}}@keyframes cyberFlow1{0%{background-position:0% 0%,0% 0%,0% 0%,0% 0%,0% 0%,0% 0%,0% 0%,0% 0%}to{background-position:200% 200%,200% 200%,300% 100%,300% 100%,100% 400%,50px 50px,50px 50px,50px 50px}}@keyframes cyberFlow2{0%{background-position:0% 0%,0% 0%,0% 0%,0% 0%,0% 0%,0% 0%,0% 0%,0% 0%}to{background-position:-200% -200%,-200% -200%,-300% -100%,-300% -100%,-100% -400%,-50px -50px,-50px -50px,-50px -50px}}@keyframes cyberFlow3{0%{background-position:0% 0%,0% 0%,0% 0%,0% 0%,0% 0%,0% 0%,0% 0%,0% 0%}to{background-position:400% 0%,400% 0%,600% 0%,600% 0%,200% 0%,100px 0px,100px 0px,100px 0px}}@keyframes cyberFlow4{0%{background-position:0% 0%,0% 0%,0% 0%,0% 0%,0% 0%,0% 0%,0% 0%,0% 0%}to{background-position:-400% 0%,-400% 0%,-600% 0%,-600% 0%,-200% 0%,-100px 0px,-100px 0px,-100px 0px}}@keyframes cyberFlow5{0%{background-position:0% 0%,0% 0%,0% 0%,0% 0%,0% 0%,0% 0%,0% 0%,0% 0%}to{background-position:0% 800%,0% 800%,0% 800%,0% 800%,0% 800%,0% 800%,0% 800%,0% 800%}}@keyframes cyberDots{0%,to{opacity:.3}50%{opacity:.8}}.toolbar-left{display:flex;align-items:center}.toolbar-logo-full{height:58px;object-fit:contain;transition:transform .4s cubic-bezier(.25,.46,.45,.94)}.toolbar-logo-full:hover{transform:scale(1.03)}.toolbar-control-capsule{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;background-color:var(--capsule-bg-color);border:1px solid var(--capsule-border-color);border-radius:50px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 4px 12px #0003;transition:transform .3s ease,box-shadow .3s ease}.toolbar-control-capsule:hover{transform:translateY(-3px);box-shadow:0 8px 20px #0000004d}.toolbar-logo-short{height:36px;object-fit:contain;margin-right:.25rem}.capsule-divider{width:1.5px;height:28px;background-color:var(--capsule-divider-glow);border-radius:1px}.capsule-button-group{display:flex;align-items:center;gap:.5rem}.toolbar button,.toolbar .load-label{background-color:transparent;border:none;border-radius:50%;width:40px;height:40px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--toolbar-icon-color);transition:all .2s ease-in-out;position:relative}.toolbar button svg,.toolbar .load-label svg{width:22px;height:22px}.toolbar button,.toolbar .load-label{all:unset;display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;cursor:pointer;color:var(--toolbar-icon-color);background-color:transparent;transition:background-color .2s ease-in-out,box-shadow .2s ease-in-out,transform .15s ease-in-out;position:relative;box-sizing:border-box}.toolbar button:hover,.toolbar .load-label:hover{background-color:#ffffff26;box-shadow:0 0 12px 2px var(--button-hover-glow)}.toolbar button:active,.toolbar .load-label:active{transform:scale(.95);background-color:#fff3}.toolbar button svg,.toolbar .load-label svg{width:22px;height:22px;pointer-events:none}[data-theme=light] .toolbar .capsule-button-group button,[data-theme=light] .toolbar .capsule-button-group .load-label{background-color:var(--primary-500);color:var(--text-white)}[data-theme=light] .toolbar .capsule-button-group button:hover,[data-theme=light] .toolbar .capsule-button-group .load-label:hover,[data-theme=light] .toolbar .capsule-button-group button:active,[data-theme=light] .toolbar .capsule-button-group .load-label:active{background-color:var(--accent-500);color:var(--text)}[data-theme=dark] .toolbar .capsule-button-group button,[data-theme=dark] .toolbar .capsule-button-group .load-label{background-color:var(--accent-500);color:var(--text-dark)}[data-theme=dark] .toolbar .capsule-button-group button:hover,[data-theme=dark] .toolbar .capsule-button-group .load-label:hover,[data-theme=dark] .toolbar .capsule-button-group button:active,[data-theme=dark] .toolbar .capsule-button-group .load-label:active{background-color:var(--primary-600);color:var(--text-white)}[data-theme=light] .toolbar-logo-full,[data-theme=light] .toolbar-logo-short{filter:invert(1) brightness(.1) saturate(0)}[data-theme=dark] .toolbar-logo-full,[data-theme=dark] .toolbar-logo-short{filter:none}:root{--panel-header-bg: var(--surface-1);--panel-body-bg: var(--editor-bg);--panel-border-color: var(--editor-gutter);--panel-glow: var(--primary-a12);--panel-text-light: var(--text);--action-pod-bg: color-mix(in srgb, var(--primary-500) 8%, transparent);--action-pod-border: var(--primary-a30);--success-color: var(--success);--codepanel-header-bg: color-mix(in srgb, var(--accent-500) 18%, var(--panel-header-bg))}[data-theme=dark]{--codepanel-header-bg: color-mix(in srgb, var(--primary-600) 24%, var(--panel-header-bg))}.code-panel{position:absolute;top:16px;right:16px;width:420px;background-color:var(--panel-body-bg);border:1px solid var(--panel-border-color);border-radius:16px;box-shadow:var(--shadow-1);z-index:40;display:flex;flex-direction:column;max-height:calc(100vh - 110px);transition:transform .4s cubic-bezier(.23,1,.32,1),opacity .4s ease;transform:translate(0);opacity:1;overflow:hidden;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.code-panel.collapsed{transform:translate(calc(100% + 32px));opacity:0;pointer-events:none}.code-panel-header{display:flex;justify-content:space-between;align-items:center;padding:10px 10px 10px 20px;background:var(--codepanel-header-bg);position:relative;z-index:2;border-bottom:1px solid var(--panel-border-color);overflow:hidden}.code-panel-header:before{content:"";position:absolute;top:0;left:-50%;width:200%;height:100%;background-image:linear-gradient(110deg,transparent 20%,var(--primary-a08) 45%,var(--primary-a08) 55%,transparent 80%);transform:translate(-100%);animation:shimmer 5s infinite linear}@keyframes shimmer{to{transform:translate(100%)}}.header-icon-container{flex-shrink:0}.code-panel-action-pod{display:flex;gap:8px;padding:6px;background-color:var(--action-pod-bg);border:1px solid var(--action-pod-border);border-radius:50px;transition:transform .3s ease,box-shadow .3s ease}.code-panel-action-pod button{background-color:transparent;border:none;border-radius:10px;width:36px;height:36px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--panel-text-light);transition:transform .18s cubic-bezier(.2,.9,.2,1),box-shadow .18s cubic-bezier(.2,.9,.2,1),background-color .16s linear,color .12s linear;will-change:transform,box-shadow}[data-theme=light] .code-panel-action-pod button{background-color:var(--primary-500);color:var(--text-white)}[data-theme=light] .code-panel-action-pod button:hover,[data-theme=light] .code-panel-action-pod button:active{transform:translateY(-2px) scale(1.04);background-color:var(--accent-500);color:var(--text);box-shadow:var(--shadow-1)}[data-theme=dark] .code-panel-action-pod button{background-color:var(--accent-500);color:var(--text-dark)}[data-theme=dark] .code-panel-action-pod button:hover,[data-theme=dark] .code-panel-action-pod button:active{transform:translateY(-2px) scale(1.04);background-color:var(--primary-600);color:var(--text-white);box-shadow:var(--shadow-1)}.code-panel-action-pod button:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.code-panel-action-pod button:disabled:hover{transform:none!important;background-color:transparent!important;box-shadow:none!important}.code-panel-action-pod button:active{transform:translateY(0) scale(.98);background-color:var(--primary-a16);box-shadow:inset 0 0 0 1px var(--action-pod-border)}.code-panel-action-pod button:focus-visible{outline:2px solid var(--primary-500);outline-offset:3px;border-radius:10px}@media(prefers-reduced-motion:reduce){.code-panel-action-pod button,.code-panel-action-pod button:hover,.code-panel-action-pod button:active{transition:none!important;transform:none!important}}.code-content-wrapper{flex-grow:1;overflow:auto;position:relative;z-index:1;background:var(--panel-body-bg);border-top:1px solid var(--panel-border-color)}.code-editor{background:transparent!important;color:var(--panel-text-light);white-space:pre-wrap!important;word-wrap:break-word!important;font-family:var(--font-mono)!important;font-size:14px!important}.code-editor textarea:focus{outline:none}.token.comment,.token.prolog,.token.doctype,.token.cdata{color:var(--syntax-comment)}.token.punctuation{color:var(--syntax-punctuation)}.token.property,.token.tag,.token.constant,.token.symbol,.token.deleted{color:var(--syntax-tag)}.token.boolean,.token.number{color:var(--syntax-number)}.token.selector,.token.attr-name,.token.string,.token.char,.token.builtin,.token.inserted{color:var(--syntax-string)}.token.operator,.token.entity,.token.url,.language-css .token.string,.style .token.string{color:var(--syntax-operator)}.token.atrule,.token.attr-value,.token.keyword{color:var(--syntax-keyword)}.token.function,.token.class-name{color:var(--syntax-function)}.token.regex,.token.important,.token.variable{color:var(--syntax-variable)}.code-content-wrapper::-webkit-scrollbar{width:8px}.code-content-wrapper::-webkit-scrollbar-track{background:transparent}.code-content-wrapper::-webkit-scrollbar-thumb{background-color:var(--action-pod-border);border-radius:10px}.code-content-wrapper::-webkit-scrollbar-thumb:hover{background-color:var(--primary-500)}.toast-notification{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background-color:var(--success-color);color:#0d1117;padding:12px 24px;border-radius:50px;font-weight:600;box-shadow:var(--shadow-1);z-index:1000;opacity:0;animation:fadeInOutToast 2s ease-in-out forwards}@keyframes fadeInOutToast{0%{opacity:0;transform:translate(-50%,20px)}20%{opacity:1;transform:translate(-50%)}80%{opacity:1;transform:translate(-50%)}to{opacity:0;transform:translate(-50%,20px)}}.code-empty-state{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);font-weight:500}:root{--python-blue: var(--primary-500);--python-dark-blue: var(--primary-600);--python-yellow: var(--accent-500);--python-dark-yellow: var(--accent-600);--energy-blue: var(--primary-500);--energy-purple: color-mix(in srgb, var(--primary-500) 40%, var(--accent-500));--energy-pink: var(--accent-500);--icon-size: 32px;--charging-duration: 4s}.alive-python-icon{width:var(--icon-size);height:var(--icon-size);position:relative;display:flex;justify-content:center;align-items:center;animation:charge-up var(--charging-duration) infinite ease-in-out}.python-svg{width:100%;height:100%;filter:drop-shadow(0 0 8px var(--primary-a30));animation:svg-pulse var(--charging-duration) infinite ease-in-out,svg-rotate 20s infinite linear;transform-origin:center}@keyframes charge-up{0%,to{transform:scale(1);filter:drop-shadow(0 0 8px var(--primary-a30))}25%{transform:scale(1.1);filter:drop-shadow(0 0 16px var(--primary-a30))}50%{transform:scale(1.05);filter:drop-shadow(0 0 24px var(--accent-a15))}75%{transform:scale(1.15);filter:drop-shadow(0 0 32px var(--accent-a15))}}@keyframes svg-pulse{0%,to{filter:brightness(1) contrast(1) saturate(1)}25%{filter:brightness(1.2) contrast(1.1) saturate(1.3)}50%{filter:brightness(1.4) contrast(1.2) saturate(1.5)}75%{filter:brightness(1.6) contrast(1.3) saturate(1.8)}}@keyframes svg-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}:root{--font-sans: "Inter", "Nunito Sans", sans-serif;--font-mono: "Roboto Mono", monospace;--bg-toolbox: var(--toolbox-bg);--bg-toolbar: var(--toolbar-bg);--bg-panel: var(--panel-bg);--bg-panel-hover: var(--primary-a12);--border-radius-main: 12px;--box-shadow-main: var(--shadow-1);--box-shadow-pulse: 0 0 0 4px var(--focus-ring)}body,html{margin:0;font-family:var(--font-sans);height:100vh;overflow:hidden;background-color:var(--workspace-bg);color:var(--text)}a{color:var(--accent-600);text-decoration-color:color-mix(in srgb,var(--accent-600) 40%,transparent)}a:hover{color:var(--accent-500);text-decoration:underline}.header-bar{display:flex;justify-content:space-between;align-items:center;background:var(--toolbar-bg);padding:10px 24px;border-bottom:2px solid var(--toolbar-border);box-shadow:var(--shadow-1);z-index:10;gap:16px}.header-bar:after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;background:var(--accent-500)}.logo-container{display:flex;align-items:center;gap:12px}.logo{height:32px;width:auto}.app-title{margin:0;font-size:20px;font-weight:700;color:var(--toolbar-text)}.toolbar{display:flex;align-items:center;gap:10px}.toolbar button,.toolbar .load-label{display:flex;align-items:center;justify-content:center;background:transparent;color:var(--toolbar-text);border:none;padding:8px;font-size:22px;border-radius:var(--border-radius-main);cursor:pointer;transition:all .25s ease-out;width:48px;height:48px}[data-theme=light] .toolbar button,[data-theme=light] .toolbar .load-label{background-color:var(--primary-500);color:var(--text-white)}[data-theme=light] .toolbar button:hover,[data-theme=light] .toolbar .load-label:hover{background-color:var(--primary-600);transform:scale(1.05);box-shadow:var(--shadow-1)}[data-theme=dark] .toolbar button,[data-theme=dark] .toolbar .load-label{background-color:var(--accent-500);color:var(--text)}[data-theme=dark] .toolbar button:hover,[data-theme=dark] .toolbar .load-label:hover{filter:brightness(1.05);transform:scale(1.05);box-shadow:var(--shadow-1)}.main-layout{display:flex;height:calc(100vh - 65px);overflow:hidden;width:100%}.blockly-container{flex-grow:1;height:100%;position:relative}.blocklyToolboxDiv{background-color:var(--muted-1)!important;padding:4px 0!important;width:0!important;opacity:0!important;overflow:hidden!important;transition:width .4s cubic-bezier(.25,.1,.25,1),opacity .3s ease-in-out;white-space:nowrap;will-change:width,opacity}.main-layout.toolbox-visible .blocklyToolboxDiv{width:250px!important;opacity:1!important;padding:4px!important}.blocklyTreeRow{padding:10px 16px!important;border-radius:8px!important;margin:6px 10px!important;font-weight:500;color:var(--text)!important;transition:all .2s ease;border-left:4px solid transparent!important}.blocklyTreeRow:hover{background-color:var(--primary-a08)!important;transform:translate(4px)}.blocklyTreeSelected{background-color:var(--primary-500)!important;color:var(--text-white)!important;font-weight:700!important;border-left:4px solid var(--accent-500)!important}.blocklyTreeLabel{font-family:var(--font-sans)}.blocklyToolboxDiv .blocklyTreeSeparator{height:1px;border-bottom:1px solid var(--bg-panel-hover);margin:8px 16px!important}.floating-code-panel{position:absolute;top:16px;right:16px;width:400px;background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:var(--border-radius-main);box-shadow:var(--box-shadow-main);z-index:50;display:flex;flex-direction:column;overflow:hidden;max-height:calc(100% - 32px);transition:transform .4s cubic-bezier(.23,1,.32,1),opacity .4s ease;transform:translate(0);opacity:1}.floating-code-panel.collapsed{transform:translate(calc(100% + 32px));opacity:0;pointer-events:none}.code-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--panel-border);position:relative}.code-header:before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:var(--accent-500)}[data-theme=light] .code-header{background:color-mix(in srgb,var(--accent-500) 10%,var(--surface-1))}[data-theme=dark] .code-header{background:color-mix(in srgb,var(--primary-500) 10%,var(--surface-1))}.code-header h3{margin:0;font-size:16px;font-weight:600;color:var(--text)}.code-header-actions{display:flex;align-items:center;gap:8px}.code-download-btn{background:var(--primary-500);color:var(--text-white);border:none;border-radius:8px;padding:8px 12px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.code-download-btn:hover{background:var(--primary-600);transform:scale(1.05);box-shadow:var(--shadow-1)}[data-theme=dark] .code-download-btn{background:var(--accent-500);color:var(--text)}[data-theme=dark] .code-download-btn:hover{filter:brightness(1.05)}.collapse-btn{background:transparent;border:none;font-size:20px;cursor:pointer;color:var(--text-mid);padding:4px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.collapse-btn:hover{background-color:var(--primary-a08);color:var(--text)}pre#pythonCode{padding:16px;margin:0;font-size:14px;font-family:var(--font-mono);background:var(--editor-bg);color:var(--text);height:100%;overflow:auto;white-space:pre-wrap}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--primary-a04)}::-webkit-scrollbar-thumb{background:var(--primary-500);border-radius:10px;border:2px solid transparent;background-clip:content-box}::-webkit-scrollbar-thumb:hover{background:var(--primary-600)}.backpack-flyout{top:auto!important;bottom:20px!important;left:270px!important}.code-execution-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000}.code-execution-modal{background-color:var(--surface-1);color:var(--text);border:1px solid var(--panel-border);border-radius:12px;width:90%;max-width:800px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-1)}.code-execution-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--panel-border);background:var(--surface-1);position:relative}.code-execution-modal-header:before{content:"";position:absolute;left:0;right:0;top:0;height:4px;background:var(--accent-500)}[data-theme=light] .code-execution-modal-header{background:color-mix(in srgb,var(--accent-500) 10%,var(--surface-1))}[data-theme=dark] .code-execution-modal-header{background:color-mix(in srgb,var(--primary-500) 10%,var(--surface-1))}.code-execution-modal-header h2{margin:0;color:var(--text);font-size:1.25rem;font-weight:600}.close-button{background:none;border:none;color:var(--muted-text);cursor:pointer;padding:8px;border-radius:6px;transition:all .2s ease}.close-button:hover{color:var(--text);background-color:var(--primary-a08)}.code-execution-modal-body{flex:1;padding:24px;overflow-y:auto;color:var(--text);font-family:var(--font-mono);font-size:14px;line-height:1.5}.execution-loading{display:flex;flex-direction:column;align-items:center;gap:16px;color:var(--muted-text)}.spinner{width:40px;height:40px;border:3px solid var(--panel-border);border-top:3px solid var(--primary-500);border-radius:50%;animation:spin 1s linear infinite}.execution-error{background-color:color-mix(in srgb,var(--danger) 10%,transparent);border:1px solid var(--danger);border-radius:8px;padding:16px}.execution-error h3{margin:0 0 12px;color:var(--danger)}.execution-error pre{margin:0;color:color-mix(in srgb,var(--danger) 75%,var(--bg-0));white-space:pre-wrap;font-family:var(--font-mono)}.server-status-note{margin-top:12px;padding:8px;background-color:var(--primary-a08);border-radius:4px;color:var(--muted-text);font-style:italic}.execution-output img{max-width:100%;height:auto;border-radius:8px;margin:16px 0;box-shadow:var(--shadow-1)}.execution-output .output-file-container{margin:20px 0;padding:16px;background:color-mix(in srgb,var(--info) 10%,transparent);border:1px solid color-mix(in srgb,var(--info) 45%,transparent);border-radius:12px;position:relative}.execution-output .output-file-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid color-mix(in srgb,var(--info) 30%,transparent)}.execution-output .output-file-title{font-weight:600;color:var(--info);font-size:14px;display:flex;align-items:center;gap:8px}.execution-output .output-file-title:before{content:"📊";font-size:16px}.execution-output .output-file-image{max-width:100%;height:auto;border-radius:8px;box-shadow:var(--shadow-1);transition:transform .2s ease}.execution-output .output-file-image:hover{transform:scale(1.02)}.execution-output .output-file-note{margin-top:12px;padding:8px 12px;background:var(--primary-a04);border-radius:6px;font-size:13px;color:var(--muted-text);border-left:3px solid var(--info)}.execution-output .download-button{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:linear-gradient(135deg,var(--primary-500),var(--accent-500));color:var(--text-white);text-decoration:none;border-radius:6px;font-size:12px;font-weight:500;transition:all .2s ease;border:none;cursor:pointer}.execution-output .download-button:hover{filter:brightness(1.05);transform:translateY(-1px);box-shadow:var(--shadow-1)}.execution-output .download-button:active{transform:translateY(0)}.output-file-error{margin-top:10px}.output-file-note{background-color:color-mix(in srgb,var(--accent-500) 18%,var(--bg-0));border:1px solid color-mix(in srgb,var(--accent-500) 35%,transparent);border-left:4px solid var(--accent-600);border-radius:4px;padding:12px;margin:8px 0;font-size:14px;line-height:1.4;color:var(--text)}.output-file-note strong{color:var(--text);font-weight:600}.output-image-loading{opacity:.6;position:relative}.output-image-loading:after{content:"";position:absolute;top:50%;left:50%;width:20px;height:20px;margin:-10px 0 0 -10px;border:2px solid var(--primary-500);border-top:2px solid transparent;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.input-form{display:flex;flex-direction:column;gap:12px}.input-field{width:100%;padding:10px 12px;border-radius:8px;border:1px solid var(--panel-border);background-color:var(--surface-1);color:var(--text);font-family:var(--font-mono)}.input-field:focus{outline:none;box-shadow:0 0 0 3px var(--focus-ring)}.input-actions{display:flex;justify-content:flex-end;gap:10px}.btn-primary,.btn-secondary{padding:10px 14px;border-radius:8px;border:1px solid transparent;cursor:pointer}.btn-primary{background-color:var(--primary-500);color:var(--text-white);border-color:var(--primary-500)}.btn-primary:hover{background-color:var(--primary-600)}.btn-primary:disabled,.btn-secondary:disabled{opacity:.7;cursor:not-allowed}.btn-secondary{background-color:transparent;color:var(--primary-500);border-color:var(--primary-500)}.btn-secondary:hover{background-color:var(--primary-500);color:var(--text-white)}.blocklyToolboxDiv{position:relative;overflow-x:hidden!important;overflow-y:auto!important;padding:8px!important;perspective:none!important;border-right:1px solid var(--editor-gutter)!important;width:100%!important;max-width:100%!important;box-sizing:border-box!important;transform:translateZ(0);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;z-index:1}.blocklyToolboxDiv:before{content:"";position:absolute;top:0;left:-75%;width:250%;height:100%;background:linear-gradient(100deg,transparent 30%,var(--primary-a08) 45%,var(--primary-a08) 55%,transparent 70%);transform:translate(-100%);animation:shimmer-toolbox 7s infinite linear;animation-delay:1.5s;pointer-events:none;z-index:1}@keyframes shimmer-toolbox{to{transform:translate(100%)}}.blocklyTreeRow{border-radius:8px!important;margin:4px 0!important;padding:8px 12px!important;transition:transform .2s cubic-bezier(.4,0,.2,1)!important;border:1px solid transparent!important;font-weight:500!important;position:relative;z-index:2;width:calc(100% - 8px)!important;box-sizing:border-box!important;transform:translateZ(0);backface-visibility:hidden;display:flex!important;align-items:center!important;min-height:32px!important}.blocklyTreeRow:not(.blocklyTreeSelected):hover{background-color:var(--primary-a12)!important;transform:scale(1.02) translateZ(0);border-color:var(--primary-a30)!important;box-shadow:var(--shadow-1)}.blocklyTreeRow.blocklyTreeSelected{background-color:var(--primary-500)!important;font-weight:700!important;border-left:4px solid var(--accent-500)!important;color:var(--text-white)!important}.blocklyTreeChildDiv{padding-left:12px;width:calc(100% - 12px)!important;box-sizing:border-box!important;position:relative;transform:translateZ(0);will-change:transform;pointer-events:auto!important;z-index:1;margin:4px 0!important}.blocklyTreeChildDiv *{pointer-events:auto!important}.category-icon{width:18px;height:18px;margin-right:12px;opacity:.8;transition:opacity .2s;flex-shrink:0}.blocklyTreeRow.blocklyTreeSelected .category-icon{opacity:1;filter:drop-shadow(0 0 5px var(--primary-a30))}.toolbox-search-label .blocklyTreeLabel{padding:0!important;width:100%}.toolbox-search-label input[type=search]{width:calc(100% - 16px);padding:10px;margin:8px;border:1px solid var(--editor-gutter);border-radius:8px;font-family:Inter,sans-serif;font-size:14px;outline:none;transition:all .2s;background-color:var(--surface-1);color:var(--text)}.toolbox-search-label input[type=search]:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px var(--focus-ring)}:root,[data-theme=light],[data-theme=dark]{--accordion-text: var(--text);--accordion-text-hover: var(--primary-600);--accordion-accent: var(--accent-500);--accordion-accent-subtle: var(--primary-a08)}.custom-category-row{position:relative;display:flex;align-items:center;padding:12px 16px!important;margin:0!important;background:transparent;color:var(--accordion-text)!important;font-family:Inter,Segoe UI,-apple-system,BlinkMacSystemFont,sans-serif!important;font-weight:400!important;font-size:14px!important;letter-spacing:.01em!important;line-height:1.4!important;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)!important;border:none;overflow:hidden;transform:translateZ(0);-webkit-transform-style:preserve-3d;transform-style:preserve-3d;backface-visibility:hidden;pointer-events:auto!important}.custom-category-row .blocklyTreeLabel{transition:all .3s cubic-bezier(.4,0,.2,1);font-family:inherit!important;font-weight:inherit!important;letter-spacing:inherit!important}.custom-category-row:focus{outline:none;background:var(--accordion-accent-subtle)}.custom-category-row:active{background:var(--accordion-accent-subtle);transform:translate(1px)}.custom-category-row:hover{background:var(--accordion-accent-subtle);color:var(--accordion-text-hover)!important;transform:translate(4px)}.custom-category-row:hover .blocklyTreeLabel{color:var(--accordion-text-hover)!important}.blocklyTreeRow.blocklyTreeSelected.custom-category-row{background:var(--primary-500);color:var(--text-white)!important;border-left:3px solid var(--accordion-accent)}.blocklyTreeRow.blocklyTreeSelected.custom-category-row .blocklyTreeLabel{color:var(--accordion-text-hover)!important;font-weight:500!important}.custom-category-icon-container{position:absolute;right:16px;width:16px;height:16px;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);opacity:.6}.custom-category-icon-container:before{content:"";width:0;height:0;border-left:4px solid var(--accordion-text);border-top:4px solid transparent;border-bottom:4px solid transparent;transition:all .3s cubic-bezier(.4,0,.2,1)}.custom-category-icon-container.is-open:before{transform:rotate(90deg);border-left-color:var(--accordion-accent)}.custom-category-row:hover .custom-category-icon-container{opacity:1}.custom-category-row:hover .custom-category-icon-container:before{border-left-color:var(--accordion-accent)}.blocklyTreeRow.blocklyTreeSelected.custom-category-row .custom-category-icon-container{opacity:1}.blocklyTreeRow.blocklyTreeSelected.custom-category-row .custom-category-icon-container:before{border-left-color:var(--accordion-accent)}:root,[data-theme=light]{--primary-500: #306998;--primary-600: #255580;--accent-500: #FFD43B;--accent-600: #F4C531;--bg-0: #FFFFFF;--surface-1: #F4F7FB;--muted-1: #E6EEF9;--text: #0B1B2B;--muted-text: #546A7A;--success: #2ECC71;--danger: #FF5C5C;--info: #4584B6;--focus-ring: rgba(69,132,182,.28);--shadow-1: 0 6px 18px rgba(6,20,32,.08);--editor-bg: #F8FAFD;--editor-gutter: #E1E8F2;--editor-cursor: #306998;--editor-selection: rgba(48,105,152,.2);--workspace-bg: var(--bg-0);--text-primary: var(--text);--text-secondary: var(--muted-text);--toolbox-bg: var(--muted-1);--toolbox-fg: var(--text);--toolbox-border: var(--editor-gutter);--toolbox-hover-bg: color-mix(in srgb, var(--primary-500) 8%, transparent);--toolbox-selected-bg: color-mix(in srgb, var(--primary-500) 12%, var(--muted-1));--toolbar-bg: linear-gradient(135deg, color-mix(in srgb, var(--primary-600) 24%, #ffffff) 0%, color-mix(in srgb, var(--primary-500) 14%, #ffffff) 52%, color-mix(in srgb, #6EC5FF 20%, #ffffff) 100% );--toolbar-text: var(--text);--toolbar-border: var(--primary-500);--panel-bg: var(--surface-1);--panel-border: var(--editor-gutter);--accent-aqua: var(--primary-500);--accent-coral: var(--accent-500);--text-white: #FFFFFF;--text-light: var(--muted-text);--text-mid: var(--muted-text);--text-dark: var(--text);--primary-a04: rgba(48,105,152,.04);--primary-a08: rgba(48,105,152,.08);--primary-a12: rgba(48,105,152,.12);--primary-a16: rgba(48,105,152,.16);--primary-a30: rgba(48,105,152,.3);--accent-a15: rgba(255,212,59,.15)}[data-theme=dark]{--primary-500: #306998;--primary-600: #3B7EB0;--accent-500: #FFD43B;--accent-600: #EBC834;--bg-0: #0B1220;--surface-1: #0F1724;--muted-1: #13202E;--text: #E6EEF8;--muted-text: #9FB4C6;--text-dark: #0B1B2B;--success: #33D17A;--danger: #FF7676;--info: #57A0DC;--focus-ring: rgba(69,132,182,.45);--shadow-1: 0 6px 18px rgba(0,0,0,.35);--editor-bg: #0D1628;--editor-gutter: #162337;--editor-cursor: #FFD43B;--editor-selection: rgba(255,212,59,.15);--workspace-bg: var(--bg-0);--text-primary: var(--text);--text-secondary: var(--muted-text);--toolbox-bg: var(--muted-1);--toolbox-fg: var(--text);--toolbox-border: var(--editor-gutter);--toolbox-hover-bg: color-mix(in srgb, var(--primary-500) 14%, transparent);--toolbox-selected-bg: color-mix(in srgb, var(--primary-500) 18%, var(--muted-1));--toolbar-bg: var(--primary-500);--toolbar-text: var(--text-white);--toolbar-border: var(--accent-500);--panel-bg: var(--surface-1);--panel-border: var(--editor-gutter);--accent-aqua: var(--primary-500);--accent-coral: var(--accent-500);--text-white: #FFFFFF;--text-light: var(--muted-text);--text-mid: var(--muted-text);--primary-a04: color-mix(in srgb, var(--primary-500) 4%, transparent);--primary-a08: color-mix(in srgb, var(--primary-500) 8%, transparent);--primary-a12: color-mix(in srgb, var(--primary-500) 12%, transparent);--primary-a16: color-mix(in srgb, var(--primary-500) 16%, transparent);--primary-a30: color-mix(in srgb, var(--primary-500) 30%, transparent);--accent-a15: rgba(255,212,59,.15)}:root,[data-theme=light]{--syntax-comment: #8ca5c3;--syntax-punctuation: #89ddff;--syntax-tag: #ff8da1;--syntax-number: #ffcb8b;--syntax-string: #c3e88d;--syntax-operator: #82aaff;--syntax-keyword: #c792ea;--syntax-function: #ffb86c;--syntax-variable: #f07178}[data-theme=dark]{--syntax-comment: #8ca5c3;--syntax-punctuation: #89ddff;--syntax-tag: #ff8da1;--syntax-number: #ffcb8b;--syntax-string: #c3e88d;--syntax-operator: #82aaff;--syntax-keyword: #c792ea;--syntax-function: #ffb86c;--syntax-variable: #f07178}:root{--toolbar-height: 72px;--tutorial-bg: var(--surface-1);--tutorial-header-footer-bg: var(--surface-1);--tutorial-border: var(--editor-gutter);--tutorial-text-primary: var(--text);--tutorial-text-secondary: var(--muted-text);--tutorial-accent: var(--primary-500);--tutorial-button-hover-bg: var(--primary-a08);--tutorial-footer-height: 72px}.tutorials-list{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background-color:var(--tutorial-bg);color:var(--tutorial-text-primary);padding:2rem;border-radius:12px;box-shadow:var(--shadow-1);z-index:1000;border:1px solid var(--tutorial-border);width:90%;max-width:500px}.tutorials-list .tutorials-list-grid{display:grid;grid-template-columns:110px 1fr;gap:1rem;align-items:start}.tutorials-tech-aside{border-right:1px dashed var(--tutorial-border);padding-right:1rem;display:flex;flex-direction:column;align-items:center;gap:.5rem}.tech-badge{width:100%;height:auto;filter:drop-shadow(0 0 10px color-mix(in srgb,var(--primary-500) 20%,transparent))}.tech-aside-label{font-size:.75rem;color:var(--tutorial-text-secondary);text-align:center;letter-spacing:.5px}.tutorials-list-main h2{margin-top:0}.tutorials-list h2{text-align:center;margin-bottom:2rem;color:var(--tutorial-text-primary);font-weight:500}.tutorials-list ul{list-style:none;padding:0;margin:0}.tutorials-list li{margin-bottom:1rem}.tutorials-list li button{width:100%;padding:1rem;background-color:var(--tutorial-button-hover-bg);color:var(--tutorial-text-primary);border:1px solid var(--tutorial-border);border-radius:8px;cursor:pointer;transition:all .2s ease;text-align:left;font-size:1rem}.tutorials-list li button:hover{background-color:var(--tutorial-header-footer-bg);border-color:var(--tutorial-accent);transform:translateY(-2px);box-shadow:var(--shadow-1)}.tutorial-side-panel{position:fixed;top:var(--toolbar-height);right:0;width:100%;max-width:420px;height:calc(100vh - var(--toolbar-height));background-color:var(--tutorial-bg);color:var(--tutorial-text-primary);border-left:1px solid var(--tutorial-border);box-shadow:var(--shadow-1);z-index:1001;display:block;box-sizing:border-box}.tutorial-panel-content-wrapper{display:grid;grid-template-rows:auto 1fr var(--tutorial-footer-height);height:100%;min-height:0;width:100%;box-sizing:border-box}.tutorial-panel-header{grid-row:1;padding:.5rem 1.5rem;background-color:var(--tutorial-header-footer-bg);border-bottom:1px solid var(--tutorial-border);z-index:2}.tutorial-panel-body{grid-row:2;overflow-y:auto;overflow-x:hidden;padding:1.5rem;min-height:0;overscroll-behavior:contain;scrollbar-width:thin;scrollbar-color:var(--tutorial-border) var(--tutorial-bg);-webkit-overflow-scrolling:touch}.tutorial-panel-body::-webkit-scrollbar{width:8px}.tutorial-panel-body::-webkit-scrollbar-track{background:var(--tutorial-bg)}.tutorial-panel-body::-webkit-scrollbar-thumb{background-color:var(--tutorial-border);border-radius:4px;border:2px solid var(--tutorial-bg)}.tutorial-header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.tutorial-title{margin:0;font-size:1.25rem;font-weight:600}.tutorial-progress{width:100%;height:4px;background-color:var(--primary-a08);border-radius:2px;overflow:hidden;margin-bottom:.5rem}.tutorial-progress-bar{height:100%;background:var(--tutorial-accent);border-radius:2px;transition:width .4s cubic-bezier(.25,1,.5,1)}.tutorial-progress-text{font-size:.8rem;color:var(--tutorial-text-secondary);text-align:center}.close-btn{background:none;border:none;font-size:1.75rem;line-height:1;color:var(--tutorial-text-secondary);cursor:pointer;padding:.5rem;margin:-.5rem;transition:color .2s ease,transform .2s ease}.close-btn:hover{color:var(--tutorial-text-primary);transform:scale(1.1)}.tutorial-panel-body{flex:1 1 auto;overflow-y:auto;overflow-x:hidden;padding:1.5rem;min-height:0;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.tutorial-step-title{font-size:1.1rem;font-weight:600;color:var(--tutorial-text-primary);margin-bottom:1.5rem}.tutorial-section{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--tutorial-border)}.tutorial-section:last-child{border-bottom:none;margin-bottom:0}.tutorial-section-title{font-weight:600;font-size:1rem;color:var(--tutorial-text-primary);display:block;margin-bottom:.75rem}.tutorial-section-content{color:var(--tutorial-text-secondary);line-height:1.6;margin:0}.tutorial-section-content code{background-color:var(--tutorial-header-footer-bg);padding:.2em .4em;border-radius:4px;font-family:Courier New,Courier,monospace}.explanation-box{background-color:var(--tutorial-button-hover-bg);border:1px solid var(--tutorial-border);border-radius:8px;padding:1rem;margin-top:1rem;display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:background-color .2s}.explanation-box:hover{background-color:var(--primary-a12)}.explanation-box span{font-weight:500}.explanation-box .plus-icon{font-size:1.5rem;font-weight:300}.tutorial-panel-footer{grid-row:3;height:var(--tutorial-footer-height);padding:.75rem 1.5rem;background-color:var(--tutorial-header-footer-bg);border-top:1px solid var(--tutorial-border);box-shadow:var(--shadow-1);z-index:2;display:flex;align-items:center}.tutorial-controls{display:flex;justify-content:space-between;gap:1rem}.tutorial-button{flex-grow:1;padding:.8rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease-in-out;border:1px solid var(--tutorial-border)}.tutorial-button.primary{background:var(--tutorial-accent);color:var(--text-white);border-color:var(--tutorial-accent)}.tutorial-button.primary:hover{filter:brightness(1.05);box-shadow:var(--shadow-1);transform:translateY(-2px)}.tutorial-button.secondary{background-color:transparent;color:var(--tutorial-text-primary)}.tutorial-button.secondary:hover{background-color:var(--tutorial-button-hover-bg);border-color:var(--tutorial-accent)}.tutorial-button:disabled{opacity:.4;cursor:not-allowed;box-shadow:none;transform:none}@keyframes highlight-fade{0%{filter:drop-shadow(0 0 10px var(--tutorial-accent))}to{filter:none}}.tutorial-highlight{animation:highlight-fade 1.5s ease-out}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.tutorial-side-panel.compact{max-height:calc(100vh - var(--toolbar-height));box-sizing:border-box}.tutorial-side-panel.compact .tutorial-panel-body{overflow:hidden}.tutorial-side-panel.compact .tutorial-panel-header,.tutorial-side-panel.compact .tutorial-panel-footer,.tutorial-side-panel.compact .tutorial-panel-body{padding-left:1rem;padding-right:1rem}.tutorial-side-panel.compact .tutorial-step-title{font-size:1rem;margin-bottom:.75rem}.tutorial-side-panel.compact .tutorial-section-title{font-size:.95rem;margin-bottom:.5rem}.tutorial-side-panel.compact .tutorial-section-content{font-size:.85rem;line-height:1.25}.tutorial-side-panel.compact .tutorial-button{padding:.5rem .75rem;font-size:.9rem}.tutorial-side-panel.compact .tutorial-panel-body *{max-width:100%;word-wrap:break-word;box-sizing:border-box}@media(max-height:900px){.tutorial-side-panel.compact .tutorial-panel-header,.tutorial-side-panel.compact .tutorial-panel-footer,.tutorial-side-panel.compact .tutorial-panel-body{padding-top:.75rem;padding-bottom:.75rem}.tutorial-side-panel.compact .tutorial-step-title{font-size:.98rem}.tutorial-side-panel.compact .tutorial-section-content{font-size:.84rem}}@media(max-height:750px){.tutorial-side-panel.compact .tutorial-panel-header,.tutorial-side-panel.compact .tutorial-panel-footer,.tutorial-side-panel.compact .tutorial-panel-body{padding-top:.5rem;padding-bottom:.5rem}.tutorial-side-panel.compact .tutorial-section-content{font-size:.8rem;line-height:1.15}.tutorial-side-panel.compact .tutorial-button{padding:.45rem .6rem;font-size:.85rem}}@media(max-height:600px){.tutorial-side-panel.compact .tutorial-panel-header,.tutorial-side-panel.compact .tutorial-panel-footer,.tutorial-side-panel.compact .tutorial-panel-body{padding-top:.4rem;padding-bottom:.4rem}.tutorial-side-panel.compact .tutorial-step-title{font-size:.9rem}.tutorial-side-panel.compact .tutorial-section-title{font-size:.85rem}.tutorial-side-panel.compact .tutorial-section-content{font-size:.76rem}.tutorial-side-panel.compact .tutorial-header-top{gap:.25rem}}@media(max-height:520px){.tutorial-side-panel.compact .tutorial-step-title{font-size:.88rem}}.tutorial-section-toggle{width:100%;display:flex;justify-content:space-between;align-items:center;background-color:var(--tutorial-button-hover-bg);border:1px solid var(--tutorial-border);border-radius:8px;cursor:pointer}.tutorial-section-collapsible{padding:.75rem .5rem}.tutorial-side-panel.minimized{width:32px;max-width:32px;overflow:hidden;transition:all .28s ease;background:transparent;border:none;box-shadow:none}.tutorial-side-panel.minimized .tutorial-panel-content-wrapper{width:32px;background:transparent}.tutorial-side-panel.minimized .tutorial-panel-header{background:transparent;border:none;padding:0;height:auto}.tutorial-side-panel.minimized .tutorial-panel-body,.tutorial-side-panel.minimized .tutorial-panel-footer,.tutorial-side-panel.minimized .tutorial-progress,.tutorial-side-panel.minimized .tutorial-progress-text,.tutorial-side-panel.minimized .tutorial-title,.tutorial-side-panel.minimized .close-btn{display:none}.tutorial-side-panel.minimized .tutorial-header-top{justify-content:center;margin:0;padding:8px 4px}.tutorial-side-panel.minimized .minimize-btn{width:24px;height:24px;background:var(--tutorial-accent);border-radius:4px;color:var(--text-white);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-1);margin:0}.tutorial-side-panel.minimized .minimize-btn:hover{transform:scale(1.1);background:var(--primary-600)}.minimize-btn{background:none;border:none;color:var(--tutorial-text-secondary);cursor:pointer;font-size:1.05rem;padding:.25rem;margin-right:.25rem}.minimize-btn:hover{color:var(--tutorial-text-primary);transform:scale(1.05)}.tutorial-side-panel.minimized{width:32px!important;max-width:32px!important;right:0!important;overflow:hidden!important}.tutorial-side-panel.minimized .tutorial-panel-content-wrapper>*{display:none!important}.tutorial-side-panel.minimized .tutorial-panel-content-wrapper .tutorial-panel-header{display:block!important;padding:6px 4px!important;background:transparent!important;border:none!important}.tutorial-side-panel.minimized .tutorial-panel-content-wrapper .tutorial-panel-header .tutorial-header-top{display:flex!important;align-items:center!important;justify-content:center!important;gap:0!important}.tutorial-side-panel.minimized .tutorial-title,.tutorial-side-panel.minimized .close-btn{display:none!important}.tutorial-side-panel.minimized .minimize-btn{display:flex!important;width:24px!important;height:24px!important;margin:0!important}.tutorial-side-panel.minimized{background:transparent!important;border-left:none!important;box-shadow:none!important}[data-theme=dark] .templates-modal-header{background:color-mix(in srgb,var(--primary-500) 12%,var(--surface-1))}[data-theme=dark] .templates-modal-footer{background:color-mix(in srgb,var(--accent-500) 8%,var(--surface-1))}[data-theme=dark] .filter-toggle{background-color:var(--accent-500);border-color:var(--accent-500);color:var(--text-dark)}[data-theme=dark] .filter-toggle:hover,[data-theme=dark] .filter-toggle.active{background-color:var(--primary-600);border-color:var(--primary-600);color:var(--text-white)}[data-theme=dark] .load-template-btn.primary{background:var(--accent-500);color:var(--text-dark)}[data-theme=dark] .load-template-btn.primary:hover{background:var(--primary-600);color:var(--text-white)}.templates-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:color-mix(in srgb,var(--text) 60%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000}.templates-modal{background-color:var(--surface-1);border:1px solid var(--panel-border);border-radius:12px;width:90%;max-width:800px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-1);color:var(--text)}.templates-modal-header{padding:24px 32px;border-bottom:1px solid var(--panel-border);flex-shrink:0;background:color-mix(in srgb,var(--accent-500) 10%,var(--surface-1))}.header-content h2{margin:0;color:var(--text);font-size:1.5rem}.header-content p{margin:4px 0 0;color:var(--text-secondary);font-size:1rem}.header-controls{display:flex;gap:16px;align-items:center;margin-top:16px}.search-container{position:relative;flex:1;max-width:300px}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-secondary);font-size:1rem}.search-input{width:100%;padding:10px 12px 10px 40px;background-color:var(--surface-1);border:1px solid var(--panel-border);border-radius:8px;color:var(--text);font-size:.9rem;transition:border-color .2s,box-shadow .2s}.search-input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px var(--focus-ring)}.search-input::placeholder{color:var(--text-secondary)}.filter-toggle{background-color:var(--primary-500);border:1px solid var(--primary-500);color:var(--text-white);border-radius:8px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.filter-toggle:hover,.filter-toggle.active{background-color:var(--accent-500);border-color:var(--accent-500);color:var(--text)}.filters-panel{background-color:var(--surface-1);border-bottom:1px solid var(--panel-border);padding:16px 32px;overflow:hidden}.filter-group{display:flex;align-items:center;gap:12px;margin-bottom:8px}.filter-group label{color:var(--text);font-size:.9rem;font-weight:500}.difficulty-select{background-color:var(--surface-1);border:1px solid var(--panel-border);border-radius:6px;color:var(--text);padding:6px 12px;font-size:.85rem;cursor:pointer;transition:border-color .2s}.difficulty-select:focus{outline:none;border-color:var(--primary-500)}.filter-stats{color:var(--text-secondary);font-size:.8rem;text-align:right}.templates-modal-footer{padding:16px 32px;border-top:1px solid var(--panel-border);display:flex;justify-content:space-between;align-items:center;flex-shrink:0;gap:16px;background:color-mix(in srgb,var(--primary-500) 8%,var(--surface-1))}.close-modal-btn{background-color:var(--primary-500);color:var(--text-white);border:none;padding:10px 20px;border-radius:8px;cursor:pointer;transition:background-color .2s,box-shadow .2s;display:flex;align-items:center;gap:8px}.close-modal-btn:hover{background-color:var(--primary-600);box-shadow:var(--shadow-1)}.load-template-btn.primary{background:var(--primary-500);color:var(--text-white);border:none;padding:12px 24px;border-radius:8px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px;font-weight:700;font-size:1rem;box-shadow:var(--shadow-1)}.load-template-btn.primary:hover{transform:translateY(-2px);background:var(--accent-500);color:var(--text);box-shadow:var(--shadow-1)}.load-template-btn.primary:disabled{opacity:.7;cursor:not-allowed;transform:none}.load-template-btn.primary.loading{pointer-events:none}.templates-modal-content{flex-grow:1;overflow:hidden;padding:24px 32px;display:flex;flex-direction:column;gap:20px;background:var(--surface-1)}.template-card{background-color:var(--surface-1);border:1px solid var(--panel-border);border-radius:10px;display:flex;align-items:stretch;overflow:hidden;transition:transform .2s,box-shadow .2s,border-color .2s}.template-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-1);border-color:var(--primary-500)}.template-card-preview{width:180px;background:linear-gradient(135deg,color-mix(in srgb,var(--primary-500) 90%,var(--surface-1)),color-mix(in srgb,var(--primary-600) 85%,var(--surface-1)),color-mix(in srgb,var(--primary-500) 90%,var(--surface-1)));flex-shrink:0;display:flex;align-items:center;justify-content:center;border-right:1px solid var(--panel-border);position:relative;overflow:hidden}.template-card-preview:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 30%,color-mix(in srgb,var(--accent-500) 10%,transparent) 0%,transparent 50%),radial-gradient(circle at 70% 70%,color-mix(in srgb,var(--primary-500) 8%,transparent) 0%,transparent 50%);animation:previewGlow 4s ease-in-out infinite alternate}.template-card-preview:after{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:conic-gradient(from 0deg,transparent,color-mix(in srgb,var(--primary-500) 6%,transparent),transparent);animation:rotate 20s linear infinite;pointer-events:none}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes previewGlow{0%{opacity:.3}to{opacity:.7}}.preview-placeholder{display:contents}.code-master-icon{position:relative;animation:codeMasterPulse 4s ease-in-out infinite}.code-master-icon svg{filter:drop-shadow(0 0 20px color-mix(in srgb,var(--primary-500) 40%,transparent))}.particle{animation:particleFloat 3s ease-in-out infinite}.particle-1{animation-delay:0s}.particle-2{animation-delay:.8s}.particle-3{animation-delay:1.6s}.particle-4{animation-delay:2.4s}@keyframes codeMasterPulse{0%,to{transform:scale(1) rotate(0);filter:drop-shadow(0 0 20px rgba(0,191,255,.4))}25%{transform:scale(1.02) rotate(1deg);filter:drop-shadow(0 0 25px rgba(0,191,255,.6))}50%{transform:scale(1.05) rotate(0);filter:drop-shadow(0 0 30px rgba(0,191,255,.8))}75%{transform:scale(1.02) rotate(-1deg);filter:drop-shadow(0 0 25px rgba(0,191,255,.6))}}@keyframes particleFloat{0%,to{transform:translateY(0) scale(1);opacity:.6}50%{transform:translateY(-8px) scale(1.2);opacity:1}}.preview-placeholder span{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text);opacity:.9}.template-card-details{padding:20px;flex-grow:1}.template-card-details h3{margin:0 0 8px;color:var(--text)}.template-card-details p{margin:0 0 16px;color:var(--text-secondary);font-size:.9rem;line-height:1.5}.template-meta{display:flex;gap:12px;align-items:center;margin-bottom:12px}.time-tag{background-color:#2a5a9e;color:#e0f4ff;padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:700;text-transform:uppercase}.template-card-tags{display:flex;gap:8px;align-items:center}.difficulty-tag,.tech-tag{background-color:color-mix(in srgb,var(--primary-500) 15%,var(--surface-1));color:var(--text-secondary);padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:700;text-transform:uppercase}.difficulty-tag{background-color:var(--accent-500);color:var(--text)}.load-template-btn:hover{background-color:var(--accent-500);color:var(--text);box-shadow:var(--shadow-1)}@media(max-width:768px){.templates-modal{width:95%;max-width:none;max-height:95vh}.templates-modal-header{padding:20px 24px}.header-content h2{font-size:1.3rem}.header-controls{flex-direction:column;gap:12px;align-items:stretch}.search-container{max-width:none}.templates-carousel-wrapper{padding:0 12px}.carousel-nav-btn{width:36px;height:36px;flex-shrink:0}.template-card{flex-direction:column;max-height:none}.template-card-preview{width:100%;height:120px}.preview-placeholder{gap:8px;padding:12px}.preview-icon{font-size:2.5rem}.code-master-icon svg{width:48px;height:48px}.templates-modal-footer{padding:16px 24px;flex-direction:column;gap:12px}.load-template-btn.primary,.close-modal-btn{width:100%;justify-content:center}}@media(max-width:480px){.templates-modal-header{padding:16px 20px}.filters-panel{padding:12px 20px}.templates-modal-content{padding:16px 0}.template-meta{flex-direction:column;align-items:flex-start;gap:8px}}.templates-carousel-wrapper{display:flex;flex-direction:row;align-items:center;justify-content:space-between;padding:0 24px;flex-grow:1;overflow:hidden;position:relative}.carousel-nav-btn{background-color:color-mix(in srgb,var(--primary-500) 25%,transparent);border:1px solid var(--panel-border);color:var(--text);border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease-in-out;z-index:10;flex-shrink:0}.carousel-nav-btn:hover{background-color:var(--accent-500);color:var(--text);border-color:var(--accent-500);transform:scale(1.05);box-shadow:var(--shadow-1)}.carousel-nav-btn.prev{margin-right:16px}.carousel-nav-btn.next{margin-left:16px}.templates-modal-content{padding:24px 0}.template-card-preview .template-techframe{width:100%;height:100%;display:block}.tech-rotor{transform-origin:50% 50%;animation:techSpin 4.5s linear infinite}@keyframes techSpin{to{transform:rotate(360deg)}}.blocks-shift{animation:blockShift 2.8s ease-in-out infinite}@keyframes blockShift{0%,to{transform:translate(0)}50%{transform:translate(6px)}}.techframe-sweep{animation:sweep 6s linear infinite}@keyframes sweep{0%{transform:translate(-100%)}to{transform:translate(100%)}}
