html footer h5{
  font-size: var(--heading-5);
  margin-bottom: 1.5rem !important;
}

.footer_layout{
    padding-inline: 3rem;
    background-color: var(--sandstone);
}

.footer_content{
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    padding-block: 5rem;
}

.footer_content .logo{
    grid-column-end: span 2;
}

.footer_content .logo img{
    width: 150px;
    height: auto;
}

.footer_content .menu{
    font-weight: var(--body-semibold);
    font-size: var(--body-small);
}

.footer_content .menu ul{
    padding-left: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: .75rem;
}

.footer_content .menu ul li a{
    color: var(--mahogany);
}

.footer_content .menu--one ul li a{
    display: flex;
    width: fit-content;
    flex-direction: row;
    gap: .5rem;
    align-items: center;
}

.footer_content .menu ul li a:is(:hover,:active,:focus){
    text-decoration: none;
    color: var(--mahogany);
}

.footer_content .menu ul li a::after{
    content: '';
    width: 1.25em;
    height: .75em;
    background-color: currentColor;
    mask: url(/wp-content/uploads/2025/08/arrow_right.svg) no-repeat center / contain;
    -webkit-mask: url(/wp-content/uploads/2025/08/arrow_right.svg) no-repeat center / contain;

    transition: transform 300ms ease-in-out;
}

.footer_content .menu ul li a:is(:hover,:active,:focus)::after{
    transform: translateX(.5rem);
}

.footer_content .menu--one{
    grid-column: 3 / span 3;
}

.footer_content .menu--two{
    grid-column-start: 7;
}

.footer_content .menu:not(.menu--one),
.footer_content .contact_info{
    grid-column-end: span 2;
}

.footer_content .contact_info .contact_content{
    font-size: var(--body-small);
    font-weight: var(--body-semibold);
    color: var(--mahogany);
}

.footer_content .contact_info .contact_content p{
    margin-bottom: .75rem;
}

.footer_content .contact_info .contact_content a{
    color: var(--mahogany);
    display: inline-block;
    margin-bottom: .75rem;
}

.footer_content .contact_info a.route_button{
    font-size: var(--body-regular);
    display: flex; flex-direction: row;
    align-items: center;
    gap: .5rem;
    color: var(--mahogany);
    font-weight: var(--body-semibold);
}

.footer_content .contact_info a.route_button:where(:hover,:active,:focus){
    text-decoration: none;
}

.footer_content .contact_info a.route_button::before{
    content: '';
    width: 1.5rem;
    height: 1rem;
    background-color: currentColor;
    mask: url(/wp-content/uploads/2025/08/arrow_right.svg) no-repeat center / contain;
    -webkit-mask: url(/wp-content/uploads/2025/08/arrow_right.svg) no-repeat center / contain;

    transition: transform 300ms ease-in-out;
}

.footer_content .contact_info a.route_button:where(:hover,:active,:focus)::before{
    transform: translateX(.25rem);
}

.footer_legal{
    padding-block: 2rem;
    color: hsla(355, 48%, 16%, 0.5);
    font-size: var(--body-small);
    border-top: 1px solid;

    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
}

.footer_legal > span{
    grid-column: 1 / 7;
}

.footer_legal > div{
    grid-column: 7/-1;
}

.footer_legal > div ul{
    padding-left: 0;
    margin-bottom: 0;
    list-style: none;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-end;
    gap: 1.5rem;
}

.footer_legal > div ul li,
.footer_legal > div ul li a{
    color: inherit;
}


@media only screen and (max-width: 992px){
    .footer_layout{
        padding-inline: 1.5rem;
    }
    .footer_content{
        grid-template-columns: repeat(5, minmax(0,1fr));
        padding-block: 2.5rem;
    }
    .footer_content .logo,
    .footer_content .menu,
    .footer_content .contact_info{
        grid-column-end: unset !important;
        grid-column: 1 / -1 !important;
    }

    .footer_content .logo{
        order: 999;
        margin-top: 2rem;
    }

    .footer_content div.menu,
    .footer_content div.contact_info{
        background-color: var(--ivory);
        padding: 1.5rem;
        margin-bottom: .5rem;
        border-radius: .75rem;
    }

    .footer_content div.menu h5,
    .footer_content div.contact_info h5{
        margin-bottom: 0 !important;
        font-weight: var(--body-semibold);
        display: grid;
        grid-template-areas: "text icon";
        grid-template-columns: auto min-content;
    }

    .footer_content div.menu h5::before,
    .footer_content div.contact_info h5::before,
    .footer_content div.menu h5::after,
    .footer_content div.contact_info h5::after{
        grid-area: icon;
        place-self: center;
        content: '';
        background-color: currentColor;
        border-radius: 2px;
        transition: transform 300ms ease-in-out;
    }
    .footer_content div.menu h5::before,
    .footer_content div.contact_info h5::before{
        width: 1rem; height: 2px;
    }
    .footer_content div.menu h5::after,
    .footer_content div.contact_info h5::after{
        height: 1rem; width: 2px;
    }

    .footer_content .menu > div,
    .footer_content .contact_info > div{
        display: grid;
        grid-template-rows: 0fr;

        transition: grid-template-rows 300ms ease-in-out;
    }

    .footer_content div.menu.open > div,
    .footer_content div.contact_info.open > div{
        grid-template-rows: 1fr;
    }

    .footer_content div.menu.open h5::before,
    .footer_content div.contact_info.open h5::before{
        transform: rotate(180deg);
    }   

    .footer_content div.menu.open h5::after,
    .footer_content div.contact_info.open h5::after{
        transform: rotate(90deg);
    }

    .footer_content .menu > div > ul,
    .footer_content .contact_info > div > div{
        font-size: var(--body-small);
        overflow: hidden;
        margin-bottom: 0;
    }

    .footer_content .menu > div > ul li a{
        font-weight: 400;
    }

    .footer_content .menu > div > ul li a::after{
        display: none;
    }

    .footer_legal{
        grid-template-columns: repeat(5, minmax(0, 1fr));
    }

    .footer_legal > div,
    .footer_legal > span {
        grid-column: 1 / -1;
    }

    .footer_legal > span {
        order: 2;
        margin-top: 1rem;
    }

    .footer_legal > div ul{
        justify-content: start;
        flex-wrap: wrap;
        column-gap: 1rem; row-gap: .25rem;
    }
}