.kb-popup{z-index:9998;color:#aaa;background:#14141ef7;border:1px solid #444;border-radius:4px;width:210px;padding:6px;font:11px monospace;position:fixed;box-shadow:0 2px 10px #00000080}.kb-title{color:#ccc;justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.kb-close{cursor:pointer}.kb-row{align-items:center;gap:6px;margin:3px 0;display:flex}.kb-label{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.kb-key{text-align:center;color:#cde;cursor:pointer;background:#236ea340;border:1px solid #444;border-radius:3px;min-width:46px;padding:2px 6px}.kb-key.capturing{color:#fff;background:#33aaff59;border-color:#3af9}.kb-reset{cursor:pointer;color:#666;padding:2px 4px}.kb-reset:hover{color:#aaa}.kb-warn{color:#f99;white-space:normal;min-height:14px;margin-top:4px;line-height:1.3}.camera-slider{cursor:pointer;appearance:none;border:none;border-radius:2px;outline:none;width:100%;height:3px}.camera-slider::-webkit-slider-thumb{appearance:none;cursor:pointer;background:#236ea3;border:1px solid #3af9;border-radius:50%;width:10px;height:10px}.camera-slider::-moz-range-thumb{cursor:pointer;background:#236ea3;border:1px solid #3af9;border-radius:50%;width:10px;height:10px}.camera-axis-label{font-family:monospace;font-size:13px}.camera-value-label{color:#555;font-family:monospace;font-size:12px}.camera-tooltip{z-index:9999;color:#ccc;pointer-events:none;white-space:normal;background:#14141ef7;border:1px solid #444;border-radius:4px;max-width:180px;padding:5px 8px;font:11px/1.35 monospace;position:fixed;box-shadow:0 2px 8px #00000080}.camera-icon-btn{cursor:pointer;color:#aaa;align-items:center;margin-left:auto;padding:0 2px;display:inline-flex}.camera-icon-btn:hover{color:#fff}.camera-scroll{scrollbar-width:thin;scrollbar-color:#555 #0000}.camera-scroll::-webkit-scrollbar{width:8px}.camera-scroll::-webkit-scrollbar-track{background:0 0}.camera-scroll::-webkit-scrollbar-thumb{background:#555;border-radius:4px}.camera-scroll::-webkit-scrollbar-thumb:hover{background:#777}body{margin:0;overflow:hidden}canvas{display:block}#ui-root{z-index:10;pointer-events:auto;position:absolute;inset:0}.ui-panel{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#14141ed9;border:1px solid #444;border-radius:8px;flex-direction:column;align-items:flex-start;gap:8px;padding:10px;display:flex}.ui-panel button{color:#fff;cursor:pointer;background:#222;border:1px solid #444;padding:4px 8px}.ui-panel button:hover{border-color:#888}.tile-btn{cursor:pointer;width:48px;height:48px;image-rendering:pixelated;border:2px solid #333}.tile-btn.selected{border-color:#fff}input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{appearance:textfield}.peel-slider{cursor:pointer;appearance:none;border:none;border-radius:2px;outline:none;width:100%;height:3px}.peel-slider::-webkit-slider-thumb{appearance:none;cursor:pointer;background:#236ea3;border:1px solid #3af9;border-radius:50%;width:10px;height:10px}.peel-slider::-moz-range-thumb{cursor:pointer;background:#236ea3;border:1px solid #3af9;border-radius:50%;width:10px;height:10px}.peel-axis-label{font-family:monospace;font-size:13px}.peel-value-label{color:#555;font-family:monospace;font-size:12px}.peel-scroll{scrollbar-width:thin;scrollbar-color:#555 #0000}.peel-scroll::-webkit-scrollbar{width:8px}.peel-scroll::-webkit-scrollbar-track{background:0 0}.peel-scroll::-webkit-scrollbar-thumb{background:#555;border-radius:4px}.peel-scroll::-webkit-scrollbar-thumb:hover{background:#777}.light-slider{cursor:pointer;appearance:none;border:none;border-radius:2px;outline:none;width:100%;height:3px}.light-slider::-webkit-slider-thumb{appearance:none;cursor:pointer;background:#236ea3;border:1px solid #3af9;border-radius:50%;width:10px;height:10px}.light-slider::-moz-range-thumb{cursor:pointer;background:#236ea3;border:1px solid #3af9;border-radius:50%;width:10px;height:10px}.light-axis-label{font-family:monospace;font-size:13px}.light-value-label{color:#555;font-family:monospace;font-size:12px}.light-scroll{scrollbar-width:thin;scrollbar-color:#555 #0000}.light-scroll::-webkit-scrollbar{width:8px}.light-scroll::-webkit-scrollbar-track{background:0 0}.light-scroll::-webkit-scrollbar-thumb{background:#555;border-radius:4px}.light-scroll::-webkit-scrollbar-thumb:hover{background:#777}.light-icon-btn{cursor:pointer;color:#aaa;align-items:center;margin-left:auto;padding:0 2px;display:inline-flex}.light-icon-btn:hover{color:#fff}.mesh-slider{cursor:pointer;appearance:none;border:none;border-radius:2px;outline:none;width:100%;height:3px}.mesh-slider::-webkit-slider-thumb{appearance:none;cursor:pointer;background:#236ea3;border:1px solid #3af9;border-radius:50%;width:10px;height:10px}.mesh-slider::-moz-range-thumb{cursor:pointer;background:#236ea3;border:1px solid #3af9;border-radius:50%;width:10px;height:10px}.mesh-axis-label{font-family:monospace;font-size:13px}.mesh-value-label{color:#555;font-family:monospace;font-size:12px}.mesh-scroll{scrollbar-width:thin;scrollbar-color:#555 #0000}.mesh-scroll::-webkit-scrollbar{width:8px}.mesh-scroll::-webkit-scrollbar-track{background:0 0}.mesh-scroll::-webkit-scrollbar-thumb{background:#555;border-radius:4px}.mesh-scroll::-webkit-scrollbar-thumb:hover{background:#777}.timeline-slider{cursor:pointer;appearance:none;border:none;border-radius:2px;outline:none;width:100%;height:3px}.timeline-slider::-webkit-slider-thumb{appearance:none;cursor:pointer;background:#236ea3;border:1px solid #3af9;border-radius:50%;width:10px;height:10px}.timeline-slider::-moz-range-thumb{cursor:pointer;background:#236ea3;border:1px solid #3af9;border-radius:50%;width:10px;height:10px}.timeline-scroll{scrollbar-width:thin;scrollbar-color:#555 #0000}.timeline-scroll::-webkit-scrollbar{width:8px}.timeline-scroll::-webkit-scrollbar-track{background:0 0}.timeline-scroll::-webkit-scrollbar-thumb{background:#555;border-radius:4px}.timeline-scroll::-webkit-scrollbar-thumb:hover{background:#777}
