/* region checkbox */
.form-check-input,
.form-switch-input {
    flex-shrink: 0;
    width: 1em;
    height: 1em;
    vertical-align: top;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-image: var(--bs-form-check-bg-image);
    background-color: var(--fnd-input-color);
    border-color: var(--fnd-input-border-color);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    -webkit-print-color-adjust: exact;
    color-adjust: exact;
    print-color-adjust: exact;
    margin-top: 0 !important;
    cursor: pointer;
    border: 2px solid var(--fnd-input-border-color);
}

.form-check-input[type=checkbox] {
    border-radius: .25em
}
.form-check-input[type=radio] {
    border-radius: 50%
}
.form-switch-input {
    --bs-form-switch-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='rgba%280, 0, 0, 0.25%29'/%3e%3c/svg%3e");
    width: 2em;
    margin-left: -2.5em;
    background-image: var(--bs-form-switch-bg);
    background-position: left center;
    border-radius: 2em;
    transition: background-position .15s ease-in-out;
    border: 2px solid var(--fnd-input-border-color);
}

.form-check-input:active,
.form-switch-input:active {
    filter: brightness(90%)
}

.form-check-input:focus {
    border-color: transparent;
    outline: 0;
    box-shadow: none;
}
.form-switch-input:focus {
    --bs-form-switch-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%2386b7fe'/%3e%3c/svg%3e");
    border-color: transparent;
    outline: 0;
    box-shadow: none;
}

.form-check-input:checked {
    background-color: var(--fnd-accent-1-color);
    border-color: var(--fnd-accent-1-color)
}
.form-check-input:checked[type=checkbox] {
    --bs-form-check-bg-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3e%3cpath fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='m6 10 3 3 6-6'/%3e%3c/svg%3e")
}
.form-check-input:checked[type=radio] {
    --bs-form-check-bg-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='2' fill='%23fff'/%3e%3c/svg%3e")
}
.form-switch-input:checked {
    background-color: var(--fnd-accent-1-color);
    border-color: var(--fnd-accent-1-color);
    background-position: right center;
    --bs-form-switch-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%23fff'/%3e%3c/svg%3e")
}

.form-check-input[type=checkbox]:indeterminate {
    background-color: var(--fnd-accent-1-color);
    border-color: var(--fnd-accent-1-color);
    --bs-form-check-bg-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3e%3cpath fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='M6 10h8'/%3e%3c/svg%3e")
}

.form-check-input:disabled,
.form-switch-input:disabled {
    pointer-events: none;
    filter: none;
    opacity: .4
}

/* endregion */

/* region switch selector */
.btn-check {
    clip: rect(0, 0, 0, 0);
    pointer-events: none
}

.btn-check:has(+label) {
    display: none;
}

.btn-check:disabled + label {
    pointer-events: none;
    filter: none;
    opacity: .4
}

.btn-check + label {
    min-height: 38px;
    text-transform: uppercase;
}

.selector-container {
    position: relative;
    display: flex;
    justify-content: space-between;
}

.selector-container .btn-check {
    display: none;
}

.selector-container .selector-highlight {
    position: absolute;
    top: 4px;
    bottom: 4px;
    left: 0;
    width: 0;
    transition: all 0.3s ease;
    z-index: 1;
}

/* endregion */