/* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
                    RESPONSIVE MOBILE DESIGN
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ */
/* OTHER IMPROVEMENTS */
/* Desktop grande */
@media (max-width: 1200px) {
    .hero-home {
        min-height: 70vh !important;
    }
}

/* Portáteis/tablets landscape */
@media (max-width: 992px) {
    .project-intro-block,
    .project-hero-slider,
    .details-grid,
    .secondary-grid {
        width: 100%;
        grid-template-columns: 1fr;
        flex-direction: column;
    }

    .hero-home,
    .home-section.section-about,
    .home-section.section-portfolio,
    .footer-bottom {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
}




/* GERAL */
/* Portáteis/tablets landscape */
@media (max-width: 992px) {
    body {
        position: relative !important;
        height: auto !important;
        overflow: visible !important;
    }

    /* Esta classe só vai travar o ecrã quando o JS a injetar ao abrir o menu */
    body.menu-aberto {
        overflow: hidden !important;
        height: 100vh !important;
        width: 100%;
    }

    .menu-page-list li, 
    .language-switcher-container {
        opacity: 0;
        /* Opcional: mantém o deslocamento inicial para a animação GSAP continuar a funcionar */
        transform: translateY(15px); 
    }

    /* 2. Forçar o contentor do menu a tapar o ecrã todo sem frestas */
    .menu-open {
        height: 100dvh !important;     
    }
}

/* Tablets */
@media (max-width: 768px) {
    /* Impede que qualquer elemento "saia" para o lado direito */
    html, body {
        overflow-x: hidden;
        width: 100%;
        position: relative;
    }

    body:has(.menu_toggle.open) {
        z-index: 9999 !important;
        overflow: hidden !important;
        height: 100vh !important;
    }

    /* 1. Trancar o fundo de forma implacável no iPhone */
    body.menu-aberto {
        overflow: hidden !important;
        position: fixed !important;     
        width: 100% !important;
        height: 100dvh !important;     
    }

    /* 2. Forçar o contentor do menu a tapar o ecrã todo sem frestas */
    .menu-open {
        height: 100dvh !important;     
    }
}




/* NAVBAR RESPONSIVE */
/* Portáteis/tablets landscape */
@media (max-width: 992px) {
    .navbar .container {
        padding: 20px 40px !important;
    }

    .navbar .custom-logo-link img {
        max-width: 160px !important;
    }

    .navbar {
        padding: 0 !important;
        position: relative !important;
        z-index: 9999 !important;
    }

    .navigation-container {
        position: relative;
    }

    .navigation-wrapper {
        gap: 0;
    }

    .menu_toggle {
        width: 40px !important;
        height: 40px !important;
        display: flex !important;
        flex-direction: column !important;
        justify-content: center !important; 
        align-items: center !important;     
        background: transparent !important;
        cursor: pointer !important;
        padding: 0 !important;
        position: relative !important;
        z-index: 10000 !important; /* Mantém um nível acima do wrapper do menu */
    }

    .menu_toggle span {
        display: block !important;
        width: 40px !important;       
        height: 4px !important;       
        background-color: var(--color-primary) !important;
        margin: 3px 0 !important;     /* Espaçamento de 3px */
        transition: all 0.3s ease !important;
    }

    /* 2. Corrigido: Mudado de .active para .open para coincidir com o teu JS */
    /* Ajustado matematicamente o translateY para 7px para cruzarem perfeitamente no centro */
    .menu_toggle.open span:nth-child(1) {
        transform: translateY(10px) rotate(45deg) !important;
    }
    .menu_toggle.open span:nth-child(2) {
        opacity: 0 !important;
    }
    .menu_toggle.open span:nth-child(3) {
        transform: translateY(-10px) rotate(-45deg) !important;
    }

    .menu-page-list,
    .language-switcher-container {
        display: none;
    }

    .navigation-wrapper.menu-open {
        display: flex;
        position: fixed;
        top: 0;
        right: 0;
        left: 0;
        bottom: 0;
        width: 100%;
        height: 100vh;
        flex-direction: column;
        justify-content: center; 
        align-items: center;     
        gap: 35px;               
        padding: 40px 24px;
        background-color: var(--color-white);
        box-shadow: none;        
        z-index: 9998;           
    }

    .navigation-wrapper.menu-open .menu-page-list {
        display: flex;
        flex-direction: column;
        align-items: center;    
        gap: 24px;               
        width: 100%;
    }

    .navigation-wrapper.menu-open .menu-page-list li {
        text-align: center;
        width: 100%;
    }

    .navigation-wrapper.menu-open .menu-page-list li a {
        padding-bottom: 0;
        font-size: 1.4rem !important;
        letter-spacing: 1px;
    }

    .navigation-wrapper.menu-open .language-switcher-container {
        display: flex;
        justify-content: center; 
        width: 100%;
        gap: 20px;
        margin-top: 15px;
    }

    .navigation-wrapper.menu-open .lang-list {
        justify-content: center;
        gap: 20px;
    }

    .navigation-wrapper.menu-open .lang-list li a {
        font-size: 1.1rem !important;
    }

    .side_padding {
        padding-left: 16px;
        padding-right: 16px;
    }

    .header-divider {
        width: 100%;
    }
}

/* Tablets */
@media (max-width: 768px) {
    .navbar .container {
        padding: 20px 30px !important;
    }

    .menu-page-list {
        flex-wrap: wrap;
        gap: 12px;
    }

    .lang-list {
        padding-left: 0 !important;
    }

    .menu-page-list li a,
    .lang-list li a {
        font-size: 0.8rem;
    }

    .navigation-wrapper.menu-open {
        top: 0 !important;
        height: 100vh !important;
        padding: 40px 24px !important;
    }

    .menu_toggle {
        width: 42px;
        height: 42px;
    }

    .menu_toggle span {
        width: 20px;
    }

    .menu-page-list li a::after {
        bottom: -5px;
    }

    .menu-page-list li a:hover::after {
        bottom: -2.5px !important; 
    }

    .page-template-page-missao-php .menu-page-list li:first-child a::after {
        content: '' !important;
        display: block !important;
        position: absolute !important;
        bottom: -5px !important;
        left: 50% !important;
        transform: translateX(-50%) !important;
        width: 115% !important;
        height: 4px !important;
        background-color: var(--color-primary) !important;
    }

    .page-template-page-missao-php .menu-page-list li:first-child a {
        color: var(--color-black) !important;
    }
}

/* Telemóveis */
@media (max-width: 576px) {
    .navbar .container{
        padding: 20px !important;
    }

    .navbar .custom-logo-link img {
        max-width: 140px !important;
    }
}





/* FOOTER RESPONSIVE */
/* Portáteis/tablets landscape */
@media (max-width: 992px) {
    .site-footer .container {
        padding-left: 90px !important;
        padding-right: 90px !important;
    }

    .footer-col-divider {
        padding-left: 14px !important;
    }

    .footer-divider-2 {
        margin: 0 -10% 20px;
        width: 114%;
        margin-top: 30px !important;
        margin-bottom: 30px !important;
    }

    .footer-bottom {
        padding-top: 0 !important;
    }
}

/* Tablets */
@media (max-width: 768px) {
    .site-footer {
        padding-left: 24px !important;
        padding-right: 24px !important;
    }

    .site-footer .container {
        padding-left: 55px !important;
        padding-right: 15px !important;
    }

    .footer-col-divider {
        border-right: none;
        border-right: 1px solid #e5e5e5;
        padding-right: 0;
        padding-bottom: 20px;
        padding-left: var(--side-padding);
        padding-right: var(--side-padding);
        min-height: auto;
        margin-bottom: 20px;
        display: flex !important;
        flex-direction: column !important;
        position: relative;
    }

    .footer-col-divider:first-child {
        display: flex !important;
        flex-direction: row !important;
        justify-content: space-between !important;
        align-items: center !important;
        flex-wrap: wrap !important;
    }

    .footer-title {
        font-size: 1.2rem !important;
        display: inline-block !important;
        margin-top: 15px;
        margin-bottom: 20px !important;
    }

    .footer-link-inline {
        font-size: 0.8rem;
    }

    .footer-label, .footer-label-inline {
        display: block !important;
        margin-top: 15px !important;
    }

    .site-footer .footer-col-divider {
        border-right: none !important;
        border-left: none !important;
        border-bottom: none !important;
    }

    .footer-bottom a {
        text-decoration: none !important;
    }

    .footer-legal-links {
        display: flex !important;
        flex-direction: column !important;
        align-items: flex-start !important;
        padding-left: 0 !important;
        margin-bottom: 0 !important;
        gap: 10px !important;
        list-style: none !important; /* Limpa pontos de lista */
    }

    .footer-legal-links li {
        border: none !important;
        padding: 0 !important;
        margin: 0 !important;
        list-style-type: none !important;
    }

    .footer-legal-links li::before,
    .footer-legal-links li::after,
    .footer-bottom a::before,
    .footer-bottom a::after {
        display: none !important;
        content: none !important;
    }

    .site-footer .social {
        justify-content: flex-start !important;
    }

    .footer-bottom {
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 20px !important;
    }

    .footer-bottom .design {
        justify-content: flex-start !important;
        padding-left: 0 !important;
        width: auto !important;
        font-size: 0.6rem !important;
    }
}

/* Telemóveis */
@media (max-width: 576px) {
    .site-footer .container {
        padding-left: 40px !important;
        padding-right: 40px !important;
    }

    .footer-col-divider {
        padding-left: 15px;
        padding-right: 15px;
        border-right: none;
        border-bottom: none;
    }

    .footer-legal-links li:not(:last-child):after {
        margin: 0 10px;
    }

    .footer-divider-2 {
        margin: 0 -10% 20px;
        width: 120%;
        margin-top: 30px !important;
        margin-bottom: 30px !important;
    }

    .footer-legal-links li:not(:last-child)::after {
        display: none !important;
    }

    .footer-bottom {
        padding-top: 0 !important;
    }

    .footer-bottom ul {
        display: flex !important;
        flex-direction: column !important;
        align-items: flex-start !important;
    }

    .social {
        justify-content: flex-start !important;
    }

    .footer-bottom a.design {
        text-align: left !important;
        justify-content: flex-start !important;
        padding-left: 0 !important;
        margin-left: 0 !important;
        margin-top: 20px !important;
    }
}




/* HOME PAGE */
    /* HERO SECTION */
    /* Portáteis/tablets landscape */
    @media (max-width: 992px) {
        .hero-home .container {
            padding-left: 100px !important;
            padding-right: 100px !important;
        }

        .hero-home .hero-content {
            padding: 0 !important;
            margin: 0 !important;
        }
        
        .hero-home {
            padding-top: 40px !important;
            padding-bottom: 40px !important;
            min-height: auto !important;
        }

        .hero-subtitle {
            font-size: 2.5rem !important;
            max-width: 100% !important;
            margin: auto !important;
        }
    }

    /* Tablets */
    @media (max-width: 768px) {
        .hero-home .container {
            padding-left: 90px !important;
            padding-right: 90px !important;
        }

        .hero-home .hero-content {
            padding: 0 !important;
            margin: 0 !important;
        }

        .hero-home {
            padding-top: 40px !important;
            padding-bottom: 40px !important;
            min-height: auto !important;
        }

        .hero-subtitle {
            font-size: 2.2rem !important;
            max-width: 100% !important;
            margin: auto !important;
        }
    }

    /* Telemóveis */
    @media (max-width: 576px) {
        .hero-home .container {
            padding-left: 73px !important;
            padding-right: 73px !important;
        }

        .hero-subtitle {
            font-size: 1.8rem !important;
            max-width: 100% !important;
            margin: 0 !important;
        }
    }


    /* SECTION ABOUT */
    /* Portáteis/tablets landscape */
    @media (max-width: 992px) {
        .section-about .container,
        .home-section .container {
            padding-left: 24px !important;
            padding-right: 24px !important;
        }

        .content-box {
            margin-bottom: 0;
        }

        /* Garante que o espaçamento interno do texto fica correto agora que está à esquerda */
        .section-about .content-box {
            padding-left: 0 !important;
            padding-right: 30px !important;
        }

        .section-about .image-wrapper img.img-fluid {
            max-width: 100% !important;
            height: auto !important;
        }

        .section-label {
            font-size: 0.6rem;
        }
    }

    /* Tablets */
    @media (max-width: 768px) {
        .section-about .container,
        .home-section .container {
            padding-left: 0px !important;
            padding-right: 0px !important;
        }

        .home-section.section-about {
            padding-bottom: 50px !important;
        }

        .content-box {
            margin-bottom: 0;
        }

        /* Garante que o espaçamento interno do texto fica correto agora que está à esquerda */
        .section-about .content-box {
            padding-left: 52px !important;
            padding-right: 52px !important;
            padding-bottom: 30px !important;
        }

        .no-padding {
            padding-left: 0 !important;
            margin-left: 0 !important;
        }

        .section-about .image-wrapper img.img-fluid {
            max-width: 100% !important;
            height: auto !important;
        }

        .section-label {
            font-size: 0.6rem;
        }

        .section-title {
            font-size: 1.8rem;
            margin-bottom: 20px !important;
        }

        .btn-link {
            padding-top: 15px;
            padding-right: 20px;
            margin-top: 20px !important;
        }
    }

    /* Telemóveis */
    @media (max-width: 576px) {
        .section-about .container {
            padding-left: 5px !important;
            padding-right: 5px !important;
        }

        .section-about .content-box {
            padding-left: 30px !important;
            padding-right: 30px !important;
        }

        .home-section.section-about {
            padding-bottom: 50px !important;
        }

        .no-padding {
            padding-left: 0 !important;
            padding-right: 0 !important;
        }

        .section-title {
            font-size: 1.6rem;
            margin-bottom: 15px !important;
        }

        .about-us-description p {
            font-size: 0.8rem;
            line-height: 1.4;
        }

        .btn-link {
            padding-top: 15px;
            padding-right: 20px;
            margin-top: 20px;
            letter-spacing: 1.25px;
        }

        .content-box {
            max-width: 100% !important;
            width: 100% !important;
            margin-left: 0 !important;
            margin-right: 0 !important;
            margin-bottom: 20px !important;
        }

        .section-about .row {
            margin-left: 0 !important;
            margin-right: 0 !important;
        }

        .section-about .col-md-5.order-md-2 {
            order: 1 !important;
            flex: 0 0 100% !important;
            max-width: 100% !important;
            width: 100% !important;
        }

        .section-about .col-md-7.order-md-1 {
            order: 2 !important;
            flex: none !important;
            width: 100vw !important;
            max-width: 100vw !important;
            margin-left: calc(-50vw + 50%) !important;
            margin-right: calc(-50vw + 50%) !important;
        }

        .section-about .image-wrapper {
            width: 100%;
            max-width: 100%;
            margin-left: 0;
            margin-right: 0;
            overflow: hidden; 
            padding-left: 0 !important;
        }
    }
    

    /* SECTION PORTFOLIO */
    /* Portáteis/tablets landscape */
    @media (max-width: 992px) {
        .section-portfolio .container {
            padding-left: 0 !important;
            padding-right: 0 !important;
        }

        /* Ajuste de espaçamento opcional caso o texto cole muito ao slider */
        .section-portfolio .content-box {
            padding-left: 60px !important;
        }

        .portfolio-title {
            font-size: 1.8rem;
            margin-bottom: 15px;
        }

        .btn-link-portfolio {
            margin-top: 20px;
            padding-right: 20px;
        }
    }

    /* Tablets */
    @media (max-width: 768px) {
        .section-portfolio .container {
            padding-left: 0 !important;
            padding-right: 0 !important;
        }

        /* Ajuste de espaçamento opcional caso o texto cole muito ao slider */
        .section-portfolio .content-box {
            padding-left: 50px !important;
        }

        .portfolio-title {
            font-size: 1.8rem;
            margin-bottom: 15px;
        }

        .btn-link-portfolio {
            padding-right: 20px;
        }

        .no-padding {
            padding-left: 0 !important;
            margin-left: 0 !important;
        }

        .portfolio-slider-wrapper {
            width: 98% !important;
            height: auto !important;
            margin-left: 15px !important;
        }
    }

    /* Telemóveis */
    @media (max-width: 576px) {
        .section-portfolio .container {
            padding-left: 0 !important;
            padding-right: 0 !important;
        }

        .section-portfolio .content-box {
            max-width: 100% !important;
            width: 100% !important;
            margin-left: 0 !important;
            margin-right: 0 !important;
            margin-bottom: -15px !important;
            padding-left: 50px !important;
            padding-right: 50px !important;
        }

        .section-portfolio .row {
            display: flex !important;
            flex-direction: column !important;
            gap: 32px !important;
        }

        .section-portfolio .row > [class*="col-"] {
            flex: 0 0 100% !important;
            max-width: 100% !important;
            width: 100% !important;
            padding-left: 0 !important;
            padding-right: 0 !important;
        }

        .section-portfolio .col-md-4 {
            padding-left: 0 !important;
            padding-right: 0 !important;
        }

        .section-portfolio .col-md-8 {
            padding-left: 0 !important;
            padding-right: 0 !important;
            height: auto !important;
            min-height: auto !important;
            padding-bottom: 0 !important;
            margin-top: -40px;
        }

        .portfolio-slider-wrapper {
            width: 100% !important;
            height: auto !important;
            margin-left: 0 !important;
            margin-top: 20px !important;
        }

        .slick-prev-custom, .slick-next-custom {
            height: 35px !important;
            width: 35px !important;
        }

        .portfolio-slider .slick-dots {
            margin-left: 50px;
        }
    }




/* QUEM SOMOS */
/* Portáteis/tablets landscape */
@media (max-width: 992px) {
    .section-about-us .container {
        padding-left: 24px !important;
        padding-right: 24px !important;
    }
    
    .images-composition {
        position: relative !important;
        width: 100% !important;
        height: 550px !important;
        display: block !important;
    }

    .img-secondary {
        position: absolute !important;
        left: 0 !important;
        width: 55% !important;
        z-index: 5 !important;
        top: 230px !important;
    }

    .img-main {
        position: absolute !important;
        bottom: 0 !important;
        right: -75px !important;
        width: 65% !important;
        z-index: 20 !important;
        top: 0 !important;
    }

    .historia-label {
        font-size: 0.6rem;
    }

    .historia-title {
        font-size: 1.8rem !important;
        margin-bottom: 20px !important;
        margin-top: 0 !important;
    }

    .about-text-wrapper {
        padding: 40px 48px !important;
        max-width: 100%;
        margin: 0;
    }

    .btn-link-missao {
        padding-right: 20px;
        margin-top: 20px !important;
        margin-bottom: 20px !important;
    }
}

/* Tablets */
@media (max-width: 768px) {
    .section-about-us {
        padding-top: 20px !important;
        padding-bottom: 20px !important;
    }

    .section-about-us .container {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    .about-us-grid {
        display: flex !important;
        flex-direction: column !important;
        gap: 40px !important;
    }

    .images-composition {
        position: relative !important;
        width: 100% !important;
        height: 90px !important;
        display: block !important;
    }

    .img-main img, 
    .img-secondary img {
        width: 100% !important;
        height: auto !important;
        display: block !important;
    }

    .img-secondary {
        position: absolute !important;
        top: 220px !important;
        left: 48px !important;
        width: 40% !important;
        z-index: 5 !important;
    }

    .img-main {
        position: absolute !important;
        bottom: 0 !important;
        right: 48px !important;
        width: 50% !important;
        z-index: 20 !important;
    }

    .about-text-wrapper {
        padding: 48px !important;
        padding-top: 490px !important;
        max-width: 100% !important;
        margin: 0 !important;
    }

    .historia-title {
        font-size: 1.8rem !important;
        margin-bottom: 20px !important;
    }

    .description-text {
        font-size: 0.8rem !important;
        letter-spacing: 0.8px !important;
        line-height: 1.2 !important;
    }

    .btn-link-missao {
        letter-spacing: 0.8px !important;
        padding-right: 20px !important;
    }
}

/* Telemóveis */
@media (max-width: 576px) {
    .section-about-us .container {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    .images-composition {
        position: relative !important;
        width: 100% !important;
        height: 24px !important;
        display: block !important;
    }

    .img-main {
        position: absolute !important;
        bottom: 0 !important;
        right: 48px !important;
        width: 50% !important;
        z-index: 20 !important;
    }
    
    .img-secondary {
        position: absolute !important;
        top: 155px !important;
        left: 48px !important;
        width: 40% !important;
        z-index: 5 !important;
    }

    .about-text-wrapper {
        padding: 48px !important;
        padding-top: 280px !important;
        max-width: 100% !important;
        margin: 0 !important;
    }
}


    /* QUEM SOMOS - TIMELINE */
    /* Portáteis/tablets landscape */
    @media (max-width: 992px) {
        .section-timeline .container {
            padding-left: 24px !important;
            padding-right: 24px !important;
        }

        .timeline-header {
            padding-left: 24px !important;
            padding-right: 24px !important;
        }

        .section-timeline {
            padding-top: 120px;
            padding-bottom: 0;
        }

        .timeline-line {
            width: 100% !important;
            left: 0 !important;
        }

        .timeline-items {
            width: 100% !important;
            margin-left: 0 !important;
        }

        .timeline-item:nth-child(odd) {
            text-align: right !important;
            padding-left: 15px !important;
        }
        .timeline-item:nth-child(even) {
            text-align: left !important;
            padding-right: 15px !important;
        }
    }

    /* Tablets */
    @media (max-width: 768px) {
        .section-timeline .container {
            padding-left: 24px !important;
            padding-right: 24px !important;
        }

        .section-timeline {
            padding-top: 90px;
            padding-bottom: 50px !important;
            height: 100vh !important;
            min-height: 100vh !important;
            display: flex !important;
            flex-direction: column !important;
            justify-content: center !important;
            box-sizing: border-box !important;
            overflow: hidden !important;
        }

        .timeline-wrapper {
            position: relative !important;
            padding: 40px 0 !important;
            width: 100% !important;
        }

        .timeline-header {
            padding-left: 24px !important;
            padding-right: 24px !important;
        }

        .timeline-title {
            font-size: 1.8rem;
            margin-bottom: 30px;
        }

        .timeline-line {
            position: absolute !important;
            left: 50% !important;
            top: 0 !important;
            width: 1.5px !important;
            height: 100%;
            background-color: #e5e5e5 !important;
            transform: translateX(-50%) !important;
            margin: 0 !important;
            z-index: 1;
        }

        .timeline-items {
            display: flex !important;
            flex-direction: column !important;
            gap: 20px !important;
            width: 100% !important;
            padding: 0 !important;
            margin: 0 !important;
            position: relative;
        }

        .timeline-item {
            position: relative !important;
            width: 100% !important;
            max-width: 100% !important;
            display: flex !important;
            flex-direction: column !important;
            margin: 0 !important;
            box-sizing: border-box !important;
            z-index: 2;
        }

        .timeline-dot {
            position: absolute !important;
            top: 6px !important;
            left: 50% !important;
            width: 12px !important;
            height: 12px !important;
            margin: 0 !important;
            transform: translateX(-50%) !important;
            background-color: var(--color-black) !important;
            border-radius: 50% !important;
            z-index: 10 !important;
        }

        .timeline-item:nth-child(odd) {
            text-align: right !important;
            padding-left: 20px !important;
            padding-right: calc(50% + 20px) !important;
            align-items: flex-end;
        }
        .timeline-item:nth-child(odd) .timeline-year span{
            text-align: right !important;
            align-items: flex-end !important;
        }
        .timeline-item:nth-child(odd) p{
            text-align: right !important;
        }
        .timeline-item:nth-child(odd) .timeline-dot {
            left: 50% !important;
            right: auto !important;
        }

        .timeline-item:nth-child(even) {
            text-align: left !important;
            padding-right: 20px !important;
            padding-left: calc(50% + 20px) !important;
            align-items: flex-start;
        }
        .timeline-item:nth-child(even) span {
            text-align: left !important;
        }
        .timeline-item:nth-child(even) p{
            text-align: left !important;
        }
        .timeline-item:nth-child(even) .timeline-dot {
            left: 50% !important;
            right: auto !important;
        }

        .timeline-year {
            font-size: 1.1rem;
            line-height: 1.2;
            display: block !important;
        }

        .timeline-desc {
            font-size: 0.8rem;
            line-height: 1.2 !important;
            margin: 0 !important;
        }
    }

    /* Telemóveis */
    @media (max-width: 576px) {
        .section-timeline .container {
            padding-left: 24px !important;
            padding-right: 24px !important;
        }

        .timeline-header {
            padding-left: 24px !important;
            padding-right: 24px !important;
        }

        .timeline-title {
            font-size: 1.6rem !important;
        }

        .timeline-item:nth-child(odd) {
            text-align: right !important;
            padding-left: 20px !important;
            padding-right: calc(50% + 20px) !important;
            align-items: flex-end;
        }

        .timeline-item:nth-child(even) {
            text-align: left !important;
            padding-right: 20px !important;
            padding-left: calc(50% + 20px) !important;
            align-items: flex-start;
        }

        .timeline-desc {
            font-size: 0.6rem !important;
            line-height: 1.2 !important;
            margin: 0 !important;
        }
    }
    



/* MISSÃO */
/* Portáteis/tablets landscape */
@media (max-width: 992px) {
    .section-mission .container {
        padding-left: 24px !important;
        padding-right: 24px !important;
    }

    .mission-grid {
        display: grid !important;
        grid-template-columns: 1.2fr 1fr !important; /* Transforma as duas colunas numa só */
        gap: 32px !important;                  /* Cria o espaçamento vertical entre a imagem e o texto */
    }

    .mission-image {
        order: 1 !important;
        width: 100% !important;
        position: relative !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        margin-bottom: 10px !important;
        padding: 0 !important;
    }

    .mission-image img {
        width: 100% !important;
        height: auto !important;
        display: block !important;
    }

    .mission-label {
        font-size: 0.6rem;
    }

    .mission-title {
        font-size: 1.8rem !important;
        margin-bottom: 20px !important;
        margin-top: 0 !important;
    }

    .mission-text {
        order: 2 !important;
        margin-left: 0 !important;
    }

    /* Valores */
    .section-principles .container {
        padding-left: 50px !important;
        padding-right: 50px !important;
    }

    .section-principles {
        padding-left: var(--side-padding) !important;
        padding-right: var(--side-padding) !important;
    }

    .principles-grid {
        grid-template-columns: 1fr 1.5fr;
        gap: 90px;
    }

    .principles-main-title {
        font-size: 1.6rem !important;
        line-height: 1.2 !important;
        margin-bottom: 20px !important;
    }

    .principle-content h3 {
        font-size: 1rem !important;
        margin-bottom: 10px !important;
        line-height: 1.2;
    }

    .closing-statement {
        font-family: var(--gotham-light) !important;
        font-style: italic !important;
        font-size: 2rem !important;
        line-height: 1.2 !important;
        margin-bottom: 10px !important;
    }
}

/* Tablets */    
@media (max-width: 768px) {
        .section-mission {
            padding-top: 20px !important;
            margin-bottom: -40px !important;
        }

        .section-mission .container,
        .section-principles .container {
            padding-left: 24px !important;
            padding-right: 24px !important;
        }

        .mission-grid {
            display: flex !important;
            flex-direction: column !important;
            gap: 30px !important;
            align-items: center !important;
        }

        .mission-text {
            order: 2 !important; 
            padding: 0 var(--side-padding) !important;
        }

        .mission-image {
            order: 1 !important;
            width: 93vw !important;
            position: relative !important;
            margin-left: -50vw !important;
            margin-right: -50vw !important;
            margin-bottom: 10px !important;
            padding: 0 !important;
        }

        .mission-image img {
            display: block !important;
            width: 100% !important;
            max-width: 100% !important;
            height: auto !important;
        }

        .mission-title {
            font-size: 1.7rem !important;
            line-height: 1.2 !important;
            margin-bottom: 20px !important;
            margin-top: 0 !important;
        }

        .mission-description p {
            font-size: 0.8rem !important;
            line-height: 1.2 !important;
        }

        /* Valores */
        .section-principles {
            padding: 40px var(--side-padding) !important;
            padding-top: 0 !important;
        }

        .principles-grid {
            display: flex !important;
            flex-direction: column !important;
            gap: 44px !important;
        }

        .principles-main-title {
            font-size: 1.8rem !important;
            line-height: 1.2 !important;
        }

        .principles-subtitle {
            font-size: 0.8rem !important;
            line-height: 1.2 !important;
        }

        .principle-item {
            display: flex !important;
            flex-direction: row !important;
            align-items: flex-start !important;
            gap: 15px !important;
            width: 100% !important;
        }

        .principle-number {
            font-size: 1rem !important;
            line-height: 1.2 !important;
            min-width: 30px !important;
        }

        .principle-content h3 {
            font-size: 1rem !important;
            margin-bottom: 10px !important;
            line-height: 1.2 !important;
        }

        .principle-content p {
            font-size: 0.8rem !important;
            line-height: 1.2 !important;
            margin: 0 !important;
        }

        /* Mensagem Final */
        .section-mission-closing {
            padding: 40px var(--side-padding);
            text-align: center !important;
        }

        .closing-statement {
            font-size: 1.8rem !important;
            line-height: 1.2 !important;
            margin-bottom: 20px !important;
        }
        
        .closing-statement br,
        .mission-title br {
            display: none !important;
        }
}

/* Telemóveis */
@media (max-width: 576px) {
    .mission-image {
        order: 1 !important;
        width: 93vw !important;
        position: relative !important;
        margin-left: -50vw !important;
        margin-right: -50vw !important;
        margin-bottom: 10px !important;
        padding: 0 !important;
    }

    .mission-text {
        order: 2 !important; 
        padding: 0 24px !important;
    }

    .section-principles {
        padding: 40px 24px !important;
        padding-top: 40px !important;
        padding-top: 0 !important;
    }

    .section-mission-closing .container {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    .section-mission-closing {
        padding: 40px var(--side-padding);
        padding-top: 0 !important;
    }

    .closing-statement {
        font-size: 1.6rem !important;
        line-height: 1.2 !important;
        margin-bottom: 10px !important;
    }

    .closing-content p {
        font-size: 0.5rem !important;
    }
}




/* SERVIÇOS */
/* Portáteis/tablets landscape */
@media (max-width: 992px) {
    .section-services-intro .container {
        padding-left: 50px !important;
        padding-right: 50px !important;
    }

    .section-services-intro {
        padding: 44px 24px 0;
    }

    .services-label {
        font-size: 0.6rem;
    }

    .services-main-title {
        font-size: 1.8rem;
        margin-top: 0 !important;
    }

    .services-main-title br {
        display: none;
    }

    .services-intro-text br {
        display: none;
    }

    .section-services-list .container {
        padding-left: 24px !important;
        padding-right: 24px !important;
    }

    .service-card {
        padding-left: 50px !important;
        min-height: 275px !important;
    }

    /* --- ALINHAR APENAS O 1º E O 4º ÍCONE DOS SERVIÇOS --- */
    /* Alvo: O ícone dentro do PRIMEIRO card */
    .services-cards-grid .service-card:nth-child(1) .service-card-icon img {
        margin-left: -10px !important;
    }

    /* Alvo: O ícone dentro do QUARTO card */
    .services-cards-grid .service-card:nth-child(4) .service-card-icon img {
        margin-left: -10px !important; 
    }

    .service-card-icon {
        margin-left: -20px !important;
    }

    .service-card-title {
        max-width: 100%;
        margin-left: 0 !important;
    }

    .service-card-title br {
        display: none;
    }

    .service-card-text {
        max-width: 100%;
        margin-left: 0 !important;
    }
}

/* Tablets */
@media (max-width: 768px) {
    .section-services-intro .container, 
    .section-services-list .container {
        padding-left: 12px !important;
        padding-right: 12px !important;
    }

    .section-services-intro {
        padding: 44px 52px 0;
    }

    .services-main-title {
        font-size: 1.8rem;
        line-height: 1.2;
    }

    .services-intro-text {
        font-size: 0.8rem;
        line-height: 1.2;
    }

    .services-intro-text br {
        display: none;
    }

    .service-card {
        padding-left: 52px !important;
        padding-right: 52px !important;
        min-height: 275px !important;
    }

    /* --- ALINHAR APENAS O 1º E O 4º ÍCONE DOS SERVIÇOS --- */
    /* Alvo: O ícone dentro do PRIMEIRO card */
    .services-cards-grid .service-card:nth-child(1) .service-card-icon img {
        margin-left: -10px !important;
    }

    /* Alvo: O ícone dentro do QUARTO card */
    .services-cards-grid .service-card:nth-child(4) .service-card-icon img {
        margin-left: -10px !important; 
    }
}

/* Telemóveis */
@media (max-width: 576px) {
    .section-services-intro {
        padding: 44px 36px 0 !important;
    }

    .service-card {
        padding-left: 36px !important;
        padding-right: 36px !important;
    }
}




/* PORTFÓLIO */
/* Portáteis/tablets landscape */
@media (max-width: 992px) {
    .section-portfolio-intro .container {
        padding-left: 24px !important;
        padding-right: 24px !important;
    }

    .section-portfolio-intro {
        padding: 40px 0 15px;
    }

    .portfolio-header {
        padding-left: 50px !important;
        padding-right: 50px !important;
    }

    .porfolio-label {
        font-size: 0.6rem;
    }

    .portfolio-main-title {
        margin-top: 0 !important;
    }

    .portfolio-main-title br {
        display: none;
    }

    .portfolio-intro-text br {
        display: none;
    }

    .portfolio-info {
        margin-left: 0 !important;
        padding-left: 50px !important;
    }

    .overlay-logo {
        width: auto; /* Impede que estique na largura */
        height: auto; /* Impede que estique na altura */
        max-width: 21%; /* Ocupa no máximo % da largura do card */
        max-height: 17%; /* Ocupa no máximo % da altura do card */
        object-fit: contain; /* Mantém a proporção sem deformar */
        overflow: visible;
    }

    .portfolio-grid > div:nth-child(2) .overlay-logo {
        width: 21% !important;   /* A nova largura diferente para o segundo logo */
        height: auto !important;   /* Mantém a proporção visual correta */
    }
}

/* Tablets */
@media (max-width: 768px) {
    .section-portfolio-intro .container {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    .portfolio-header {
        padding-left: 64px !important;
        padding-right: 64px !important;
    }

    .portfolio-main-title {
        font-size: 1.8rem;
        line-height: 1.2;
    }

    .portfolio-intro-text {
        font-size: 0.8rem;
        line-height: 1.2;
    }

    .portfolio-grid {
        gap: 50px;
    }
}

/* Telemóveis */
@media (max-width: 576px) {
    .portfolio-header {
        padding-left: 48px !important;
        padding-right: 48px !important;
        margin-bottom: 30px !important;
    }

    .portfolio-info {
        margin-left: 0 !important;
        padding-left: 48px !important;
    }
}




/* PROJECT DETAILS */
/* Portáteis/tablets landscape */
@media (max-width: 992px) {
    .py-5 {
        padding-bottom: 0 !important;
    }

    .container-custom {
        width: 100%;
        margin: 0 auto;
        padding: 0 40px;
    }

    .close-project {
        right: 25px !important;
    }

    .project-hero {
        padding-bottom: 40px !important;
    }

    .project-hero .row,
    .project-hero .bg-bege,
    .project-hero .col-md-7,
    .mainProjectSwiper,
    .mainProjectSwiper .swiper-wrapper,
    .mainProjectSwiper .swiper-slide {
        height: 400px !important;
        min-height: 400px !important;
        max-height: 400px !important;
    }

    .mainProjectSwiper .img-full-height {
        width: 100% !important;
        height: 100% !important;
        max-height: 100% !important;
        object-fit: cover !important;
    }

    .project-hero .bg-bege {
        display: flex !important;
        align-items: center !important;
    }

    .project-hero .bg-bege .p-5 {
        padding: 2rem 35px !important; /* Reduz o preenchimento interno */
    }

    .project-hero .project-main-title {
        font-size: 1.5rem !important;
        line-height: 1.2 !important;
        margin-bottom: 0.6rem !important;
    }

    .project-hero .project-description-short {
        font-size: 0.7rem !important;
        line-height: 1.2 !important;
    }

    .project-meta-info .meta-row {
        margin-bottom: 15px !important; 
        margin-left: 0 !important;      
        margin-right: 0 !important;     
    }

    .project-meta-info-divider {
        margin-top: 0 !important;
    }

    .project-meta-info {
        margin-top: 10px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
    }

    .details-grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 0;
    }

    .characteristics-container .icons-grid {
        display: flex !important;
        flex-direction: row !important; 
        gap: 20px !important;
        width: 100% !important;
        margin-top: 0 !important;
    }

    .characteristics-container {
        width: 100% !important;
        padding-left: 35px !important;
    }
    .characteristics-container .icon-item {
        display: flex !important;
        flex-direction: column !important; 
        align-items: flex-start !important; 
        gap: 20px !important;
        width: 100% !important;
    }

    .characteristics-container .icon-wrapper {
        flex-shrink: 0 !important;
        width: 50px !important;
        height: 40px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        margin-bottom: 0 !important;
    }

    .characteristics-container .icon-wrapper img {
        height: 32px !important;
        width: auto !important;
        max-width: 100% !important;
        object-fit: contain !important;
    }

    .project-details-section .icons-grid .icon-item:nth-child(2) .icon-wrapper img {
        padding-top: 5px !important; /* Ajuste específico para o segundo ícone */
    }

    .characteristics-container .icon-text {
        display: flex !important;
        flex-direction: column !important;
        text-align: left !important;
    }

    .characteristics-container .caract-title {
        font-size: 1rem !important;
        line-height: 1.2 !important;
        margin-bottom: 2px !important;
        display: block !important;
    }

    .characteristics-container .caract-info {
        font-size: 0.8em !important;
        color: var(--color-secondary);
        display: block !important;
        width: 200px !important;
    }

    .project-info-row {
        padding-left: 30px !important;
    }

    .project-info-row::before {
        display: none !important;
        left: -10px;
        top: 46%;
        height: calc(100% + 20px);
    }

    .charac-divider {
        display: block !important;
        border: 0 !important;
        border-top: 1px solid rgba(0, 0, 0, .1) !important;
        width: 100% !important;
        margin: 1rem 0 !important;
    }

    .charac-subtitle-1 {
        font-size: 0.8rem !important;
    }
    
    .charac-subtitle-2 {
        font-size: 0.8rem !important;
        margin-left: 0 !important;
    }

    .project-info-row > .row {
        display: flex !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important; /* Impede o título de empurrar a lista para baixo */
        align-items: flex-start !important; /* Alinha o topo do título com o topo da lista */
    }

    /* Controla a largura da coluna da Lista (55% do ecrã + 5% de margem) */
    .project-info-row .col-md-6.offset-md-1 {
        flex: 0 0 55% !important;
        max-width: 55% !important;
        margin-left: 5% !important; /* Cria um espaçamento elegante entre os dois */
    }

    .project-secondary-content .header-evolucao {
        margin-left: 70px !important;
        margin-right: 30px !important;
        margin-bottom: 25px !important;
    }

    .label-red {
        margin-left: 0 !important;
    }

    .project-secondary-content .title-evolucao {
        text-align: left !important;
        font-size: 1.5rem !important; 
        margin-left: 0 !important;
        margin-top: 0 !important;
    }

     .project-secondary-content .projeto-imagem-extra-container {
        width: 100% !important;
    }

    .project-secondary-content .projeto-imagem-extra-container img {
        width: 100% !important;
        height: auto !important;
    }

    .project-secondary-content .long-description {
        margin-top: 30px !important;
        font-size: 0.7rem !important;
    }

    .project-secondary-content .slider-col-wrapper {
        width: calc(100% + 20px) !important;
    }


    .project-secondary-content .secondary-controls-wrapper {
        display: flex !important;       
        position: absolute !important;
        bottom: 0 !important;           
        left: 0 !important;
        width: 100% !important;
        height: 24px !important;
        justify-content: flex-start !important;
        align-items: center !important;
        z-index: 50 !important;    
        padding-left: 50px !important;
    }

    .project-secondary-content .custom-nav-arrows {
        display: flex !important;
        align-items: center !important;
        gap: 0px !important;
    }
}

/* Tablets */
@media (max-width: 768px) {
    .container-custom {
        width: 100%;
        margin: 0 auto;
        padding: 0 15px;
    }

    .close-project {
        right: 0 !important;
    }

    .project-meta-info {
        margin-top: 40px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
    }

    .project-meta-info .meta-row {
        margin-bottom: 15px !important; 
        margin-left: 0 !important;      
        margin-right: 0 !important;     
    }

    .project-hero .bg-bege .p-5 {
        padding: 2rem 50px !important;
    }

    .py-5 {
        padding-top: 1rem !important;
        padding-bottom: 1rem !important;
    }

    .project-hero {
        padding-bottom: 44px !important;
    }

    .project-details-section {
        padding-top: 400px !important;
        padding-left: 20px !important;
    }

    .details-grid {
        display: flex !important;
        flex-direction: column !important;
        gap: 20px !important;
    }

    .details-grid > div {
        grid-column: auto !important;
        width: 100% !important;
        margin: 0 !important;
    }

    .characteristics-container .icons-grid {
        display: flex !important;
        flex-direction: row !important; 
        gap: 20px !important;
        width: 100% !important;
        margin-top: 0 !important;
    }

    .characteristics-container {
        width: 100% !important;
        padding-left: 45px !important;
    }
    .characteristics-container .icon-item {
        display: flex !important;
        flex-direction: column !important; 
        align-items: flex-start !important; 
        gap: 20px !important;
        width: 100% !important;
    }

    .characteristics-container .icon-wrapper {
        flex-shrink: 0 !important;
        width: 50px !important;
        height: 40px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        margin-bottom: 0 !important;
    }

    .characteristics-container .icon-wrapper img {
        height: 32px !important;
        width: auto !important;
        max-width: 100% !important;
        object-fit: contain !important;
    }

    .project-details-section .icons-grid .icon-item:nth-child(2) .icon-wrapper img {
        padding-top: 5px !important; /* Ajuste específico para o segundo ícone */
    }

    .characteristics-container .icon-text {
        display: flex !important;
        flex-direction: column !important;
        text-align: left !important;
    }

    .characteristics-container .caract-title {
        font-size: 1rem !important;
        line-height: 1.2 !important;
        margin-bottom: 2px !important;
        display: block !important;
    }

    .characteristics-container .caract-info {
        font-size: 0.8em !important;
        color: var(--color-secondary);
        display: block !important;
        width: 200px !important;
    }

    .project-info-row:before {
        display: none !important;
    }

    .project-info-row {
        padding-left: 45px !important;
    }

    .charac-divider {
        display: block !important;
        margin-top: 1rem !important;
        margin-bottom: 1rem !important;
        border: 0 !important;
        border-top: 1px solid rgba(0, 0, 0, .1) !important;
        width: calc(100% + 32px);
        margin-left: -16px;
    }
    
    .charac-subtitle-2 {
        margin-left: 0 !important;
    }

    .project-info-row > .row {
        display: flex !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important; /* Impede o título de empurrar a lista para baixo */
        align-items: flex-start !important; /* Alinha o topo do título com o topo da lista */
    }

    /* Controla a largura da coluna do Título (40% do ecrã) */
    .project-info-row .col-md-5 {
        flex: 0 0 40% !important;
        max-width: 40% !important;
    }

    /* Controla a largura da coluna da Lista (55% do ecrã + 5% de margem) */
    .project-info-row .col-md-6.offset-md-1 {
        flex: 0 0 55% !important;
        max-width: 55% !important;
        margin-left: 5% !important; /* Cria um espaçamento elegante entre os dois */
    }

    /* [OPCIONAL] Se quiseres que o Cargo (Função) e o Nome do parceiro também fiquem em coluna, um sob o outro: */
    .partner-item {
        display: flex !important;
        flex-direction: column !important;
        gap: 2px !important; /* Espaço curtinho entre a função e o nome */
    }

    .project-secondary-content .row {
        display: flex !important;
        flex-direction: column !important;
        padding: 0 15px !important;
    }

    .project-secondary-content .col-md-7,
    .project-secondary-content .col-md-5,
    .project-secondary-content .sidebar-evolucao {
        display: contents !important;
    }

    .project-secondary-content .header-evolucao {
        order: 1 !important;
        margin-left: 45px !important;
        margin-right: 45px !important;
        margin-bottom: 25px !important;
    }

    .label-red {
        margin-left: 0 !important;
    }

    .project-secondary-content .title-evolucao {
        text-align: left !important;
        font-size: 1.5rem !important; 
        margin-left: 0 !important;
    }

     .project-secondary-content .projeto-imagem-extra-container {
        order: 2 !important;
        width: calc(100% + 30px) !important;
        margin-left: -15px !important;
        margin-right: 0 !important;
        margin-bottom: 20px !important;
    }

    .project-secondary-content .projeto-imagem-extra-container img {
        width: 100% !important;
        height: auto !important;
    }

    .project-secondary-content .long-description {
        order: 3 !important;
        width: 100% !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        margin-bottom: 35px !important;
        margin-top: 20px !important;
        padding: 0 !important;
        padding-left: 45px !important;
        padding-right: 45px !important;
        text-align: left !important;  
        font-size: 0.8rem !important;
    }

    .project-secondary-content .slider-col-wrapper {
        order: 4 !important;
        width: calc(100% + 51px) !important;
        margin-left: -35px !important;
        height: auto !important;
        margin-right: 0 !important;
    }

    .project-secondary-content .secondaryProjectSwiper {
        overflow: hidden !important;
        padding-bottom: 50px !important;
    }

    .project-secondary-content .secondary-controls-wrapper {
        display: flex !important;       
        position: absolute !important;
        bottom: 0 !important;           
        left: 0 !important;
        width: 100% !important;
        height: 24px !important;
        justify-content: flex-start !important;
        align-items: center !important;
        z-index: 50 !important;    
        padding-left: 60px !important;
    }

    .project-secondary-content .custom-nav-arrows {
        display: flex !important;
        align-items: center !important;
        gap: 0px !important;
    }
}

/* Telemóveis */
@media (max-width: 576px) {
    .container-custom {
        width: 100% !important;
        margin: 0 auto !important;
        padding: 0 15px !important;
    }

    .close-project {
        right: 0 !important;
    }

    .project-hero .bg-bege .p-5 {
        padding: 2rem 34px !important;
    }

    .project-hero {
        padding-top: 20px !important;
    }

    .project-meta-info {
        margin-top: 10px !important;
    }

    .project-details-section {
        margin-left: 24px !important;
        margin-top: 400px !important;
    }

    .project-info-row:before {
        display: none !important;
    }

    .charac-divider {
        display: block !important;
        margin-top: 1rem !important;
        margin-bottom: 1rem !important;
        border: 0 !important;
        border-top: 1px solid rgba(0, 0, 0, .1) !important;
        width: calc(100% + 32px) !important;
        margin-left: -40px !important;
    }

    .characteristics-container {
        padding-left: 9px !important;
    }

    .characteristics-container .icons-grid {
        display: flex !important;
        flex-direction: column !important; 
        gap: 20px !important;
        width: 100% !important;
        margin-top: 0 !important;
    }

    .characteristics-container .icon-item {
        display: flex !important;
        flex-direction: column !important; 
        align-items: flex-start !important; 
        gap: 0 !important;
        width: 100% !important;
    }

    .characteristics-container .icon-wrapper {
        flex-shrink: 0 !important;
        width: 50px !important;
        height: 40px !important;
        display: flex !important;
        align-items: center !important;
        margin-bottom: 0 !important;
    }

    .details-grid {
        display: flex !important;
        flex-direction: column !important;
        gap: 16px !important;
    }

    .details-grid > div {
        grid-column: auto !important;
        width: 100% !important;
        margin: 0 !important;
    }

    .project-info-row {
        padding-left: 9px !important;
    }

    .project-info-row > .row {
        flex-direction: column !important;
        flex-wrap: wrap !important;
        gap: 15px !important; /* Cria um espaço vertical saudável entre o título e a lista */
    }

    /* 2. Força as duas colunas a ocupar a largura total do ecrã */
    .project-info-row .col-md-5,
    .project-info-row .col-md-6.offset-md-1 {
        flex: 0 0 100% !important;
        max-width: 100% !important;
    }

    /* 3. Mata o espaçamento à esquerda herdado do tablet */
    .project-info-row .col-md-6.offset-md-1 {
        margin-left: 0 !important;
        padding-left: 16px !important; /* Garante que fica totalmente encostado à esquerda */
    }

    .project-secondary-content .header-evolucao {
        order: 1 !important;
        margin-left: 30px !important;
        margin-right: 30px !important;
        margin-bottom: 10px !important;
    }

    .project-secondary-content .title-evolucao {
        margin-top: 0 !important;
    }

    .project-secondary-content .projeto-imagem-extra-container {
        order: 2 !important;
        width: calc(100% + 30px) !important;
        margin-left: -15px !important;
        margin-right: 0 !important;
        margin-bottom: 20px !important;
    }

    .project-secondary-content .projeto-imagem-extra-container img {
        width: 100% !important;
        height: auto !important;
    }

    .project-secondary-content .slider-col-wrapper {
        order: 4 !important;
        width: calc(100% + 51px) !important;
        margin-left: -35px !important;
        height: auto !important;
        margin-right: 0 !important;
    }

    .project-secondary-content .secondary-controls-wrapper {
        padding-left: 45px !important;
    }
}




/* CONTACTS */
/* Portáteis/tablets landscape */
@media (max-width: 992px) {
    .section-contact .container {
        padding-left: 50px !important;
        padding-right: 50px !important;
    }

    .contact-grid {
        display: flex !important;
        flex-direction: column !important;
        gap: 0px !important;
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
        padding: 40px 24px 0 !important;
    }

    .contact-info {
        width: 100% !important;
        max-width: 100% !important;
    }

    .contact-intro-text {
        max-width: 100% !important;
        width: 100% !important;
        margin-right: 0 !important;
        text-align: left !important;
    }

    .contact-form-wrapper {
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
        margin-top: 50px !important;
    }

    .contact-form-wrapper .wpcf7,
    .contact-form-wrapper form,
    .contact-form-wrapper .form-row,
    .contact-form-wrapper .wpcf7-form-control-wrap,
    .contact-form-wrapper p,
    .contact-form-wrapper div,
    .contact-form-wrapper span {
        display: block !important;
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        float: none !important;
    }

    .contact-form-wrapper input[type="text"],
    .contact-form-wrapper input[type="email"],
    .contact-form-wrapper textarea {
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box !important; 
    }

    .cf7-custom-form input[type="submit"],
    .contact-form-wrapper input[type="submit"],
    .contact-form-wrapper button[type="submit"],
    .wpcf7-form input[type="submit"],
    .wpcf7-form button[type="submit"],
    .contact-form-wrapper button,
    .contact-form-wrapper input[type="button"],
    .contact-form-wrapper a.button,    
    .contact-form-wrapper .wpcf7-submit {
        display: inline-block !important; 
        width: auto !important;
        min-width: 30% !important;
        max-width: 100% !important;      
        position: relative !important;
        top: auto !important;
        bottom: auto !important;
        left: auto !important;
        right: auto !important;
        margin-left: 0 !important;       
        margin-top: 0 !important;
        padding: 0 !important;
        text-align: left !important; 
        box-sizing: border-box !important;
    }

    .wpcf7-acceptance {
        display: block !important;
        width: 100% !important;
        margin-top: 25px !important;
        margin-bottom: 20px !important;
        position: relative !important; 
        top: auto !important;
        bottom: auto !important;
        left: auto !important;
        right: auto !important;
        padding-left: 0 !important;
    }

    .wpcf7-acceptance .wpcf7-list-item {
        display: flex !important;
        flex-direction: row !important; 
        align-items: flex-start !important; 
        gap: 15px !important;
        margin: 0 !important;
    }

    .wpcf7-acceptance input[type="checkbox"] {
        flex-shrink: 0 !important;
        position: relative !important;
    }

    .wpcf7-acceptance .wpcf7-list-item-label {
        display: inline !important;
        align-items: center !important; 
        gap: 12px !important;
        font-size: 0.8rem !important;
        margin: 0 !important;
        padding-left: 0 !important;
        text-align: left !important;
    }

    .wpcf7-acceptance .wpcf7-list-item-label:before {
        content: "" !important;
        position: relative !important;  
        top: auto !important;
        left: auto !important;
        transform: none !important;     
        width: 18px !important;
        height: 18px !important;
        flex-shrink: 0 !important;      
        margin: 0 !important;
        margin-right: 10px !important;
    }
}

/* Tablets */
@media (max-width: 768px) {
    .section-contact .container {
        padding-left: 40px !important;
        padding-right: 40px !important;
    }

    .contact-grid {
        display: flex !important;
        flex-direction: column !important;
        gap: 0px !important;
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
        padding: 40px 24px 0 !important;
    }

    .contact-info {
        width: 100% !important;
        max-width: 100% !important;
    }

    .contact-intro-text {
        max-width: 100% !important;
        width: 100% !important;
        margin-right: 0 !important;
        text-align: left !important;
    }

    .contact-form-wrapper {
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
        margin-top: 50px !important;
    }

    .contact-form-wrapper .wpcf7,
    .contact-form-wrapper form,
    .contact-form-wrapper .form-row,
    .contact-form-wrapper .wpcf7-form-control-wrap,
    .contact-form-wrapper p,
    .contact-form-wrapper div,
    .contact-form-wrapper span {
        display: block !important;
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        float: none !important;
    }

    .contact-form-wrapper input[type="text"],
    .contact-form-wrapper input[type="email"],
    .contact-form-wrapper textarea {
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box !important; 
    }

    .cf7-custom-form input[type="submit"],
    .contact-form-wrapper input[type="submit"],
    .contact-form-wrapper button[type="submit"],
    .wpcf7-form input[type="submit"],
    .wpcf7-form button[type="submit"],
    .contact-form-wrapper button,
    .contact-form-wrapper input[type="button"],
    .contact-form-wrapper a.button,    
    .contact-form-wrapper .wpcf7-submit {
        display: inline-block !important; 
        width: auto !important;
        min-width: 30% !important;
        max-width: 100% !important;      
        position: relative !important;
        top: auto !important;
        bottom: auto !important;
        left: auto !important;
        right: auto !important;
        margin-left: 0 !important;       
        margin-top: 0 !important;
        padding: 0 !important;
        text-align: left !important; 
        box-sizing: border-box !important;
    }

    .wpcf7-acceptance {
        display: block !important;
        width: 100% !important;
        margin-top: 25px !important;
        margin-bottom: 20px !important;
        position: relative !important; 
        top: auto !important;
        bottom: auto !important;
        left: auto !important;
        right: auto !important;
        padding-left: 0 !important;
    }

    .wpcf7-acceptance .wpcf7-list-item {
        display: flex !important;
        flex-direction: row !important; 
        align-items: flex-start !important; 
        gap: 15px !important;
        margin: 0 !important;
    }

    .wpcf7-acceptance input[type="checkbox"] {
        flex-shrink: 0 !important;
        position: relative !important;
    }

    .wpcf7-acceptance .wpcf7-list-item-label {
        display: inline !important;
        align-items: center !important; 
        gap: 12px !important;
        font-size: 0.8rem !important;
        margin: 0 !important;
        padding-left: 0 !important;
        text-align: left !important;
    }

    .wpcf7-acceptance .wpcf7-list-item-label:before {
        content: "" !important;
        position: relative !important;  
        top: auto !important;
        left: auto !important;
        transform: none !important;     
        width: 18px !important;
        height: 18px !important;
        flex-shrink: 0 !important;      
        margin: 0 !important;
        margin-right: 10px !important;
    }

    .contact-form-wrapper form .btn-wrapper {
        width: -webkit-fit-content !important;
        width: -moz-fit-content !important;
        width: fit-content !important;
        margin-left: 0 !important; /* Garante que fica alinhado à esquerda se necessário */
        display: block !important;
    }

    .contact-form-wrapper form .wpcf7-submit {
        width: auto !important; /* Impede o input nativo do CF7 de esticar */
        font-size: 0.8rem !important;
    }
}

/* Telemóveis */
@media (max-width: 576px) {
    .section-contact .container {
        padding-left: 24px !important;
        padding-right: 24px !important;
    }

    .contact-grid { 
        padding: 40px 24px 0 !important;
    }
}


@media (max-width: 991px) {
    /* 1. Impede que o container do projeto sofra cortes invisíveis de overflow */
    .single-project-page,
    .single-project-page .project-hero,
    .single-project-page .col-md-7 {
        overflow: visible !important;
        width: 100% !important;
        max-width: 100% !important;
    }

    /* 2. Remove os paddings agressivos do desktop que esmagam o slider contra as bordas */
    .main-wrapper.side_padding {
        padding-left: 15px !important;
        padding-right: 15px !important;
    }

    /* 3. Garante que o Swiper ocupa o espaço real visível do telemóvel */
    .single-project-page .mainProjectSwiper {
        height: 50vh !important;
        min-height: 350px !important;
        width: 100% !important;
        transform: none !important; /* Anula qualquer resquício de 'x' do GSAP que tenha ficado preso */
    }
}