/* ===== OO Checkbox =====
   Tokens: theme1.css
   ===================== */

.oo-checkbox {
    position: relative;
    outline: none;
    display: inline-flex;
}

/* ── Label-Wrapper ── */

.oo-checkbox .form--label {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    cursor: pointer;
    margin: 0;
}

/* ── Nativer Input – unsichtbar, vollflächig klickbar ── */

.oo-checkbox input {
    position: absolute;
    inset: 0;
    opacity: 0;
    cursor: pointer;
    z-index: 5;
    margin: 0;
}

.oo-checkbox input:disabled {
    cursor: not-allowed;
}

/* ── Fake-Box ── */

.oo-checkbox--fake-input {
    flex-shrink: 0;
    position: relative;
    /*width: 1.1rem;
    height: 1.1rem;*/
    border: var(--oo-border-width) solid var(--oo-color-border-strong);
    border-radius: var(--oo-radius-sm);
    transition: background var(--oo-transition), border-color var(--oo-transition);
}

/* Hover */
.oo-checkbox input:not(:disabled):hover ~ .oo-checkbox--fake-input {
    border-color: var(--oo-primary);
}


/* Checked */
.oo-checkbox input:checked ~ .oo-checkbox--fake-input {
    background: var(--oo-primary);
    border-color: var(--oo-primary);
}

/* Disabled */
.oo-checkbox input:disabled ~ .oo-checkbox--fake-input {
    background: var(--oo-gray-200);
    border-color: var(--oo-color-border-strong);
    opacity: 0.6;
}

/* ── Häkchen ── */

.oo-checkbox--fake-input::after {
    content: "";
    position: absolute;
    display: none;
    left: 0.35rem;
    top: 0.15rem;
    width: 0.3rem;
    height: 0.55rem;
    border: solid var(--oo-primary-on);
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

.oo-checkbox input:checked ~ .oo-checkbox--fake-input::after {
    display: block;
}

.oo-checkbox input:disabled:checked ~ .oo-checkbox--fake-input::after {
}

/* ── Validation ── */

.oo-checkbox.invalid .oo-checkbox--fake-input {
    border-color: var(--oo-danger);
}

.oo-checkbox.invalid:hover .oo-validation-tooltip {
    display: block;
}

/* ── Label-Text-Position ── */

.oo-checkbox .form--label-text.LabelLinks {
    order: -1;
}

/* ── Checkbox Size Varianten ──────────────────────────── */

.oo-size-xs .oo-checkbox--fake-input {
    width: 0.85rem;
    height: 0.85rem;
}

    .oo-size-xs .oo-checkbox--fake-input::after {
        left: 0.27rem;
        top: 0.1rem;
        width: 0.22rem;
        height: 0.42rem;
    }

.oo-size-sm .oo-checkbox--fake-input {
    width: 1rem;
    height: 1rem;
}

    .oo-size-sm .oo-checkbox--fake-input::after {
        left: 0.32rem;
        top: 0.13rem;
        width: 0.27rem;
        height: 0.5rem;
    }

.oo-size-md .oo-checkbox--fake-input {
    width: 1.1rem;
    height: 1.1rem;
}

    .oo-size-md .oo-checkbox--fake-input::after {
        left: 0.35rem;
        top: 0.15rem;
        width: 0.3rem;
        height: 0.55rem;
    }

.oo-size-lg .oo-checkbox--fake-input {
    width: 1.35rem;
    height: 1.35rem;
}

    .oo-size-lg .oo-checkbox--fake-input::after {
        left: 0.44rem;
        top: 0.18rem;
        width: 0.37rem;
        height: 0.68rem;
    }

.oo-size-xl .oo-checkbox--fake-input {
    width: 1.6rem;
    height: 1.6rem;
}

    .oo-size-xl .oo-checkbox--fake-input::after {
        left: 0.53rem;
        top: 0.22rem;
        width: 0.44rem;
        height: 0.82rem;
    }

/* Ende Size */