/* --- CSS FOOTER ELEMENTOS - GRIDS PRINCIPAIS EM layout.css --- */

/* ==========================
LOGO E BRANDING
========================== */
.footer-brand {
    position: relative;
    grid-row: 1;
    grid-column: 1 / span 2;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: auto;
    width: 100%;
    margin-top: 26px;
    left: 1px;
    column-gap: 40px;
    height: 38px;
}

.footer-logo {
    display: flex;
    justify-content: flex-start;
    height: 38px;
    max-width: 110px;
    width: 100%;
    padding-bottom: 4.881px;
}

/* .footer-links { 
    grid-area: links;
    width: 100%;
    max-width: 500px;
} */

.footer .footer-links {
    margin-top: -10px;
    /* margin-left: auto;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    row-gap: 20px;
    column-gap: 10px;
    justify-items: center;
    color: var(--Black-Black-01, #292929);
    font-family: Goldplay;
    font-size: 12px;
    font-style: normal;
    font-weight: 400;
    line-height: 18px;
    max-width: 767px;
    width: 100%; */
}

.footer .givos {
    grid-row: 2;
    grid-column: 1;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.footer .servicos {
    grid-row: 2;
    grid-column: 2;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.footer .usar-pontos {
    grid-row: 3;
    grid-column: 1;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.footer .juntar-pontos {
    grid-row: 3;
    grid-column: 2;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}


.footer .footer-cta {
    grid-row: 4;
    grid-column: 1 / span 2;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0px;
    margin-top: 27px;
}

.footer-cta .participe {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    overflow-wrap: break-word;
    width: 55%;

}

.footer .footer-cta a {
    color: var(--black-01);
}

.footer .footer-cta .indique {
    width: 100%;
    display: flex;
    flex-direction: row;
}

.footer .footer-cta p {
    line-height: 18px;
    margin-right: 25px;
    text-wrap: auto;
}

.footer-cta.text-medium span {
    text-decoration: underline;
}

/* ==========================
CARD DO APP
========================== */

.footer .app-card {
    grid-row: 5;
    grid-column: 1 / span 2;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    width: 100%;
    padding: 26px 27px;
    gap: 14px;
    background: var(--gray-01);
    border-radius: 20px;
    flex-shrink: 0;
}

.footer .app-card .app-head {
    display: flex;
    align-items: center;
    gap: 13px;
}

.footer .app-card .app-title {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.footer .app-card .stars {
    color: var(--yellow-01);
    font-size: 12px;
}

.footer .instalar-app {
    margin-top: -15px;
}

.footer .app-card .text-regular {
    line-height: var(--line-height-xs);
    margin-top: 5px;
}

/* ==========================
SELOS DE CONFIANÇA
========================== */
.trust-badges {
    grid-row: 6;
    grid-column: 1 / span 2;
    min-width: 288px;
    width: 100%;
    height: 128px;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-around;
    gap: 7px;
}

.trust-badges .badges-row {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 16px;
}

.trust-badges .badges-sm img {
    height: 36px;
    width: auto;
}

.trust-badges .badges-lg img {
    height: 64px;
    width: auto;
}

.trust-badges .badge {
    display: flex;
    align-items: center;
    gap: 8px;
}

.trust-badges .badge-caption {
    font-family: 'Goldplay', 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    font-weight: 400;
    font-size: var(--font-size-xs);
    line-height: var(--line-height-xs);
    color: var(--black-02);
}

.trust-badges img {
    filter: grayscale(1);
    opacity: .85;
}

/* ==========================
CARD JOY (CENTRAL DE AJUDA)
========================== */
.joy-card {
    grid-row: 7;
    grid-column: 1 / span 2;
    min-height: 80px;
    width: 100%;
    border: 2px solid var(--purple-01);
    border-radius: 16px;
    display: flex;
    align-items: center;
    gap: 12px;
    background: var(--white);
    padding-left: 13px;
}

.joy-avatar {
    width: 60px;
    height: 60px;
    background-color: var(--white);
}

.joy-info {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.joy-card .joy-name {
    font-family: 'Goldplay SemiBold', 'Goldplay', 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    font-weight: 600;
    font-size: var(--font-size-md);
    line-height: var(--line-height-md);
    color: var(--purple-01);
}

.joy-card .joy-role {
    font-family: 'Goldplay Medium', 'Goldplay', 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    font-weight: 500;
    font-size: 10px;
    line-height: 15px;
    color: var(--black-02);
}

/* ==========================
REDES SOCIAIS
========================== */
.footer .social-icons-wrapper {
    grid-row: 8;
    grid-column: 1 / span 2;
    width: 100%;
    min-width: 288px;
    height: 49px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 5px;

}

.social-icons {
    min-width: 212px;
    max-width: 100%;
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
    flex-wrap: nowrap;
    gap: 9.921px;
}

.social-icon-link {
    display: inline-flex;
    width: 18px;
    height: 18px;
}

.social-icon-link:hover {
    opacity: .8;
}

.social-label {
    color: var(--purple-01);
    font-family: 'Goldplay SemiBold', 'Goldplay', 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    font-weight: 600;
    font-size: var(--font-size-xs);
    line-height: var(--line-height-sm);

}

/* ==========================
ÁREA LEGAL
========================== */
.footer-legal {
    grid-row: 9;
    grid-column: 1 / span 2;
    width: 100%;
    padding-top: var(--gap-lg);
    display: flex;
    flex-direction: column;
    position: relative;
}

.footer-legal .text-regular {
    overflow-wrap: break-word;
    width: 85%;
}

.footer-legal .decor-arrows {
    position: absolute;
    right: 16px;
    top: -8px;
    width: 36px;
    height: 85px;
    overflow: hidden;
}

.footer-legal p {
    font-family: 'Goldplay Medium', 'Goldplay', 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    font-weight: 500;
    font-size: var(--font-size-xs);
    line-height: var(--line-height-xs);
    color: var(--black-01);
}

.footer-legal .legal-links {
    margin-top: -10px;
    display: flex;
    flex-direction: column;
    gap: var(--gap-xs);
}

.footer-legal .legal-links a {
    font-family: 'Goldplay Medium', 'Goldplay', 'Goldplay', 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    font-weight: 500;
    font-size: var(--font-size-xs);
    line-height: var(--line-height-xs);
    color: var(--black-01);
    text-decoration: underline;
}

.copyright {
    font-size: var(--font-size-xs);
    line-height: var(--line-height-xs);
    color: var(--black-02);
}

.footer .footer-line {
    position: absolute;
    left: 0;
    top: -12px;
    min-width: 288px;
    width: 100%;
    stroke-width: 1.5px;
    stroke: var(--Purple-Purple-01, #7D55C6);
}

.footer-legal::after {
    content: '';
    position: absolute;
    right: 0;
    /* Alinha ao final do texto */
    top: 0;
    height: 100%;
    /* Ajusta a altura do pseudo-elemento */
    width: 10px;
    /* Ajusta a largura, se necessário */
    background-color: white;
    /* Cor de fundo igual ao do container */
    margin-left: 20px;
    /* Espaço entre texto e o fim do pipe, se necessário */
}

/* ==========================
LINKS
========================== */
.footer-links-column {
    /* flex: 1 1 40%; 
    min-width: 150px;
    flex-direction: column;*/
    gap: 3px;
}

.footer-links-column h4 {
    font-weight: 600;
    font-size: var(--font-size-sm);
    line-height: var(--line-height-sm);
    color: var(--purple-01);
    margin-bottom: var(--gap-xs);
}

.footer-links-column a {
    font-family: 'Goldplay Medium', 'Goldplay', 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    font-weight: 500;
    font-size: var(--font-size-xs);
    line-height: var(--line-height-xs);
    color: var(--black-01);
    text-decoration: none;
}

.footer-links-column a:hover {
    text-decoration: underline;
}

/* ==========================
CALL TO ACTION
========================== */
.footer-cta .text-medium {
    width: 45%;
}

.footer-cta.text-medium span {
    text-decoration: underline;
}





/* ==========================
NEWSLETTER
========================== */
.footer-newsletter {
    display: flex;
    flex-direction: column;
    gap: var(--gap-sm);
}

.footer-input-group {
    display: flex;
    flex-direction: column;
    gap: var(--gap-sm);
}

/* ==========================
TIPOGRAFIA ESPECÍFICA
========================== */
.footer .title-semibold {
    color: var(--purple-01);
    font-family: 'Goldplay SemiBold', 'Goldplay', 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    font-weight: 600;
    font-size: var(--font-size-xs);
    line-height: var(--line-height-xs);
    overflow-wrap: break-word;
    width: 100px;
}

.footer-brand-row .text-medium {
    width: 100%;
    margin-right: 0px;
}

.footer-cta .text-medium {
    width: 45%;
}

/* ==========================
UTILITÁRIOS
========================== */

/* Seções que devem ocupar largura total */
.footer-legal,
.footer-newsletter {
    max-width: 100%;
}

/* ==========================
ESTILOS ADICIONAIS
========================== */
div.text-medium {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    text-wrap: wrap;
    width: 122px;
    font-size: 16px;
}

.footer-newsletter {
    margin-top: var(--gap-md);
    padding: var(--gap-sm);
    background-color: var(--background-light, #f8f9fa);
    border-radius: 8px;
}

.footer h4 {
    font-size: 1.1rem;
    margin-bottom: var(--gap-sm);
    color: var(--text-primary, #333);
}

.footer .back-to-top {
    position: absolute;
    right: 5px;
    top: 20px;
    z-index: 1;
    align-self: flex-end;
    padding: 10px;
    width: 30px;
    height: 85px;
    display: inline-flex;
    align-items: flex-start;
    justify-content: center;
    border-radius: 20px;
    border: 2px solid var(--purple-01);
    color: var(--purple-01);
    background: transparent;
    transition: background-color .2s ease, color .2s ease, border-color .2s ease;
    animation: bounce-up 1.8s ease-in-out infinite;
}

.footer .back-to-top:hover {
    background: rgba(125, 85, 198, 0.06);
}

.footer .back-to-top:focus-visible {
    outline: 2px solid var(--purple-02);
    outline-offset: 2px;
}

.footer .back-to-top svg {
    pointer-events: none;
    display: flex;
    width: 15px;
    height: 25px;
    stroke-width: 1px;
    stroke: var(--Purple-Purple-01, #7D55C6);
    justify-content: center;
    align-items: flex-start;
    gap: 10px;
    flex-shrink: 0;
}

.footer-legal .divider-legal{
    position: absolute;
    left: 0;
    right: 0;
    top: -10px;
    height: 2px;
    background: var(--purple-01);
    opacity: 0.685;
    border-radius: 50px;
}

/* .footer a {
    color: var(--text-secondary, #666);
    transition: color 0.2s ease;
}

.footer a:hover {
    color: var(--primary-color, #7D55C6);
} */

/* ==========================
MÍDIAS adicionais
========================== */

/* Botão Voltar ao Topo (apenas mobile) */
@media (max-width: 766.98px) {
    .footer .joy-card {
        max-width: 230px;
        width: 100
    }

    .footer .divider {
        display: none;
    }

}

/* @media (min-width: 1440px) {
    .footer .back-to-top {
        display: none;
    }
} */

@keyframes bounce-up {

    0%,
    100% {
        transform: translateY(0);
    }

    50% {
        transform: translateY(-4px);
    }
}

@media (prefers-reduced-motion: reduce) {
    .footer .back-to-top {
        animation: none;
        transition: none;
    }
}

/*
================================================================================
 TABLETS
================================================================================
*/
@media (min-width: 768px) and (max-width: 1023.98px) {

    .footer-brand {
        position: relative;
        grid-row: 1;
        grid-column: 1;
        display: flex;
        flex-direction: column;
        max-width: 100%;
        gap: 11px;
        overflow-wrap: break-word;
        width: 55%;
        top: -25px;
    }

    .footer .givos {
        grid-row: 1;
        grid-column: 2;
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 0px;
    }

    .footer .servicos {
        grid-row: 1;
        grid-column: 3;
    }

    .footer .usar-pontos {
        grid-row: 2;
        grid-column: 3;
    }

    .footer .juntar-pontos {
        grid-row: 2;
        grid-column: 2;
    }

    .footer .joy-card {
        grid-row: 3;
        grid-column: 1;
        display: flex;
        width: 245px;
        height: 80px;
        padding: 0px 10px;
        justify-content: center;
        align-items: center;
        gap: 12px;

    }

    .footer .social-icons-wrapper {
        grid-row: 3;
        grid-column: 2 / span 2;
        width: 100%;
        gap: 13.478px;
        position: relative;
        display: flex;
        flex-direction: column;
        align-items: center;
        white-space: nowrap;
    }

    .footer .social-icons-wrapper .title-semibold {
        margin-left: -115px;
    }

    .footer .footer-cta {
        position: relative;
        top: -25px;
        grid-row: 2;
        grid-column: 1;
    }

    .footer .footer-cta p {
        text-wrap: inherit;

    }

    .footer .app-card {
        grid-row: 4;
        grid-column: 1 / span 3;
        display: flex;
        width: 100%;
        height: 94px;
        padding: 30px;
        flex-direction: row;
        justify-content: center;
        align-items: center;
        gap: 30px;
        margin-top: 0px;
    }

    .footer .app-card .text-regular {
        margin-top: 10px;
        font-size: 10px;
        line-height: 10px;
    }

    .footer .trust-badges {
        position: relative;
        grid-row: 5;
        grid-column: 1 / span 3;
        display: flex;
        flex-direction: row;
        flex-wrap: wrap;
        width: 100%;
        justify-content: space-between;
        align-items: center;
    }

    .footer .footer-legal {
        grid-row: 6;
        grid-column: 1 / span 3;
        display: flex;
        flex-direction: row;
        flex-wrap: wrap;
        width: 100%;
        ;
        justify-content: space-between;
        align-items: center;
    }

    .footer .title-semibold {
        font-size: 14px;

    }

}

/*
================================================================================
 DESKTOPS
================================================================================
*/

@media (min-width: 1024px) and (max-width: 1439.98px) {

    .footer-brand {
        position: relative;
        grid-row: 1;
        grid-column: 1;
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        margin-top: 49px;
        gap: 5px;
        height: 149px;
        margin-left: 36px;
    }

    .footer-brand div.text-regular {
        position: absolute;
        top: 55px;
        overflow-wrap: break-word;
        width: 130px;
    }

    .footer-brand .text-regular p {
        font-size: 16px;
        line-height: 24px;
        margin-bottom: 25px;
    }

    .footer-brand .text-regular span {
        font-size: 16px;

    }

    .footer .footer-logo {
        position: absolute;
        top: 3px;
        max-width: 100px;
        width: 100%;
    }

    .footer-brand .divider {
        position: absolute;
        height: 0.5px;
        width: 17%;
        background-color: var(--purple-01);
        border: 1px solid var(--purple-01);
        border-radius: 50px;
        margin: 0;
        top: 153px;
    }

    .footer .title-semibold {
        font-size: var(--font-size-md);
        margin-bottom: 25px;
    }

    .footer .givos {
        position: absolute;
        top: 57px;
        left: 30px;
        grid-row: 1;
        grid-column: 2;
    }

    .footer .servicos {
        position: relative;
        top: 57px;
        left: 15px;
        grid-row: 1;
        grid-column: 3;

    }

    .footer .usar-pontos {
        position: relative;
        top: 57px;
        left: 3px;
        grid-row: 1;
        grid-column: 4;

    }

    .footer .juntar-pontos {
        position: absolute;
        grid-row: 2;
        grid-column: 1;
        white-space: nowrap;
        margin-left: 38px;
    }

    .footer .juntar-pontos .title-semibold {
        font-size: 16px;
        margin-bottom: 30px;
        text-decoration: underline;
    }

    .footer .footer-links-column a {
        font-size: 16px;
        line-height: 24px;
    }

    .footer .joy-card {
        position: relative;
        left: 45px;
        top: -5px;
        grid-row: 2;
        grid-column: 2;
        display: flex;
        max-width: 248px;
        width: 100%;
        height: 81px;
        justify-content: center;
        align-items: center;
        gap: 15px;

    }

    .footer .social-icons-wrapper {
        position: relative;
        grid-row: 2;
        grid-column: 3 / span 2;
        width: 100%;
        gap: 13px;
        display: flex;
        flex-direction: column;
        justify-content: end;
        left: 143px;
        top: -8px;

    }

    .footer .social-icons-wrapper .title-semibold {
        font-size: 19px;
        width: 100%;
    }

    .footer .social-label {
        position: absolute;
        left: 5px;
    }

    .footer .social-icons-wrapper p {
        font-size: 19px;
        line-height: 24px;
    }

    .footer .social-icons-wrapper .social-icons {
        position: absolute;
        top: 40px;
        left: 0;
        display: flex;
        flex-direction: row;
        align-items: center;
        gap: 13.478px;
        justify-content: flex-start;
        margin-left: 0;
    }

    .footer .social-icon-link {
        width: 24px;
        height: 24px;
        align-items: center;
    }

    .footer .footer-cta {
        position: absolute;
        grid-row: 3;
        grid-column: 1;
        top: -24px;
        margin-left: 37px;
        /* 156.25% */

    }

    .footer .footer-cta .participe {
        position: relative;
        top: -20px;
        overflow-wrap: break-word;
        /* Quebra palavras longas */
        width: 190px;
        /* Define uma largura para a div */
    }

    .footer .footer-cta h3 {
        font-size: 16px;
        line-height: 24px;
        white-space: nowrap;
    }

    .footer .footer-cta p span {
        font-size: 16px;
        line-height: 25px;
    }

    .footer .footer-cta a {
        font-size: 16px;
        line-height: 24px;
        font-weight: 600;
        text-decoration: none;
    }

    .footer .footer-cta .indique {
        position: relative;
        top: -20px;
    }

    .footer .footer-cta-button {
        font-size: 20px;
        line-height: 24px;
        max-width: 194px;
        width: 100%;
        height: 48px;
        display: flex;
        padding-left: 20px;
        padding-right: 20px;
    }

    .footer .app-card {
        position: absolute;
        top: 1px;
        left: 70px;
        grid-row: 3;
        grid-column: 2 / span 3;
        display: flex;
        max-width: 568px;
        width: 100%;
        height: 94px;
        padding: 30px;
        flex-direction: row;
        justify-content: center;
        align-items: center;
        gap: 16px;
    }

    .footer .app-card .app-head {
        gap: 10px;
        margin-top: -10px;
        margin-left: -2px;
    }

    .footer .app-card .text-regular {
        margin-top: 15px;
    }

    .footer .app-card .instalar-app {
        max-width: 103px;
        width: 100%;
        display: flex;
        margin-top: 0px;
        margin-right: 8px;
    }

    .footer .trust-badges {
        grid-row: 4;
        grid-column: 2 / span 3;
        display: flex;
        flex-direction: row;
        flex-wrap: nowrap;
        justify-content: space-between;
        max-width: 656px;
        width: 100%;
        align-items: center;
        margin-top: 20px;
        margin-left: 120px;
        padding-right: 110px;;
        gap:14px;
    }

    .footer .trust-badges svg{
        margin-right: 5px;
    }

    .footer .footer-legal {
        position: relative;
        top: 12px;
        grid-row: 5;
        grid-column: 1 / span 4;
        display: flex;
        flex-direction: row;
        flex-wrap: nowrap;
        width: 100%;
        justify-content: center;
        align-items: center;
        gap: 0px;
        border-top: none;
        padding-top: 5px;
    }

    .footer .footer-legal p {
        font-size: 16px;
        line-height: 24px;
        margin-left: 37px;
    }

    .footer-legal .divider-legal {
        position: absolute;
        left: 0;
        right: 0;
        top: -10px;
        height: 2px;
        width: auto;
        background: rgba(125, 85, 198, 0.2);
        border-radius: 50px;
    }

    .footer .footer-legal .legal-links {
        display: flex;
        flex-direction: row;
        flex-wrap: nowrap;
        gap: 55px;
        justify-content: center;
        margin-top: 0px;
        white-space: nowrap;
        margin-right: 40px;
    }

    .footer .footer-legal .legal-links a {
        font-size: 16px;
        line-height: 24px;
    }

    .footer .back-to-top {
        position: absolute;
        right: 65px;
        top: -610px;
        /* alinha com padding lateral do conteúdo */
        /* sobe para alinhar com a primeira linha de texto */
        z-index: 1;
        align-self: flex-end;
        padding: 5px;
        width: 30px;
        height: 85px;
        display: inline-flex;
        align-items: flex-start;
        justify-content: center;
        border-radius: 20px;
        border: 2px solid var(--purple-01);
        color: var(--purple-01);
        background: transparent;
        transition: background-color .2s ease, color .2s ease, border-color .2s ease;
        animation: bounce-up 1.8s ease-in-out infinite;
    }

    .footer .back-to-top:hover {
        background: rgba(125, 85, 198, 0.06);
    }

    .footer .back-to-top:focus-visible {
        outline: 2px solid var(--purple-02);
        outline-offset: 2px;
    }

    .footer .back-to-top svg {
        pointer-events: none;
    }
}

@media (min-width: 1440px) {


    .footer-brand {
        position: relative;
        grid-row: 1;
        grid-column: 1;
        min-width: 149px;
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        overflow-wrap: break-word;
        width: 11%;
        left: 6.25%;
        top: 55px;
        font-size: 16px;
    }

    .footer-brand .text-regular {
        margin: 6px 3px;
        overflow-wrap: break-word;
        width: 89%;
        
    }

    .footer-brand .divider {
        position: absolute;
        top: 150px;
        left: 5%;
        display: block;
        background: #7D55C6;
        width: 22%;
        height: 1.5px;
        border-radius: 50px;
        opacity: 1;
    }

    .footer .footer-links-column * {
        font-size: 16px;
        line-height: 24px;
    }
    .footer .footer-links-column a{
        font-family: 'Goldplay', 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
        font-weight: 400;
    }

    .footer .givos {
        margin-left: 19%;
        margin-top: 82px;
        grid-row: 1;
        grid-column: 1;
    }

    .footer .servicos {
        margin-left: 485px;
        margin-top: 82px;
        grid-row: 1;
        grid-column: 1;
    }

    .footer .usar-pontos {
        margin-left: 703px;
        margin-top: 82px;
        grid-row: 1;
        grid-column: 1;
    }

    .footer .juntar-pontos {
        margin-left: 920px;
        margin-top: 82px;
        grid-row: 1;
        grid-column: 1;
        white-space: nowrap;
    }

    .footer .footer-cta {
        grid-row: 2;
        grid-column: 1;
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 0px;
        margin-top: -13px;
        margin-left: 94px;
        min-width: 11%;
    }

    footer .footer-cta .participe {
        overflow-wrap: break-word;
        width: 14%;
        margin-top: 4px;
    }

    .footer .footer-cta h3.title-semibold {
        font-size: 16px;
        line-height: 24px;
        white-space: nowrap;
    }

    .footer .footer-cta .indique {
        width: 15%;
    }

    /* usado em footer-cta e footer-brand*/
    .footer .text-regular,
    .footer span {
        font-size: 16px;
    }

    .footer .joy-card {
        grid-row: 2;
        grid-column: 1;
        display: flex;
        margin-left: 410px;
        width: 100%;
        max-width: 245px;
        max-height: 82px;
        margin-top: -15px;
        padding: 15px;
    }

    .footer .joy-name {
        font-size: 16px;
        line-height: 24px;
    }

    .footer .joy-card .joy-info{
        margin-top: 5px;
        gap: 0px;
    }

    .footer .social-icons-wrapper {
        grid-row: 2;
        grid-column: 1;
        margin-left: 410px;
        margin-top: 100px;
    }
    .footer .social-icons{
        gap:13px;
    }
    .footer .social-icons-wrapper h3 {
        font-size: 16px;
        white-space: nowrap;
    }

    .social-icon-link {
        width: 24px;
        height: 24px;
    }

    .footer .app-card {
        grid-row: 2;
        grid-column: 1;
        display: flex;
        flex-direction: row;
        justify-content: center;
        justify-items: center;
        margin-left: 830px;
        margin-top: -15px;
        width: 486px;
        height: 135px;
        gap: 15px;
        padding-top: 40px;
    }

    .footer .app-card .text-regular {
        font-size: 10px;
        line-height: 14px;
        margin-top: 0px;

    }

    .footer .app-card .text-bold {
        margin-top: 20px;
        font-size: 10px;
        text-decoration: underline;
        line-height: 14px;

    }

    .footer .app-card .instalar-app {
        margin-top: -2px;
        margin-right: 18px;
        min-width: none;
    }


    /* .footer-newsletter {
        grid-column: 2;
        grid-row: 1;
        margin-left: 75%;
    } */


    .footer-input-group {
        flex-direction: row;
        gap: var(--gap-sm);
    }

    .footer-input-group .newsletter-input {
        flex: 1;
    }

    .footer-input-group .btn-primary {
        width: auto;
        min-width: 120px;
    }

    .footer-links {
        grid-column: 1;
        grid-row: 4;
        flex-direction: column;
        gap: var(--gap-xl);
    }

    .footer-payments {
        grid-column: 1;
        grid-row: 3;
    }

    .payment-icons {
        grid-template-columns: repeat(4, 1fr);
    }

    .footer-support {
        grid-column: 2;
        grid-row: 2;
    }

    .social-icons {
        justify-content: center;
        margin-top: 3px;
    }

    .footer .trust-badges {
        grid-column: 1;
        grid-row: 4;
        margin-top: -8%;
        width: 40%;
        justify-self: center;
        gap: 0px;
    }

    .footer-legal {
        position: absolute;
        grid-column: 1;
        grid-row: 4;
        flex-direction: row;
        flex-wrap: nowrap;
        justify-items: flex-start;
        justify-content: space-between;
        /* align-items: center; */
        top: 20%;
        left: 6.5%;
        max-width: 87%;
        padding-top: 0px;
        gap: 0px;
    }

    .footer-legal .text-regular{
        margin-left: 0.5%;
    }

    .footer-legal .legal-links{
        flex-direction: row;
        flex-wrap: nowrap;
        justify-content: flex-end;
        width: 100%;
        gap: 32%;
        margin-top: 0px;
        margin-right: 10px;
    }

    .footer-legal .legal-links a{
        font-size: 16px;
    }

    .footer-legal .divider-legal {
        position: absolute;
        height: 2px;
        top: -25px;
        width: 100%;
        background: rgb(128 128 128 / 20%)
    }

    /* .footer .footer-legal .text-regular,
    .footer .footer-legal .legal-links {
        margin-top: -1%;
    } */

    .footer .spacing-row {
        grid-row: 1;
        grid-column: 1;
        margin: 0;
        width: 100%;
        height: auto;
        background-color: red;
        z-index: 9020;
    }

    .footer .footer-links-column {
        line-height: 24px;
    }

    .footer .footer-links-column .title-semibold {
        padding-bottom: 15px;
    }

    .footer-legal .back-to-top{
        right: 30px;
        top: -590px;
    }



}