:root{--color-primary: #646cff;--color-primary-hover: #535bf2;--color-primary-active: #4249d6;--color-background-dark: #1a1a1a;--color-background-medium: #2d2d2d;--color-background-light: #323232;--color-background-lighter: #3a3a3a;--color-background-input: #373737;--color-background-input-focus: #424242;--color-border: #404040;--color-border-light: #505050;--color-text-primary: #e0e0e0;--color-text-secondary: #888;--color-text-disabled: #666;--color-success: #4caf50;--color-error: #ff4444;--color-error-bg: rgba(255, 68, 68, .95);--color-warning: #ff9800;--color-delete: #f44336;--spacing-xs: 5px;--spacing-sm: 10px;--spacing-md: 12px;--spacing-lg: 15px;--spacing-xl: 20px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .2);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .5);--shadow-primary: 6px 0 16px rgba(100, 108, 255, .6);--shadow-success: 0 4px 12px rgba(76, 175, 80, .3);--shadow-warning: 0 4px 12px rgba(255, 152, 0, .3);--z-base: 1;--z-editor: 10;--z-header: 50;--z-overlay: 100;--z-dropdown: 1000;--z-notification: 1000;--transition-fast: .2s;--transition-medium: .3s;--font-xs: 12px;--font-sm: 13px;--font-md: 14px;--font-lg: 16px;--font-xl: 18px}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#e8e8e8;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.app-container{display:flex;gap:20px;padding:0 20px 20px;height:100vh;box-sizing:border-box;background-color:#fff}.editor-section{display:flex;flex-direction:column;gap:0;min-width:550px;height:calc(100vh - 40px);overflow:visible;position:relative;transition:all .3s ease;border-radius:12px;margin-top:20px;flex-shrink:0}.editor-section.collapsed{min-width:0;max-width:50px}.collapse-toggle-btn{position:absolute;right:-16px;top:50%;transform:translateY(-50%);z-index:100;width:32px;height:80px;background:linear-gradient(135deg,#646cff,#535bf2);color:#fff;border:none;border-radius:12px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:4px 0 12px #00000080}.collapse-toggle-btn.collapsed{position:fixed;left:0;right:auto;border-radius:0 12px 12px 0}.collapse-toggle-btn:hover{background:linear-gradient(135deg,#535bf2,#4249d6);width:36px;box-shadow:6px 0 16px #646cff99}.collapse-toggle-btn:active{transform:translateY(-50%) scale(.95)}.editor-container{display:flex;flex-direction:column;gap:10px;flex:1;min-height:0;overflow:hidden;background-color:#1e1e1e;padding:20px;border-radius:0}.editor-container h2{margin:0;font-size:1.2rem;flex-shrink:0;color:#fff}.editor-wrapper{flex:1;position:relative;display:flex;flex-direction:column;min-height:0;overflow:hidden}.editor-text-wrapper{flex:1;min-width:0;overflow:hidden}.editor-with-lines{flex:1;display:flex;border:1px solid #404040;border-radius:0;overflow:hidden;min-height:0;background-color:#2d2d2d}.line-numbers{background-color:#252525;color:#666;padding:10px 8px;text-align:right;font-family:Courier New,Courier,monospace;font-size:14px;line-height:1.5;-webkit-user-select:none;user-select:none;overflow-y:scroll;overflow-x:hidden;border-right:1px solid #404040;min-width:40px;scrollbar-width:none;-ms-overflow-style:none}.line-numbers::-webkit-scrollbar{display:none}.line-number{height:21px}.json-editor{flex:1;font-family:Courier New,Courier,monospace;font-size:14px;line-height:1.5;padding:10px;border:none;outline:none;resize:none;box-sizing:border-box;transition:border-color .3s;width:100%;height:100%;background-color:#2d2d2d;color:#e0e0e0}.json-editor:focus{background-color:#323232}.json-editor-error,.editor-with-lines.has-error{border:2px solid #ff4444}.json-error-overlay{position:absolute;bottom:10px;left:10px;right:10px;padding:8px 12px;background-color:#ff4444f2;color:#fff;border-radius:4px;font-size:13px;box-shadow:0 2px 8px #0003;pointer-events:none;z-index:10;animation:errorSlideUp .3s ease-out}@keyframes errorSlideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.preview-section{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden;position:relative;padding-top:80px;margin-top:20px;border-radius:12px;background-color:#fff}.preview-container{display:flex;flex-direction:column;gap:10px;flex:1;min-height:0;background:#fff}.preview-container h2{margin:0;font-size:1.2rem;flex-shrink:0}.floorplan-svg{border:none;background:#fff;width:100%;height:100%;flex:1}.floorplan-svg g[data-room-id]:hover .room-fill{fill:#e3f2fd}.floorplan-svg g[data-room-id]:hover .room-outline{stroke:#2196f3;stroke-width:3}.floorplan-svg g[data-room-id]:hover .room-rect{cursor:pointer}.floorplan-svg .door-group:hover rect,.floorplan-svg .door-group:hover path{stroke:#4caf50;stroke-width:3;cursor:pointer}.floorplan-svg .window-group:hover rect{fill:#fff3e0;stroke:#ff9800;stroke-width:3;cursor:pointer}.floorplan-svg .room-object:hover{opacity:.8;stroke:#9c27b0;stroke-width:2;cursor:pointer}.button-row{display:flex;gap:10px;flex-shrink:0;min-height:48px;align-items:center;padding:10px;background-color:#2d2d2d;border-radius:0 0 12px 12px}.upload-button,.download-button,.share-button{padding:12px 16px;font-size:13px;font-weight:600;background-color:#646cff;color:#fff;border:none;border-radius:6px;cursor:pointer;transition:background-color .2s;flex:1;white-space:nowrap}.upload-button:hover,.download-button:hover,.share-button:hover{background-color:#535bf2}.upload-button:active,.download-button:active,.share-button:active{background-color:#4249d6}.format-button{padding:8px 16px;font-size:13px;font-weight:500;background-color:transparent;color:#888;border:1px solid #404040;border-radius:4px;cursor:pointer;transition:all .2s}.format-button:hover{background-color:#2d2d2d;color:#b0b0b0;border-color:#505050}.format-button:active{background-color:#353535}.download-svg-button{position:absolute;bottom:20px;left:20px;padding:12px 24px;font-size:13px;font-weight:600;background-color:#646cff;color:#fff;border:none;border-radius:6px;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #0003;z-index:10}.download-svg-button:hover{background-color:#535bf2}.download-svg-button:active{background-color:#4249d6}.svg-control-buttons{position:absolute;bottom:20px;right:20px;display:flex;flex-direction:column;gap:8px;z-index:10}.add-room-button,.add-part-button,.add-door-button,.add-window-button,.add-object-button{padding:10px 20px;font-size:14px;font-weight:600;color:#fff;border:none;border-radius:6px;cursor:pointer;transition:all .2s;box-shadow:0 2px 6px #0003;min-width:120px}.add-room-button{background-color:#4caf50;font-size:16px;padding:12px 24px}.add-room-button:hover{background-color:#45a049}.add-room-button:active{background-color:#3d8b40}.add-part-button{background-color:#26a69a}.add-part-button:hover{background-color:#00897b}.add-part-button:active{background-color:#00796b}.add-door-button{background-color:#2196f3}.add-door-button:hover{background-color:#1976d2}.add-door-button:active{background-color:#1565c0}.add-window-button{background-color:#ff9800}.add-window-button:hover{background-color:#f57c00}.add-window-button:active{background-color:#e65100}.add-object-button{background-color:#9c27b0}.add-object-button:hover{background-color:#7b1fa2}.add-object-button:active{background-color:#6a1b9a}.delete-element-button{padding:10px 20px;font-size:14px;font-weight:600;color:#e53935;background-color:#fff;border:2px solid #e53935;border-radius:6px;cursor:pointer;transition:all .2s;box-shadow:0 2px 6px #00000026;min-width:120px;display:flex;align-items:center;justify-content:center;gap:6px}.delete-element-button:before{content:"✕";font-size:12px;font-weight:700}.delete-element-button:hover{background-color:#ffebee;border-color:#c62828;color:#c62828}.delete-element-button:active{background-color:#ffcdd2;border-color:#b71c1c;color:#b71c1c}.add-object-container{position:relative;display:inline-block}.object-type-menu{position:absolute;bottom:100%;left:0;margin-bottom:4px;background-color:#2d2d2d;border:1px solid #444;border-radius:4px;box-shadow:0 4px 12px #0000004d;z-index:1000;min-width:120px;overflow:hidden}.object-type-option{display:block;width:100%;padding:10px 16px;font-size:13px;font-weight:500;color:#fff;background-color:transparent;border:none;text-align:left;cursor:pointer;font-family:inherit;transition:background-color .2s}.object-type-option:hover{background-color:#9c27b0}.object-type-option:active{background-color:#7b1fa2}.grid-settings-container{position:absolute;bottom:20px;left:200px;z-index:10}.grid-settings-button{padding:12px 20px;font-size:13px;font-weight:600;background-color:#607d8b;color:#fff;border:none;border-radius:6px;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #0003;min-width:130px}.grid-settings-button:hover{background-color:#546e7a}.grid-settings-button:active{background-color:#455a64}.grid-step-menu{position:absolute;bottom:100%;left:0;margin-bottom:4px;background-color:#2d2d2d;border:1px solid #444;border-radius:6px;box-shadow:0 4px 12px #0000004d;min-width:130px;overflow:hidden}.grid-step-option{display:block;width:100%;padding:10px 16px;font-size:13px;font-weight:500;color:#fff;background-color:transparent;border:none;text-align:left;cursor:pointer;font-family:inherit;transition:background-color .2s}.grid-step-option:hover{background-color:#607d8b}.grid-step-option.active{background-color:#455a64;font-weight:700}.grid-step-option:active{background-color:#546e7a}.grid-custom-input-container{display:flex;padding:8px;gap:6px;border-bottom:1px solid #444}.grid-custom-input{flex:1;padding:8px 10px;font-size:13px;font-family:inherit;background-color:#3d3d3d;color:#fff;border:1px solid #555;border-radius:4px;min-width:0}.grid-custom-input:focus{outline:none;border-color:#607d8b}.grid-custom-input::placeholder{color:#888}.grid-custom-input::-webkit-outer-spin-button,.grid-custom-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.grid-custom-input[type=number]{-moz-appearance:textfield}.grid-custom-apply-btn{padding:8px 12px;font-size:12px;font-weight:600;font-family:inherit;background-color:#607d8b;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.grid-custom-apply-btn:hover{background-color:#546e7a}.grid-custom-apply-btn:active{background-color:#455a64}.grid-presets-divider{padding:6px 16px;font-size:11px;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.5px}.zoom-controls{position:absolute;top:70px;right:20px;display:flex;flex-direction:column;align-items:center;gap:4px;z-index:10;background-color:#f5f5f5f2;padding:6px 10px;border-radius:8px;box-shadow:0 2px 8px #0000001a}.zoom-button{width:32px;height:32px;padding:0;font-size:18px;font-weight:600;background-color:#fff;color:#555;border:1px solid #ccc;border-radius:4px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.zoom-button:hover{background-color:#f0f0f0;border-color:#aaa;color:#333}.zoom-button:active{background-color:#e5e5e5}.zoom-level{font-size:12px;font-weight:500;color:#666;min-width:45px;text-align:center;padding:0 4px}.dsl-editor-container{height:100%;display:flex;flex-direction:column;background-color:#1e1e1e;color:#d4d4d4;font-family:Consolas,Monaco,Courier New,monospace;font-size:14px;line-height:1.5;overflow:hidden;border-radius:12px 12px 0 0}.dsl-editor-header{display:flex;align-items:center;padding:10px;background-color:#2d2d2d;border-radius:12px 12px 0 0;font-size:13px;font-weight:600;color:#888;flex-shrink:0}.dsl-code-mirror-wrapper{flex:1;min-height:0;overflow:hidden}.dsl-codemirror{height:100%;border-radius:0;overflow:hidden}.dsl-codemirror .cm-editor{height:100%;border-radius:0}.dsl-editor-wrapper{display:flex;height:100%;position:relative}.dsl-line-numbers{background-color:#252525;color:#858585;padding:10px;text-align:right;-webkit-user-select:none;user-select:none;min-width:50px;border-right:1px solid #3e3e42;overflow-y:hidden;overflow-x:hidden}.dsl-line-numbers div{padding-right:10px;line-height:1.5}.dsl-editor-content{flex:1;position:relative;overflow:hidden}.dsl-highlight{position:absolute;top:0;left:0;width:100%;height:100%;padding:10px;overflow:auto;pointer-events:none;white-space:pre;word-wrap:normal;overflow-wrap:normal;z-index:0}.dsl-highlight pre{margin:0;padding:0;font-family:inherit;font-size:inherit;line-height:inherit}.dsl-highlight code{font-family:inherit;font-size:inherit;line-height:inherit}.dsl-textarea{position:absolute;top:0;left:0;width:100%;height:100%;padding:10px;margin:0;border:none;outline:none;background:transparent;color:transparent;font-family:inherit;font-size:inherit;line-height:inherit;resize:none;overflow:auto;white-space:pre;word-wrap:normal;overflow-wrap:normal;caret-color:#fff;z-index:1;-webkit-text-fill-color:transparent}.dsl-textarea::selection{background-color:#3a71cf80;color:transparent}.dsl-textarea::-moz-selection{background-color:#3a71cf80;color:transparent}.dsl-textarea:disabled{cursor:not-allowed;opacity:.6}.dsl-keyword{color:#569cd6;font-weight:700}.dsl-identifier{color:#4ec9b0}.dsl-number{color:#b5cea8}.dsl-string{color:#ce9178}.dsl-comment{color:#6a9955;font-style:italic}.dsl-wall,.dsl-swing{color:#c586c0}.dsl-anchor{color:gold;font-weight:500}.dsl-object-type{color:#4ec9b0}.dsl-color{color:#ce9178}.dsl-punctuation{color:#fff;font-weight:500}@keyframes highlight-fade-out{0%{background-color:#ffd50066}70%{background-color:#ffd50040}to{background-color:transparent}}.cm-highlighted-line{background-color:#ffd50066!important;animation:highlight-fade-out 2s ease-out forwards;border-radius:2px}.dsl-docs-panel{display:flex;align-items:center;gap:12px;padding:6px 12px;background-color:#1e1e1e;border-top:1px solid #3c3c3c;font-size:12px;font-family:system-ui,-apple-system,sans-serif;color:#ccc;height:28px;box-sizing:border-box;flex-shrink:0}.dsl-docs-title{color:#569cd6;font-weight:700;flex-shrink:0}.dsl-docs-syntax{color:#4ec9b0;background-color:#2d2d2d;padding:2px 6px;border-radius:3px;font-size:11px;font-family:Consolas,Monaco,monospace;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:400px}._menu_m9kia_1{position:absolute;top:100%;right:0;margin-top:var(--spacing-xs);background-color:var(--color-background-medium);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:var(--z-dropdown);min-width:250px;max-height:400px;overflow-y:auto}._menuItem_m9kia_16{width:100%;padding:var(--spacing-sm) var(--spacing-lg);text-align:left;background-color:transparent;color:var(--color-text-primary);border:none;cursor:pointer;font-size:var(--font-md);transition:background-color var(--transition-fast);border-bottom:1px solid var(--color-border)}._menuItem_m9kia_16:hover{background-color:var(--color-background-lighter)}._divider_m9kia_33{height:1px;background-color:var(--color-border-light);margin:var(--spacing-xs) 0}._label_m9kia_39{padding:var(--spacing-sm) var(--spacing-lg) var(--spacing-xs) var(--spacing-lg);font-size:var(--font-xs);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase}._empty_m9kia_47{padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-sm);color:var(--color-text-disabled);font-style:italic}._savedItem_m9kia_54{display:flex;align-items:center;border-bottom:1px solid var(--color-border)}._loadButton_m9kia_60{flex:1;padding:var(--spacing-sm) var(--spacing-lg);text-align:left;background-color:transparent;color:var(--color-text-primary);border:none;cursor:pointer;font-size:var(--font-sm);transition:background-color var(--transition-fast)}._loadButton_m9kia_60:hover{background-color:var(--color-background-lighter)}._deleteButton_m9kia_76{padding:var(--spacing-sm) var(--spacing-lg);background-color:transparent;color:var(--color-delete);border:none;cursor:pointer;font-size:var(--font-xl);font-weight:700;transition:all var(--transition-fast)}._deleteButton_m9kia_76:hover{background-color:var(--color-delete);color:#fff}._header_szyff_1{display:flex;gap:var(--spacing-sm);align-items:center;background-color:var(--color-background-medium);padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--radius-xl);position:absolute;top:0;left:var(--spacing-xl);right:var(--spacing-xl);z-index:var(--z-header);box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--color-border);transition:left var(--transition-medium)}.show-grid ._header_szyff_1{left:20px}._nameInput_szyff_23{padding:8px 12px;font-size:var(--font-md);font-weight:600;background-color:var(--color-background-input);color:var(--color-text-primary);border:1px solid var(--color-border);border-radius:var(--radius-sm);transition:border-color var(--transition-medium);flex:1}._nameInput_szyff_23:focus{outline:none;border-color:var(--color-primary);background-color:var(--color-background-input-focus)}._menuContainer_szyff_41{position:relative}._menuButton_szyff_45{padding:8px 16px;font-size:var(--font-md);font-weight:600;background-color:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background-color var(--transition-fast);white-space:nowrap}._menuButton_szyff_45:hover{background-color:var(--color-primary-hover)}._container_dof0d_1{position:absolute;top:70px;left:var(--spacing-xl);display:flex;gap:var(--spacing-sm);z-index:var(--z-header);transition:left var(--transition-medium)}.show-grid ._container_dof0d_1{left:20px}._button_dof0d_15{padding:8px 16px;font-size:var(--font-sm);font-weight:600;background-color:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}._button_dof0d_15:hover:not(:disabled){background-color:var(--color-primary-hover)}._button_dof0d_15:active:not(:disabled){background-color:var(--color-primary-active)}._button_dof0d_15:disabled{background-color:#3a3a3a;color:#888;cursor:not-allowed;opacity:.7}._manualLink_dof0d_43{display:inline-flex;align-items:center;padding:8px 16px;font-size:var(--font-sm);font-weight:600;background-color:var(--color-primary);color:#fff;border-radius:var(--radius-md);text-decoration:none;transition:background-color var(--transition-fast);box-shadow:var(--shadow-sm)}._manualLink_dof0d_43:hover{background-color:var(--color-primary-hover)}._panel_1tyi2_1{position:absolute;bottom:var(--spacing-xl);left:var(--spacing-xl);right:var(--spacing-xl);background-color:var(--color-background-medium);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-md);box-shadow:var(--shadow-lg);z-index:var(--z-overlay);max-height:200px;overflow-y:auto}._jsonError_1tyi2_16,._positioningError_1tyi2_17,._positioningWarning_1tyi2_18{padding:8px var(--spacing-md);margin-bottom:var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-sm)}._jsonError_1tyi2_16:last-child,._positioningError_1tyi2_17:last-child,._positioningWarning_1tyi2_18:last-child{margin-bottom:0}._jsonError_1tyi2_16,._positioningError_1tyi2_17{background-color:var(--color-error-bg);color:#fff}._positioningWarning_1tyi2_18{background-color:#ff9800f2;color:#fff}._update_1l7sn_1{position:absolute;top:var(--spacing-xl);left:50%;transform:translate(-50%);background-color:var(--color-success);color:#fff;padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--radius-lg);font-weight:600;font-size:var(--font-md);box-shadow:var(--shadow-success);z-index:var(--z-notification);animation:_slideInTop_1l7sn_1 var(--transition-medium) ease-out,_fadeOut_1l7sn_1 var(--transition-medium) ease-in .7s}._copy_1l7sn_19{position:absolute;top:var(--spacing-xl);left:50%;transform:translate(-50%);background-color:var(--color-success);color:#fff;padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--radius-lg);font-weight:600;font-size:var(--font-md);box-shadow:var(--shadow-success);z-index:var(--z-notification);animation:_slideInTop_1l7sn_1 var(--transition-medium) ease-out}._urlError_1l7sn_35{position:absolute;top:var(--spacing-xl);left:50%;transform:translate(-50%);background-color:var(--color-warning);color:#fff;padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--radius-lg);font-weight:600;font-size:var(--font-md);box-shadow:var(--shadow-warning);z-index:var(--z-notification);animation:_slideInTop_1l7sn_1 var(--transition-medium) ease-out}@keyframes _slideInTop_1l7sn_1{0%{transform:translate(-50%) translateY(-50px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}@keyframes _fadeOut_1l7sn_1{0%{opacity:1}to{opacity:0}}
