:root{
    --flash-color: var(--text-color);
    --flash-bg: var(--bg-level-2);
    --cross: var(--bleu);
}


@media screen and (max-width:599px){
    .add-flash{
        min-width: 40vw;
        max-width: calc(100vw - 20px);
    }
}

.add-flash{
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    z-index: 9998;
    position: fixed;
    bottom: 10px;
    right: 10px;
    width: 40vw;
    transform: translate(0, -100%);
    opacity: 0;
    animation: add-flash-render 10s;
    background: var(--flash-bg);
    border-radius: var(--radius);
    display: flex;
    align-items: stretch;
    overflow: hidden;
    pointer-events: none;

    div[role="button"]{
        color: var(--cross);
        cursor: pointer;
        min-width: 50px;
        align-self: center;
        display: flex;
        justify-content: center;

        &:hover{
            filter: hue-rotate(90deg);
            transform: scale(var(--scale-grow));
        }
    }

}

@keyframes add-flash-render {
    from, to {
        transform: translate(0, 100%);
        opacity: 0;
        pointer-events: auto;
    }
    5%, 95%{
        transform: translate(0, 0);
        opacity: 1;
        pointer-events: auto;
    }
}

.add-flash-indicateur-visuel {
    position: relative;
    padding: 20px;
    box-sizing: border-box;
    width: 80px;
    display: flex;
    justify-content: center;
    align-items: center;
    align-content: center;
    color: var(--blanc);
    font-size: 40px;
}

.add-flash-message{
    padding: 10px 20px;
    color: var(--flash-color);
    flex: 1;
    align-content: center;

}
