body {
    background-color: #fafafa;

    .header-white {
        position: absolute;
        width: 100%;
        height: 155px;
        background-color: white;
        top: 0;
        left: 0;
        box-shadow: 0px 4px 4px 0px #d9d9d966;
    }

    .wp-site-blocks {
        overflow: hidden;
        width: 1340px;
        margin: 30px auto 0 auto;
    }

    .main-menu {
        width: 100%;
        color: white;
        position: relative;
        z-index: 1;

        .main-menu-first-level {
            background-color: #002990;
            width: 1123px;
            height: 36px;
            margin: 0 auto;
            font-weight: 700;
            font-size: 20px;
            display: flex;
            flex-direction: row;
            justify-content: center;
            align-items: center;
            gap: 40px;
            list-style-type: none;
            padding: 0;
            li {
                a {
                    text-decoration: none;
                }
            }
        }
    }

    .main-menu-submenu {
        display: none;
        width: 1085px;
        padding: 0px;
        margin: 0 auto;
        position: absolute;
        z-index: 2;
        left: 50%;
        transform: translateX(-50%);
        background-color: white;
        min-height: 224px;

        ul {
            list-style-type: none;
            padding: 20px;
            margin: 0;
            li {
                margin: 10px 0;
                a {
                    font-weight: 500;
                    color: #002990;
                    font-size: 20px;
                    text-decoration: none;
                }
            }
        }
        .submenu-about-us,
        .submenu-our-work {
            display: none;
            flex-direction: row;
            justify-content: space-around;
            align-items: center;
            width: 100%;

            .submenu-about-us-director {
                max-width: 340px;
                border-left: 2px solid #002990;
                padding-left: 61px;
                display: flex;
                flex-direction: column;
                margin: 20px 0 20px 0;
                .submenu-about-us-director-image {
                    font-size: 15px;
                    font-weight: 500;
                    display: flex;
                    justify-content: flex-start;
                    align-items: center;
                    div {
                        margin-left: 20px;
                    }
                }
                p {
                    font-size: 14px;
                    font-weight: 300;
                }
            }

            .submenu-about-us-quote {
                width: 340px;
                font-size: 20px;
                color: #002990;
                font-weight: 500;
                display: flex;
                flex-direction: column;
                align-items: center;

                .submenu-about-us-quote-up {
                    margin-bottom: 10px;
                }
                .submenu-about-us-quote-down {
                    margin-top: 10px;
                }
                span {
                    text-align: center;
                }
            }
        }
        .submenu-our-work {
            .submenu-our-work-links {
                display: flex;
                flex-direction: row;
                gap: 10px;
                flex-wrap: wrap;
                width: 600px;

                .submenu-our-work-link-first {
                    display: flex;
                    border-bottom: 2px solid #002990;
                    flex-direction: row;
                    justify-content: flex-start;
                    align-items: center;
                    a {
                        font-weight: 900;
                    }

                    img {
                        margin-left: 10px;
                    }
                }
            }
        }
    }

    .destacadas-grid {
        overflow: hidden;
        position: relative;
        margin-top: -20px !important;
        z-index: 0;
        .destacada-principal {
            width: 100%;
            margin: 0 auto;
            height: 665px;
            overflow: hidden;
            position: relative;

            .destacada-thumbnail {
                position: relative;
                width: 100%;
                height: 100%;
                overflow: hidden;
            }

            .destacada-thumbnail img {
                width: 100%;
                height: 100%;
                object-fit: cover;
            }

            .destacada-content {
                width: 50%;
                height: 100%;
                position: absolute;
                top: 0;
                left: 0;
                display: flex;
                flex-direction: column;
                align-items: flex-start;
                justify-content: center;

                h2 {
                    padding: 0;
                    margin: 0 0 0 150px;
                    a {
                        font-weight: 700;
                        font-size: 54px;
                        color: white;
                        width: auto;
                        background-color: #002a90;
                        text-decoration: none;
                        padding: 0 20px;
                        line-height: 80px;
                    }
                }
            }
        }
        .destacada-secundaria,
        .destacada-terciaria {
            width: 48%;
            float: left;
            overflow: hidden;
            margin-top: 24px;
            .destacada-thumbnail {
                float: left;
                width: 50%;
                position: relative;
                overflow: hidden;
            }

            .destacada-thumbnail img {
                object-fit: cover;
                height: 272px;
            }

            .destacada-content {
                width: calc(50% - 10px);
                padding-left: 10px;
                display: flex;
                flex-direction: column;
                a {
                    text-decoration: none;
                }
                h2 {
                    padding: 0;
                    margin: 0;
                    font-weight: 700;
                    font-size: 24px;
                    line-height: 24px;
                }
                .destacada-excerpt {
                    margin-top: 14px;
                    font-size: 16px;
                    font-weight: 300;
                }
            }
        }
        .destacada-terciaria {
            float: right;
        }
    }

    .principal-parrafo {
        strong {
            font-weight: 700;
            font-size: 24px;
        }
        font-size: 16px;
    }

    .section-divisor {
        gap: 0px;
        margin: 52px 0 !important;
        hr {
            height: 2px; /* Define el grosor */
            background-color: #d0142c !important;
        }
        h2 {
            padding: 0;
            font-size: 48px;
            font-weight: 700;
            background-color: transparent !important;
        }
    }

    .home-cuba-review {
        width: 100%;
        padding: 0;
        margin: 0;
        max-width: 100%;

        p {
            width: 100%;
            padding: 0;
            margin: 0;

            strong {
                font-weight: 700;
                font-size: 24px;
            }
        }
    }

    .home-quotes-grid {
        display: flex;
        gap: 100px;
        flex-direction: row;

        .quote-card {
            display: flex;
            flex-direction: column;
            width: 256px;

            .quote-text-container {
                filter: drop-shadow(0px 4px 10px #d9d9d966);
            }
            .quote-text {
                position: relative;
                background: white;
                padding: 20px;
                width: 216px;
                border-top-left-radius: 20px;
                border-top-right-radius: 20px;
                border-bottom-right-radius: 20px;
                clip-path: polygon(
                    0% 0%,
                    100% 0%,
                    100% 90%,
                    15% 90%,
                    0 100%,
                    0 85%,
                    0 90%
                );
                min-height: 133px;
                padding-bottom: 35%;
                font-size: 12px;
            }

            .quote-stars {
                position: absolute;
                bottom: 25%;
            }

            .quote-author {
                display: flex;
                flex-direction: row;

                .quote-author-photo {
                    margin: -5px 0px 0px 15px;
                    width: 56px;
                    height: 56px;
                    border-radius: 50%;
                    overflow: hidden;
                    display: flex;
                    justify-content: center;
                    align-items: center;
                    background-color: #f0f0f0;
                    min-width: 56px;
                }

                .quote-author-photo img {
                    max-width: 100%;
                    max-height: 100%;
                    display: block;
                }

                .quote-author-name {
                    padding-left: 10px;
                    font-size: 14px;
                    font-weight: 700;
                }

                .quote-author-subtitle {
                    padding-left: 10px;
                    font-size: 12px;
                    font-weight: 300;
                }
            }
        }
    }

    .core-beliefs-container {
        display: flex;
        flex-direction: row;
        gap: 50px 110px;
        justify-content: center;
        flex-wrap: wrap;

        a {
            text-decoration: none;
        }

        .core-belief-item {
            background-color: #d9d9d9;
            border-radius: 12px;
        }

        .core-belief-see-more {
            font-size: 10px;
            font-weight: 700;
            margin-left: 26px;
            margin-top: -15px;
            padding-bottom: 15px;
        }

        .core-belief-overlay {
            padding: 0 20px 0 0;
            display: flex;
            flex-direction: row;
            width: 353px;
            height: 140px;

            align-items: center;

            .core-belief-content {
                position: relative;
                width: 100%;

                .core-belief-title {
                    font-size: 25px;
                    display: inline;
                    background: #d0142c;
                    box-shadow:
                        -15px 0px 0 -2px #d0142c,
                        -15px 0 0 #d0142c;
                    font-weight: 700;
                    color: white;
                    margin-left: 15px;
                    padding-right: 5px;
                    text-transform: uppercase;
                    box-decoration-break: clone;
                    -webkit-box-decoration-break: clone;
                }
                .core-belief-title.odd {
                    background: #002a90;
                    box-shadow:
                        -15px 0px 0 -2px #002a90,
                        -15px 0 0 #002a90;
                }
            }

            .core-belief-thumbnail {
                width: 130px;
                height: 155px;
                display: flex;
                justify-content: center;
                align-items: center;
                flex-grow: 1;

                img {
                    max-width: 100%;
                    max-height: 100%;
                    object-fit: contain;
                    display: block;
                    margin: auto;
                }
            }
        }
    }

    .core-beliefs-container-header {
        width: 1120px;
        margin: 0 auto;
        a {
            text-decoration: none;
        }

        .core-belief-item {
            background-color: #d9d9d9;
            border-radius: 12px;
        }

        .core-belief-overlay {
            padding: 40px 100px 40px 0;
            display: flex;
            flex-direction: row;
            align-items: center;

            .core-belief-content {
                position: relative;
                width: 100%;

                .core-belief-title {
                    font-size: 74px;
                    display: inline;
                    background: #d0142c;
                    box-shadow:
                        -45px 0px 0 -2px #d0142c,
                        -45px 0 0 #d0142c;
                    font-weight: 700;
                    color: white;
                    margin-left: 45px;
                    padding-right: 15px;
                    text-transform: uppercase;
                    box-decoration-break: clone;
                    -webkit-box-decoration-break: clone;
                }
                .core-belief-title.odd {
                    background: #002a90;
                    box-shadow:
                        -15px 0px 0 -2px #002a90,
                        -15px 0 0 #002a90;
                }
            }

            .core-belief-thumbnail {
                min-width: 260px;
                min-height: 260px;
                display: flex;
                justify-content: center;
                align-items: center;
                flex-grow: 1;

                img {
                    max-width: 100%;
                    max-height: 100%;
                    object-fit: contain;
                    display: block;
                    margin: auto;
                }
            }
        }
    }

    .about-us-container,
    .our-work-container {
        max-width: 1340px;
        margin: 0 auto;
        display: flex;
        flex-wrap: wrap;
        gap: 50px;
        justify-content: center;
        margin-top: 50px;

        .about-us-item {
            background-color: #ededed;
            border-radius: 12px;

            .about-us-thumbnail img {
                width: 111px;
            }

            .about-us-content {
                width: 208px;
            }

            .about-us-title img {
                margin-bottom: -5px;
            }

            a {
                min-width: 470px;
                min-height: 170px;
                text-decoration: none;
                color: #002990;
                font-size: 36px;
                font-weight: 700;
                display: flex;
                flex-direction: row;
                justify-content: space-around;
                align-items: center;
            }
        }
    }

    .our-work-container {
        .about-us-item {
            .about-us-thumbnail img {
                width: 150px;
                max-height: 150px;
            }
            .about-us-content {
                width: auto;
            }
            a {
                min-width: 370px;
                padding: 10px 0;
                flex-direction: column;
            }
        }
    }

    .breadcrumb-title-container {
        display: flex;
        align-items: center;
        gap: 1rem;
        width: 1120px;
        min-height: 50px;
        margin: 20px auto;

        .breadcrumb-wrapper {
            flex-shrink: 0;
            font-size: 12px;
            font-weight: 500;
        }

        .breadcrumb-separator {
            flex: 1 1 auto;
            min-width: 20px;
            height: 3px;
            background-color: #d0142c;
        }

        .page-title-wrapper {
            flex-shrink: 0;
            display: flex;
        }

        .breadcrumb-list {
            display: flex;
            list-style: none;
            margin: 0;
            padding: 0;
            gap: 5px;
            align-items: center;
        }

        .breadcrumb-item {
            display: flex;
            align-items: center;
        }

        .breadcrumb-item:not(:last-child)::after {
            content: "/";
            margin-left: 5px;
            opacity: 0.5;
        }

        .breadcrumb-item.active {
            font-weight: 500;
        }

        .page-title {
            margin: 0;
            white-space: nowrap;
            font-size: 40px;
            font-weight: 700;
        }
    }

    .members-category {
        display: flex;
        flex-direction: row;
        align-items: center;

        h2 {
            white-space: nowrap;
            padding: 0px 30px 0 0;
            margin: 0;
            font-size: 36px;
            font-weight: 700;
            color: #d0142c;
        }

        .members-category-separator {
            width: 100%;
            height: 9px;
            background-color: #d0142c;
        }
    }

    ul.members-list {
        list-style-type: none;
        padding: 0;
        margin: 50px 20px 50px 0;
        display: inline-flex;

        li a {
            color: #002a90;
            text-decoration: none;
            background-color: #ededed;
            box-shadow: 0px 4px 4px 0px #d9d9d9;
            width: 262px;
            height: 109px;
            display: inline-flex;
            flex-direction: column;
            align-items: flex-start;
            border-radius: 12px;
            padding-top: 20px;
            margin-left: 36px;

            .members-name {
                font-size: 18px;
                display: inline;
                background: #002a90;
                box-shadow:
                    -15px 0px 0 -2px #002a90,
                    -15px 0 0 #002a90;
                font-weight: 700;
                color: white;
                margin-left: 15px;
                padding-right: 5px;
                box-decoration-break: clone;
                -webkit-box-decoration-break: clone;
            }

            .members-organization {
                font-size: 18px;
                margin-left: 15px;
                font-weight: 400;
                font-style: italic;
                margin-top: 5px;
            }

            .members-sector {
                font-size: 18px;
                margin-left: 15px;
                font-weight: 500;
                font-style: italic;
                margin-top: 5px;
            }
        }
    }

    .posts-header {
        display: flex;
        flex-direction: row;
        align-items: center;

        h2 {
            white-space: nowrap;
            padding: 0px 30px 0 0;
            margin: 0;
            font-size: 36px;
            font-weight: 700;
            color: #002990;
        }

        .post-header-separator {
            width: 100%;
            height: 9px;
            background-color: #002990;
        }
    }

    ul.posts {
        list-style-type: none;
        display: flex;
        flex-wrap: wrap;
        gap: 30px;
        padding: 0;
        margin: 50px 0;
        flex-direction: row;
        align-content: center;
        justify-content: center;
        a {
            text-decoration: none;
        }
    }

    ul.posts.newsletters-list li,
    ul.posts.press_releases-list li {
        width: 505px;
        background-color: #ededed;
        box-shadow: 0px 4px 4px 0px #d9d9d9;
        padding: 20px;
        position: relative;
        min-height: 131px;

        h3 {
            font-size: 24px;
            font-weight: 700;
            color: #d0142c;
            overflow: hidden;
            display: -webkit-box;
            -webkit-line-clamp: 3;
            -webkit-box-orient: vertical;
            margin: 0;
        }

        .posts-date {
            font-size: 18px;
            font-weight: 500;
            color: #002a90;
            position: absolute;
            bottom: 20px;
            margin-left: 235px;
        }

        .posts-date.no-thumbnail {
            margin-left: 0px;
        }

        .thumbnail-container {
            height: 131px;
            width: 216px;
            float: left;
            margin-right: 20px;

            img {
                object-fit: cover;
                width: 100%;
                height: 100%;
                border-radius: 12px;
            }
        }
    }

    ul.posts.partnerships-list li {
        width: 100%;
        padding: 50px 20px;
        position: relative;
        min-height: 131px;

        h3 {
            font-size: 24px;
            font-weight: 700;
            margin: 0;
        }

        .posts-date {
            display: none;
        }

        .thumbnail-container {
            width: 233px;
            float: left;
            margin-right: 20px;

            img {
                object-fit: cover;
                width: 100%;
                height: 100%;
                border-radius: 12px;
            }
        }
    }

    ul.posts.blog_posts-list li,
    ul.posts.white_papers-list li,
    ul.posts.polls-list li {
        width: 321px;
        background-color: #ededed;
        box-shadow: 0px 4px 4px 0px #d9d9d9;
        padding: 20px;
        display: flex;
        flex-direction: column;
        position: relative;

        h3 {
            font-size: 24px;
            font-weight: 700;
            color: #d0142c;
            overflow: hidden;
            display: -webkit-box;
            -webkit-line-clamp: 3;
            -webkit-box-orient: vertical;
        }

        h3.no-thumbnail {
            display: block;
            margin-top: 0;
        }

        .posts-date {
            font-size: 18px;
            font-weight: 500;
            color: #002a90;
            position: absolute;
            bottom: 10px;
        }

        .thumbnail-container {
            height: 161px;
            width: 320px;

            img {
                object-fit: cover;
                width: 100%;
                height: 100%;
                border-radius: 12px;
            }
        }
    }

    ul.posts.video-list li,
    ul.posts.csg_resources-list li,
    ul.posts.videos-list li {
        width: 521px;
        max-height: 240px;
        background-color: #ededed;
        box-shadow: 0px 4px 4px 0px #d9d9d9;
        position: relative;

        .h3-container {
            width: 80%;
        }

        h3 {
            font-size: 16px;
            font-weight: 700;
            display: inline;
            background: #002a90;
            box-shadow:
                -15px 0px 0 -2px #002a90,
                -15px 0 0 #002a90;
            color: white;
            margin-left: 15px;
            word-wrap: break-word;
            text-transform: uppercase;
            box-decoration-break: clone;
            -webkit-box-decoration-break: clone;
        }

        .posts-date {
            font-size: 18px;
            font-weight: 500;
            color: white;
            position: absolute;
            bottom: 20px;
            right: 10px;
        }

        .thumbnail-container {
            height: 100%;
            width: 100%;
            margin-bottom: -100px;

            img {
                object-fit: cover;
                width: 100%;
                height: 100%;
                border-radius: 12px;
            }
        }
    }

    footer.wp-block-template-part {
        position: absolute;
        width: 100%;
        left: 0;
        background-color: #3f3f3f !important;
        overflow: hidden;

        .footer-center {
            display: flex;
            align-items: center;
            width: 34%;
            border-left: 1px solid #d9d9d9;
            border-right: 1px solid #d9d9d9;
        }

        .footer-text {
            font-size: 16px;
            font-weight: 500;
        }

        .footer-rights {
            font-size: 16px;
            font-weight: 300;
            font-style: italic;
        }
    }

    footer.wp-block-template-part > div > div > div {
        gap: 0px;
    }

    footer.wp-block-template-part > div > div > div div {
        width: 28%;
    }

    footer.wp-block-template-part > div > div > div div:last-child {
        width: 400px;
    }

    .wpsf-form-wrap.wpsf-template-2.wpsf-subscription {
        border: none;
        background-color: transparent;
        padding: 0;
        margin: 0;
        form {
            h2 {
                font-size: 32px;
                font-weight: 700;
            }
            .wpsf-form-submit {
                background-color: #d0142c;
            }
            .wpsf-form-submit:hover {
                background-color: black;
            }

            .both-fields-wrap {
                margin-bottom: 10px;
                .wpsf-field-wrap {
                    input {
                        padding: 0 0 0 10px;
                        height: 33px;
                        width: 80%;
                    }
                }
                .wpsf-field-wrap:first-child {
                    margin-bottom: 20px;
                }
            }
        }
    }
}
