.M05 {
    padding: 80px 0 50px 0;
        position: relative;
}

.M05.v1 {
    padding: 80px 0 50px 0;
        position: relative;
        background:
        radial-gradient(56.95% 93.49% at 0% 100%, rgba(239, 243, 254, 1) 4.47%, rgba(243, 246, 254, 0.68) 24.43%, rgba(249, 251, 255, 0.34) 31.62%, rgba(255, 255, 255, 0.00) 83.44%),
        radial-gradient(56.95% 93.49% at 100% 100%, rgba(237, 242, 254, .4) 25.47%, rgba(243, 246, 254, 0.68) 46.43%, rgba(249, 251, 255, 0.34) 66.62%, rgba(255, 255, 255, 0.00) 83.44%);
}


.M05.v2 {
        background:
        radial-gradient(56.95% 93.49% at 0% 100%, rgba(239, 243, 254, 1) 4.47%, rgba(243, 246, 254, 0.68) 24.43%, rgba(249, 251, 255, 0.34) 31.62%, rgba(255, 255, 255, 0.00) 83.44%),
                radial-gradient(56.95% 93.49% at 100% 100%, rgba(237, 242, 254, .4) 25.47%, rgba(243, 246, 254, 0.68) 46.43%, rgba(249, 251, 255, 0.34) 66.62%, rgba(255, 255, 255, 0.00) 83.44%);

}

.M05.v2::after{
    content: '';
    position: absolute;
    background: radial-gradient(56.95% 93.49% at 0% 100%, rgba(237, 242, 254, .4) 25.47%, rgba(243, 246, 254, 0.68) 46.43%, rgba(249, 251, 255, 0.34) 66.62%, rgba(255, 255, 255, 0.00) 83.44%);
    z-index: 1;
    width: 100%;
    height: 100%;
    bottom: 0;
}

.M05 .contData {
    display: flex;
    flex-direction: row;
    gap: 32px;
}

.M05 .contData .contCards .cardItem .contInfo .downData .laboral.contact{
    padding-bottom: 16px;
    border-bottom: 1px solid #666;
}

/*v2*/
.M05.v2 .contData .contLeft {
    max-width: clamp(290px, 32vw,404px);
    width: 100%;
}

.M05.v2 .contData .leftCard {
    width: 100%;
    height: 398px;
    position: relative;
    display: flex;
    flex-direction: row;
    align-items: flex-end;
    padding: 24px;
    margin: 10px 0;
}

.M05 .contData .leftCard .contImg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.M05 .contData .leftCard .contImg img {
    object-fit: cover;
    object-position: top;
    width: 100%;
    height: 100%;
}

.M05 .contData .leftCard .contTexts {
    position: relative;
    z-index: 2;
}

/*v1*/
.M05.v1 .contData .leftCard {
    width: clamp(290px, 25vw,404px);
    height: calc(100vh - 233px);
    position: sticky;
    top: 158px;
    display: flex;
    flex-direction: row;
    align-items: flex-end;
    padding: 24px;

}

.M05.v1 .contCards{
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    column-gap: 16px;
    row-gap: 32px;
    position: relative;
    z-index: 2;
}


.M05 .contData .leftCard .contTexts .titleCard *{
    font-family: "FS Emeric";
    font-size: 38px;
    font-style: normal;
    font-weight: 350;
    line-height: 100%;
    letter-spacing: -0.45px;
    margin-bottom: 24px;
}

.M05 .contData .leftCard .contTexts .contentCard {
    font-family: "FS Emeric";
    font-size: 16px;
    font-style: normal;
    font-weight: 350;
    line-height: 140%;
    margin-bottom: 0;
}

/* Swiper */
.M05 .contData .contCards {
    width: 100%;
    overflow: hidden;
}

.M05.v2 .swiper-wrapper {
    display: flex;
}

.M05.v2 .swiper-slide {
    flex-shrink: 0;
    height: auto;
}

/*Controllers Swiper*/
.M05 .controllers{
    display: flex;
    flex-direction: row;
    justify-content: flex-end;
    align-items: center;
    gap: 16px;
    margin-top: 32px;
}

.M05 .controllers .btns{
    position: unset;
    min-width: 24px;
    width: 24px;
    height: 24px;
    border-radius: 1000px;
    border: 1px solid #6B8FFF;
    box-shadow: 0 0 8px 0 rgba(0, 0, 0, 0.15);
    margin-top: unset!important;
    background-color: #FFF;
    transition: all .3s linear;
}

.M05 .controllers .btns svg{
    width: 8px;
    height: 10px;
}

.M05 .controllers .btns:after{
    content: unset;
}

.M05 .controllers .swiper-pagination{
    width: fit-content;
    position: unset;
    color: #666;
    font-family: "FS Emeric";
    font-size: 12px;
    font-style: normal;
    font-weight: 350;
    line-height: 120%;
    letter-spacing: 0.25px;
}

.M05 .controllers .btns path{
    stroke: #6B8FFF;
    transition: all .3s linear;
}

/*Accesible States Btn*/
.M05 .controllers .btns:hover{background-color: #6B8FFF;}
.M05 .controllers .btns:hover path{ stroke: #FFF;}

.M05 .controllers .btns:active{ background: #A6BCFF;}
.M05 .controllers .btns:active path{ stroke: #A6BCFF;}

.M05 .controllers .btns:focus,
.M05 .controllers .btns:focus-visible {
    outline: 2px solid #3869FF;
    outline-offset: 3px;
    border-radius: 1000px;
}

/*Cards*/

.M05 .contCards{
    max-width: 100%;
    position: relative;
    z-index: 2;
}

.M05 .contData .contCards .cardItem {
    border-radius: 10px;
    min-height: 398px;
    position: relative;
    padding: 16px;
    overflow: hidden;
    cursor: pointer;
    text-decoration: unset;
    box-shadow: 0 4px 12.8px 0 rgba(33, 37, 41, 0.15);
    height: auto;
}

.M05 .contData .contCards .cardItem .contImg {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
}

.M05 .contData .contCards .cardItem .contImg img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    transition: all .3s linear;
    filter: grayscale(1);
}

.M05 .contData .contCards .cardItem .contInfo{
    position: relative;
    z-index: 2;
}
.M05 .contData .contCards .cardItem .contInfo .tags { display: flex; align-items: center; flex-wrap: wrap; gap: 4px; }
.M05 .contData .contCards .cardItem .contInfo .tag{
    border-radius: 5px;
    padding:  3px 6px 1px 6px;
    color: #FFF;
    font-family: "FS Emeric";
    font-size: 12px;
    font-style: normal;
    font-weight: 450;
    line-height: 120%; /* 14.4px */
    letter-spacing: 0.05px;
    background-color: #3869FF;
    width: fit-content;
}


.M05 .contData .contCards .cardItem .contInfo{
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    height: 100%;
}

.M05 .contData .contCards .cardItem .contInfo .downData{
    display: flex;
    flex-direction: column;
}

.M05 .contData .contCards .cardItem .contInfo .downData .name{
    color: #FFF;
    font-family: "FS Emeric";
    font-size: 20px;
    font-style: normal;
    font-weight: 450;
    line-height: 110%;
    letter-spacing: -0.25px;
    margin-bottom: 5px;
}

.M05 .contData .contCards .cardItem .contInfo .downData .laboral{
    color: #ECECEC;
    font-family: "FS Emeric";
    font-size: 14px;
    font-style: normal;
    font-weight: 350;
    line-height: 120%;
    transition: all .3s linear;
}

.M05 .contData .contCards .cardItem .contInfo .downData .btnDown{
    background-color: unset;
    border: unset;
    width: fit-content;
    margin-top: 8px;
    padding: 0;
}

.M05 .contData .contCards .cardItem .contInfo .downData .btnDown span{
    color: #ECECEC;
    font-family: "FS Emeric";
    font-size: 16px;
    font-style: normal;
    font-weight: 450;
    line-height: 100%;
    letter-spacing: -0.25px;
    margin-right: 8px;
}

/*Hovers Accesibilidad*/

.M05 .contData .contCards .cardItem {
    position: relative;
    overflow: hidden;
}

.M05 .contData .contCards .cardItem::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(
            180deg,
            rgba(33, 37, 41, 0) 55.83%,
            rgba(33, 37, 41, 0.80) 91.4%
    );
    z-index: 1;
}

.M05 .contData .contCards .cardItem::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(
            180deg,
            rgba(33, 37, 41, 0) 55.83%,
            rgba(34, 72, 231, 1) 91.4%
    );
    opacity: 0;
    transition: opacity 0.3s linear;
    z-index: 1;
}

.M05 .contData .contCards .cardItem:hover::after {
    opacity: 1;
}

.M05 .contData .contCards .cardItem:hover .contInfo .downData .laboral.contact{
    border-color: #FFF;
}

.M05 .contData .contCards .cardItem:active .contImg img,
.M05 .contData .contCards .cardItem:hover .contImg img{
    filter: grayscale(0);
}

.M05 .contData .contCards .cardItem:active::after {
    opacity: 0.6;
    background: linear-gradient(
            180deg,
            rgba(255, 255, 255, 0.78) 55.83%,
            rgba(56, 105, 255, 1) 91.4%

    );
    mix-blend-mode: screen; /* o lighten */
    z-index: 2;
}

.M05 .contData .contCards .swiperCards {
    padding: 10px;
}

.M05 .contData .contCards .swiperCards  .swiper-wrapper{
    height: fit-content;
}

.M05 .contData .contCards .cardItem:focus,
.M05 .contData .contCards .cardItem:focus-visible {
    outline: 2px solid #3869FF;
    outline-offset: 4px;
    border-radius: 10px;
}

.M05 .contData .leftCard{
    padding-right: 20px;
}

@media screen and (max-width: 1250px){
    .M05.v1 .contCards {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        column-gap: 16px;
        row-gap: 32px;
    }
    .M05.v2 .contData .leftCard {
        max-width: clamp(290px, 60vw, 404px);
        width: 100%;
    }

    .M05 .contData .contCards .swiperCards{
        padding: 10px 0;
    }

    .M05 .controllers{
        padding-bottom: 5px;
    }
}

@media screen and (max-width: 992px){
    .M05 .contData .leftCard .contTexts .titleCard *{
        color: #FFF;
        font-family: "FS Emeric";
        font-size: 28px;
        font-style: normal;
        font-weight: 350;
        line-height: 120%; /* 33.6px */
        letter-spacing: -0.25px;
        margin-bottom: 10px;
    }

    .M05.v1 .contCards {
        display: grid;
        padding: 0;
        column-gap: 16px;
        row-gap: 32px;
    }

    .M05{
        padding-top: 48px;
    }

    .M05 .controllers{
        padding-right: 20px;
    }
}

@media screen and (max-width: 767px){
    .M05.v2 .contData .contLeft{
        max-width: 100%;
    }

    .M05.v1 .contData .contLeft .leftCard{
        width: 100%;
        min-height: 335px;
        height: 100%;
    }

    .M05.v1 .contCards {
        display: block;
        padding: 0;
    }

    .M05.v1 .contData .contLeft{
        padding: 0 20px;
    }

    .M05.v2::after{ content: unset; }

    .M05.v2,
    .M05.v1{
        background: radial-gradient(
                150% 150% at 0% 100%, /* tamaño MUCHO mayor y origen en bottom-left */
                #EDF2FE 25.47%,
                rgba(243, 246, 254, 0.68) 46.43%,
                rgba(249, 251, 255, 0.34) 66.62%,
                rgba(255, 255, 255, 0) 83.44%
        );
        background-repeat: no-repeat;
        background-position: left bottom;
        background-size: 100% 100%; /* para que se ajuste al contenedor */

    }

    .M05 .contData{
        flex-direction: column;
    }

    .M05.v2 .container .contData .leftCard{
        max-width: 100%;
        padding-right: 20px;
    }
}

@media screen and (max-width: 567px){
    .M05.v1 .contCards{
        grid-template-columns: 1fr;
    }

    .M05 .contData .contCards .swiperCards{
        padding: 0 0 0 20px;
    }

    .M05 .contData .contLeft{
        padding: 0 20px;
    }

}