From Mozilla Developers Network:
The HTML <label> element is appropriate for form-related elements, but many form controls are implemented as a dynamic JavaScript widget, using <div>s or <span>s. WAI-ARIA, the Accessible Rich Internet Applications specification from the W3C's Web Accessibility Initiative, provides the aria-labelledby attribute for these cases.
When you come across a set of radio buttons that are properly labeled does a screen reader user know the purpose of these controls?
There is a way to logically and visually group non-standard form controls (radio buttons, check boxes, etc.)
The example below shows a radio button group implemented using an unordered list. Note the <li> element sets the aria-labelledby attribute to "rg1_label," the id of the <h3> element, which is the label for the radio group.
The form below uses a radio group implemented using an unordered list (adapted from http://www.oaa-accessibility.org/examplep/radio1/)
plus a bunch of JavaScript and CSS.
 <div role="application">
    
     <h3 id="rg1_label">Lunch   Options</h3>
    
    <ul  class="radiogroup"
    id="rg1" 
     role="radiogroup"
     aria-labelledby="rg1_label"
    >
    <li id="r1" 
     tabindex="-1"
    role="radio" 
    aria-checked="false">
    <img  role="presentation"   src="http://www.oaa-accessibility.org/media/examples/images/radio-unchecked.gif"   />
    Thai
    </li>
    <li id="r2" 
     tabindex="-1"
    role="radio" 
    aria-checked="false">
    <img  role="presentation"   src="http://www.oaa-accessibility.org/media/examples/images/radio-unchecked.gif"   />
    Subway
    </li>
    <li id="r3" 
     tabindex="-1"
    role="radio" 
    aria-checked="false">
    <img  role="presentation"   src="http://www.oaa-accessibility.org/media/examples/images/radio-unchecked.gif"   />
    Jimmy Johns
    </li>
  </ul>
  </div>