.page-footer .footer {
    z-index: 1; /* Ajustado para 2 para mover para frente da outra div */
    --footer-background: #660000;
    display: grid;
    position: relative;
    grid-area: footer;
    margin-bottom: -50px;
}

.page-footer .footer .bubbles {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 1rem;
    max-height: fit-content;
    background: var(--footer-background);
    filter: url("#blob");
}

.page-footer .footer .bubbles .bubble {
    position: absolute;
    left: var(--position, 50%);
    background: var(--footer-background);
    border-radius: 100%;
    animation: bubble-size var(--time, 4s) ease-in infinite var(--delay, 0s), bubble-move var(--time, 4s) ease-in infinite var(--delay, 0s);
    transform: translate(-50%, 65%);
}

.page-footer .footer .contents {
    z-index: 3; /* Ajustado para 3 para estar na frente do rodapé */
    display: grid;
    grid-template-columns: 1fr auto;
    grid-gap: 2%;
    padding: 2%;
    background: var(--footer-background);
}

.page-footer .footer .contents a,
.page-footer .footer .contents p {
  color: #f5f7fa;
  text-decoration: none;
}

.page-footer .footer .contents b {
  color: white;
}

.page-footer .footer .contents p {
  margin: 0;
  font-size: 0.75rem;
}

.page-footer .footer .contents > div {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.page-footer .footer .contents > div > div {
    margin: 0.25rem 0;
}

.page-footer .footer .contents > div > div > * {
    margin-right: 0.25rem;
}

.page-footer .footer .contents > div .image {
    align-self: center;
    width: 4rem;
    height: 4rem;
    margin: 0.25rem 0;
    background-size: cover;
    background-position: center;
}

@keyframes bubble-size {
    0%, 75% {
        width: var(--size, 4rem);
        height: var(--size, 4rem);
    }
    100% {
        width: 0rem;
        height: 0rem;
    }
}

@keyframes bubble-move {
    0% {
        bottom: -4rem;
    }
    100% {
        bottom: var(--distance, 10rem);
    }
}


@media screen and (max-width: 414px) {
    .page-footer .footer .bubbles {
        display: none;
    }

    .page-footer .footer .contents {
        padding: 0.5rem;
    }

    .page-footer .footer .contents p {
        font-size: 0.4rem;
    }

    .page-footer .footer .contents b {
        font-size: 0.6rem;
    }
}
