/* Responsive overrides - load this file after your main stylesheet */

:root{
    --container-padding: 1rem;
}

html{
    width: 100%;
    overflow-x: hidden;
    touch-action: auto;
    overscroll-behavior: auto;
}

body{
    width: 100%;
    overflow-x: hidden;
    touch-action: auto;
    overscroll-behavior: auto;
}

.bd-container{
    width: min(100% - (var(--container-padding) * 2), 1024px);
    margin-inline: auto;
}

.bd-grid{
    display: grid;
    grid-template-columns: minmax(0, 1fr);
}

.section{
    padding-inline: 0;
}

.button{
    max-width: 100%;
    text-align: center;
}

/* Fix typo/invalid declaration from the original CSS */
.about__descrition,
.about__description{
    font-size: var(--h2-font-size);
}

/* Navigation */
@media screen and (max-width: 767px){
    body{
        margin-top: var(--header-height);
    }

    .nav__menu{
        max-height: calc(100svh - var(--header-height));
        overflow-y: auto;
    }

    .nav__list{
        padding-bottom: 1rem;
    }

    .active-link::after{
        left: 50%;
        width: 2rem;
        transform: translateX(-50%);
    }
}

@media screen and (min-width: 768px){
    .nav__menu{
        position: static;
        width: auto;
        padding-top: 0;
        background-color: transparent;
        border-radius: 0;
        box-shadow: none;
    }
}

/* Home */
.home__container{
    min-height: calc(100svh - var(--header-height));
    height: auto;
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: auto auto auto;
    align-content: center;
    justify-items: center;
    row-gap: 1.5rem;
    padding-top: calc(var(--header-height) + 1.5rem);
    padding-bottom: 2.5rem;
    text-align: center;
}

.home__data,
.home__social,
.home__img{
    min-width: 0;
}

.home__data{
    position: relative;
    z-index: 2;
    max-width: 100%;
    padding-left: 2rem !important;
    padding-right: 1rem;
}

.home__greeting{
    display: block !important;
    color: var(--first-color-lighten) !important;
    font-size: clamp(.9rem, 3.6vw, 1.25rem);
    line-height: 1.4;
    margin-bottom: .35rem;
    opacity: 1 !important;
    visibility: visible !important;
    position: relative;
    z-index: 3;
}

.home__name{
    font-size: clamp(2rem, 11vw, 3.25rem);
    line-height: 1.05;
    overflow-wrap: anywhere;
}

.home__profession{
    max-width: 32rem;
    margin-inline: auto;
}

.home__social{
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    gap: 1rem;
    position: relative;
    z-index: 2;
}

.home__social-icon{
    margin: 0;
}

.home__img{
    position: relative;
    right: auto;
    bottom: auto;
    justify-self: center;
    width: min(68vw, 260px);
    max-width: 100%;
    z-index: 1;
}

.home__img img{
    width: 100%;
    max-height: 40svh;
    object-fit: contain;
    border-radius: .5rem;
}

@media screen and (max-width: 360px){
    .home__data{
        padding-inline: .875rem;
    }

    .home__img{
        width: min(72vw, 220px);
    }
}

@media screen and (min-width: 576px){
    .home__img{
        width: min(44vw, 320px);
    }
}

@media screen and (min-width: 768px){
    body{
        margin-top: 0;
    }

    .home__container{
        min-height: 100svh;
        grid-template-columns: minmax(0, 1fr) minmax(240px, 38%);
        grid-template-rows: auto auto;
        align-content: center;
        align-items: center;
        justify-items: stretch;
        column-gap: 2rem;
        padding-top: calc(var(--header-height) + 3rem);
        padding-bottom: 3rem;
        text-align: left;
    }

    .home__data{
        grid-column: 1;
        grid-row: 1;
        padding-inline: 0;
    }

    .home__greeting{
        font-size: 1.25rem;
    }

    .home__name{
        font-size: clamp(3rem, 7vw, var(--biggest-font-size));
    }

    .home__profession{
        margin-inline: 0;
    }

    .home__social{
        grid-column: 1;
        grid-row: 2;
        justify-content: flex-start;
    }

    .home__img{
        grid-column: 2;
        grid-row: 1 / 3;
        align-self: center;
        justify-self: center;
        width: min(36vw, 420px);
    }

    .home__img img{
        max-height: 70svh;
    }
}

/* Cards and grids */
.about__container,
.qualification__container,
.services__container,
.portfolio__container,
.contact__container,
.contact__content{
    width: 100%;
    min-width: 0;
}

.services__data,
.portfolio__content,
.contact__box,
.project__container,
.testimonial__content{
    min-width: 0;
    max-width: 100%;
}

.services__container,
.portfolio__container,
.contact__content{
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 240px), 1fr));
}

.section-title,
.section-subtitle,
.about__description,
.about__descrition,
.qualification__area,
.qualification__work,
.services__description,
.portfolio__title,
.project__title,
.project__description,
.testimonial__description,
.contact__description,
.contact__description__mail,
.footer__description,
.footer__copy{
    overflow-wrap: anywhere;
}

/* About */
.about__img{
    width: min(70vw, 280px);
    max-width: 100%;
}

.about__data{
    min-width: 0;
}

/* Qualification */
.qualification__box{
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: .35rem;
}

.qualification__title{
    flex-wrap: wrap;
    gap: .35rem;
}

/* Services */
.services__data{
    padding: clamp(1.5rem, 5vw, 3rem) 1rem;
}

.portfolio__nav{
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: .75rem 1rem;
}

.portfolio__item{
    margin: 0;
}

.portfolio__img,
.portfolio__content img{
    width: 100% !important;
    height: auto !important;
    aspect-ratio: auto !important;
    object-fit: contain !important;
}

.portfolio__data{
    min-width: 0;
}

/* Modal */
.modal{
    padding: 1rem;
}

.modal img{
    width: auto;
    height: auto;
    max-width: 100%;
    max-height: calc(100svh - 2rem);
    object-fit: contain;
}

/* Project block */
.project.section{
    width: min(100% - (var(--container-padding) * 2), 920px);
    margin-inline: auto;
}

.project__container{
    overflow: hidden;
    width: 100%;
    padding: clamp(2rem, 5vw, 4rem) clamp(1rem, 5vw, 3rem);
}

.project__data,
.projet__data{
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
    min-width: 0;
    text-align: center;
}

.project__data > div{
    min-width: 0;
    width: 100%;
}

.project__icon{
    flex: 0 0 auto;
    margin-bottom: .5rem;
}

.project__description{
    max-width: 46rem;
    margin-inline: auto;
    line-height: 1.7;
    text-align: left;
    overflow-wrap: normal;
    word-break: normal;
    hyphens: none;
}

.project__description p{
    margin-bottom: 1rem;
}

.project__description p:last-child{
    margin-bottom: 0;
}

.project__title{
    text-align: center;
}

.project__data > div:last-of-type{
    display: flex;
    justify-content: center;
}

.project__data .button{
    margin-inline: auto;
}

.project__description br{
    display: none;
}

@media screen and (min-width: 768px){
    .project__data,
    .projet__data{
        display: grid;
        grid-template-columns: 5rem minmax(0, 1fr);
        align-items: start;
        text-align: left;
        column-gap: 2rem;
        row-gap: 2rem;
        max-width: 54rem;
        margin-inline: auto;
    }

    .project__data > div:first-of-type{
        grid-column: 2;
        grid-row: 1;
    }

    .project__data > div:last-of-type{
        grid-column: 2;
        grid-row: 2;
    }

    .project__icon{
        grid-column: 1;
        grid-row: 1 / 3;
        margin-top: .25rem;
        justify-self: center;
        font-size: 4.25rem;
    }

    .qualification__box{
        grid-template-columns: minmax(0, 1fr) auto;
        align-items: start;
    }
}

/* Contact */
.contact__form{
    width: 100%;
    min-width: 0;
}

.contact__inputs{
    grid-template-columns: 1fr;
    width: 100%;
}

.contact__input{
    min-width: 0;
}

.contact__description__mail{
    margin-left: 0;
    overflow-wrap: anywhere;
}

textarea.contact__input{
    resize: vertical;
}

/* Footer */
.footer__container{
    width: min(100% - 2rem, 1024px);
    margin-inline: auto;
}

.footer__social{
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: .75rem 1rem;
}

.footer__link{
    margin: 0;
}

@media screen and (min-width: 576px){
    .contact__form{
        width: min(100%, 450px);
        justify-self: center;
    }
}

@media screen and (min-width: 768px){
    .contact__inputs{
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

/* Small screens */
@media screen and (max-width: 575px){
    .section{
        padding-top: 2rem;
    }

    .about__container,
    .qualification__container,
    .services__container,
    .portfolio__container,
    .contact__container,
    .contact__content{
        grid-template-columns: minmax(0, 1fr);
    }

    .about__data,
    .qualification__content,
    .services__data,
    .portfolio__data,
    .project__container,
    .testimonial__content,
    .contact__box,
    .footer__container{
        text-align: center;
    }

    .project__icon{
        font-size: 3rem;
    }

    .project__title{
        font-size: clamp(1.35rem, 8vw, 1.75rem);
        text-align: center;
    }

    .project__description{
        font-size: .95rem;
        line-height: 1.7;
        text-align: left;
    }

    .contact__box{
        padding: 1.25rem 1rem;
    }
}

@media screen and (max-width: 767px){
    .qualification__container,
    .qualification__content,
    .qualification__content > .bd-grid{
        display: grid !important;
        grid-template-columns: 1fr !important;
        width: 100% !important;
    }

    .qualification__content{
        row-gap: 1.5rem !important;
    }

    .qualification__title{
        justify-content: center !important;
        text-align: center !important;
    }

    .qualification__data,
    .qualification__box{
        width: 100% !important;
    }

    .qualification__box{
        display: grid !important;
        grid-template-columns: 1fr !important;
        row-gap: .5rem !important;
        text-align: center !important;
    }

    .qualification__area,
    .qualification__work{
        text-align: center !important;
    }
}

@media screen and (max-width: 420px){
    :root{
        --container-padding: .875rem;
    }

    .section-title{
        margin-bottom: var(--mb-2);
    }

    .services__data,
    .portfolio__data,
    .contact__box,
    .testimonial__content{
        padding: 1.25rem .875rem;
    }

    .project__container{
        padding: 1.5rem .875rem;
    }

    .footer__link{
        display: inline-flex;
        margin-bottom: .75rem;
    }
}

/* Tablet balance */
@media screen and (min-width: 576px) and (max-width: 767px){
    .about__container,
    .qualification__container,
    .services__container,
    .portfolio__container{
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .contact__container,
    .contact__content{
        grid-template-columns: minmax(0, 1fr);
    }

    .home__container{
        row-gap: 1rem;
    }
}

@media screen and (min-width: 768px){
    .about__container{
        grid-template-columns: minmax(0, 1fr) minmax(220px, 300px);
        align-items: center;
    }

    .services__container,
    .portfolio__container{
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .contact__content{
        grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    }
}

/* Large screens */
@media screen and (min-width: 1024px){
    :root{
        --container-padding: 2rem;
    }

    .home__img{
        width: min(34vw, 520px);
    }

    .qualification__container{
        column-gap: 6rem;
    }
}

/* Final project-section override */
.project.section.bd-container{
    max-width: 920px !important;
    width: calc(100% - 2rem) !important;
    margin-inline: auto !important;
}

.project__container{
    padding: clamp(2rem, 4vw, 3.5rem) clamp(1.25rem, 4vw, 3rem) !important;
}

.project__data{
    display: grid !important;
    grid-template-columns: 1fr !important;
    justify-items: center !important;
    gap: 1.25rem !important;
    max-width: 760px !important;
    margin-inline: auto !important;
    text-align: center !important;
}

.project__icon{
    margin: 0 auto .25rem !important;
    font-size: clamp(3rem, 6vw, 4.5rem) !important;
}

.project__title{
    width: 100% !important;
    max-width: 760px !important;
    margin: 0 auto 1.5rem !important;
    text-align: center !important;
    font-size: clamp(1.75rem, 4vw, 2.75rem) !important;
}

.project__description{
    max-width: 700px !important;
    margin-inline: auto !important;
    text-align: left !important;
    line-height: 1.7 !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    hyphens: none !important;
}

.project__description p{
    margin-bottom: 1rem !important;
}

.project__description p:last-child{
    margin-bottom: 0 !important;
}

.project__data > div{
    width: 100% !important;
    min-width: 0 !important;
}

.project__data > div:last-of-type{
    display: flex !important;
    justify-content: center !important;
    margin-top: .75rem !important;
}

.project__data .button{
    margin-inline: auto !important;
}

@media screen and (min-width: 768px){
    .project__data{
        grid-template-columns: 4.5rem minmax(0, 1fr) !important;
        column-gap: 1.5rem !important;
        align-items: start !important;
        justify-items: stretch !important;
        max-width: 760px !important;
    }

    .project__icon{
        grid-column: 1 !important;
        grid-row: 1 / 3 !important;
        justify-self: center !important;
    }

    .project__data > div:first-of-type{
        grid-column: 2 !important;
        grid-row: 1 !important;
    }

    .project__data > div:last-of-type{
        grid-column: 2 !important;
        grid-row: 2 !important;
    }
}

@media screen and (max-width: 767px){
    .project.section.bd-container{
        width: calc(100% - 1.5rem) !important;
    }

    .project__description{
        text-align: left !important;
        font-size: .95rem !important;
    }
}

/* Project centered layout requested */
.project.section.bd-container{
    max-width: 920px !important;
}

.project__data,
.projet__data{
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 1.25rem !important;
    max-width: 760px !important;
    margin-inline: auto !important;
    text-align: center !important;
}

.project__icon{
    display: block !important;
    margin: 0 auto .25rem !important;
    font-size: clamp(3.5rem, 7vw, 5rem) !important;
    text-align: center !important;
}

.project__data > div:first-of-type{
    width: 100% !important;
}

.project__title{
    width: 100% !important;
    margin: 0 auto 1.5rem !important;
    text-align: center !important;
}

.project__description{
    max-width: 680px !important;
    margin-inline: auto !important;
    text-align: center !important;
}

.project__description p{
    text-align: center !important;
}

.project__data > div:last-of-type{
    width: 100% !important;
    display: flex !important;
    justify-content: center !important;
}

@media screen and (min-width: 768px){
    .project__data,
    .projet__data{
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        text-align: center !important;
    }

    .project__icon,
    .project__data > div:first-of-type,
    .project__data > div:last-of-type{
        grid-column: auto !important;
        grid-row: auto !important;
    }
}

/* Match only the typography of "Suivi personnel" with "Sécurité au quotidien" */
.about__description,
.about__descrition{
    font-size: .9rem !important;
    font-weight: var(--font-medium) !important;
    line-height: 1.65 !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    hyphens: none !important;
}

.about__description span,
.about__descrition span{
    font-size: clamp(1.35rem, 3vw, 2rem) !important;
    font-weight: var(--font-semi-bold) !important;
    line-height: 1.2 !important;
}

/* Final mobile override for Qualification section */
@media screen and (max-width: 767px){
    .qualification__container{
        display: flex !important;
        flex-direction: column !important;
        gap: 2rem !important;
        width: 100% !important;
    }

    .qualification__content{
        display: block !important;
        width: 100% !important;
    }

    .qualification__content > .bd-grid{
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 1.5rem !important;
        width: 100% !important;
    }

    .qualification__title{
        display: flex !important;
        justify-content: center !important;
        align-items: center !important;
        width: 100% !important;
        margin-bottom: 1.5rem !important;
        text-align: center !important;
    }

    .qualification__data,
    .qualification__box,
    .qualification__area,
    .qualification__work{
        width: 100% !important;
        text-align: center !important;
    }

    .qualification__box{
        display: grid !important;
        grid-template-columns: 1fr !important;
        justify-items: center !important;
        gap: .5rem !important;
    }
}
