<div>
<label class="rad-label">
<input type="radio" class="rad-input" name="rad">
<div class="rad-design"></div>
<div class="rad-text">Air</div>
</label>
<label class="rad-label">
<input type="radio" class="rad-input" name="rad">
<div class="rad-design"></div>
<div class="rad-text">Clouds</div>
</label>
<label class="rad-label">
<input type="radio" class="rad-input" name="rad">
<div class="rad-design"></div>
<div class="rad-text">Earth</div>
</label>
<label class="rad-label">
<input type="radio" class="rad-input" name="rad">
<div class="rad-design"></div>
<div class="rad-text">Water</div>
</label>
</div>
<a href="https://abubakersaeed.netlify.app/designs/d15-radio-buttons" class="abs-site-link" rel="nofollow noreferrer" target="_blank">abs/designs/d15-radio-buttons</a>
/* DEFAULTS */
/* =============================================== */
body {
display: grid;
place-content: center;
min-height: 100vh;
margin: 0;
padding: 40px;
box-sizing: border-box;
font-family: system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Open Sans', sans-serif;
}
/* MAIN */
/* =============================================== */
.rad-label {
display: flex;
align-items: center;
border-radius: 100px;
padding: 14px 16px;
margin: 10px 0;
cursor: pointer;
transition: .3s;
}
.rad-label:hover,
.rad-label:focus-within {
background: hsla(0, 0%, 80%, .14);
}
.rad-input {
position: absolute;
left: 0;
top: 0;
width: 1px;
height: 1px;
opacity: 0;
z-index: -1;
}
.rad-design {
width: 22px;
height: 22px;
border-radius: 100px;
background: linear-gradient(to right bottom, hsl(154, 97%, 62%), hsl(225, 97%, 62%));
position: relative;
}
.rad-design::before {
content: '';
display: inline-block;
width: inherit;
height: inherit;
border-radius: inherit;
background: hsl(0, 0%, 90%);
transform: scale(1.1);
transition: .3s;
}
.rad-input:checked+.rad-design::before {
transform: scale(0);
}
.rad-text {
color: hsl(0, 0%, 60%);
margin-left: 14px;
letter-spacing: 3px;
text-transform: uppercase;
font-size: 18px;
font-weight: 900;
transition: .3s;
}
.rad-input:checked~.rad-text {
color: hsl(0, 0%, 40%);
}
/* ABS */
/* ====================================================== */
.abs-site-link {
position: fixed;
bottom: 40px;
left: 20px;
color: hsla(0, 0%, 0%, .5);
font-size: 16px;
}
// @AbubakerSaeed96
// abubakersaeed.netlify.app
// Trying out different styles for radio buttons while keeping them accessible so this...
// Thanks for viewing!
This Pen doesn't use any external CSS resources.
This Pen doesn't use any external JavaScript resources.