*{margin:0;padding:0;box-sizing:border-box}body{overflow:hidden;font-family:Arial,sans-serif}body>canvas{display:block;position:absolute;top:40px;left:25%}body.play-mode>canvas{left:0}#react-root{position:absolute;top:0;left:0;width:25%;height:100vh;z-index:10;pointer-events:none;overflow:visible}body.play-mode #react-root{width:100%}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%) translateY(-5px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.room-panel{background-color:#000000b3;color:#fff;padding:20px;height:100%;overflow-y:auto;pointer-events:auto;display:flex;flex-direction:column}.room-panel h1{font-size:20px;margin-bottom:20px;color:#87ceeb}.panel-tabs{display:flex;gap:4px;margin-bottom:16px;border-bottom:1px solid rgba(135,206,235,.3);padding-bottom:4px}.panel-tab{flex:1;padding:10px 12px;background-color:#ffffff0d;border:1px solid transparent;border-bottom:none;border-radius:6px 6px 0 0;color:#888;font-size:13px;font-weight:700;cursor:pointer;transition:all .2s;font-family:inherit}.panel-tab:hover{background-color:#ffffff1a;color:#add8e6}.panel-tab.active{background-color:#87ceeb33;border-color:#87ceeb4d;color:#87ceeb}.tab-content{flex:1;overflow-y:auto}.collapsible-tree{margin-bottom:15px}.tree-header{display:flex;align-items:center;gap:8px;width:100%;padding:10px 12px;background-color:#ffffff1a;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s;-webkit-user-select:none;user-select:none;font-family:inherit;text-align:left}.tree-header:hover{background-color:#ffffff26}.tree-toggle{font-size:10px;color:#87ceeb;width:12px;transition:transform .2s}.tree-title{font-size:14px;font-weight:700;color:#add8e6;flex:1}.tree-count{font-size:12px;color:#888;background-color:#ffffff1a;padding:2px 8px;border-radius:10px}.tree-items{padding-left:20px;margin-top:4px}.tree-item{display:block;width:100%;padding:8px 12px;font-size:14px;font-family:inherit;color:#e0e0e0;background:none;border:none;border-left:2px solid transparent;cursor:pointer;transition:all .2s;border-radius:0 4px 4px 0;text-align:left}.tree-item:hover{background-color:#ffffff1a;border-left-color:#87ceeb}.tree-item.selected{background-color:#87ceeb33;border-left-color:#fff;color:#fff}.tree-item.deletable-item{display:flex;align-items:center;padding:0}.tree-item-name{flex:1;padding:8px 12px;font-size:14px;font-family:inherit;color:inherit;background:none;border:none;cursor:pointer;text-align:left}.tree-item-delete{padding:4px 10px;font-size:16px;color:#888;background:none;border:none;cursor:pointer;transition:color .2s;font-family:inherit}.tree-item-delete:hover{color:#ff6464}.tree-item.editing{background-color:#87ceeb26}.tree-item-edit-input{flex:1;padding:6px 10px;margin:2px 4px;font-size:14px;font-family:inherit;color:#fff;background-color:#0006;border:1px solid #87ceeb;border-radius:3px;outline:none}.tree-item-edit-input:focus{border-color:#add8e6;box-shadow:0 0 4px #87ceeb66}.panel-actions{margin-top:20px;padding-top:15px;border-top:1px solid rgba(135,206,235,.3)}.btn-add-room{width:100%;padding:12px 16px;background-color:#87ceeb33;border:1px solid #87ceeb;color:#87ceeb;font-size:14px;font-weight:700;border-radius:6px;cursor:pointer;transition:all .2s}.btn-add-room:hover{background-color:#87ceeb66;color:#fff;box-shadow:0 0 10px #87ceeb4d}.btn-add-room.active{background-color:#00ff004d;border-color:#0f0;color:#0f0;box-shadow:0 0 15px #00ff004d}.btn-add-room.active:hover{background-color:#ff64644d;border-color:#ff6464;color:#ff6464;box-shadow:0 0 15px #ff64644d}.btn-add-corridor{width:100%;padding:12px 16px;margin-top:10px;background-color:#ffa50033;border:1px solid #ffa500;color:orange;font-size:14px;font-weight:700;border-radius:6px;cursor:pointer;transition:all .2s}.btn-add-corridor:hover{background-color:#ffa50066;color:#fff;box-shadow:0 0 10px #ffa5004d}.btn-add-token-line{width:100%;padding:12px 16px;margin-top:10px;background-color:#ffd70033;border:1px solid #ffd700;color:gold;font-size:14px;font-weight:700;border-radius:6px;cursor:pointer;transition:all .2s}.btn-add-token-line:hover{background-color:#ffd70066;color:#fff;box-shadow:0 0 10px #ffd7004d}.btn-add-token-line.active{background-color:#00ff004d;border-color:#0f0;color:#0f0;box-shadow:0 0 15px #00ff004d}.btn-add-token-line.active:hover{background-color:#ff64644d;border-color:#ff6464;color:#ff6464;box-shadow:0 0 15px #ff64644d}.scene-save-buttons{display:flex;flex-direction:column;gap:10px;margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid rgba(135,206,235,.3)}.btn-save-scene{width:100%;padding:12px 16px;font-size:14px;font-weight:700;border-radius:6px;cursor:pointer;transition:all .2s;font-family:inherit}.btn-save-3d{background-color:#87ceeb33;border:1px solid #87ceeb;color:#87ceeb}.btn-save-3d:hover:not(:disabled){background-color:#87ceeb66;color:#fff;box-shadow:0 0 10px #87ceeb4d}.btn-save-2d{background-color:#90ee9033;border:1px solid #90ee90;color:#90ee90}.btn-save-2d:hover:not(:disabled){background-color:#90ee9066;color:#fff;box-shadow:0 0 10px #90ee904d}.btn-save-scene:disabled{opacity:.4;cursor:not-allowed}.tree-item-empty{padding:8px 12px;font-size:13px;color:#666;font-style:italic}.data-tab-content{padding:20px 0}.data-description{color:#add8e6;font-size:14px;margin-bottom:20px;line-height:1.5}.btn-save-all{width:100%;padding:16px 20px;background-color:#32cd3233;border:1px solid #32cd32;color:#32cd32;font-size:16px;font-weight:700;border-radius:6px;cursor:pointer;transition:all .2s;font-family:inherit}.btn-save-all:hover{background-color:#32cd3266;color:#fff;box-shadow:0 0 15px #32cd3266}.storage-statistics{margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid rgba(135,206,235,.3)}.stats-section-title{font-size:14px;font-weight:700;color:#add8e6;margin:0 0 12px}.stats-section-title:not(:first-child){margin-top:20px}.stats-comparison{display:flex;gap:20px}.stats-column{flex:1;background-color:#ffffff0d;border-radius:6px;padding:12px}.stats-label{display:block;font-size:11px;font-weight:700;color:#888;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.stats-value{font-size:13px;color:#e0e0e0;padding:4px 0}.stats-timestamp{margin-top:16px;font-size:12px;color:#666;text-align:center}.camera-tab-content{padding:10px 0}.camera-section{margin-bottom:20px;background-color:#ffffff0d;border-radius:6px;padding:12px}.camera-section-title{font-size:13px;font-weight:700;color:#add8e6;margin:0 0 10px;text-transform:uppercase;letter-spacing:.5px}.camera-values{display:flex;flex-direction:column;gap:6px}.camera-value-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0}.camera-label{font-size:12px;color:#888;font-weight:500}.camera-value{font-size:14px;font-family:Courier New,Courier,monospace;color:#e0e0e0;background-color:#0000004d;padding:4px 8px;border-radius:4px;min-width:80px;text-align:right}.camera-description{color:#666;font-size:12px;margin-top:16px;text-align:center;font-style:italic}.btn-copy-camera{width:100%;padding:12px 16px;margin-top:16px;background-color:#87ceeb33;border:1px solid #87ceeb;color:#87ceeb;font-size:14px;font-weight:700;border-radius:6px;cursor:pointer;transition:all .2s;font-family:inherit}.btn-copy-camera:hover:not(:disabled){background-color:#87ceeb66;color:#fff;box-shadow:0 0 10px #87ceeb4d}.btn-copy-camera:disabled{opacity:.4;cursor:not-allowed}.edit-panel{position:fixed;top:0;right:0;width:25%;height:100vh;background-color:#000000d9;color:#fff;z-index:200;display:flex;flex-direction:column;pointer-events:auto;animation:slideIn .3s ease-out}.edit-panel-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:2px solid #87ceeb}.edit-panel-header h2{font-size:18px;color:#add8e6;margin:0}.header-title{display:flex;align-items:center;gap:10px}.back-button{background:none;border:1px solid rgba(135,206,235,.5);color:#87ceeb;font-size:18px;cursor:pointer;padding:4px 10px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s}.back-button:hover{background-color:#87ceeb33;border-color:#87ceeb;color:#fff}.close-button{background:none;border:none;color:#fff;font-size:32px;cursor:pointer;line-height:1;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:color .2s}.close-button:hover{color:#ff6b6b}.edit-panel-content{padding:20px;overflow-y:auto;flex:1}.info-section{margin-bottom:25px;background-color:#ffffff0d;border-radius:6px;padding:15px}.info-section h3{font-size:14px;color:#87ceeb;margin-bottom:12px;border-bottom:1px solid rgba(135,206,235,.3);padding-bottom:8px}.info-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:13px}.info-label{color:#888}.info-value{color:#e0e0e0;text-align:right}.edit-section{margin-bottom:25px}.edit-section h3{font-size:14px;color:#87ceeb;margin-bottom:15px;border-bottom:1px solid rgba(135,206,235,.3);padding-bottom:8px}.input-group{display:flex;flex-direction:column;gap:12px}.input-group label{display:flex;flex-direction:column;gap:5px;font-size:14px;color:#e0e0e0}.input-group input{background-color:#ffffff1a;border:1px solid rgba(135,206,235,.5);color:#fff;padding:8px 12px;border-radius:4px;font-size:14px;transition:all .2s}.input-group input:focus{outline:none;border-color:#87ceeb;background-color:#ffffff26}.input-group input:hover{border-color:#add8e6}.openings-section .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;border-bottom:1px solid rgba(135,206,235,.3);padding-bottom:8px}.openings-section .section-header h3{margin:0;border:none;padding:0}.btn-add{background-color:#87ceeb4d;border:1px solid #87ceeb;color:#87ceeb;padding:4px 12px;border-radius:4px;font-size:12px;cursor:pointer;transition:all .2s}.btn-add:hover{background-color:#87ceeb80;color:#fff}.openings-list{display:flex;flex-direction:column;gap:8px}.opening-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background-color:#ffffff0d;border-radius:4px;border-left:3px solid #00ff00;transition:all .2s}.opening-item-clickable{cursor:pointer}.opening-item-clickable:hover{background-color:#00ffff26;border-left-color:#0ff;box-shadow:0 0 8px #0ff3}.opening-wall{font-weight:700;color:#add8e6}.opening-corridor{font-weight:400;color:#0ff}.opening-item-clickable:hover .opening-wall,.opening-item-clickable:hover .opening-corridor{color:#0ff}.opening-details{font-size:12px;color:#888}.no-openings{color:#666;font-style:italic;font-size:13px}.connects-section{margin-bottom:25px;background-color:#ffffff0d;border-radius:6px;padding:15px}.connects-section h3{font-size:14px;color:#87ceeb;margin-bottom:12px;border-bottom:1px solid rgba(135,206,235,.3);padding-bottom:8px}.connects-list{display:flex;flex-direction:column;gap:8px}.room-link{background-color:#87ceeb1a;border:1px solid rgba(135,206,235,.3);color:#add8e6;padding:10px 14px;border-radius:4px;font-size:13px;cursor:pointer;transition:all .2s;text-align:left}.room-link:hover{background-color:#00ffff40;border-color:#0ff;color:#0ff;box-shadow:0 0 8px #00ffff4d}.room-link:active{background-color:#0ff6}.corridor-link{background-color:#87ceeb1a;border:1px solid rgba(135,206,235,.3);color:#add8e6;padding:10px 14px;border-radius:4px;font-size:13px;cursor:pointer;transition:all .2s;text-align:left}.corridor-link:hover{background-color:#00ffff40;border-color:#0ff;color:#0ff;box-shadow:0 0 8px #00ffff4d}.corridor-link:active{background-color:#0ff6}.position-input-row{display:grid;grid-template-columns:1fr 1fr;gap:15px}.position-input{flex:1}.position-input .numeric-input-field,.position-input .numeric-input-controls{width:100%}.section-readonly-badge{font-size:10px;color:#888;background-color:#6464644d;padding:2px 8px;border-radius:10px;margin-left:10px;font-weight:400}.numeric-input{display:flex;flex-direction:column;gap:5px;position:relative}.numeric-input-label{font-size:13px;color:#87ceeb;font-weight:500}.numeric-input-controls{display:flex;align-items:center;gap:0}.numeric-input-arrow{background-color:#87ceeb33;border:1px solid rgba(135,206,235,.5);color:#87ceeb;width:32px;height:36px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:10px;transition:all .2s}.numeric-input-decrement{border-radius:4px 0 0 4px;border-right:none}.numeric-input-increment{border-radius:0 4px 4px 0;border-left:none}.numeric-input-arrow:hover:not(:disabled){background-color:#87ceeb66;color:#fff}.numeric-input-arrow:active:not(:disabled){background-color:#87ceeb99}.numeric-input-arrow:disabled{opacity:.4;cursor:not-allowed}.numeric-input-field{background-color:#ffffff1a;border:1px solid rgba(135,206,235,.5);color:#fff;padding:8px 12px;font-size:14px;width:80px;text-align:center;transition:all .2s;-moz-appearance:textfield}.numeric-input-field::-webkit-outer-spin-button,.numeric-input-field::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.numeric-input-field:focus{outline:none;border-color:#87ceeb;background-color:#ffffff26}.numeric-input-field:hover:not(:disabled):not([readonly]){border-color:#add8e6}.numeric-input.read-only .numeric-input-field{background-color:#64646433;color:#888;cursor:not-allowed}.numeric-input.read-only .numeric-input-arrow{background-color:#64646433;color:#666;cursor:not-allowed}.numeric-input.read-only .numeric-input-label{color:#666}.numeric-input-readonly-indicator{position:absolute;right:-24px;top:50%;transform:translateY(-50%);font-size:14px;opacity:.6;cursor:help}.numeric-input.disabled .numeric-input-field,.numeric-input.disabled .numeric-input-arrow{opacity:.5;cursor:not-allowed}.numeric-input-tooltip{position:absolute;top:100%;left:50%;transform:translate(-50%);background-color:#000000e6;color:#ff6b6b;padding:6px 12px;border-radius:4px;font-size:12px;white-space:nowrap;z-index:100;margin-top:4px;animation:tooltipFadeIn .2s ease-out;border:1px solid rgba(255,107,107,.5)}.numeric-input-tooltip:before{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-bottom-color:#000000e6}.numeric-input-tooltip.min{color:#ff6b6b;border-color:#ff6b6b80}.numeric-input-tooltip.max{color:orange;border-color:#ffa50080}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#000c;display:flex;justify-content:center;align-items:center;z-index:100;pointer-events:auto}.modal-content{background-color:#1a1a2e;border:2px solid #87ceeb;border-radius:8px;width:520px;max-width:95vw;max-height:90vh;overflow-y:auto;color:#fff;pointer-events:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;border-bottom:1px solid rgba(135,206,235,.3)}.modal-header h2{margin:0;font-size:18px;color:#add8e6}.modal-header .close-button{background:none;border:none;color:#fff;font-size:32px;cursor:pointer;line-height:1;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:color .2s}.modal-header .close-button:hover{color:#ff6b6b}.modal-body{padding:20px}.modal-instructions{font-size:13px;color:#888;margin-bottom:15px;text-align:center}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:15px 20px;border-top:1px solid rgba(135,206,235,.3)}.btn-cancel{background-color:transparent;border:1px solid #666;color:#888;padding:8px 16px;border-radius:4px;cursor:pointer;transition:all .2s}.btn-cancel:hover{border-color:#888;color:#fff}.btn-confirm{background-color:#87ceeb;border:none;color:#1a1a2e;padding:8px 16px;border-radius:4px;cursor:pointer;font-weight:700;transition:all .2s}.btn-confirm:hover{background-color:#add8e6}.btn-confirm:disabled{background-color:#444;color:#666;cursor:not-allowed}.canvas-container{display:flex;justify-content:center;align-items:center;margin-bottom:20px;border-radius:4px;overflow:hidden;position:relative;width:100%;min-height:400px;background-color:#16213e}.canvas-container canvas{border-radius:4px;position:relative!important;left:auto!important;top:auto!important;display:block!important;margin:0 auto!important}.opening-controls{display:flex;gap:20px;justify-content:center;margin-bottom:20px}.control-group{display:flex;flex-direction:column;gap:5px}.control-group label{display:flex;flex-direction:column;gap:5px;font-size:13px;color:#e0e0e0}.control-group input{background-color:#ffffff1a;border:1px solid rgba(135,206,235,.5);color:#fff;padding:6px 10px;border-radius:4px;font-size:13px;width:80px}.control-group input:focus{outline:none;border-color:#87ceeb}.preview-info{background-color:#ff6b6b1a;border:1px solid rgba(255,107,107,.3);border-radius:4px;padding:12px;margin-bottom:10px}.preview-info h4{margin:0 0 8px;font-size:13px;color:#ff6b6b}.preview-info p{margin:4px 0;font-size:12px;color:#e0e0e0}.corridor-modal{width:600px}.corridor-info-message{text-align:center;padding:20px}.corridor-info-message .info-icon{font-size:48px;margin-bottom:15px}.corridor-info-message h3{color:orange;margin-bottom:15px;font-size:18px}.corridor-info-message p{color:#aaa;margin-bottom:10px;line-height:1.5}.corridor-info-message strong{color:#87ceeb}.corridor-info-message .info-steps{background-color:#87ceeb1a;border:1px solid rgba(135,206,235,.3);border-radius:6px;padding:15px;margin-top:20px;text-align:left}.corridor-info-message .info-steps p{margin-bottom:8px;color:#87ceeb}.corridor-info-message .info-steps ol{margin:0;padding-left:20px;color:#e0e0e0}.corridor-info-message .info-steps li{margin-bottom:5px}.btn-add-room-link{background-color:#87ceeb33;border:1px solid #87ceeb;color:#87ceeb;padding:8px 16px;border-radius:4px;cursor:pointer;font-weight:700;transition:all .2s}.btn-add-room-link:hover{background-color:#87ceeb66;color:#fff}.corridor-selection-container{display:flex;gap:20px;margin-bottom:20px;align-items:flex-start}.opening-selection{flex:1}.opening-selection h4{color:#87ceeb;margin-bottom:10px;font-size:14px}.opening-list{max-height:250px;overflow-y:auto;border:1px solid rgba(135,206,235,.3);border-radius:6px;background-color:#0003}.opening-option{padding:12px;cursor:pointer;border-bottom:1px solid rgba(135,206,235,.1);transition:all .2s}.opening-option:last-child{border-bottom:none}.opening-option:hover{background-color:#87ceeb1a}.opening-option.selected{background-color:#87ceeb4d;border-left:3px solid #87ceeb}.opening-option.disabled{opacity:.4;cursor:not-allowed}.opening-option.disabled:hover{background-color:transparent}.opening-room-name{font-weight:700;color:#e0e0e0;margin-bottom:4px}.opening-size{font-size:11px;color:#666;margin-top:2px}.corridor-connection-arrow{display:flex;align-items:center;justify-content:center;padding:20px 10px;color:orange;font-size:24px}.no-openings-message{padding:20px;text-align:center;color:#666;font-style:italic}.corridor-preview{background-color:#00ff001a;border:1px solid rgba(0,255,0,.3);border-radius:4px;padding:12px}.corridor-preview h4{margin:0 0 8px;font-size:13px;color:#0f0}.corridor-preview p{margin:0;font-size:12px;color:#e0e0e0}.corridor-preview strong{color:#87ceeb}#compass{position:fixed;bottom:20px;left:calc(25% + 20px);z-index:15;pointer-events:none}body.play-mode #compass{left:20px}body:has(.modal-overlay) #compass{display:none}body.view-2d .compass-needle{height:30px;transform:translate(-50%,-50%) rotate(0)!important}.compass-ring{width:80px;height:80px;border-radius:50%;background:radial-gradient(circle,#000000b3,#000000d9);border:2px solid rgba(135,206,235,.6);position:relative;box-shadow:0 0 15px #00000080,inset 0 0 20px #0000004d}.compass-direction{position:absolute;font-size:12px;font-weight:700;color:#e0e0e0;text-shadow:0 0 3px rgba(0,0,0,.8)}.compass-n{top:6px;left:50%;transform:translate(-50%);color:#ff6b6b;font-size:14px}.compass-s{bottom:6px;left:50%;transform:translate(-50%)}.compass-e{right:8px;top:50%;transform:translateY(-50%)}.compass-w{left:8px;top:50%;transform:translateY(-50%)}.compass-needle{position:absolute;top:50%;left:50%;width:4px;height:50px;transform:translate(-50%,-50%);background:linear-gradient(to top,#666,#87ceeb 45%,#ff6b6b 55%,#ff6b6b);border-radius:2px}.compass-needle:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:10px;height:10px;background:#87ceeb;border-radius:50%;box-shadow:0 0 5px #87ceeb80}#view-toggle{position:fixed;bottom:20px;right:20px;z-index:15;display:flex;gap:4px;background:#000000b3;padding:6px;border-radius:8px;border:1px solid rgba(135,206,235,.4);box-shadow:0 2px 10px #0000004d}body:has(.modal-overlay) #view-toggle{display:none}.view-toggle-btn{width:36px;height:36px;border:none;border-radius:6px;background:#ffffff1a;color:#a0a0a0;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;padding:0}.view-toggle-btn:hover{background:#87ceeb4d;color:#fff}.view-toggle-btn.active{background:#87ceeb80;color:#fff;box-shadow:0 0 8px #87ceeb66}.view-toggle-btn .icon{display:block;width:20px;height:20px;background-color:currentColor;-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center}.icon-3d{-webkit-mask-image:url("data:image/svg+xml,%3csvg%20viewBox='0%200%2024%2024'%20xmlns='http://www.w3.org/2000/svg'%20fill='black'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3e%3cpath%20d='M12%202L2%207l10%205%2010-5-10-5zM2%2017l10%205%2010-5M2%2012l10%205%2010-5'/%3e%3c/svg%3e");mask-image:url("data:image/svg+xml,%3csvg%20viewBox='0%200%2024%2024'%20xmlns='http://www.w3.org/2000/svg'%20fill='black'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3e%3cpath%20d='M12%202L2%207l10%205%2010-5-10-5zM2%2017l10%205%2010-5M2%2012l10%205%2010-5'/%3e%3c/svg%3e")}.icon-2d{-webkit-mask-image:url("data:image/svg+xml,%3csvg%20viewBox='0%200%2024%2024'%20xmlns='http://www.w3.org/2000/svg'%20fill='black'%20stroke='black'%20stroke-width='2'%3e%3crect%20x='3'%20y='3'%20width='18'%20height='18'%20rx='2'%20fill='none'/%3e%3crect%20x='7'%20y='7'%20width='4'%20height='4'/%3e%3crect%20x='13'%20y='13'%20width='4'%20height='4'/%3e%3c/svg%3e");mask-image:url("data:image/svg+xml,%3csvg%20viewBox='0%200%2024%2024'%20xmlns='http://www.w3.org/2000/svg'%20fill='black'%20stroke='black'%20stroke-width='2'%3e%3crect%20x='3'%20y='3'%20width='18'%20height='18'%20rx='2'%20fill='none'/%3e%3crect%20x='7'%20y='7'%20width='4'%20height='4'/%3e%3crect%20x='13'%20y='13'%20width='4'%20height='4'/%3e%3c/svg%3e")}.icon-settings{-webkit-mask-image:url("data:image/svg+xml,%3csvg%20viewBox='0%200%2024%2024'%20xmlns='http://www.w3.org/2000/svg'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3e%3ccircle%20cx='12'%20cy='12'%20r='3'/%3e%3cpath%20d='M19.4%2015a1.65%201.65%200%200%200%20.33%201.82l.06.06a2%202%200%200%201%200%202.83%202%202%200%200%201-2.83%200l-.06-.06a1.65%201.65%200%200%200-1.82-.33%201.65%201.65%200%200%200-1%201.51V21a2%202%200%200%201-2%202%202%202%200%200%201-2-2v-.09A1.65%201.65%200%200%200%209%2019.4a1.65%201.65%200%200%200-1.82.33l-.06.06a2%202%200%200%201-2.83%200%202%202%200%200%201%200-2.83l.06-.06a1.65%201.65%200%200%200%20.33-1.82%201.65%201.65%200%200%200-1.51-1H3a2%202%200%200%201-2-2%202%202%200%200%201%202-2h.09A1.65%201.65%200%200%200%204.6%209a1.65%201.65%200%200%200-.33-1.82l-.06-.06a2%202%200%200%201%200-2.83%202%202%200%200%201%202.83%200l.06.06a1.65%201.65%200%200%200%201.82.33H9a1.65%201.65%200%200%200%201-1.51V3a2%202%200%200%201%202-2%202%202%200%200%201%202%202v.09a1.65%201.65%200%200%200%201%201.51%201.65%201.65%200%200%200%201.82-.33l.06-.06a2%202%200%200%201%202.83%200%202%202%200%200%201%200%202.83l-.06.06a1.65%201.65%200%200%200-.33%201.82V9a1.65%201.65%200%200%200%201.51%201H21a2%202%200%200%201%202%202%202%202%200%200%201-2%202h-.09a1.65%201.65%200%200%200-1.51%201z'/%3e%3c/svg%3e");mask-image:url("data:image/svg+xml,%3csvg%20viewBox='0%200%2024%2024'%20xmlns='http://www.w3.org/2000/svg'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3e%3ccircle%20cx='12'%20cy='12'%20r='3'/%3e%3cpath%20d='M19.4%2015a1.65%201.65%200%200%200%20.33%201.82l.06.06a2%202%200%200%201%200%202.83%202%202%200%200%201-2.83%200l-.06-.06a1.65%201.65%200%200%200-1.82-.33%201.65%201.65%200%200%200-1%201.51V21a2%202%200%200%201-2%202%202%202%200%200%201-2-2v-.09A1.65%201.65%200%200%200%209%2019.4a1.65%201.65%200%200%200-1.82.33l-.06.06a2%202%200%200%201-2.83%200%202%202%200%200%201%200-2.83l.06-.06a1.65%201.65%200%200%200%20.33-1.82%201.65%201.65%200%200%200-1.51-1H3a2%202%200%200%201-2-2%202%202%200%200%201%202-2h.09A1.65%201.65%200%200%200%204.6%209a1.65%201.65%200%200%200-.33-1.82l-.06-.06a2%202%200%200%201%200-2.83%202%202%200%200%201%202.83%200l.06.06a1.65%201.65%200%200%200%201.82.33H9a1.65%201.65%200%200%200%201-1.51V3a2%202%200%200%201%202-2%202%202%200%200%201%202%202v.09a1.65%201.65%200%200%200%201%201.51%201.65%201.65%200%200%200%201.82-.33l.06-.06a2%202%200%200%201%202.83%200%202%202%200%200%201%200%202.83l-.06.06a1.65%201.65%200%200%200-.33%201.82V9a1.65%201.65%200%200%200%201.51%201H21a2%202%200%200%201%202%202%202%202%200%200%201-2%202h-.09a1.65%201.65%200%200%200-1.51%201z'/%3e%3c/svg%3e")}#canvas-2d{display:none;position:absolute;top:0;left:25%}#canvas-2d.visible{display:block}body.view-2d>canvas{display:none!important}#canvas-settings{position:relative}#settings-btn.active{background:#87ceeb80;color:#fff;box-shadow:0 0 8px #87ceeb66}.settings-dropdown{position:absolute;bottom:46px;right:0;min-width:220px;background:#141414f2;border:1px solid rgba(135,206,235,.4);border-radius:8px;padding:12px;box-shadow:0 4px 20px #00000080;display:none}.settings-dropdown.visible{display:block}.settings-dropdown h3{margin:0 0 12px;padding:0 0 8px;font-size:13px;font-weight:600;color:#87ceeb;border-bottom:1px solid rgba(135,206,235,.3);text-transform:uppercase;letter-spacing:.5px}.settings-group{margin-bottom:12px}.settings-group:last-child{margin-bottom:0}.settings-group label{display:block;font-size:11px;color:#aaa;margin-bottom:6px;text-transform:uppercase;letter-spacing:.3px}.settings-group select{width:100%;padding:8px 10px;background:#282828e6;border:1px solid rgba(135,206,235,.3);border-radius:4px;color:#e0e0e0;font-size:12px;cursor:pointer;transition:border-color .2s}.settings-group select:hover{border-color:#87ceeb99}.settings-group select:focus{outline:none;border-color:#87ceeb}.settings-group input[type=number]{width:100%;padding:8px 10px;background:#282828e6;border:1px solid rgba(135,206,235,.3);border-radius:4px;color:#e0e0e0;font-size:12px;transition:border-color .2s;box-sizing:border-box}.settings-group input[type=number]:hover{border-color:#87ceeb99}.settings-group input[type=number]:focus{outline:none;border-color:#87ceeb}.settings-toggle{display:flex;align-items:center;justify-content:space-between;padding:8px 0}.settings-toggle span{font-size:12px;color:#e0e0e0}.toggle-switch{position:relative;width:40px;height:20px;background:#3c3c3ce6;border-radius:10px;cursor:pointer;transition:background-color .2s}.toggle-switch.active{background:#87ceeb99}.toggle-switch:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;background:#e0e0e0;border-radius:50%;transition:transform .2s}.toggle-switch.active:after{transform:translate(20px)}.settings-note{margin-top:12px;padding-top:8px;border-top:1px solid rgba(135,206,235,.2);font-size:10px;color:#777;line-height:1.4}#history-controls{position:fixed;bottom:20px;right:140px;z-index:15;display:flex;gap:4px;background:#000000b3;padding:6px;border-radius:8px;border:1px solid rgba(135,206,235,.4);box-shadow:0 2px 10px #0000004d}body:has(.modal-overlay) #history-controls{display:none}body.play-mode #history-controls{display:none}.history-btn{width:36px;height:36px;border:none;border-radius:6px;background:#ffffff1a;color:#a0a0a0;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;padding:0}.history-btn:hover:not(:disabled){background:#87ceeb4d;color:#fff}.history-btn:disabled{opacity:.4;cursor:not-allowed}.history-btn.active{background:#87ceeb80;color:#fff;box-shadow:0 0 8px #87ceeb66}.history-btn .icon{display:block;width:20px;height:20px;background-color:currentColor;-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center}.icon-undo{-webkit-mask-image:url("data:image/svg+xml,%3csvg%20viewBox='0%200%2024%2024'%20xmlns='http://www.w3.org/2000/svg'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3e%3cpath%20d='M3%207v6h6'/%3e%3cpath%20d='M21%2017a9%209%200%200%200-9-9%209%209%200%200%200-6.24%202.51L3%2013'/%3e%3c/svg%3e");mask-image:url("data:image/svg+xml,%3csvg%20viewBox='0%200%2024%2024'%20xmlns='http://www.w3.org/2000/svg'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3e%3cpath%20d='M3%207v6h6'/%3e%3cpath%20d='M21%2017a9%209%200%200%200-9-9%209%209%200%200%200-6.24%202.51L3%2013'/%3e%3c/svg%3e")}.icon-redo{-webkit-mask-image:url("data:image/svg+xml,%3csvg%20viewBox='0%200%2024%2024'%20xmlns='http://www.w3.org/2000/svg'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3e%3cpath%20d='M21%207v6h-6'/%3e%3cpath%20d='M3%2017a9%209%200%200%201%209-9%209%209%200%200%201%206.24%202.51L21%2013'/%3e%3c/svg%3e");mask-image:url("data:image/svg+xml,%3csvg%20viewBox='0%200%2024%2024'%20xmlns='http://www.w3.org/2000/svg'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3e%3cpath%20d='M21%207v6h-6'/%3e%3cpath%20d='M3%2017a9%209%200%200%201%209-9%209%209%200%200%201%206.24%202.51L21%2013'/%3e%3c/svg%3e")}.icon-history{-webkit-mask-image:url("data:image/svg+xml,%3csvg%20viewBox='0%200%2024%2024'%20xmlns='http://www.w3.org/2000/svg'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3e%3cpath%20d='M14.5%202H6a2%202%200%200%200-2%202v16a2%202%200%200%200%202%202h12a2%202%200%200%200%202-2V7.5L14.5%202z'/%3e%3cpolyline%20points='14%202%2014%208%2020%208'/%3e%3cline%20x1='8'%20y1='13'%20x2='16'%20y2='13'/%3e%3cline%20x1='8'%20y1='17'%20x2='16'%20y2='17'/%3e%3cline%20x1='8'%20y1='9'%20x2='10'%20y2='9'/%3e%3c/svg%3e");mask-image:url("data:image/svg+xml,%3csvg%20viewBox='0%200%2024%2024'%20xmlns='http://www.w3.org/2000/svg'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3e%3cpath%20d='M14.5%202H6a2%202%200%200%200-2%202v16a2%202%200%200%200%202%202h12a2%202%200%200%200%202-2V7.5L14.5%202z'/%3e%3cpolyline%20points='14%202%2014%208%2020%208'/%3e%3cline%20x1='8'%20y1='13'%20x2='16'%20y2='13'/%3e%3cline%20x1='8'%20y1='17'%20x2='16'%20y2='17'/%3e%3cline%20x1='8'%20y1='9'%20x2='10'%20y2='9'/%3e%3c/svg%3e")}.history-modal .modal-content{width:450px}.history-list{max-height:400px;overflow-y:auto;margin:0;padding:0;list-style:none}.history-item{display:flex;align-items:center;padding:10px 12px;border-bottom:1px solid rgba(135,206,235,.15);transition:background-color .15s}.history-item:last-child{border-bottom:none}.history-item:hover{background-color:#87ceeb1a}.history-item-icon{width:24px;height:24px;margin-right:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.history-item-icon .icon{width:16px;height:16px;background-color:#87ceeb;-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center}.history-item-content{flex:1;min-width:0}.history-item-action{font-size:14px;color:#e0e0e0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.history-item-time{font-size:11px;color:#666;margin-top:2px}.history-item-type{font-size:11px;padding:2px 6px;border-radius:3px;background-color:#87ceeb33;color:#87ceeb;margin-left:8px;flex-shrink:0}.history-item-type.undo{background-color:#ffa50033;color:orange}.history-item-type.redo{background-color:#00ff7f33;color:#00ff7f}.history-empty{text-align:center;padding:40px 20px;color:#666;font-size:14px}.history-empty-icon{font-size:48px;margin-bottom:12px;opacity:.5}.icon-add-room{-webkit-mask-image:url("data:image/svg+xml,%3csvg%20viewBox='0%200%2024%2024'%20xmlns='http://www.w3.org/2000/svg'%20fill='black'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3e%3cpath%20d='M12%202L2%207l10%205%2010-5-10-5zM2%2017l10%205%2010-5M2%2012l10%205%2010-5'/%3e%3c/svg%3e");mask-image:url("data:image/svg+xml,%3csvg%20viewBox='0%200%2024%2024'%20xmlns='http://www.w3.org/2000/svg'%20fill='black'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3e%3cpath%20d='M12%202L2%207l10%205%2010-5-10-5zM2%2017l10%205%2010-5M2%2012l10%205%2010-5'/%3e%3c/svg%3e")}.icon-delete{background-color:#ff6b6b!important}.icon-action-undo{-webkit-mask-image:url("data:image/svg+xml,%3csvg%20viewBox='0%200%2024%2024'%20xmlns='http://www.w3.org/2000/svg'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3e%3cpath%20d='M3%207v6h6'/%3e%3cpath%20d='M21%2017a9%209%200%200%200-9-9%209%209%200%200%200-6.24%202.51L3%2013'/%3e%3c/svg%3e");mask-image:url("data:image/svg+xml,%3csvg%20viewBox='0%200%2024%2024'%20xmlns='http://www.w3.org/2000/svg'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3e%3cpath%20d='M3%207v6h6'/%3e%3cpath%20d='M21%2017a9%209%200%200%200-9-9%209%209%200%200%200-6.24%202.51L3%2013'/%3e%3c/svg%3e")}.icon-action-redo{-webkit-mask-image:url("data:image/svg+xml,%3csvg%20viewBox='0%200%2024%2024'%20xmlns='http://www.w3.org/2000/svg'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3e%3cpath%20d='M21%207v6h-6'/%3e%3cpath%20d='M3%2017a9%209%200%200%201%209-9%209%209%200%200%201%206.24%202.51L21%2013'/%3e%3c/svg%3e");mask-image:url("data:image/svg+xml,%3csvg%20viewBox='0%200%2024%2024'%20xmlns='http://www.w3.org/2000/svg'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3e%3cpath%20d='M21%207v6h-6'/%3e%3cpath%20d='M3%2017a9%209%200%200%201%209-9%209%209%200%200%201%206.24%202.51L21%2013'/%3e%3c/svg%3e")}.history-modal .modal-footer{justify-content:space-between}.btn-clear-history{background-color:transparent;border:1px solid #ff6b6b;color:#ff6b6b;padding:8px 16px;border-radius:4px;cursor:pointer;transition:all .2s}.btn-clear-history:hover{background-color:#ff6b6b33}.btn-clear-history:disabled{opacity:.4;cursor:not-allowed}.context-menu{position:fixed;background-color:#1a1a2e;border:1px solid #87ceeb;border-radius:6px;min-width:150px;box-shadow:0 4px 12px #00000080;z-index:200;overflow:hidden;pointer-events:auto}.context-menu-header{padding:8px 12px;font-size:12px;color:#888;border-bottom:1px solid rgba(135,206,235,.2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.context-menu-item{display:block;width:100%;padding:10px 12px;border:none;background:none;color:#fff;font-size:14px;text-align:left;cursor:pointer;transition:background-color .15s}.context-menu-item:hover{background-color:#87ceeb33}.context-menu-item-delete{color:#ff6b6b}.context-menu-item-delete:hover{background-color:#ff6b6b33}.top-panel{position:fixed;top:0;left:25%;right:0;height:40px;background-color:#000000d9;display:flex;align-items:center;justify-content:center;gap:20px;z-index:100;border-bottom:1px solid rgba(135,206,235,.3);pointer-events:auto}.top-panel-controls{display:flex;align-items:center;gap:8px}.top-panel-button{display:flex;align-items:center;gap:6px;padding:6px 14px;background-color:#ffffff1a;border:1px solid rgba(135,206,235,.3);border-radius:4px;color:#add8e6;font-size:13px;font-weight:700;cursor:pointer;transition:all .2s;font-family:inherit}.top-panel-button:hover:not(:disabled){background-color:#87ceeb33;border-color:#87ceeb80}.top-panel-button:disabled{opacity:.5;cursor:not-allowed}.top-panel-button.active{background-color:#87ceeb4d;border-color:#87ceeb;color:#87ceeb}.button-icon,.button-label{font-size:12px}.play-mode-hint{color:#888;font-size:12px;padding:4px 10px;background-color:#ffffff0d;border-radius:4px}.top-panel~canvas{top:40px!important}body.play-mode .top-panel{left:0}
