*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background-color:#f8fafc;color:#1e293b}.p-2{padding:.5rem}.flex{display:flex}.gap-2{gap:.5rem}a{color:#3b82f6;text-decoration:none}a:hover{text-decoration:underline}a.active{font-weight:700;color:#1e40af}hr{border:none;border-top:1px solid #e2e8f0;margin:.5rem 0}h3{margin:0 0 1rem;color:#1e293b}h4{margin:0 0 .5rem;font-size:1rem;color:#374151}.mb-4{margin-bottom:1rem}.w-5{width:1.25rem}.h-5{height:1.25rem}.items-center{align-items:center}.modeling-app{display:flex;height:100vh;background:#f8fafc;position:relative}.scene-hierarchy-panel{position:absolute;top:20px;left:20px;z-index:10}.inspector-panel{position:absolute;bottom:20px;left:20px;z-index:10}.scene-info-panel{position:absolute;top:20px;right:20px;z-index:10}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.toolbar{position:absolute;bottom:20px;left:50%;transform:translate(-50%);height:60px;background:#1e293bf2;border:1px solid #475569;border-radius:16px;display:flex;align-items:center;padding:8px 12px;z-index:10;backdrop-filter:blur(8px);box-shadow:0 8px 24px #0003}.toolbar-main{display:flex;align-items:center;gap:4px}.toolbar-button{width:44px;height:44px;background:transparent;border:none;border-radius:10px;color:#94a3b8;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;position:relative}.toolbar-button:hover{background:#374151;color:#f1f5f9}.toolbar-button.active{background:#3b82f6;color:#fff}.toolbar-icon{width:20px;height:20px}.add-menu{position:absolute;bottom:70px;right:8px;background:#1e293bf2;border:1px solid #475569;border-radius:12px;padding:8px;display:flex;flex-direction:column;gap:4px;box-shadow:0 8px 24px #0003;backdrop-filter:blur(8px);z-index:15}.add-menu-button{width:36px;height:36px;background:transparent;border:none;border-radius:4px;color:#94a3b8;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.add-menu-button:hover{background:#374151;color:#f1f5f9}.viewport{width:100vw;height:100vh;background:#fff;position:relative;overflow:hidden}.viewport-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#64748b;text-align:center}.viewport-placeholder h3{margin-bottom:1rem;color:#334155}.viewport-placeholder p{margin:.5rem 0}.viewport-placeholder strong{color:#3b82f6;text-transform:capitalize}.scene-info{width:200px;background:#1e293bf2;border:1px solid #475569;border-radius:12px;backdrop-filter:blur(8px);box-shadow:0 8px 24px #0003;overflow:hidden}.scene-stats{margin:0}.undo-redo-controls{padding:12px 16px;border-bottom:1px solid #475569;background:#0f172a80}.undo-redo-buttons{display:flex;gap:8px;margin-bottom:8px}.undo-btn,.redo-btn{background:#334155cc;border:1px solid #475569;color:#e2e8f0;padding:8px 12px;border-radius:6px;cursor:pointer;font-size:12px;transition:all .15s ease;flex:1;display:flex;align-items:center;justify-content:center;gap:4px}.undo-btn:hover:not(:disabled),.redo-btn:hover:not(:disabled){background:#475569e6;border-color:#64748b}.undo-btn:disabled,.redo-btn:disabled{opacity:.5;cursor:not-allowed}.undo-redo-info{font-size:11px;color:#e2e8f0;text-align:center}.history-info{display:flex;flex-direction:column;gap:2px}.current-action{font-weight:700;color:#f1f5f9}.history-count{color:#cbd5e1;opacity:.9;font-size:10px}.inspector{width:280px;background:#1e293bf2;border:1px solid #475569;border-radius:12px;backdrop-filter:blur(8px);box-shadow:0 8px 24px #0003;overflow:hidden;z-index:10}.inspector-header{padding:12px 16px;border-bottom:1px solid #475569;background:#0f172a80}.inspector-header h3{margin:0 0 6px;color:#f1f5f9;font-size:13px;font-weight:600}.object-info{display:flex;flex-direction:column;gap:3px}.object-name{color:#e2e8f0;font-size:11px;font-weight:500}.object-type{color:#94a3b8;font-size:10px;text-transform:capitalize}.inspector-content{padding:12px 16px}.inspector-placeholder{color:#64748b;font-size:12px;text-align:center;margin:0}.property-section{margin-bottom:16px}.property-section h4{margin:0 0 8px;color:#e2e8f0;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.property-group{display:flex;align-items:center;gap:6px;margin-bottom:8px}.property-group label{color:#cbd5e1;font-size:10px;font-weight:500;min-width:85px;flex-shrink:0}.property-group input[type=range]{flex:1;height:4px;background:#475569;border-radius:2px;outline:none;-webkit-appearance:none}.property-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;background:#3b82f6;border-radius:50%;cursor:pointer;box-shadow:0 2px 4px #0003}.property-group input[type=range]::-moz-range-thumb{width:14px;height:14px;background:#3b82f6;border-radius:50%;cursor:pointer;border:none;box-shadow:0 2px 4px #0003}.property-value{color:#f1f5f9;font-size:11px;font-weight:600;min-width:24px;text-align:right;flex-shrink:0}.scene-hierarchy{background:#1e293bf2;backdrop-filter:blur(10px);border:1px solid #475569;border-radius:12px;box-shadow:0 8px 24px #0003;overflow:visible;width:280px;max-height:400px;display:flex;flex-direction:column}.hierarchy-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid #475569;background:#0f172a80;border-radius:12px 12px 0 0}.hierarchy-header h3{margin:0;font-size:14px;font-weight:600;color:#f1f5f9}.add-object-dropdown{position:relative}.add-object-button{width:24px;height:24px;border-radius:50%;border:1px solid #475569;background:#334155cc;color:#e2e8f0;cursor:pointer;font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.add-object-button:hover{background:#475569e6;border-color:#64748b}.add-object-menu{position:absolute;top:100%;right:0;background:#1e293bf2;border:1px solid #475569;border-radius:8px;box-shadow:0 8px 24px #0000004d;backdrop-filter:blur(8px);z-index:1000;min-width:120px;overflow:hidden;margin-top:4px}.add-object-menu button{width:100%;padding:8px 12px;background:none;border:none;text-align:left;cursor:pointer;font-size:12px;color:#e2e8f0;transition:background .15s ease;display:flex;align-items:center;gap:8px}.add-object-menu button:hover{background:#334155cc}.hierarchy-tree{flex:1;overflow-y:auto;overflow-x:hidden;padding:4px 0 0;max-height:300px;border-radius:0 0 12px 12px;min-height:100px;transition:background-color .15s ease}.hierarchy-empty-drop-zone{min-height:40px;margin:8px;border:2px dashed transparent;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;opacity:0;pointer-events:none}.hierarchy-empty-drop-zone.visible{opacity:1;pointer-events:auto;border-color:#3b82f6;background:#3b82f61a}.hierarchy-empty-drop-zone.drop-over{border-color:#2563eb;background:#3b82f633;transform:scale(1.02)}.drop-zone-text{color:#3b82f6;font-size:12px;font-weight:500;text-align:center}.hierarchy-node{position:relative}.hierarchy-item{display:flex;align-items:center;padding:6px 8px;margin:1px 8px;border-radius:4px;cursor:pointer;user-select:none;gap:6px;transition:all .15s ease;position:relative;min-height:32px}.hierarchy-item:hover{background:#33415580}.hierarchy-item.selected{background:#3b82f633;border:1px solid #3b82f6}.hierarchy-item.dragging{opacity:.5;transform:rotate(2deg)}.hierarchy-item.drop-target,.hierarchy-item.drop-target-child{background:#3b82f633;border:2px dashed #3b82f6;border-radius:4px}.hierarchy-item.drop-target-child:after{content:"Make Child";position:absolute;top:-20px;right:4px;background:#3b82f6;color:#fff;padding:2px 6px;border-radius:3px;font-size:10px;font-weight:500;z-index:10}.hierarchy-item.drop-target-before:before{content:"";position:absolute;top:-2px;left:0;right:0;height:2px;background:#10b981;border-radius:1px}.hierarchy-item.drop-target-before:after{content:"Insert Before";position:absolute;top:-20px;right:4px;background:#10b981;color:#fff;padding:2px 6px;border-radius:3px;font-size:10px;font-weight:500;z-index:10}.hierarchy-item.drop-target-after:before{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background:#10b981;border-radius:1px}.hierarchy-item.drop-target-after:after{content:"Insert After";position:absolute;top:-20px;right:4px;background:#10b981;color:#fff;padding:2px 6px;border-radius:3px;font-size:10px;font-weight:500;z-index:10}.hierarchy-item.drop-target-sibling{background:#10b98133;border:2px dashed #10b981;border-radius:4px}.hierarchy-item.drop-target-sibling:after{content:"Reorder";position:absolute;top:-20px;right:4px;background:#10b981;color:#fff;padding:2px 6px;border-radius:3px;font-size:10px;font-weight:500;z-index:10}.expand-icon{font-size:8px;color:#6b7280;width:12px;text-align:center;cursor:pointer;user-select:none}.object-icon{font-size:14px;width:16px;text-align:center;flex-shrink:0}.object-name{flex:1;font-size:12px;font-weight:500;color:#e2e8f0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.object-type{font-size:10px;color:#94a3b8;text-transform:uppercase;font-weight:500;letter-spacing:.05em;flex-shrink:0}.rename-input{flex:1;padding:2px 4px;border:1px solid #3b82f6;border-radius:2px;font-size:12px;background:#1e293be6;color:#e2e8f0;outline:none}.hierarchy-children{margin-left:12px}.empty-hierarchy{padding:32px 16px;text-align:center;color:#94a3b8;font-size:12px;font-style:italic}.hierarchy-tree::-webkit-scrollbar{width:4px}.hierarchy-tree::-webkit-scrollbar-track{background:transparent}.hierarchy-tree::-webkit-scrollbar-thumb{background:#0003;border-radius:2px}.hierarchy-tree::-webkit-scrollbar-thumb:hover{background:#0000004d}
