/* --- Animations für das Einblenden und Verschieben --- */

.hidden {
    display: none;  /* Damit das Element nicht angezeigt wird, wenn es versteckt ist */
}

.showElement {
    animation: fadeInMoveDown 0.5s ease-out forwards;
}

.hideElement {
    animation: fadeOutMoveUp 0.5s ease-out forwards;
}

@keyframes fadeInMoveDown {
    0% {
        opacity: 0;
        transform: translateY(-20px); /* Startet etwas über der Position */
    }
    100% {
        opacity: 1;
        transform: translateY(0); /* Endposition, zentriert */
    }
}

@keyframes fadeOutMoveUp {
    0% {
        opacity: 1;
        transform: translateY(0);
    }
    100% {
        opacity: 0;
        transform: translateY(-20px); /* Bewegt sich nach oben */
    }
}


.button {
    --color: #00A97F;
    padding: 0.8em 1.7em;
    background-color: transparent;
    border-radius: .3em;
    position: relative;
    overflow: hidden;
    cursor: pointer;
    transition: .5s;
    font-weight: 400;
    font-size: 17px;
    border: 1px solid;
    color: var(--color);
    z-index: 1;
    min-width: 10em;
    margin-bottom: 10px;
    margin-right: 10px;
}

.button::before, .button::after {
    content: '';
    display: block;
    width: 50px;
    height: 50px;
    transform: translate(-50%, -50%);
    position: absolute;
    border-radius: 50%;
    z-index: -1;
    background-color: var(--color);
    transition: 1s ease;
}

.button::before {
    top: -1em;
    left: -1em;
}

.button::after {
    left: calc(100% + 1em);
    top: calc(100% + 1em);
}

.button:hover::before, .button:hover::after {
    height: 410px;
    width: 410px;
}

.button:hover {
    color: rgb(10, 25, 30);
}

.button:active {
    filter: brightness(.8);
}
