#main_footer{
    width: 100%;
    min-height: 40em;
    background: #6e4739b0;
    color: white;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 5vh;
    padding: 5vh 5vw 1vh;
}












#main_footer .info_container{
    width: 100%;
    max-width: 130em;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-evenly;
    padding: 1em;
    font-size: min(1em, 3.75vw);
}


#main_footer .info_container>div{
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.5em;
}


#main_footer .info_container>div img{
    height: 3em;
}

#main_footer .info_container>div .label{
    text-align: center;
    max-width: 10em;
}

















#main_footer .main_container{
    width: 100%;
    max-width: 130em;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-evenly;
    gap: 5vh;
    flex-wrap: wrap;
    margin: auto;
}


#main_footer .main_container .title_container{
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 2em;
    align-self: stretch;
}

#main_footer .main_container .title_container .title{
    font-size: min(3.5em, 13vw);
    font-weight: 100;
}

#main_footer .main_container .title_container .sub_title{
    font-size: min(0.95em, 4vw);
    text-align: justify;
    max-width: 35em;
    line-height: 1.7em;
}




#main_footer .main_container .title_container .production_container{
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 2em;
    flex-wrap: wrap;
}


#main_footer .main_container .title_container .production_container .production_name{
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 1em;
}


#main_footer .main_container .title_container .production_container .production_address{
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 0.5em;
}










#main_footer .main_container .links_container{
    display: flex;
    flex-direction: row;
    align-items: flex-end;
    justify-content: flex-start;
    gap: 5vw;
    flex-wrap: wrap;
    align-self: stretch;
}


#main_footer .main_container .links_container ul{
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 1em;
}


#main_footer .main_container .links_container ul .link{
    /*width: 100%;*/
}


#main_footer .main_container .links_container ul a{
    /*width: 100%;*/
    font-size: 1.1em;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    gap: 0.25em;
    position: relative;
    padding: 0.25em 0;
    padding-left: 1.75em;
    padding-right: 0;
    transition: 0.25s padding-right ease-in-out, 0.25s padding-left ease-in-out;
}

#main_footer .main_container .links_container ul a:hover{
    padding-right: 1.75em;
    padding-left: 0;
}

#main_footer .main_container .links_container ul a::after{
    content: "";
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    max-width: 0;
    height: 1px;
    background: white;
    border-radius: 1em;
    transition: 0.25s max-width ease-in-out;
}
#main_footer .main_container .links_container ul a:hover::after{
    max-width: 100%;
}

#main_footer .main_container .links_container ul a .app_icon{
    min-width: 1.5em;
    fill: white;
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    transition: 0.25s left ease-in-out;
}
#main_footer .main_container .links_container ul a:hover .app_icon{
    left: calc(100% - 1.5em);
}














#main_footer .picto_container{
    width: 100%;
    padding: 1em;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-evenly;
    flex-wrap: wrap;
    gap: 2em;
    font-size: min(1em, 4vw);
}


#main_footer .picto_container img{
    height: 3em;
}

#main_footer .picto_container img:not(.ce){
    height: 3.5em;
    background: white;
    border-radius: 0.5em;
}

#main_footer .picto_container img.age_limit{
    border-radius: 50%;
    box-shadow: inset 0 0 0 2px #ee1c24;
    border: 1px solid #ee1c24;
}

















#main_footer .copyright_container{
    margin-bottom: 1em;
    font-size: min(1em, 3vw);
}
