
.pergoline-radio {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    border: none;
}

.pergoline-radio:hover .pergoline-radio-button {
    border-color: #060606;
}

.pergoline-radio-button {
    width: 20px;
    height: 20px;
    border-radius: 50%;
    border: 1px solid #b4b4b4;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: border-color 0.2s;
    background-color: #fff;
}

.pergoline-radio-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background-color: #060606;
    display: none;
}


.pergoline-radio-color-swatch {
    width: 18px;
    height: 18px;
    border-radius: 2px;
    flex-shrink: 0;
}

.pergoline-radio-label {
    color: #1e1e1e;
    font-size: 14px;
    font-weight: 500;
    line-height: 150%;
}

/* Focus styles for accessibility */
.pergoline-radio:focus {
    outline: 2px solid #060606;
    outline-offset: 2px;
    border-radius: 4px;
}

/* Hidden radio input for semantic HTML */
.pergoline-radio input[type="radio"] {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.pergoline-radio.checked > .pergoline-radio-button > .pergoline-radio-dot {
    display: block;
}








.card{
  max-width: 350px;
  width: 100%;
  margin: 170px auto;
  background: #fff;
  border-radius: 5px;
  padding: 20px;
  box-shadow: 0 5px 10px rgba(0, 0, 0, 0.15);
}
.card .title{
  font-size: 22px;
  font-weight: 500;
}
.card .content{
  margin-top: 20px;
}
.card  label.box{
  background: #ddd;
  margin-top: 12px;
  padding: 10px 12px;
  display: flex;
  border-radius: 5px;
  border: 2px solid transparent;
  cursor: pointer;
  transition: all 0.25s ease;
}
#one:checked ~ label.first,
#two:checked ~ label.second,
#three:checked ~ label.third{
  border-color: #8E49E8;
  background: #d5bbf7;
}
.card  label.box:hover{
  background: #d5bbf7;
}
.card  label.box .circle{
  height: 22px;
  width: 22px;
  background: #ccc;
  border: 5px solid transparent;
  display: inline-block;
  margin-right: 15px;
  border-radius: 50%;
  transition: all 0.25s ease;
  box-shadow: inset -4px -4px 10px rgba(0, 0, 0, 0.2);
}
#one:checked ~ label.first .circle,
#two:checked ~ label.second .circle,
#three:checked ~ label.third .circle{
  border-color: #8E49E8;
  background: #fff;
}
.card  label.box .plan{
  display: flex;
  width: 100%;
  align-items: center;
}
.card input[type="radio"]{
  display: none;
}


