.main-left-panel{position:absolute;top:16px;left:28px;bottom:16px;width:180px;background:#1e1e24f2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:12px;display:flex;flex-direction:column;z-index:200;box-shadow:4px 0 16px #0000004d;transition:transform .3s ease}.mlp-tools-header{padding:12px;background:#ffffff08;border-bottom:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;gap:12px;flex-shrink:0}.tool-row{display:flex;gap:8px}.tool-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 4px;background:#ffffff0d;border:1px solid transparent;border-radius:6px;color:#888;cursor:pointer;transition:all .2s;height:56px}.tool-btn:hover{background:#ffffff1a;color:#ccc}.tool-btn.active{background:#6366f133;color:#fff;border-color:#6366f180;box-shadow:0 0 10px #6366f133}.tool-icon{font-size:1.4rem;margin-bottom:2px}.tool-label{font-size:.7rem;font-weight:600;text-transform:uppercase}.tool-badge{position:absolute;top:4px;right:4px;background:#ef4444;color:#fff;font-size:.6rem;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700}.tool-row.secondary{align-items:center;height:28px}.toggle-pill{flex:1;display:flex;background:#0000004d;border-radius:14px;padding:2px;height:100%}.toggle-pill button{flex:1;background:transparent;border:none;color:#666;font-size:10px;cursor:pointer;border-radius:12px;font-weight:500;transition:all .2s}.toggle-pill button.active{background:#555;color:#fff;box-shadow:0 1px 3px #0003}.icon-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#ccc;cursor:pointer;transition:all .2s;font-size:14px}.icon-btn:hover{background:#ffffff26;color:#fff}.mlp-assets-container{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:12px}.asset-group{margin-bottom:4px}.group-header{padding:6px 0;font-size:.75rem;font-weight:700;color:#888;cursor:pointer;display:flex;align-items:center;text-transform:uppercase;letter-spacing:.5px;-webkit-user-select:none;user-select:none;transition:color .2s}.group-header:hover{color:#fff}.group-arrow{font-size:.6rem;margin-right:6px;width:12px;text-align:center}.group-content{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;padding-left:6px;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.asset-item{aspect-ratio:1;border:1px solid transparent;border-radius:8px;background:#ffffff0d;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden;transition:all .2s}.asset-item:hover{background:#ffffff26;transform:translateY(-2px);box-shadow:0 4px 8px #0003}.asset-item.selected{border-color:#6366f1;background:#6366f126;box-shadow:0 0 0 1px #6366f180}.asset-thumb-wrapper{width:70%;height:70%;display:flex;align-items:center;justify-content:center}.asset-thumb{max-width:100%;max-height:100%;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}.asset-name{position:absolute;bottom:0;left:0;right:0;font-size:.6rem;background:#000c;color:#fff;padding:3px 0;text-align:center;transform:translateY(100%);transition:transform .2s}.asset-item:hover .asset-name{transform:translateY(0)}.custom-scrollbar::-webkit-scrollbar{width:4px}.custom-scrollbar::-webkit-scrollbar-track{background:transparent}.custom-scrollbar::-webkit-scrollbar-thumb{background:#444;border-radius:4px}.custom-scrollbar::-webkit-scrollbar-thumb:hover{background:#666}.shortcuts-row{margin-top:4px}.shortcuts-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:8px 12px;background:linear-gradient(135deg,#6366f14d,#8b5cf64d);border:1px solid rgba(99,102,241,.4);border-radius:8px;color:#e0e0ff;cursor:pointer;font-size:.75rem;font-weight:500;transition:all .2s}.shortcuts-btn:hover{background:linear-gradient(135deg,#6366f180,#8b5cf680);border-color:#6366f199;color:#fff;box-shadow:0 0 12px #6366f14d}.shortcut-icon{font-size:1rem}.shortcut-text{flex:1;text-align:left}.shortcut-key{background:#ffffff26;border:1px solid rgba(255,255,255,.2);border-radius:4px;padding:2px 6px;font-family:monospace;font-size:.7rem;color:#fff}.compact .shortcuts-btn{padding:8px;gap:0;justify-content:center}.compact .shortcut-text{display:none}.compact .shortcut-icon{font-size:1.2rem}.compact .shortcut-key{display:none}.main-left-panel.compact{width:80px}.compact-toggle-btn{position:absolute;top:4px;right:4px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:#666;cursor:pointer;font-size:14px;z-index:10;border-radius:4px}.compact-toggle-btn:hover{background:#ffffff1a;color:#fff}.compact .mlp-tools-header{padding-top:24px}.compact .tool-label{display:none}.compact .tool-btn{height:auto;aspect-ratio:1;padding:6px}.compact .tool-badge{top:-4px;right:-4px;width:16px;height:16px;font-size:9px;line-height:16px}.compact .tool-row{flex-direction:column;gap:8px;height:auto}.compact .toggle-pill{flex-direction:column;width:100%;height:auto;border-radius:8px;background:#0003;padding:2px}.compact .toggle-pill button{width:100%;padding:6px 0;border-radius:6px;font-size:9px;height:24px;display:flex;align-items:center;justify-content:center}.compact .icon-btn{width:100%;height:32px}.compact .group-content{grid-template-columns:1fr;padding-right:6px}.compact .group-header{justify-content:center}.compact .group-name{display:none;display:block;font-size:.6rem}.compact .group-arrow{display:none}.asset-text-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;text-align:center;font-size:.55rem;color:#ccc;padding:0;word-break:normal;overflow-wrap:break-word;line-height:1.1;font-weight:500;overflow:hidden}.compact .mlp-assets-container{overflow-y:auto;gap:4px;padding:8px}.asset-group-compact{position:relative;margin-bottom:0}.group-trigger-icon{width:100%;aspect-ratio:1;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:all .2s}.group-trigger-icon:hover{background:#ffffff26;border-color:#ffffff4d}.rep-thumb-wrapper{width:60%;height:60%;display:flex;align-items:center;justify-content:center}.rep-thumb{max-width:100%;max-height:100%;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}.compact-group-label{font-size:.5rem;color:#aaa;text-transform:uppercase;margin-top:4px;font-weight:700;text-align:center;line-height:1}.group-popover{position:fixed;left:120px;width:220px;background:#1e1e24fa;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:12px;z-index:300;box-shadow:0 4px 16px #00000080;animation:fadeIn .15s ease-out;display:block}.group-popover:before{content:"";position:absolute;left:-6px;top:16px;width:12px;height:12px;background:#1e1e24fa;transform:rotate(45deg);border-bottom:1px solid rgba(255,255,255,.1);border-left:1px solid rgba(255,255,255,.1);border-bottom-left-radius:2px}.popover-header-text{font-size:.7rem;font-weight:700;color:#888;text-transform:uppercase;margin-bottom:8px;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:4px}.popover-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;max-height:300px;overflow-y:auto}.quest-importer-wrapper input[type=file]{display:none}.custom-file-upload{display:inline-block;padding:6px 12px;cursor:pointer;border:1px solid var(--border-color);border-radius:4px;background-color:var(--button-bg-color);color:var(--text-color);font-size:14px;transition:background-color .2s ease}.custom-file-upload:hover{background-color:var(--button-hover-bg-color)}.editorToolbar{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;height:48px;box-sizing:border-box;transition:background-color .2s,color .2s}.editorToolbar.light{background-color:#f5f5f5;border-bottom:1px solid #e0e0e0;color:#333}.editorToolbar.dark{background-color:#1e1e1e;border-bottom:1px solid #333333;color:#e0e0e0}.editorToolbar.light .toolbar-left svg{fill:#555}.editorToolbar.dark .toolbar-left svg{fill:#ccc}.toolbar-left{display:flex;gap:8px;align-items:center}.editor-switch-group{display:flex;gap:4px;align-items:center;background-color:#e0e0e0;padding:3px;border-radius:6px}.editorToolbar.dark .editor-switch-group{background-color:#333}.editor-switch-group button{background:none;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:13px;font-weight:500;color:#666;transition:all .2s;white-space:nowrap}.editorToolbar.dark .editor-switch-group button{color:#aaa}.editor-switch-group button:hover{background-color:#0000000d;color:#333}.editorToolbar.dark .editor-switch-group button:hover{background-color:#ffffff1a;color:#e0e0e0}.editor-switch-group button.active{background-color:#fff;color:#1976d2;box-shadow:0 1px 3px #0000001a;font-weight:600}.editorToolbar.dark .editor-switch-group button.active{background-color:#444;color:#64b5f6;box-shadow:0 1px 3px #0000004d}.editorLabel{font-weight:700;font-size:14px;color:#333;padding:0 8px}.editorToolbar.dark .editorLabel{color:#e0e0e0}.help-button{padding:6px 14px;font-size:13px}.settings-button{background:none;border:none;cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary-light);border-radius:50%;transition:background-color .2s}@media (prefers-color-scheme: dark){.settings-button{color:var(--text-secondary-dark)}}.settings-button:hover{background-color:#0000000d;color:var(--text-primary-light)}@media (prefers-color-scheme: dark){.settings-button:hover{background-color:#ffffff1a;color:var(--text-primary-dark)}}.docs-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.docs-panel{background:var(--background-color, #fff);color:var(--text-color, #333);border-radius:12px;width:60vw;height:auto;max-height:85vh;max-width:800px;box-shadow:0 10px 25px #0003;display:flex;flex-direction:column}.docs-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-color, #eee);padding:16px 24px;flex-shrink:0}.docs-header h3{margin:0;font-size:1.25rem;font-weight:600}.docs-close-button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-color-secondary, #666);line-height:1;padding:4px;border-radius:4px;transition:background .2s}.docs-close-button:hover{background:#0000000d;color:var(--text-color, #333)}.docs-body{flex-grow:1;padding:0;overflow-y:auto;min-height:0}.docs-iframe{width:100%;height:75vh;border:none;border-radius:0 0 12px 12px;display:block}.hints-container{padding:24px 32px;text-align:left;max-width:900px;margin:0 auto}.hint-section{margin-bottom:24px;background:var(--background-color-secondary, #f8f9fa);padding:20px 24px;border-radius:12px;border-left:6px solid var(--primary-color, #4ade80);box-shadow:0 2px 8px #0000000d}.hint-section h4{margin-top:0;margin-bottom:16px;font-size:1.15rem;font-weight:700;color:var(--text-color-primary, #1f2937);display:flex;align-items:center;gap:8px}.hint-section p{margin:0;line-height:1.6;font-size:1rem;color:var(--text-color, #374151);white-space:pre-wrap}.hint-list{margin:0;padding-left:20px}.hint-list li{margin-bottom:12px;line-height:1.5;color:var(--text-color, #374151)}@media (prefers-color-scheme: dark){.hint-section{background:#ffffff0d}}.settings-panel-container{position:absolute;top:40px;right:0;z-index:30;padding:10px;pointer-events:none}.settings-panel{width:250px;background-color:var(--background-color);border:1px solid var(--border-color);border-radius:4px;box-shadow:-2px 2px 5px #0000001a;transform:translate(calc(100% + 20px));transition:transform .3s ease-in-out;visibility:hidden;padding:15px;box-sizing:border-box;pointer-events:auto}.settings-panel-container.open .settings-panel{transform:translate(0);visibility:visible}.settings-panel h3{margin-top:0;margin-bottom:20px;border-bottom:1px solid var(--border-color);padding-bottom:10px}.setting-item{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.setting-item label{display:flex;align-items:center;gap:8px}.setting-item select,.setting-item input{background-color:var(--button-bg-color);color:var(--text-color);border:1px solid var(--border-color);border-radius:4px;padding:5px}.snippet-toolbox{width:220px;display:flex;flex-direction:column;overflow-y:auto;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;-webkit-user-select:none;user-select:none;transition:background-color .2s,color .2s}.snippet-toolbox.light{background-color:#f5f5f5;border-right:1px solid #e0e0e0;color:#333}.snippet-toolbox.dark{background-color:#252526;border-right:1px solid #333;color:#fff}.snippet-toolbox.light .snippet-search-container{background-color:#f5f5f5;border-bottom:1px solid #e0e0e0}.snippet-toolbox.dark .snippet-search-container{background-color:#252526;border-bottom:1px solid #333}.snippet-search-container{padding:10px}.snippet-search-input{width:100%;padding:6px 8px;border-radius:4px;font-size:13px;outline:none}.snippet-toolbox.light .snippet-search-input{border:1px solid #ccc;background-color:#fff;color:#333}.snippet-toolbox.dark .snippet-search-input{border:1px solid #555;background-color:#3c3c3c;color:#fff}.snippet-search-input:focus{border-color:#007fd4}.snippet-toolbox-content{flex:1;overflow-y:auto}.snippet-toolbox.light .snippet-toolbox-content{background-color:#f5f5f5}.snippet-toolbox.dark .snippet-toolbox-content{background-color:#252526}.snippet-category-header{padding:10px 15px;cursor:pointer;font-weight:500;font-size:14px;display:flex;align-items:center;background-color:transparent;border-left:8px solid var(--category-color);transition:background-color .2s}.snippet-toolbox.light .snippet-category-header{color:#333}.snippet-toolbox.dark .snippet-category-header{color:#fff}.snippet-category-header:hover{background-color:#0000000d}.snippet-toolbox.dark .snippet-category-header:hover{background-color:#ffffff1a}.snippet-category-content{display:flex;flex-direction:column;padding:8px;gap:6px}.snippet-toolbox.light .snippet-category-content{background-color:#fafafa}.snippet-toolbox.dark .snippet-category-content{background-color:#1e1e1e}.snippet-item{padding:8px 10px;border-radius:4px;cursor:grab;font-size:13px;font-family:Monaco,Menlo,Ubuntu Mono,Consolas,source-code-pro,monospace;box-shadow:0 1px 2px #0000000d;transition:all .15s ease;position:relative;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.snippet-toolbox.light .snippet-item{background-color:#fff;border:1px solid #ddd;color:#333}.snippet-toolbox.dark .snippet-item{background-color:#2d2d2d;border:1px solid #444;color:#ccc}.snippet-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background-color:var(--category-color, #ccc)}.snippet-item:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.snippet-toolbox.light .snippet-item:hover{border-color:#bbb}.snippet-toolbox.dark .snippet-item:hover{border-color:#666;background-color:#333}.snippet-item:active{cursor:grabbing;transform:translateY(0)}.snippet-item-label{margin-left:8px}.mazeContainer{width:95%;max-width:400px;aspect-ratio:1 / 1;position:relative;border:1px solid var(--border-color);margin:auto;background-color:#f1eee7}.mazeMap{width:100%;height:100%;position:relative}.mapCell{width:12.5%;height:12.5%;position:absolute;overflow:hidden}.tileImage{width:500%;height:400%;background-image:url(/assets/maze/tiles_pegman.png);background-size:100% 100%;position:absolute}.pegman{position:absolute;width:49px;height:52px;background-image:url(/assets/maze/pegman.png);background-size:1029px 52px;transition:top .1s linear,left .1s linear}.finishMarker{position:absolute;width:20px;height:34px}.pondContainer{display:flex;flex-direction:column;align-items:center}.canvasWrapper{width:400px;height:400px;position:relative;border:1px solid var(--border-color)}.canvasWrapper canvas{position:absolute;top:0;left:0;width:100%;height:100%}#displayCanvas{z-index:1}#scratchCanvas{z-index:0;display:none}.statsContainer{display:flex;width:402px;margin-top:4px}.avatarStatCard{flex:1;border:1px solid #888;padding:4px;text-align:center;color:#fff;font-weight:700;position:relative;overflow:hidden}.avatarStatCard .healthBarBackground{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#555;z-index:1}.avatarStatCard .healthBar{position:absolute;top:0;left:0;height:100%;z-index:2;transition:width .2s ease}.avatarStatCard .avatarName{position:relative;z-index:3}.turtleContainer{width:400px;height:400px;position:relative;border:1px solid var(--border-color)}.turtleContainer canvas{position:absolute;top:0;left:0;width:100%;height:100%}#displayCanvas{z-index:2;background-color:transparent}#answerCanvas{z-index:1}#scratchCanvas{z-index:0}.quest-player-container{width:100%;height:100%}[data-resize-handle-id]{width:6px;background-color:var(--border-color);transition:background-color .2s ease}[data-resize-handle-id]:hover{background-color:#007bff}.visualizationColumn{height:100%;display:flex;flex-direction:column;background-color:var(--background-color);border:1px solid var(--border-color)}.main-content-wrapper{flex-grow:1;display:flex;flex-direction:column;min-height:0}.controlsArea{padding:8px 12px;height:48px;box-sizing:border-box;border-bottom:1px solid var(--border-color);background-color:var(--background-color);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.blocklyColumn{position:relative;width:100%;height:100%;border:1px solid var(--border-color);display:flex;flex-direction:column}.fill-container{width:100%;flex-grow:1;min-height:0}.descriptionArea{padding:10px;text-align:center;border-top:1px solid var(--border-color);background-color:var(--background-color);font-style:italic;flex-shrink:0}.emptyState{flex-grow:1;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:20px;text-align:center;color:#888}.visualization-wrapper{flex-grow:1;position:relative;display:flex;flex-direction:column;min-height:0}.stats-overlay{position:absolute;top:10px;right:10px;z-index:10;background-color:#0000004d;color:#fff;padding:8px 12px;border-radius:5px;font-family:monospace;font-size:14px;pointer-events:none}.quest-player-container .blocklyToolboxDiv{display:block!important;visibility:hidden!important;height:0!important;width:0!important;pointer-events:none;position:absolute;top:0;left:0}.stat-item{margin-bottom:4px}.stat-item:last-child{margin-bottom:0}.random-mode-badge{background:linear-gradient(135deg,#8b5cf6,#d946ef);color:#fff;padding:4px 10px;border-radius:12px;font-weight:600;font-size:12px;margin-bottom:8px;display:inline-flex;align-items:center;gap:4px;cursor:help;animation:subtle-pulse 2s ease-in-out infinite}@keyframes subtle-pulse{0%,to{opacity:1}50%{opacity:.85}}.primaryButton{padding:8px 16px;font-size:14px;cursor:pointer;margin:0 5px;border-radius:5px;color:var(--text-color);background-color:var(--button-bg-color);border:1px solid var(--border-color)}.primaryButton:hover{background-color:var(--button-hover-bg-color)}.themed-select{background-color:var(--button-bg-color);color:var(--text-color);border:1px solid var(--border-color);border-radius:4px;padding:6px 10px;font-size:14px;cursor:pointer;transition:border-color .2s}.themed-select:hover{border-color:var(--text-color)}.themed-select:focus{outline:none;border-color:#007bff}.control-group{display:flex;align-items:center;gap:6px;color:var(--text-color)}.control-group svg{width:18px;height:18px;flex-shrink:0}.controls-left{display:flex;align-items:center;gap:12px}.blockly-renderer-container .injectionDiv{width:100%!important;height:100%!important}.blockly-renderer-container svg.blocklySvg{width:100%!important;height:100%!important;min-height:150px!important;background-color:transparent!important}.blockly-renderer-container.frameless{border:none!important;background-color:transparent!important;box-shadow:none!important}.blockly-renderer-container.frameless .injectionDiv{background-color:transparent!important}.blockly-mini-toolbar{position:absolute;top:12px;right:12px;display:flex;flex-direction:row;gap:8px;z-index:50}.blockly-mini-toolbar button{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background-color:#ffffffd9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(0,0,0,.1);border-radius:8px;cursor:pointer;font-size:16px;color:#444c56;box-shadow:0 2px 6px #00000014;transition:all .2s cubic-bezier(.4,0,.2,1);font-weight:600;white-space:nowrap;line-height:1}:where(.theme-dark,.dark-mode) .blockly-mini-toolbar button{background-color:#30363dcc;border-color:#f0f6fc1a;color:#c9d1d9}.blockly-mini-toolbar button:hover{background-color:#fff;color:#0969da;border-color:#0969da;transform:scale(1.05);box-shadow:0 4px 12px #0969da33}:where(.theme-dark,.dark-mode) .blockly-mini-toolbar button:hover{background-color:#1f6feb;color:#fff;border-color:#58a6ff}.blockly-mini-toolbar button.active{background-color:#0969da;color:#fff;border-color:#0969da}.blockly-code-view{position:absolute;top:0;left:0;width:100%;height:100%;z-index:5;background-color:#0d1117;border-radius:12px;padding:12px;overflow:auto}.blockly-renderer-container .blocklyBlockCanvas{visibility:visible!important;opacity:1!important}.blockly-renderer-container .blocklyBlock{visibility:visible!important;opacity:1!important;display:block!important}.blocklyScrollbarBackground,.blocklyScrollbarHandle{display:none!important;fill-opacity:0}.guide-renderer{--guide-bg: #ffffff;--guide-text: #24292e;--guide-border: #eaecef;--guide-heading: #1a1f23;--guide-primary: #0969da;--guide-secondary-bg: #f6f8fa;--guide-code-bg: rgba(27, 31, 35, .05);--guide-blockquote-color: #57606a;--guide-blockquote-border: #d0d7de;--guide-blockquote-bg: #f6f8fa;--guide-note-bg: #ddf4ff;--guide-note-border: #0969da;--guide-card-bg: #ffffff;--guide-card-shadow: 0 4px 12px rgba(0, 0, 0, .08);--guide-hover-bg: #f3f4f6;--guide-blockly-canvas-bg: #ffffff;--guide-blockly-border: #d0d7de;padding:32px 20px;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif;color:var(--guide-text);background-color:transparent;overflow-y:auto;height:100%;line-height:1.7;font-size:16px;box-sizing:border-box;scroll-behavior:smooth;max-width:100%;margin:0 auto}@media (max-width: 1024px){.guide-renderer{padding:24px 20px}}:where(.theme-dark,.dark-mode) .guide-renderer{--guide-bg: #0d1117;--guide-text: #c9d1d9;--guide-border: #30363d;--guide-heading: #f0f6fc;--guide-primary: #58a6ff;--guide-secondary-bg: #161b22;--guide-code-bg: rgba(110, 118, 129, .4);--guide-blockquote-color: #8b949e;--guide-blockquote-border: #30363d;--guide-blockquote-bg: #161b22;--guide-note-bg: rgba(56, 139, 253, .1);--guide-note-border: #1f6feb;--guide-card-bg: #161b22;--guide-card-shadow: 0 8px 24px rgba(0, 0, 0, .4);--guide-hover-bg: #21262d;--guide-blockly-canvas-bg: rgba(255, 255, 255, .96);--guide-blockly-border: #444c56}.guide-renderer *{max-width:100%;box-sizing:border-box}.guide-renderer h1{font-size:32px;border-bottom:2px solid var(--guide-border);padding-bottom:.4em;margin-top:0;margin-bottom:32px;color:var(--guide-primary);font-weight:800;letter-spacing:-.02em;background:linear-gradient(135deg,var(--guide-primary),#3b82f6);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.guide-renderer h2{font-size:24px;margin-top:48px;margin-bottom:20px;font-weight:700;color:var(--guide-heading);border-bottom:1px solid var(--guide-border);padding-bottom:.3em;display:flex;align-items:center}.guide-renderer h3{font-size:20px;margin-top:32px;margin-bottom:14px;font-weight:600;color:var(--guide-heading)}.guide-renderer p{margin-bottom:20px}.guide-renderer strong{color:var(--guide-heading);font-weight:600}.guide-renderer blockquote{margin:24px 0;padding:12px 20px;color:var(--guide-blockquote-color);border-left:4px solid var(--guide-blockquote-border);background-color:var(--guide-blockquote-bg);border-radius:6px;font-style:italic;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.guide-renderer code{background-color:var(--guide-code-bg);padding:.2em .4em;border-radius:6px;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,Liberation Mono,monospace;font-size:.9em}.guide-renderer ul,.guide-renderer ol{padding-left:1.5rem;margin-bottom:20px}.guide-renderer li{margin-bottom:.5em}.guide-renderer img{height:auto;border-radius:12px;box-shadow:var(--guide-card-shadow);margin:24px auto;display:block;max-width:100%;transition:transform .3s ease}.guide-renderer img:hover{transform:scale(1.01)}.blockly-xml-block{margin:28px 0;position:relative;border-radius:12px;overflow:hidden;border:1px solid var(--guide-blockly-border);box-shadow:var(--guide-card-shadow);background-color:var(--guide-blockly-canvas-bg);transition:transform .2s ease,box-shadow .2s ease}.blockly-xml-block:hover{box-shadow:0 12px 32px #0000001f}.btn-run-code{background:linear-gradient(135deg,#2ea44f,#238636);color:#fff;border:none;border-radius:6px;padding:8px 18px;font-size:14px;cursor:pointer;font-weight:600;box-shadow:0 4px 12px #2386364d;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;gap:6px}.btn-run-code:hover{transform:translateY(-2px);box-shadow:0 6px 16px #23863666;filter:brightness(1.1)}.btn-run-code:active{transform:translateY(0)}.btn-edit-block{background:linear-gradient(135deg,#0969da,#0550ae);color:#fff;border:none;border-radius:6px;padding:8px 18px;font-size:14px;cursor:pointer;font-weight:600;box-shadow:0 4px 12px #0969da4d;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;gap:6px}.btn-edit-block:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0969da66;filter:brightness(1.1)}.btn-edit-block:active{transform:translateY(0)}.blockly-xml-block{transition:height .4s cubic-bezier(.4,0,.2,1)}.view-controls{display:flex;flex-direction:column;gap:5px}.view-controls button{width:40px;height:40px;background-color:var(--surface-glass);border:1px solid var(--border-solid);color:var(--text-primary);font-weight:700;border-radius:var(--radius-xs);cursor:pointer;transition:background-color .2s;font-size:14px;display:flex;align-items:center;justify-content:center}.view-controls button:hover{background-color:var(--accent-primary);border-color:var(--accent-primary-active)}.welcome-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease-out}.welcome-modal-content{background:linear-gradient(180deg,#2a2a3a,#1e1e2e);color:#f0f0f0;padding:24px;border-radius:16px;border:1px solid rgba(255,255,255,.1);width:90%;max-width:720px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 25px 50px #00000080;animation:scaleIn .25s cubic-bezier(.4,0,.2,1)}.welcome-modal-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:16px;margin-bottom:16px}.welcome-modal-header h2{margin:0;font-size:1.4rem;font-weight:600;background:linear-gradient(135deg,#6366f1,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.welcome-modal-close-btn{background:#ffffff1a;border:none;font-size:1.5rem;color:#888;cursor:pointer;padding:4px 10px;border-radius:8px;line-height:1;transition:all .15s ease}.welcome-modal-close-btn:hover{background:#ffffff26;color:#fff}.welcome-modal-body{overflow-y:auto;flex-grow:1;line-height:1.6;padding-right:8px}.welcome-modal-body h3{color:#a5b4fc;margin-top:20px;margin-bottom:12px;font-size:1.1rem;font-weight:600}.welcome-modal-body h4{color:#c4b5fd;margin-top:12px;margin-bottom:8px;font-size:.95rem}.welcome-modal-body p{color:#b0b0c0;margin-bottom:12px}.welcome-modal-body ul,.welcome-modal-body ol{padding-left:20px;color:#b0b0c0}.welcome-modal-body li{margin-bottom:6px}.welcome-modal-body code{background:#6366f133;padding:2px 6px;border-radius:4px;font-size:.85em;color:#a5b4fc}.welcome-modal-body kbd{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 6px;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:4px;font-family:SF Mono,Monaco,Consolas,monospace;font-size:11px;font-weight:600;color:#d0d0d8}.wm-highlight-box{background:linear-gradient(135deg,#6366f126,#a855f726);border:1px solid rgba(99,102,241,.3);border-radius:12px;padding:16px;margin:16px 0}.wm-highlight-box h3{margin-top:0!important;color:#a5b4fc}.wm-highlight-box ul{margin-bottom:0}.wm-mode-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:16px 0}.wm-mode-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:16px;transition:all .2s ease}.wm-mode-card:hover{border-color:#6366f166;background:#6366f114}.wm-mode-card h4{margin:0 0 8px;color:#f0f0f5;font-size:1rem}.wm-mode-card p{margin:0 0 12px;font-size:.85rem;color:#888;font-style:italic}.wm-mode-card ol{margin:0;padding-left:18px;font-size:.9rem}.wm-mode-card li{margin-bottom:4px}.wm-shortcuts-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:12px 0}.wm-shortcut{display:flex;align-items:center;gap:8px;padding:8px 10px;background:#ffffff0d;border-radius:8px;font-size:12px}.wm-shortcut kbd{min-width:auto;height:auto;padding:3px 6px}.wm-shortcut span{color:#a0a0b0}.welcome-modal-footer{display:flex;justify-content:space-between;align-items:center;border-top:1px solid rgba(255,255,255,.1);padding-top:16px;margin-top:20px}.welcome-modal-footer label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.9rem;color:#888}.welcome-modal-footer input[type=checkbox]{width:16px;height:16px;accent-color:#6366f1}.welcome-modal-ok-btn{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;padding:10px 24px;border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:500;transition:all .2s ease;box-shadow:0 4px 12px #6366f14d}.welcome-modal-ok-btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px #6366f166}.welcome-modal-ok-btn:active{transform:translateY(0)}@media (max-width: 600px){.wm-mode-cards{grid-template-columns:1fr}.wm-shortcuts-grid{grid-template-columns:repeat(2,1fr)}}.inspector-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 12px;background-color:#1e293b;border:1px solid #334155;border-radius:6px;color:#e2e8f0;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.inspector-toggle:hover{background-color:#334155}.inspector-content{margin-top:0;padding:12px;background-color:transparent;border:none;border-radius:0;font-size:.8125rem}.inspector-toolbar{display:flex;gap:8px;margin-bottom:12px}.refresh-btn,.export-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:6px 12px;background-color:#3b82f6;color:#fff;border:none;border-radius:4px;font-size:.75rem;font-weight:500;cursor:pointer;transition:background-color .2s;flex:1}.refresh-btn:hover,.export-btn:hover{background-color:#2563eb}.export-btn{background-color:#475569}.export-btn:hover{background-color:#64748b}.metrics-section{margin-bottom:16px;padding-bottom:12px;border-bottom:none}.metrics-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-top:8px}.metric-item{background-color:#1e293b;padding:8px;border-radius:4px;display:flex;flex-direction:column}.metric-label{color:#94a3b8;font-size:.7rem;text-transform:uppercase;margin-bottom:2px}.metric-value{color:#f8fafc;font-weight:600;font-size:1rem}.detected-topology{margin-top:8px;padding:6px 8px;background-color:#334155;border-radius:4px;color:#e2e8f0;font-size:.75rem;display:flex;align-items:center;gap:6px}.tier-section{margin-bottom:16px}.tier-header{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:#64748b;margin-top:0;margin-bottom:8px;border-bottom:none;padding-bottom:4px}.tier-section:first-of-type .tier-header{margin-top:0}.items-list{display:flex;flex-direction:column;gap:4px;max-height:200px;overflow-y:auto}.item-row{display:flex;align-items:center;gap:8px;padding:4px 6px;border-radius:4px;cursor:pointer;transition:background-color .15s}.item-row:hover{background-color:#1e293b}.item-info{flex:1;display:flex;flex-direction:column;min-width:0;align-items:flex-start}.item-name{color:#e2e8f0;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-meta{color:#64748b;font-size:.7rem}.color-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.point-type,.priority-badge,.relation-type,.pattern-type{display:inline-block;padding:1px 4px;border-radius:3px;font-size:.65rem;font-weight:600;text-transform:uppercase;background-color:#334155;color:#94a3b8;margin-right:6px}.priority-badge.priority-primary{background-color:#7c3aed;color:#fff}.priority-badge.priority-secondary{background-color:#2563eb;color:#fff}.priority-badge.priority-tertiary{background-color:#059669;color:#fff}.priority-badge.priority-connector{background-color:#d97706;color:#fff}.point-type.type-start{background-color:#16a34a;color:#fff}.point-type.type-target{background-color:#dc2626;color:#fff}.point-type.type-turn{background-color:#ca8a04;color:#fff}.point-type.type-junction{background-color:#9333ea;color:#fff}.priority-score{font-family:monospace;font-size:.7rem;color:#94a3b8;background-color:#0f172a;padding:2px 4px;border-radius:3px;border:1px solid #334155}.inspector-error{padding:8px;margin-bottom:12px;background-color:#450a0a;border:1px solid #7f1d1d;color:#fca5a5;border-radius:4px;font-size:.75rem}.empty-state{text-align:center;padding:24px 0;color:#64748b;font-style:italic}.more-items{padding:4px 8px;font-size:.7rem;color:#64748b;text-align:center;font-style:italic}.report-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.report-modal{background-color:#1e293b;width:800px;max-width:90vw;height:80vh;border-radius:8px;display:flex;flex-direction:column;box-shadow:0 10px 25px -5px #00000080,0 8px 10px -6px #0000001a;border:1px solid #334155;animation:modalSlideIn .2s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.report-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid #334155;background-color:#0f172a;border-radius:8px 8px 0 0}.report-header h3{margin:0;color:#f1f5f9;font-size:1rem}.report-actions{display:flex;gap:8px}.report-actions button{background:transparent;border:1px solid #334155;color:#94a3b8;padding:4px 8px;border-radius:4px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.report-actions button:hover{background-color:#334155;color:#f1f5f9}.report-content{flex:1;background-color:#0f172a;color:#e2e8f0;font-family:Menlo,Monaco,Courier New,monospace;font-size:.8rem;padding:16px;border:none;resize:none;outline:none;line-height:1.5;white-space:pre;overflow:auto}.report-content::-webkit-scrollbar{width:10px;height:10px}.report-content::-webkit-scrollbar-track{background:#0f172a}.report-content::-webkit-scrollbar-thumb{background:#334155;border-radius:5px;border:2px solid #0f172a}.report-content::-webkit-scrollbar-thumb:hover{background:#475569}.inspector-group-header{display:flex;align-items:center;gap:6px;cursor:pointer;padding:6px 8px;margin:0 -8px 4px;border-radius:4px;transition:background-color .15s;-webkit-user-select:none;user-select:none;background:transparent}.inspector-group-header:hover{background-color:#1e293b}.inspector-group-header svg:first-child{color:#64748b;flex-shrink:0}.collapsible-section{border-bottom:1px solid var(--border-solid);background:var(--bg-elevated)}.collapsible-section:last-child{border-bottom:none}.collapsible-header{display:flex;justify-content:space-between;align-items:center;width:100%;padding:12px 14px;background:linear-gradient(135deg,var(--bg-tertiary) 0%,var(--bg-elevated) 100%);border:none;color:var(--text-primary);font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s ease}.collapsible-header:hover{background:linear-gradient(135deg,var(--bg-hover) 0%,var(--bg-tertiary) 100%)}.collapsible-section.collapsed .collapsible-header{background:var(--bg-elevated)}.header-content{display:flex;align-items:center;gap:8px}.header-icon{font-size:1rem}.header-title{font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}.header-badge{margin-left:auto;padding:2px 8px;background:#3b82f633;border-radius:10px;font-size:.7rem;font-weight:500;color:#3b82f6}.toggle-icon{font-size:.65rem;color:var(--text-label);transition:transform .3s ease}.toggle-icon.collapsed{transform:rotate(-90deg)}.collapsible-content{overflow:hidden;transition:max-height .3s ease,opacity .2s ease}.content-inner{padding:0}.collapsible-section.collapsed .collapsible-content{max-height:0!important;opacity:0}.collapsible-section.expanded .collapsible-content{opacity:1}.collapsible-section.properties .collapsible-header{background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-elevated) 100%)}.collapsible-section.quest .collapsible-header{background:linear-gradient(135deg,#1e3a29 0%,var(--bg-elevated) 100%)}.collapsible-section.json .collapsible-header{background:linear-gradient(135deg,#2d1f3d 0%,var(--bg-elevated) 100%)}.topology-panel{display:flex;flex-direction:column;gap:0;padding:0;background:var(--bg-elevated)}.section-icon{vertical-align:middle;margin-right:6px}.hint-icon{vertical-align:middle;margin-right:4px;color:var(--accent-primary)}.spin-icon{animation:spin 1s linear infinite}.post-generate-section{padding:12px;background:#22c55e1a;border-bottom:1px solid rgba(34,197,94,.3);margin-bottom:12px}.post-generate-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}.status-indicator{font-size:.9rem}.status-text{font-size:.75rem;color:#22c55e}.post-generate-hint{margin:8px 0 0;font-size:.75rem;color:#aaa;line-height:1.4}.post-generate-hint strong{color:#22c55e}.topology-panel .collapsible-section{border:1px solid var(--border-solid);border-radius:var(--radius-md);background:var(--bg-secondary);overflow:hidden;margin:0 12px 8px;padding:0!important}.topology-panel .collapsible-section:first-child{margin-top:12px}.topology-panel .collapsible-header{display:flex;width:100%;margin:0;border:none!important;background:linear-gradient(180deg,var(--bg-tertiary) 0%,var(--bg-elevated) 100%)!important;padding:12px}.section-header{display:flex;justify-content:space-between;align-items:center;width:100%;padding:12px;background:var(--bg-tertiary);border:none;color:var(--text-primary);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s}.section-header:hover{background:var(--bg-hover)}.toggle-icon{font-size:.7rem;color:var(--text-label)}.section-content{padding:12px;background:var(--bg-elevated)}.topology-select{width:100%;padding:8px 10px;border-radius:var(--radius-sm);border:1px solid var(--border-solid);background:var(--bg-tertiary);color:var(--text-primary);font-size:.85rem;cursor:pointer;transition:border-color .2s}.topology-select:hover{border-color:#666}.topology-select:focus{outline:none;border-color:var(--accent-primary)}.topology-select optgroup{background:var(--bg-elevated);color:var(--text-label);font-weight:600}.topology-select option{background:var(--bg-tertiary);color:var(--text-primary)}.params-container{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-solid)}.params-label{display:block;font-size:.75rem;font-weight:600;color:var(--text-label);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.param-group{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}.param-group label{font-size:.8rem;color:var(--text-secondary)}.param-group input[type=number],.param-group input[type=text],.param-group select{padding:8px 10px;border-radius:var(--radius-sm);border:1px solid var(--border-solid);background:var(--bg-tertiary);color:var(--text-primary);font-size:.85rem}.param-group input:focus,.param-group select:focus{outline:none;border-color:var(--accent-primary)}.checkbox-group{flex-direction:row;align-items:center;gap:8px}.checkbox-group input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent-primary)}.no-params{color:#666;font-size:.8rem;font-style:italic;margin:0}.strategy-row{display:flex;gap:8px}.strategy-select{flex:1}.difficulty-select{flex:0 0 90px}.item-goals{margin-top:12px}.item-goals-label{display:block;font-size:.75rem;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.item-goals-row{display:flex;gap:8px}.item-goal{flex:1;display:flex;flex-direction:column;gap:4px}.item-goal label{font-size:.7rem;color:#888}.item-goal input{padding:6px 8px;border-radius:var(--radius-xs);border:1px solid var(--border-solid);background:var(--bg-tertiary);color:var(--text-primary);font-size:.8rem;text-align:center}.item-goal input:focus{outline:none;border-color:var(--accent-primary)}.generate-section{margin-top:20px;display:flex;flex-direction:column;gap:8px}.generate-btn{width:100%;padding:14px 20px;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-primary-active) 100%);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-weight:600;font-size:1rem;transition:all .2s;box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center;gap:8px}.generate-btn:hover:not(:disabled){background:linear-gradient(135deg,var(--accent-primary-active) 0%,#4338ca 100%);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.generate-btn:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-sm)}.generate-btn:disabled{opacity:.6;cursor:wait;background:linear-gradient(135deg,var(--bg-tertiary) 0%,var(--bg-elevated) 100%)}.hint-text{font-size:12px;color:var(--text-label);text-align:center;margin-top:12px;line-height:1.4}.hint-text strong{color:var(--accent-primary)}.topology-panel::-webkit-scrollbar{width:8px}.topology-panel::-webkit-scrollbar-track{background:var(--bg-elevated)}.topology-panel::-webkit-scrollbar-thumb{background:#555;border-radius:4px}.topology-panel::-webkit-scrollbar-thumb:hover{background:#666}.validation-report{background:var(--color-surface, #1a1a2e);border-radius:8px;padding:16px;margin-top:16px;border:1px solid var(--color-border, #333)}.validation-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.validation-header h3{margin:0;font-size:16px;color:var(--color-text, #fff)}.validation-header .close-btn{background:transparent;border:none;color:#888;font-size:20px;cursor:pointer;padding:0;line-height:1}.validation-header .close-btn:hover{color:#fff}.validation-summary{padding:12px;border-radius:6px;margin-bottom:16px;font-weight:500}.validation-summary.valid{background:#22c55e26;border:1px solid rgba(34,197,94,.3);color:#22c55e}.validation-summary.invalid{background:#ef444426;border:1px solid rgba(239,68,68,.3);color:#ef4444}.tier-section{margin-bottom:12px;border-radius:6px;overflow:hidden;border:1px solid #333}.tier-section.passed{border-color:#22c55e4d}.tier-section.failed{border-color:#ef44444d}.tier-header{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#ffffff0d}.tier-icon{font-size:14px}.tier-title{font-weight:600;font-size:13px;color:var(--color-text, #fff)}.tier-checks{padding:8px 12px}.check-item{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:12px}.check-item.pass{color:#86efac}.check-item.fail{color:#fca5a5}.check-icon{width:16px;text-align:center}.check-name{font-weight:500;min-width:100px}.check-message{color:#999;flex:1}.check-item.pass .check-message{color:#86efac99}.check-item.fail .check-message{color:#fca5a5cc}.suggestions{background:#3b82f61a;border:1px solid rgba(59,130,246,.2);border-radius:6px;padding:12px;margin-top:12px}.suggestions h4{margin:0 0 8px;font-size:13px;color:#60a5fa}.suggestions ul{margin:0;padding-left:20px}.suggestions li{font-size:12px;color:#93c5fd;margin-bottom:4px}.validation-badge-container{position:absolute;z-index:1000}.validation-badge-container.top-left{top:20px;left:20px}.validation-badge-container.top-right{top:20px;right:80px}.validation-badge-container.bottom-left{bottom:20px;left:20px}.validation-badge-container.bottom-right{bottom:20px;right:20px}.validation-badge{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#1e1e1ef2;border-radius:8px;border:2px solid #555;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #0000004d}.validation-badge:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0006}.validation-badge.valid{border-color:#22c55e;background:linear-gradient(135deg,#1e1e1ef2,#22c55e1a)}.validation-badge.warning{border-color:#f59e0b;background:linear-gradient(135deg,#1e1e1ef2,#f59e0b1a)}.validation-badge.invalid{border-color:#ef4444;background:linear-gradient(135deg,#1e1e1ef2,#ef44441a)}.validation-badge.unknown{border-color:#6b7280}.validation-badge.validating{animation:pulse-border 1.5s infinite}@keyframes pulse-border{0%,to{border-color:#3b82f6}50%{border-color:#1d4ed8}}.badge-icon{font-size:1.2rem}.badge-label{font-size:.85rem;font-weight:600;color:#fff}.refresh-btn{background:transparent;border:none;font-size:.9rem;cursor:pointer;padding:2px 4px;border-radius:4px;transition:background .2s}.refresh-btn:hover{background:#ffffff1a}.expand-hint{font-size:.6rem;color:#888;margin-left:4px}.badge-report-wrapper{margin-top:8px;max-width:400px;max-height:400px;overflow-y:auto;border-radius:8px;box-shadow:0 8px 24px #0006}.validation-badge-container.top-right .badge-report-wrapper,.validation-badge-container.bottom-right .badge-report-wrapper{right:0}.validation-badge-container.top-left .badge-report-wrapper,.validation-badge-container.bottom-left .badge-report-wrapper{left:0}.badge-no-report{margin-top:8px;padding:16px 20px;background:#1e1e1ef2;border-radius:8px;border:1px solid #555;color:#aaa;text-align:center;box-shadow:0 4px 12px #0000004d}.badge-no-report p{margin:0 0 10px;font-size:.85rem}.validate-now-btn{padding:8px 16px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:500;transition:all .2s}.validate-now-btn:hover{background:linear-gradient(135deg,#2563eb,#1e40af);transform:translateY(-1px)}.badge-report-wrapper::-webkit-scrollbar{width:6px}.badge-report-wrapper::-webkit-scrollbar-track{background:#0003;border-radius:3px}.badge-report-wrapper::-webkit-scrollbar-thumb{background:#555;border-radius:3px}.badge-report-wrapper::-webkit-scrollbar-thumb:hover{background:#666}.keyboard-shortcuts-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9000;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease-out}.keyboard-shortcuts-panel{width:480px;max-width:90vw;max-height:80vh;background:linear-gradient(180deg,#1e1e2dfa,#141423fa);border:1px solid rgba(255,255,255,.1);border-radius:16px;box-shadow:0 25px 50px #00000080;overflow:hidden;animation:scaleIn .25s cubic-bezier(.4,0,.2,1)}.ks-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.1);background:#0003}.ks-header h2{margin:0;font-size:18px;font-weight:600;color:#f0f0f5}.ks-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#ffffff14;border:none;border-radius:6px;color:#a0a0b0;font-size:14px;cursor:pointer;transition:all .15s ease}.ks-close:hover{background:#ffffff26;color:#f0f0f5}.ks-content{padding:16px 20px;max-height:50vh;overflow-y:auto}.ks-category{margin-bottom:20px}.ks-category:last-child{margin-bottom:0}.ks-category h3{margin:0 0 10px;font-size:13px;font-weight:600;color:#a0a0b0;text-transform:uppercase;letter-spacing:.5px}.ks-list{display:flex;flex-direction:column;gap:6px}.ks-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:#ffffff0a;border-radius:8px;transition:background-color .15s ease}.ks-item:hover{background:#ffffff14}.ks-description{font-size:13px;color:#d0d0d8}.ks-keys{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;background:#6366f133;border:1px solid rgba(99,102,241,.3);border-radius:6px;font-family:SF Mono,Monaco,Consolas,monospace;font-size:11px;font-weight:600;color:#a5b4fc;letter-spacing:.5px}.ks-footer{padding:12px 20px;border-top:1px solid rgba(255,255,255,.08);background:#00000026;text-align:center}.ks-footer span{font-size:12px;color:#707080}.ks-footer kbd{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;margin:0 4px;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:4px;font-family:inherit;font-size:11px;font-weight:600;color:#a0a0b0}.placement-selector{background:var(--bg-secondary, #1e1e2e);border-radius:8px;padding:12px;font-size:13px}.selector-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.selector-header h3{margin:0;font-size:14px;font-weight:600;color:var(--text-primary, #e0e0e0)}.selection-count{font-size:11px;color:var(--text-secondary, #888);background:var(--bg-tertiary, #2a2a3a);padding:2px 8px;border-radius:10px}.element-group{margin-bottom:12px}.element-group:last-child{margin-bottom:0}.group-header{display:flex;align-items:center;gap:6px;padding:6px 8px;background:var(--bg-tertiary, #2a2a3a);border-radius:6px;font-size:12px;font-weight:500;color:var(--text-secondary, #aaa);cursor:pointer}.group-icon{font-size:10px}.group-elements{padding:8px 0 0 12px}.positions-group summary{list-style:none}.positions-group summary::-webkit-details-marker{display:none}.positions-group summary:before{display:none}.positions-group[open] .group-arrow{transform:rotate(90deg)}.placement-element{margin-bottom:6px;background:var(--bg-primary, #16161e);border-radius:6px;border:1px solid transparent;transition:all .15s ease}.placement-element:hover{border-color:var(--accent, #6366f1)}.placement-element.selected{border-color:var(--success, #22c55e);background:#22c55e1a}.element-header{display:flex;align-items:center;gap:8px;padding:8px 10px;cursor:pointer}.element-icon{font-size:10px;width:16px;text-align:center}.element-name{flex:1;font-size:12px;color:var(--text-primary, #e0e0e0)}.element-badge{font-size:9px;padding:2px 6px;border-radius:8px;text-transform:uppercase;font-weight:600}.badge-critical{background:#ef444433;color:#ef4444}.badge-important{background:#3b82f633;color:#3b82f6}.badge-recommended{background:#22c55e33;color:#22c55e}.badge-optional{background:#9ca3af33;color:#9ca3af}.badge-avoid{background:#ef44444d;color:#f87171}.placement-element.disabled{opacity:.6;border-color:#ef44444d}.placement-element.disabled:hover{border-color:#ef44444d;cursor:not-allowed}.element-header.not-selectable{cursor:not-allowed}.avoid-message{padding:6px 10px 10px;font-size:11px;color:#f87171;font-style:italic}.element-controls{display:flex;align-items:center;gap:10px;padding:0 10px 10px}.item-type-select{flex:1;padding:6px 8px;border-radius:4px;border:1px solid var(--border, #3a3a4a);background:var(--bg-secondary, #1e1e2e);color:var(--text-primary, #e0e0e0);font-size:12px;cursor:pointer}.item-type-select:focus{outline:none;border-color:var(--accent, #6366f1)}.symmetric-toggle{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--text-secondary, #888);cursor:pointer}.symmetric-toggle input{cursor:pointer}.apply-placement-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px 16px;margin-top:16px;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.apply-placement-btn:hover:not(:disabled){background:linear-gradient(135deg,#16a34a,#15803d);transform:translateY(-1px);box-shadow:0 4px 12px #22c55e4d}.apply-placement-btn:disabled{background:var(--bg-tertiary, #2a2a3a);color:var(--text-secondary, #888);cursor:not-allowed;opacity:.6}.pattern-selector{background:var(--bg-secondary, #1e1e2e);border-radius:8px;margin-bottom:12px;overflow:hidden}.pattern-selector-header{display:flex;justify-content:space-between;align-items:center;width:100%;padding:10px 12px;background:var(--bg-tertiary, #2a2a3a);border:none;color:var(--text-primary, #e0e0e0);cursor:pointer;transition:background .2s}.pattern-selector-header:hover{background:var(--bg-hover, #3a3a4a)}.header-content{display:flex;align-items:center;gap:8px;font-weight:600;font-size:13px}.header-right{display:flex;align-items:center;gap:8px}.selected-pattern-badge{font-size:11px;padding:2px 8px;background:#22c55e33;color:#22c55e;border-radius:10px}.pattern-content{padding:12px}.pattern-warning{text-align:center;color:var(--text-secondary, #888);font-size:12px;font-style:italic;padding:8px}.quick-patterns{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:12px}.quick-pattern{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;background:var(--bg-tertiary, #2a2a3a);border:2px solid transparent;border-radius:6px;cursor:pointer;transition:all .15s}.quick-pattern:hover:not(:disabled){border-color:var(--accent, #6366f1);background:#6366f11a}.quick-pattern.selected{border-color:#22c55e;background:#22c55e26}.quick-pattern:disabled{opacity:.4;cursor:not-allowed}.quick-pattern-preview{display:flex;gap:2px;font-size:12px}.quick-pattern-name{font-size:10px;color:var(--text-secondary, #aaa)}.pattern-categories{display:flex;flex-direction:column;gap:4px}.pattern-category{border-radius:6px;overflow:hidden}.category-header{display:flex;align-items:center;gap:8px;width:100%;padding:6px 10px;background:transparent;border:none;color:var(--text-secondary, #aaa);font-size:11px;cursor:pointer;transition:background .15s}.category-header:hover{background:var(--bg-tertiary, #2a2a3a)}.category-icon{font-size:10px;width:24px;text-align:center}.category-name{flex:1;text-align:left}.category-count{color:var(--text-muted, #666)}.category-patterns{display:flex;flex-direction:column;gap:4px;padding:4px 8px 8px 32px}.pattern-option{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;background:var(--bg-primary, #16161e);border:1px solid transparent;border-radius:6px;cursor:pointer;transition:all .15s}.pattern-option:hover:not(:disabled){border-color:var(--accent, #6366f1)}.pattern-option.selected{border-color:#22c55e;background:#22c55e1a}.pattern-option:disabled{opacity:.5;cursor:not-allowed}.pattern-preview{display:flex;gap:2px;font-size:14px;min-width:60px}.pattern-item{display:inline-block}.pattern-item.pattern-c{color:#3b82f6}.pattern-item.pattern-s{color:#f97316}.pattern-item.pattern--{color:#666}.pattern-info{display:flex;flex-direction:column;align-items:flex-start;flex:1;min-width:0}.pattern-name{font-size:12px;color:var(--text-primary, #e0e0e0);font-weight:500}.pattern-desc{font-size:10px;color:var(--text-secondary, #888);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.pattern-min{font-size:9px;color:var(--text-muted, #666);padding:2px 4px;background:var(--bg-tertiary, #2a2a3a);border-radius:3px}.template-manager{background:var(--bg-secondary, #1e1e2e);border-radius:8px;padding:12px;font-size:13px}.manager-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.manager-header h3{margin:0;font-size:14px;font-weight:600;color:var(--text-primary, #e0e0e0)}.header-actions{display:flex;gap:4px}.btn-icon{width:28px;height:28px;border:none;background:var(--bg-tertiary, #2a2a3a);border-radius:4px;cursor:pointer;font-size:12px;transition:background .15s}.btn-icon:hover:not(:disabled){background:var(--bg-hover, #3a3a4a)}.btn-icon:disabled{opacity:.5;cursor:not-allowed}.template-list{max-height:200px;overflow-y:auto;margin-bottom:12px}.template-item{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;margin-bottom:4px;background:var(--bg-primary, #16161e);border-radius:6px;border:1px solid transparent;cursor:pointer;transition:all .15s ease}.template-item:hover{border-color:var(--accent, #6366f1)}.template-item.selected{border-color:var(--success, #22c55e);background:#22c55e1a}.template-info{display:flex;flex-direction:column;gap:2px}.template-name{font-size:12px;font-weight:500;color:var(--text-primary, #e0e0e0)}.template-rules{font-size:10px;color:var(--text-secondary, #888)}.btn-delete{width:20px;height:20px;border:none;background:transparent;color:var(--text-secondary, #888);font-size:16px;cursor:pointer;opacity:0;transition:opacity .15s,color .15s}.template-item:hover .btn-delete{opacity:1}.btn-delete:hover{color:var(--danger, #ef4444)}.btn-apply{width:100%;padding:10px;border:none;background:var(--accent, #6366f1);color:#fff;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s}.btn-apply:hover:not(:disabled){background:var(--accent-hover, #4f46e5)}.btn-apply:disabled{opacity:.5;cursor:not-allowed}.dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.dialog{background:var(--bg-secondary, #1e1e2e);border-radius:12px;padding:20px;min-width:280px;box-shadow:0 10px 40px #0000004d}.dialog h4{margin:0 0 16px;font-size:15px;font-weight:600;color:var(--text-primary, #e0e0e0)}.dialog input{width:100%;padding:10px 12px;border:1px solid var(--border, #3a3a4a);background:var(--bg-primary, #16161e);color:var(--text-primary, #e0e0e0);border-radius:6px;font-size:13px;margin-bottom:16px}.dialog input:focus{outline:none;border-color:var(--accent, #6366f1)}.dialog-actions{display:flex;gap:8px;justify-content:flex-end}.dialog-actions button{padding:8px 16px;border:none;background:var(--bg-tertiary, #2a2a3a);color:var(--text-primary, #e0e0e0);border-radius:6px;font-size:12px;cursor:pointer;transition:background .15s}.dialog-actions button:hover{background:var(--bg-hover, #3a3a4a)}.dialog-actions button.primary{background:var(--accent, #6366f1)}.dialog-actions button.primary:hover{background:var(--accent-hover, #4f46e5)}.export-actions{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.export-actions button,.import-label{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;border:1px solid var(--border, #3a3a4a);background:var(--bg-primary, #16161e);color:var(--text-primary, #e0e0e0);border-radius:6px;font-size:13px;cursor:pointer;transition:all .15s}.export-actions button:hover,.import-label:hover{border-color:var(--accent, #6366f1);background:#6366f11a}.placement-variants{background:var(--bg-secondary, #1e1e2e);border-radius:8px;padding:12px;font-size:13px}.variants-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.variants-header h3{margin:0;font-size:14px;font-weight:600;color:var(--text-primary, #e0e0e0)}.variant-count{font-size:11px;color:var(--text-secondary, #888);background:var(--bg-tertiary, #2a2a3a);padding:2px 8px;border-radius:10px}.generate-variants-btn{width:100%;padding:10px 16px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;margin-bottom:12px}.generate-variants-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.generate-variants-btn:disabled{background:#444;cursor:not-allowed}.error-message{background:#ef444426;border:1px solid rgba(239,68,68,.3);color:#f87171;padding:8px 12px;border-radius:6px;font-size:12px;margin-bottom:12px}.category-filters{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.filter-btn{padding:4px 8px;font-size:11px;border:1px solid #444;border-radius:12px;background:transparent;color:#aaa;cursor:pointer;transition:all .15s}.filter-btn:hover{border-color:#666;color:#fff}.filter-btn.active{background:#6366f1;border-color:#6366f1;color:#fff}.filter-btn .count{opacity:.7;font-size:10px}.cat-sequential{border-color:#3b82f6}.cat-loop{border-color:#22c55e}.cat-conditional{border-color:#eab308}.cat-function{border-color:#a855f7}.cat-variable{border-color:#f97316}.cat-combination{border-color:#ec4899}.filter-btn.active.cat-sequential{background:#3b82f6;border-color:#3b82f6}.filter-btn.active.cat-loop{background:#22c55e;border-color:#22c55e}.filter-btn.active.cat-conditional{background:#eab308;border-color:#eab308}.filter-btn.active.cat-function{background:#a855f7;border-color:#a855f7}.filter-btn.active.cat-variable{background:#f97316;border-color:#f97316}.filter-btn.active.cat-combination{background:#ec4899;border-color:#ec4899}.placements-list{max-height:350px;overflow-y:auto;margin-bottom:12px}.placement-item{background:var(--bg-primary, #16161e);border-radius:6px;padding:10px;margin-bottom:8px;border:1px solid transparent;cursor:pointer;transition:all .15s}.placement-item:hover{border-color:var(--accent, #6366f1)}.placement-item.selected{border-color:var(--success, #22c55e);background:#22c55e1a}.placement-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.concept-badge{font-size:10px;padding:2px 6px;border-radius:10px;text-transform:capitalize;font-weight:500}.concept-badge.cat-sequential{background:#3b82f633;color:#3b82f6}.concept-badge.cat-loop{background:#22c55e33;color:#22c55e}.concept-badge.cat-conditional{background:#eab30833;color:#eab308}.concept-badge.cat-function{background:#a855f733;color:#a855f7}.concept-badge.cat-variable{background:#f9731633;color:#f97316}.concept-badge.cat-combination{background:#ec489933;color:#ec4899}.difficulty-badge{font-size:10px;padding:2px 6px;border-radius:10px;color:#fff;font-weight:600}.placement-name{font-size:13px;font-weight:500;color:var(--text-primary, #e0e0e0);margin-bottom:4px}.placement-meta{display:flex;gap:12px;font-size:11px;color:var(--text-secondary, #888)}.placement-details{margin-top:10px;padding-top:10px;border-top:1px solid #333;font-size:11px;color:var(--text-secondary, #aaa)}.pattern-desc{margin:0 0 8px;font-style:italic}.blocks-list{margin:0 0 8px}.items-preview{margin-top:8px}.items-preview ul{margin:4px 0 0;padding-left:16px}.items-preview li{margin:2px 0}.apply-variant-btn{width:100%;padding:10px 16px;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.apply-variant-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #22c55e4d}.empty-state{text-align:center;color:var(--text-secondary, #888);padding:20px;font-size:12px}.empty-state p{margin:0}.apply-section{display:flex;flex-direction:column;gap:8px}.toolbox-warning{background:#ef444426;border:1px solid rgba(239,68,68,.3);color:#fca5a5;padding:10px 12px;border-radius:6px;font-size:11px;line-height:1.4;display:flex;flex-wrap:wrap;align-items:center;gap:8px}.toolbox-warning strong{color:#f87171}.toolbox-suggestion{background:#22c55e1a;border:1px solid rgba(34,197,94,.25);color:#86efac;padding:8px 12px;border-radius:6px;font-size:11px;display:flex;align-items:center;gap:8px}.toolbox-suggestion strong{color:#4ade80}.suggest-toolbox-btn{padding:4px 10px;background:linear-gradient(135deg,#f97316,#ea580c);color:#fff;border:none;border-radius:4px;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}.suggest-toolbox-btn:hover{transform:translateY(-1px);box-shadow:0 2px 8px #f973164d}.suggest-toolbox-btn.small{padding:3px 8px;font-size:10px;background:#16a34a}.suggest-toolbox-btn.small:hover{background:#22c55e;box-shadow:0 2px 6px #22c55e4d}.full-editor-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.full-editor-dialog{width:90vw;max-width:1200px;height:85vh;background:#1e1e1e;border-radius:12px;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000080;border:1px solid #333;overflow:hidden}.full-editor-header{display:flex;align-items:center;padding:12px 16px;background:linear-gradient(135deg,#2d2d2d,#252525);border-bottom:1px solid #444;gap:16px}.full-editor-title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:#fff}.full-editor-title svg{color:#3b82f6}.full-editor-variables{flex:1;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.full-editor-variables-label{font-size:12px;color:#888}.full-editor-variable-badge{background:#fbbf2426;color:#fbbf24;padding:2px 8px;border-radius:4px;font-size:11px;font-family:Menlo,Monaco,Courier New,monospace}.full-editor-close{background:transparent;border:none;color:#888;cursor:pointer;padding:6px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.full-editor-close:hover{background:#ffffff1a;color:#fff}.full-editor-body{flex:1;min-height:0;overflow:hidden}.full-editor-footer{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#252525;border-top:1px solid #444}.full-editor-hint{font-size:12px;color:#888}.full-editor-hint code{background:#3b82f633;color:#60a5fa;padding:2px 6px;border-radius:4px;font-family:Menlo,Monaco,Courier New,monospace}.full-editor-done-btn{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;padding:8px 20px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease}.full-editor-done-btn:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-1px)}.full-editor-done-btn:active{transform:translateY(0)}.full-editor-body .monaco-editor,.full-editor-body .monaco-editor .margin,.full-editor-body .monaco-editor-background{background-color:#1e1e1e!important}.notebook-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.notebook-dialog{width:95vw;max-width:1400px;height:90vh;background:#1a1a1a;border-radius:12px;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #0009;border:1px solid #333;overflow:hidden}.notebook-header{display:flex;align-items:center;padding:12px 16px;background:linear-gradient(135deg,#2d2d2d,#252525);border-bottom:1px solid #444;gap:16px}.notebook-title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:#fff}.notebook-title svg{color:#f97316}.notebook-toolbar{flex:1;display:flex;align-items:center;gap:8px}.notebook-toolbar-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;font-size:12px;font-weight:500;color:#888;background:#ffffff0d;border:1px solid #444;border-radius:6px;cursor:pointer;transition:all .15s ease}.notebook-toolbar-btn:hover{color:#fff;background:#ffffff1a;border-color:#555}.notebook-toolbar-btn--primary{color:#fff;background:linear-gradient(135deg,#22c55e,#16a34a);border-color:#22c55e}.notebook-toolbar-btn--primary:hover{background:linear-gradient(135deg,#16a34a,#15803d)}.notebook-toolbar-divider{width:1px;height:24px;background:#444;margin:0 8px}.notebook-close{background:transparent;border:none;color:#888;cursor:pointer;padding:6px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.notebook-close:hover{background:#ffffff1a;color:#fff}.notebook-cells{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:8px}.notebook-cell{background:#252525;border-radius:8px;border:1px solid #333;overflow:hidden;transition:border-color .15s ease}.notebook-cell:hover{border-color:#444}.notebook-cell--markdown{border-left:3px solid #3b82f6}.notebook-cell--code{border-left:3px solid #22c55e}.notebook-cell__toolbar{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;background:#0003;border-bottom:1px solid #333}.notebook-cell__type{display:flex;align-items:center;gap:4px;font-size:10px;font-weight:600;text-transform:uppercase;color:#666}.notebook-cell--markdown .notebook-cell__type{color:#3b82f6}.notebook-cell--code .notebook-cell__type{color:#22c55e}.notebook-cell__actions{display:flex;align-items:center;gap:4px}.notebook-cell__action{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:transparent;border:none;color:#666;cursor:pointer;border-radius:4px;transition:all .15s ease}.notebook-cell__action:hover:not(:disabled){background:#ffffff1a;color:#fff}.notebook-cell__action:disabled{opacity:.3;cursor:not-allowed}.notebook-cell__action--run{color:#22c55e}.notebook-cell__action--run:hover:not(:disabled){background:#22c55e33}.notebook-cell__action--delete:hover:not(:disabled){background:#ef444433;color:#ef4444}.notebook-cell__content{min-height:60px}.notebook-cell__markdown-preview{padding:12px 16px;color:#d4d4d4;cursor:text;min-height:40px}.notebook-cell__markdown-preview:hover{background:#ffffff05}.notebook-md-h2{margin:0 0 8px;font-size:20px;font-weight:600;color:#fff}.notebook-md-h3{margin:0 0 6px;font-size:16px;font-weight:600;color:#eee}.notebook-md-h4{margin:0 0 4px;font-size:14px;font-weight:600;color:#ddd}.notebook-cell__markdown-preview p{margin:0 0 8px;line-height:1.6}.notebook-cell__markdown-preview li{margin-left:20px;line-height:1.5}.notebook-cell__markdown-preview code{background:#3b82f633;color:#60a5fa;padding:2px 6px;border-radius:4px;font-family:Menlo,Monaco,monospace;font-size:12px}.notebook-cell__markdown-edit{width:100%;min-height:100px;padding:12px 16px;background:transparent;border:none;color:#d4d4d4;font-family:Menlo,Monaco,monospace;font-size:13px;line-height:1.5;resize:vertical}.notebook-cell__markdown-edit:focus{outline:none}.notebook-cell__output{border-top:1px solid #333;background:#0000004d}.notebook-cell__output.success{border-top-color:#22c55e4d}.notebook-cell__output.error{border-top-color:#ef44444d}.notebook-cell__output-header{display:flex;align-items:center;gap:6px;padding:8px 12px;font-size:11px;font-weight:600;text-transform:uppercase;color:#666;border-bottom:1px solid #333}.notebook-cell__output.success .notebook-cell__output-header{color:#22c55e}.notebook-cell__output.error .notebook-cell__output-header{color:#ef4444}.notebook-cell__output-metrics{display:flex;gap:16px;padding:8px 12px;font-size:12px;color:#888}.notebook-cell__output-metrics span{display:flex;align-items:center;gap:4px}.notebook-cell__output-ascii{padding:12px;margin:0;font-family:Menlo,Monaco,monospace;font-size:12px;line-height:1.4;color:#d4d4d4;background:#0003;overflow-x:auto}.notebook-cell__output-error{padding:12px;margin:0;font-family:Menlo,Monaco,monospace;font-size:12px;color:#ef4444;white-space:pre-wrap;word-break:break-word}.notebook-cell__add-row{display:flex;justify-content:center;gap:8px;padding:4px 0;opacity:0;transition:opacity .15s ease}.notebook-cell:hover .notebook-cell__add-row{opacity:1}.notebook-cell__add-btn{display:flex;align-items:center;gap:4px;padding:4px 10px;font-size:10px;font-weight:500;color:#666;background:transparent;border:1px dashed #444;border-radius:4px;cursor:pointer;transition:all .15s ease}.notebook-cell__add-btn:hover{color:#fff;border-color:#666;background:#ffffff0d}.notebook-footer{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#252525;border-top:1px solid #444}.notebook-footer-info{font-size:12px;color:#666}.notebook-footer-btn{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;padding:8px 20px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease}.notebook-footer-btn:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-1px)}.spinning{animation:spin 1s linear infinite}.notebook-cell__content .monaco-editor,.notebook-cell__content .monaco-editor .margin,.notebook-cell__content .monaco-editor-background{background-color:#252525!important}.template-panel{display:flex;flex-direction:column;gap:16px;padding:16px}.template-panel__header{display:flex;align-items:center;gap:8px;padding-bottom:12px;border-bottom:1px solid var(--border-color, #333)}.template-panel__header h3{margin:0;font-size:14px;font-weight:600;color:var(--text-primary, #fff)}.template-panel__header-icon{font-size:18px}.template-selector{display:flex;flex-direction:column;gap:8px}.template-selector__label{font-size:12px;font-weight:500;color:var(--text-secondary, #aaa)}.template-selector__dropdown{padding:8px 12px;border-radius:6px;border:1px solid var(--border-color, #444);background:var(--bg-secondary, #2a2a2a);color:var(--text-primary, #fff);font-size:13px;cursor:pointer;transition:border-color .2s,box-shadow .2s}.template-selector__dropdown:hover{border-color:var(--accent-color, #4a9eff)}.template-selector__dropdown:focus{outline:none;border-color:var(--accent-color, #4a9eff);box-shadow:0 0 0 2px #4a9eff33}.template-selector__info{display:flex;flex-direction:column;gap:6px;padding:10px 12px;background:var(--bg-tertiary, #333);border-radius:6px;font-size:12px}.template-selector__difficulty{color:gold}.template-selector__concept{color:var(--text-secondary, #888);font-style:italic}.template-selector__tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px;width:100%}.template-selector__tag{font-size:10px;padding:2px 6px;border-radius:4px;background:#ffffff1a;color:#ccc;border:1px solid rgba(255,255,255,.2)}.template-variables{display:flex;flex-direction:column;background:var(--bg-tertiary, #252525);border-radius:10px;border:1px solid var(--border-color, #444)}.template-variables--expanded{border-color:#4a9eff4d}.template-variables__header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 12px;background:transparent;border:none;cursor:pointer;transition:background .15s ease}.template-variables__header:hover{background:#ffffff08}.template-variables__header-left{display:flex;align-items:center;gap:8px}.template-variables__header-left svg{color:var(--accent-color, #4a9eff)}.template-variables__title{font-size:12px;font-weight:700;color:var(--accent-color, #4a9eff);letter-spacing:.5px}.template-variables__count{display:flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;font-size:12px;font-weight:600;color:#fff;background:var(--accent-color, #4a9eff);border-radius:9px}.template-variables__header>svg{color:var(--text-secondary, #888);transition:transform .2s ease}.template-variables__auto{display:flex;align-items:center;gap:4px;margin-left:auto;font-size:11px;font-weight:500;color:var(--text-secondary, #aaa);cursor:pointer;text-transform:none;background:var(--bg-secondary, #333);padding:4px 8px;border-radius:4px;transition:all .2s}.template-variables__auto:hover{background:var(--bg-tertiary, #444);color:var(--accent-color, #4a9eff)}.template-variables__auto input{width:14px;height:14px;accent-color:var(--accent-color, #4a9eff);cursor:pointer}.template-variables__auto-info{padding:12px;background:#4a9eff1a;border:1px dashed var(--accent-color, #4a9eff);border-radius:6px;font-size:12px;color:var(--accent-color, #4a9eff);text-align:center}.template-variables__list{display:flex;flex-direction:column;gap:2px;padding:0 8px 8px}.template-variables__item{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:4px 8px;background:#00000026;border-radius:4px;border:1px solid transparent;transition:border-color .15s ease}.template-variables__item:hover{border-color:#ffffff1a;background:#0000004d}.template-variables__label{font-size:12px;font-weight:500;color:var(--text-primary, #ddd)}.template-variables__number-input{width:50px;padding:2px 4px;font-size:13px;font-weight:600;color:var(--text-primary, #fff);background:var(--bg-secondary, #333);border:1px solid var(--border-color, #444);border-radius:4px;text-align:center;transition:border-color .15s ease;height:24px}.template-variables__number-input:focus{outline:none;border-color:var(--accent-color, #4a9eff)}.template-variables__hint{font-size:10px;color:var(--text-tertiary, #666);padding:4px 8px 8px;text-align:center}.template-variables__slider{width:100%;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--bg-secondary, #333);border-radius:3px;outline:none;cursor:pointer}.template-variables__slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent-color, #4a9eff);cursor:pointer;transition:transform .1s}.template-variables__slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.template-variables__slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--accent-color, #4a9eff);cursor:pointer;border:none}.template-variables__range{display:flex;justify-content:space-between;font-size:10px;color:var(--text-tertiary, #666)}.template-variables__range-editable{display:flex;justify-content:space-between;align-items:center;gap:8px}.template-variables__range-input{width:48px;padding:4px 6px;border:1px solid var(--border-color, #444);border-radius:4px;background:var(--bg-secondary, #2a2a2a);color:var(--text-primary, #fff);font-size:11px;text-align:center;outline:none;transition:border-color .2s}.template-variables__range-input:focus{border-color:var(--accent-color, #4a9eff)}.template-variables__range-input::-webkit-inner-spin-button,.template-variables__range-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.template-variables__range-separator{color:var(--text-tertiary, #666);font-size:12px}.template-editor{display:flex;flex-direction:column;gap:8px;flex:1;min-height:200px}.template-editor__header{display:flex;align-items:center;justify-content:space-between;gap:8px}.template-editor__label{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:500;color:var(--text-secondary, #aaa)}.template-editor__full-btn{display:flex;align-items:center;gap:4px;padding:4px 10px;font-size:11px;font-weight:500;color:#888;background:transparent;border:1px solid #444;border-radius:4px;cursor:pointer;transition:all .15s ease}.template-editor__full-btn:hover{color:#fff;background:#3b82f626;border-color:#3b82f6}.template-editor__full-btn svg{color:#3b82f6}.template-editor__buttons{display:flex;gap:6px}.template-editor__full-btn--notebook:hover{background:#f9731626;border-color:#f97316}.template-editor__full-btn--notebook svg{color:#f97316}.template-editor-modes{display:flex;gap:8px}.template-editor-modes__btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;font-size:12px;font-weight:500;color:#888;background:var(--bg-tertiary, #252525);border:1px solid var(--border-color, #444);border-radius:8px;cursor:pointer;transition:all .15s ease}.template-editor-modes__btn:hover{color:#fff;background:#3b82f61a;border-color:#3b82f6}.template-editor-modes__btn svg{color:#3b82f6}.template-editor-modes__btn--notebook:hover{background:#f973161a;border-color:#f97316}.template-editor-modes__btn--notebook svg{color:#f97316}.template-editor__wrapper{position:relative;flex:1;display:flex;border:1px solid var(--border-color, #444);border-radius:6px;overflow:hidden;background:var(--bg-code, #1e1e1e)}.template-editor__lines{padding:12px 4px;background:var(--bg-tertiary, #252525);color:var(--text-tertiary, #666);font-family:Fira Code,Consolas,monospace;font-size:12px;line-height:1.5;text-align:right;-webkit-user-select:none;user-select:none;min-width:24px;border-right:1px solid var(--border-color, #333);white-space:pre}.template-editor__var-hint{margin-left:auto;font-size:10px;font-weight:400;color:var(--accent-color, #4a9eff);background:#4a9eff1a;padding:2px 8px;border-radius:4px}.template-editor__textarea{position:relative;flex:1;padding:12px;border:none;background:transparent;color:var(--text-primary, #d4d4d4);font-family:Fira Code,Consolas,monospace;font-size:12px;line-height:1.5;resize:none;outline:none;white-space:pre;overflow-x:auto;caret-color:#fff;z-index:1}.template-editor__textarea::placeholder{color:var(--text-tertiary, #555)}.template-preview{display:flex;flex-direction:column;gap:8px}.template-preview__label{font-size:12px;font-weight:500;color:var(--text-secondary, #aaa)}.template-preview__content{padding:12px;background:var(--bg-tertiary, #252525);border-radius:6px;border:1px solid var(--border-color, #333)}.template-preview__metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:12px}.template-preview__metric{display:flex;flex-direction:column;align-items:center;padding:8px;background:var(--bg-secondary, #2a2a2a);border-radius:4px}.template-preview__metric-value{font-size:18px;font-weight:600;color:var(--accent-color, #4a9eff)}.template-preview__metric-label{font-size:10px;color:var(--text-tertiary, #888);text-transform:uppercase}.template-preview__ascii{font-family:Fira Code,Consolas,monospace;font-size:13px;line-height:1.2;white-space:pre;overflow-x:auto;color:#a3e635;background:#111;padding:16px;border-radius:4px;border:1px solid #333;letter-spacing:2px}.template-preview__error{padding:12px;background:#ff64641a;border:1px solid rgba(255,100,100,.3);border-radius:6px;color:#ff6b6b;font-size:12px}.template-preview__error-title{font-weight:600;margin-bottom:4px}.template-actions{display:flex;gap:8px;padding-top:12px;border-top:1px solid var(--border-color, #333)}.template-actions__btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.template-actions__btn--primary{background:var(--accent-color, #4a9eff);color:#fff}.template-actions__btn--primary:hover:not(:disabled){background:var(--accent-hover, #3a8eef);transform:translateY(-1px)}.template-actions__btn--secondary{background:var(--bg-secondary, #333);color:var(--text-primary, #fff);border:1px solid var(--border-color, #444)}.template-actions__btn--secondary:hover:not(:disabled){background:var(--bg-tertiary, #3a3a3a)}.template-actions__btn:disabled{opacity:.5;cursor:not-allowed}.template-panel--loading{opacity:.7;pointer-events:none}@media (max-width: 400px){.template-preview__metrics{grid-template-columns:1fr}.template-actions{flex-direction:column}}.properties-panel-overlay{flex-shrink:0;display:flex;flex-direction:column}.properties-panel{background-color:var(--bg-elevated);padding:15px;box-sizing:border-box;color:var(--text-primary);flex-shrink:0;border-bottom:1px solid var(--border-solid)}.properties-panel.empty-state{display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;color:var(--text-label)}.properties-panel.empty-state p{margin:5px 0}.panel-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-solid);padding-bottom:10px;margin-bottom:15px}.panel-header h2{margin:0;font-size:1.5em}.clear-btn{background:none;border:none;color:var(--text-tertiary);font-size:20px;cursor:pointer;padding:0 5px;transition:color .2s}.clear-btn:hover{color:var(--accent-danger-hover)}.props-title{margin-top:20px;margin-bottom:15px;font-size:.9em;text-transform:uppercase;color:var(--text-tertiary);font-weight:600;border-top:1px solid var(--border-solid);padding-top:15px}.prop-group{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-size:14px}.prop-group label{color:var(--text-secondary);text-transform:capitalize}.prop-group.info-group span{color:var(--text-primary);background-color:var(--bg-tertiary);padding:4px 8px;border-radius:4px;font-family:monospace;font-size:13px}.prop-group .object-id{font-size:11px;max-width:150px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.prop-group input,.prop-group select{width:150px;background-color:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-solid);border-radius:var(--radius-xs);padding:6px 8px;box-sizing:border-box}.prop-group input:read-only{background-color:var(--bg-tertiary);color:var(--text-secondary);cursor:not-allowed}.selection-controls{margin-top:20px;padding-top:15px;border-top:1px solid var(--border-solid)}.selection-controls h3{margin-top:0;margin-bottom:10px;font-size:.9em;text-transform:uppercase;color:var(--text-tertiary);font-weight:600}.action-description{font-size:13px;color:var(--text-secondary);margin-bottom:15px;background-color:var(--bg-tertiary);padding:8px;border-radius:4px;text-align:center}.action-buttons{gap:10px}.action-buttons.single-action{display:flex}.action-buttons.multiple-actions{display:grid;grid-template-columns:1fr 1fr}.action-btn{flex-grow:1;padding:10px;border-radius:5px;border:none;cursor:pointer;font-weight:700;transition:background-color .2s;display:flex;align-items:center;justify-content:center;gap:8px}.delete-btn{background-color:#5a2d2d;color:#ffc2c2;border:1px solid #803e3e}.delete-btn:hover{background-color:#7a3b3b}.copy-btn{background-color:#2d4a5a;color:#c2eaff;border:1px solid #3e6a80}.copy-btn:hover{background-color:#3b607a}.duplicate-btn{background-color:#5a532d;color:#fffec2;border:1px solid #80773e}.duplicate-btn:hover{background-color:#7a703b}.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin .8s ease-in-out infinite}@keyframes spin{to{transform:rotate(360deg)}}.action-btn.loading{opacity:.8;cursor:wait}.quest-details-panel{background-color:var(--bg-elevated);padding:12px;box-sizing:border-box;display:flex;flex-direction:column;overflow-y:auto;gap:8px}.quest-details-panel.empty-state{justify-content:center;align-items:center;min-height:300px}.empty-state-content{text-align:center;color:var(--text-label)}.empty-state-content .empty-icon{font-size:48px;display:block;margin-bottom:16px}.empty-state-content p{margin-bottom:16px;font-size:14px}.collapsible-section{background-color:var(--bg-secondary);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-solid)}.collapsible-section .section-header{display:flex;align-items:center;width:100%;padding:12px;background:linear-gradient(180deg,var(--bg-tertiary) 0%,var(--bg-elevated) 100%);border:none;color:var(--text-primary);cursor:pointer;font-size:14px;font-weight:600;text-align:left;transition:background .2s}.collapsible-section .section-header:hover{background:linear-gradient(180deg,var(--bg-hover) 0%,var(--bg-tertiary) 100%)}.section-icon{margin-right:8px;font-size:16px}.section-title{flex:1}.section-badge{padding:2px 8px;border-radius:10px;font-size:11px;font-weight:500;margin-right:8px}.badge-green{background-color:#28a74533;color:#5cb85c}.badge-orange{background-color:#ff980033;color:#ffa726}.badge-red{background-color:#dc354533;color:#ef5350}.badge-blue{background-color:#2196f333;color:#64b5f6}.section-toggle{color:var(--text-label);font-size:10px}.section-content{padding:12px;display:flex;flex-direction:column;gap:10px}.field-row{display:flex;flex-direction:column;gap:4px}.field-row label{font-size:12px;color:var(--text-tertiary);font-weight:500}.field-row input[type=text],.field-row input[type=number],.field-row textarea{width:100%;background-color:var(--bg-input);border:1px solid var(--border-solid);color:var(--text-primary);padding:8px 10px;border-radius:var(--radius-sm);font-size:13px;box-sizing:border-box;transition:border-color .2s,box-shadow .2s}.field-row input:focus,.field-row textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-primary-glow, rgba(99, 102, 241, .2))}.custom-select{width:100%;padding:8px 10px;background-color:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-solid);border-radius:var(--radius-sm);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%27http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%27%20width%3D%27292.4%27%20height%3D%27292.4%27%3E%3Cpath%20fill%3D%27%23888888%27%20d%3D%27M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.4-5.4-12.8z%27%2F%3E%3C%2Fsvg%3E);background-repeat:no-repeat;background-position:right 10px center;background-size:10px auto;cursor:pointer}.custom-select:focus{outline:none;border-color:var(--accent-primary)}.action-row{display:flex;align-items:center;gap:10px}.button-group{display:flex;gap:8px}.button-group.vertical{flex-direction:column}.action-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 14px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;border:none;transition:all .2s}.action-btn.primary{background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-primary-active) 100%);color:#fff}.action-btn.primary:hover{background:linear-gradient(135deg,var(--accent-primary-hover) 0%,var(--accent-primary) 100%);transform:translateY(-1px);box-shadow:0 4px 12px var(--accent-primary-glow, rgba(99, 102, 241, .3))}.action-btn.secondary{background-color:var(--bg-hover);color:var(--text-primary);border:1px solid var(--border-solid)}.action-btn.secondary:hover{background-color:var(--bg-tertiary)}.action-btn.full-width{width:100%}.action-btn:disabled{opacity:.5;cursor:not-allowed}.action-btn:disabled:hover{transform:none;box-shadow:none}.toggle-btn{background:transparent;border:1px dashed var(--border-solid);color:var(--text-label);padding:8px 12px;border-radius:6px;font-size:12px;cursor:pointer;width:100%;text-align:left;transition:all .2s}.toggle-btn:hover{background-color:var(--bg-tertiary);border-color:var(--border-emphasis);color:var(--text-secondary)}.import-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;border:none;transition:all .2s}.import-btn.primary{background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-primary-active) 100%);color:#fff}.import-btn.primary:hover{background:linear-gradient(135deg,var(--accent-primary-hover) 0%,var(--accent-primary) 100%)}.solution-summary{display:flex;gap:16px;padding:10px;background-color:var(--bg-input);border-radius:var(--radius-sm);margin-top:4px}.summary-item{display:flex;align-items:center;gap:6px}.summary-item .label{color:var(--text-label);font-size:12px}.summary-item .value{color:#5cb85c;font-weight:600;font-size:13px}.info-text{font-size:12px;color:var(--text-label)}.raw-solution-editors{display:flex;flex-direction:column;gap:12px;margin-top:8px}.editor-group{display:flex;flex-direction:column;gap:4px}.editor-group label{font-size:11px;color:#888;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.json-editor{font-family:var(--font-mono);font-size:11px;line-height:1.4;background-color:var(--bg-primary);border:1px solid var(--border-solid);border-radius:var(--radius-sm);color:#b8d4e8;padding:10px;resize:vertical;width:100%;box-sizing:border-box}.json-editor:focus{outline:none;border-color:var(--accent-primary)}.sub-section{padding-top:8px;border-top:1px dashed var(--border-solid)}.translations-grid{display:flex;flex-direction:column;gap:8px;margin-top:8px}.quest-details-panel::-webkit-scrollbar{width:6px}.quest-details-panel::-webkit-scrollbar-track{background:var(--bg-secondary)}.quest-details-panel::-webkit-scrollbar-thumb{background:var(--border-solid);border-radius:3px}.quest-details-panel::-webkit-scrollbar-thumb:hover{background:#5a5a62}.sync-status{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:var(--radius-sm);font-size:12px;margin-top:4px}.sync-status.success{background-color:#28a74526;color:#5cb85c;border:1px solid rgba(40,167,69,.3)}.sync-status.error{background-color:#dc354526;color:#ef5350;border:1px solid rgba(220,53,69,.3)}.blockly-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.blockly-modal-content{background-color:var(--bg-elevated);padding:20px;border-radius:var(--radius-md);width:80vw;height:80vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.blockly-modal-header{display:flex;align-items:center;margin-bottom:15px;border-bottom:1px solid var(--border-solid);padding-bottom:10px}.blockly-modal-header h2{color:var(--text-primary);margin:0;flex-grow:1}.modal-btn{padding:8px 16px;border:none;border-radius:var(--radius-xs);cursor:pointer;font-weight:700;margin-left:10px}.save-btn{background-color:var(--accent-success);color:#fff}.save-btn:hover{background-color:var(--accent-success-hover)}.close-btn{background-color:var(--accent-danger);color:#fff}.close-btn:hover{background-color:#bd2130}.blockly-container{flex-grow:1;position:relative}.json-output-panel{padding:16px;background-color:var(--bg-elevated);border-top:1px solid var(--border-solid)}.json-output-panel .panel-header{display:flex;flex-direction:column;align-items:flex-start;margin-bottom:12px;gap:8px}.json-output-panel h3{margin:0;font-size:16px;color:var(--text-primary)}.json-output-panel .header-buttons{display:flex;gap:8px}.json-output-panel .start-blocks-btn{background-color:var(--accent-primary);color:#fff;border:none}.json-output-panel .start-blocks-btn:hover{background-color:var(--accent-primary-active)}.json-output-panel .header-buttons .render-btn,.json-output-panel .header-buttons .action-button,.json-output-panel .header-buttons .json-action-btn{background-color:var(--bg-hover)!important;color:var(--text-primary);border:1px solid var(--border-solid);padding:6px 12px;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s ease}.json-output-panel .header-buttons .render-btn:hover,.json-output-panel .header-buttons .action-button:hover,.json-output-panel .header-buttons .json-action-btn:hover{background-color:var(--bg-tertiary)!important}.json-textarea{width:100%;height:1000px;background-color:var(--bg-primary);color:var(--text-secondary);border:1px solid var(--border-solid);border-radius:var(--radius-xs);padding:10px;font-family:var(--font-mono, "Courier New", Courier, monospace);font-size:14px;resize:vertical;box-sizing:border-box;outline:none}.right-panel-tabs{display:flex;flex-direction:column;height:100%;background:var(--bg-secondary)}.tab-bar{display:flex;background:var(--bg-tertiary);border-bottom:2px solid var(--border-solid);flex-shrink:0}.tab-button{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:12px 8px;background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;transition:all .2s ease;position:relative;font-size:13px;font-weight:500}.tab-button:hover{background:var(--bg-hover);color:var(--text-primary)}.tab-button.active{background:var(--bg-secondary);color:var(--accent-primary);border-bottom:2px solid var(--accent-primary)}.tab-button.active .tab-icon{transform:scale(1.1)}.tab-icon{font-size:16px;transition:transform .2s ease}.tab-label{font-size:13px}.tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;background:var(--accent-primary);color:var(--text-primary);border-radius:10px;font-size:11px;font-weight:600;margin-left:4px}.tab-content{flex:1;overflow-y:auto;overflow-x:hidden}.tab-content::-webkit-scrollbar{width:8px}.tab-content::-webkit-scrollbar-track{background:var(--bg-secondary)}.tab-content::-webkit-scrollbar-thumb{background:var(--border-solid);border-radius:var(--radius-xs)}.tab-content::-webkit-scrollbar-thumb:hover{background:#555}@media (max-width: 320px){.tab-label{display:none}.tab-button{flex-direction:column;padding:8px 4px}}.tab-content>*{animation:fadeIn .2s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.center-toolbar{position:absolute;top:16px;left:50%;transform:translate(-50%);z-index:100;display:flex;align-items:center;gap:24px;background:#2a2a2ef2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:10px 20px;box-shadow:0 4px 12px #0000004d,0 0 0 1px #ffffff0d}.toolbar-group{display:flex;align-items:center;gap:8px}.toolbar-label{font-size:.85rem;font-weight:500;color:#ccc;white-space:nowrap}.toolbar-select{background:#ffffff14;border:1px solid transparent;border-radius:6px;color:#eee;padding:6px 12px;font-size:.85rem;cursor:pointer;transition:all .2s;min-width:100px;font-weight:500}.toolbar-select:hover{background:#ffffff26}.toolbar-select:focus{outline:none;background:#fff3;box-shadow:0 0 0 2px #ffffff1a}.toolbar-checkbox{display:flex;align-items:center;gap:6px;cursor:pointer;-webkit-user-select:none;user-select:none}.toolbar-checkbox input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--accent-primary)}.checkbox-label{font-size:.85rem;font-weight:500;color:#e0e0e0;white-space:nowrap}.toolbar-checkbox:hover .checkbox-label{color:#fff}@media (max-width: 768px){.center-toolbar{flex-direction:column;gap:12px;padding:12px 16px;top:8px}.toolbar-group{width:100%;justify-content:space-between}.toolbar-select{flex:1;min-width:auto}}.app-container{display:flex;width:100%;height:100%}.builder-scene-wrapper{flex-grow:1;min-width:0;height:100%;position:relative}.right-sidebar{height:100%;display:flex;flex-direction:column;overflow-y:auto;flex-shrink:0;border-left:1px solid var(--border-solid)}.resizer{width:5px;height:100%;background-color:var(--bg-primary);cursor:col-resize;flex-shrink:0;border-left:1px solid var(--border-solid);border-right:1px solid var(--border-solid);transition:background-color .2s}.resizer:hover{background-color:var(--accent-primary)}.toggle-sidebar-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:90;background-color:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border-solid);padding:12px 4px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;font-size:16px;width:20px}.toggle-sidebar-btn:hover{background-color:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.toggle-sidebar-btn.left{left:0;border-left:none;border-top-right-radius:8px;border-bottom-right-radius:8px;box-shadow:2px 0 5px #0003}.toggle-sidebar-btn.right{right:0;border-right:none;border-top-left-radius:8px;border-bottom-left-radius:8px;box-shadow:-2px 0 5px #0003}.mode-switcher button{flex:1;padding:10px;font-size:14px;background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-solid);border-radius:4px;cursor:pointer;transition:background-color .2s,border-color .2s}.mode-switcher button.active{background-color:var(--accent-primary);border-color:var(--accent-primary-active);color:#fff;font-weight:700}.context-menu{position:fixed;z-index:1000;background-color:var(--bg-elevated);border:1px solid var(--border-solid);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);min-width:150px;padding:5px 0}.context-menu ul{list-style:none;padding:0;margin:0}.context-menu li{padding:8px 15px;cursor:pointer;font-size:14px;color:#e0e0e0;transition:background-color .2s;display:flex;align-items:center;gap:10px}.context-menu li.has-submenu{position:relative}.context-menu .sub-menu{position:absolute;top:-6px;left:100%;margin-left:1px;max-height:400px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border-solid) var(--bg-elevated)}.context-menu .sub-menu::-webkit-scrollbar{width:8px}.context-menu .sub-menu::-webkit-scrollbar-track{background:var(--bg-elevated)}.context-menu .sub-menu::-webkit-scrollbar-thumb{background-color:var(--border-solid);border-radius:var(--radius-xs);border:2px solid var(--bg-elevated)}.context-menu-thumbnail{width:24px;height:24px;object-fit:contain;background-color:var(--bg-hover);border-radius:3px;flex-shrink:0}.context-menu li:hover{background-color:var(--accent-primary);color:#fff}.context-menu li.delete:hover{background-color:var(--accent-danger)}.context-menu li.separator{height:1px;background-color:var(--border-solid);margin:5px 0;padding:0;cursor:default}.context-menu li.separator:hover{background-color:#444}.context-menu li.separator-header{color:#999;font-weight:700;text-transform:uppercase;font-size:12px;padding:8px 15px 4px;cursor:default;display:block}:root{--bg-primary: #1a1a2e;--bg-secondary: #1e1e28;--bg-tertiary: #252530;--bg-elevated: #2a2a35;--bg-overlay: rgba(0, 0, 0, .6);--bg-input: #1a1a22;--bg-hover: #2a2a38;--surface-dark: rgba(20, 20, 30, .95);--surface-medium: rgba(30, 30, 45, .9);--surface-light: rgba(40, 40, 60, .8);--surface-hover: rgba(50, 50, 75, .9);--surface-active: rgba(60, 60, 90, .95);--surface-glass: rgba(30, 30, 36, .95);--border-subtle: rgba(255, 255, 255, .08);--border-default: rgba(255, 255, 255, .12);--border-emphasis: rgba(255, 255, 255, .2);--border-focus: rgba(99, 102, 241, .5);--border-solid: #3a3a45;--text-primary: #f0f0f5;--text-secondary: #a0a0b0;--text-tertiary: #707080;--text-muted: #505060;--text-inverse: #1a1a2e;--text-label: #888888;--accent-primary: #6366f1;--accent-primary-hover: #818cf8;--accent-primary-active: #4f46e5;--accent-success: #10b981;--accent-success-hover: #34d399;--accent-warning: #f59e0b;--accent-warning-hover: #fbbf24;--accent-danger: #ef4444;--accent-danger-hover: #f87171;--accent-info: #3b82f6;--accent-info-hover: #60a5fa;--gradient-primary: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);--gradient-success: linear-gradient(135deg, #10b981 0%, #34d399 100%);--gradient-dark: linear-gradient(180deg, rgba(30, 30, 45, 1) 0%, rgba(20, 20, 30, 1) 100%);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 8px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .5);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .6);--shadow-glow: 0 0 20px rgba(99, 102, 241, .3);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "SF Mono", "Monaco", "Consolas", monospace;--font-size-xs: 10px;--font-size-sm: 12px;--font-size-md: 14px;--font-size-lg: 16px;--font-size-xl: 18px;--font-size-2xl: 24px;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 16px;--spacing-xl: 24px;--spacing-2xl: 32px;--radius-xs: 4px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--transition-fast: .1s ease;--transition-normal: .2s ease;--transition-slow: .3s ease;--transition-smooth: .3s cubic-bezier(.4, 0, .2, 1);--transition-bounce: .4s cubic-bezier(.68, -.55, .265, 1.55);--z-base: 0;--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal-backdrop: 400;--z-modal: 500;--z-popover: 600;--z-tooltip: 700;--z-toast: 800}.btn,button,[role=button]{transition:background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast)}.btn:active,button:active,[role=button]:active{transform:scale(.98)}.panel,.sidebar,.modal,.collapsible-section{transition:opacity var(--transition-normal),transform var(--transition-smooth)}input,select,textarea{transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast)}input:focus,select:focus,textarea:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #6366f133}.card,.item-card,.asset-item{transition:transform var(--transition-normal),box-shadow var(--transition-normal),border-color var(--transition-fast)}.card:hover,.item-card:hover,.asset-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.animate-fadeIn{animation:fadeIn var(--transition-normal) forwards}.animate-fadeOut{animation:fadeOut var(--transition-normal) forwards}.animate-slideUp{animation:slideUp var(--transition-smooth) forwards}.animate-slideDown{animation:slideDown var(--transition-smooth) forwards}.animate-slideIn{animation:slideIn var(--transition-smooth) forwards}.animate-scaleIn{animation:scaleIn var(--transition-smooth) forwards}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-spin{animation:spin 1s linear infinite}.animate-bounce{animation:bounce .5s ease infinite}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb{background:var(--surface-light);border-radius:var(--radius-sm);transition:background-color var(--transition-fast)}::-webkit-scrollbar-thumb:hover{background:var(--surface-hover)}*:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}::selection{background:var(--accent-primary);color:#fff}html,body,#root{width:100%;height:100%;margin:0;padding:0;overflow:hidden;background-color:var(--bg-primary, #1a1a2e);color:var(--text-primary, #f0f0f5);font-family:var(--font-family, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif)}
