.datetime-br-wrapper {
    position: relative;
    display: block;
}

.datetime-br-wrapper > input {
    padding-right: 2.5rem;
}

.datetime-br-wrapper > input.is-valid,
.datetime-br-wrapper > input.is-invalid {
    padding-right: 4.5rem;
}

.datetime-br-wrapper .datetime-br-display {
    padding-right: 2.5rem;
}

.datetime-br-wrapper .datetime-br-native {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    cursor: pointer;
    z-index: 2;
    pointer-events: none;
}

.datetime-br-wrapper .datetime-br-btn {
    position: absolute;
    top: 50%;
    right: 0.75rem;
    transform: translateY(-50%);
    z-index: 3;
    border: 0;
    background: transparent;
    padding: 0;
    color: #6c757d;
    font-size: 1rem;
    line-height: 1;
}

.datetime-br-wrapper > input.is-valid ~ .datetime-br-btn,
.datetime-br-wrapper > input.is-invalid ~ .datetime-br-btn {
    right: 2.75rem;
}

.datetime-br-wrapper .datetime-br-btn:focus-visible {
    outline: none;
    box-shadow: 0 0 0 0.2rem rgba(102, 126, 234, 0.25);
    border-radius: 0.25rem;
}
