/* CUSTOM CHECKBOX STYLES */

/* Usage Example (HTML):
----------------------------------------------
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Custom Checkbox Example</title>
    <!-- Link to the custom checkbox CSS -->
    <link rel="stylesheet" href="custom-checkbox.css">
</head>
<body>

<div class="checkbox-wrapper">
  <input type="checkbox" id="custom_checkbox">
  <label for="custom_checkbox">
    <div class="tick_mark"></div>
  </label>
</div>

</body>
</html>
----------------------------------------------
*/

/* BEGIN CUSTOM CHECKBOX */
.hfm-checkbox-wrapper {
    -webkit-tap-highlight-color: transparent;
    outline: none;
}

.hfm-checkbox-wrapper input[type="checkbox"] {
    /* Hide the original checkbox */
    display: none;
}

.hfm-checkbox-wrapper label {
    /* Set size and default colors */
    --hfm-size: 30px; /* Adjust the size here */
    --hfm-shadow: calc(var(--hfm-size) * .07) calc(var(--hfm-size) * .1);

    /* Styling the checkbox visual representation */
    position: relative;
    display: block;
    width: var(--hfm-size);
    height: var(--hfm-size);
    margin: 0 auto;
    background-color: #f72414; /* Default unchecked color */
    border-radius: 50%;
    box-shadow: 0 var(--hfm-shadow) #ffbeb8;
    cursor: pointer;
    transition: 0.2s ease transform, 0.2s ease background-color, 0.2s ease box-shadow;
    overflow: hidden;
    z-index: 1;
}

.hfm-checkbox-wrapper label:before {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    left: 0;
    width: calc(var(--hfm-size) * .7);
    height: calc(var(--hfm-size) * .7);
    margin: 0 auto;
    background-color: #fff;
    transform: translateY(-50%);
    border-radius: 50%;
    box-shadow: inset 0 var(--hfm-shadow) #ffbeb8;
    transition: 0.2s ease width, 0.2s ease height;
}

.hfm-checkbox-wrapper label:hover:before {
    /* Change size slightly on hover */
    width: calc(var(--hfm-size) * .55);
    height: calc(var(--hfm-size) * .55);
    box-shadow: inset 0 var(--hfm-shadow) #ff9d96;
}

.hfm-checkbox-wrapper label:active {
    /* Reduce scale when clicked */
    transform: scale(0.9);
}

.hfm-checkbox-wrapper .hfm-tick_mark {
    position: absolute;
    top: -1px;
    right: 0;
    left: calc(var(--hfm-size) * -.05);
    width: calc(var(--hfm-size) * .6);
    height: calc(var(--hfm-size) * .6);
    margin: 0 auto;
    margin-left: calc(var(--hfm-size) * .14);
    transform: rotateZ(-40deg);
}

.hfm-checkbox-wrapper .hfm-tick_mark:before,
.hfm-checkbox-wrapper .hfm-tick_mark:after {
    content: "";
    position: absolute;
    background-color: #fff;
    border-radius: 2px;
    opacity: 0;
    transition: 0.2s ease transform, 0.2s ease opacity;
}

.hfm-checkbox-wrapper .hfm-tick_mark:before {
    left: 0;
    bottom: 0;
    width: calc(var(--hfm-size) * .1);
    height: calc(var(--hfm-size) * .3);
    box-shadow: -2px 0 5px rgba(0, 0, 0, 0.23);
    transform: translateY(calc(var(--hfm-size) * -.68));
}

.hfm-checkbox-wrapper .hfm-tick_mark:after {
    left: 0;
    bottom: 0;
    width: 100%;
    height: calc(var(--hfm-size) * .1);
    box-shadow: 0 3px 5px rgba(0, 0, 0, 0.23);
    transform: translateX(calc(var(--hfm-size) * .78));
}

.hfm-checkbox-wrapper input[type="checkbox"]:checked + label {
    /* Change color when checked */
    background-color: #07d410;
    box-shadow: 0 var(--hfm-shadow) #92ff97;
}

.hfm-checkbox-wrapper input[type="checkbox"]:checked + label:before {
    width: 0;
    height: 0;
}

.hfm-checkbox-wrapper input[type="checkbox"]:checked + label .hfm-tick_mark:before,
.hfm-checkbox-wrapper input[type="checkbox"]:checked + label .hfm-tick_mark:after {
    transform: translate(0);
    opacity: 1;
}
/* END CUSTOM CHECKBOX */
