$checkbox-size: 20px;
$check-width: 14px;
$check-height: 14px;
$check: '';

.check {
  @apply relative flex;
}

.check:hover {
  cursor: pointer;
}

.check-text {
  @apply block;
  padding-left: ($checkbox-size * 1.75);
  line-height: $checkbox-size;
  min-height: $checkbox-size;
}

.check-text::before,
.check-text::after {
  content: '';
}

.check-text::before {
  @apply absolute top-0 left-0 block rounded border border-border-line-purple;
  width: $checkbox-size;
  height: $checkbox-size;
}

.check-text::after {
  @apply absolute block opacity-0;
  top: (($checkbox-size - $check-height) / 2);
  left: (($checkbox-size - $check-width) / 2);
  width: $check-width;
  height: $check-height;
  transition: background-color 150ms ease-in-out, opacity 150ms ease-in-out;
  background: url($check) center no-repeat;
}

.check-input:checked ~ .check-text::after {
  opacity: 1;
}

.check-input:checked ~ .check-text::before {
  @apply bg-support-purple border-support-purple;
}

.check-input {
  position: absolute;
  left: -999em;
}

/* Disabled checkbox */
.check-input[disabled] ~ .check-text::before {
  @apply bg-dead-state-purple border-dead-state-purple;
}

.check-input[disabled] ~ .check-text {
  @apply text-dead-state-purple;
}
