
.hero-section a {
    width: 100%;
}
.hero-section img {
    height: auto;
    width: 100%;
}

.hero-section .show-mobile {
    display: none;
}

/* Contenedor principal */
.hay-vacantes .benefits {
    background: #2941AF;
    color: white;
    padding: 4.44rem 0;
}

.hay-vacantes .benefits .container {
    max-width: 1068px;
}

/* Contenedor grid */
.hay-vacantes .benefits .container.grid-3 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    max-width: 1200px;
    margin: 0 auto;
}

/* Estilo de cada columna */
.hay-vacantes .benefit {
    text-align: center;
    padding: 1rem;
}
.hay-vacantes .benefit img {
    height: 68px;
    width: 68px;
}
.hay-vacantes .benefit h3 {
    color: #FFF;
    text-align: center;
    font-family: "Bricolage Grotesque", sans-serif;
    font-size: 30px;
    font-style: normal;
    font-weight: 700;
    letter-spacing: -0.9px;
    line-height: normal;
    margin-top: 30px;
    margin-bottom: 36px;
    padding: 0px;
}

.hay-vacantes .benefit p {
    color: #FFF;
    text-align: center;
    font-family: "Bricolage Grotesque";
    font-size: 20px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
}

.section-middle::before {
    background-color: #E4281C;
    bottom: -116px;
    content: "";
    display: block;
    height: 238.041px;
    left: -130px;
    position: absolute;
    transform: rotate(46.828deg);
    width: 264.34px;
    z-index: 1;
}

.section-middle::after {
    background-color: #5170FF;
    content: "";
    display: block;
    height: 238.041px;
    right: -40px;
    position: absolute;
    top: -175px;
    transform: rotate(-14.881deg);
    width: 264.34px;
    z-index: 1;
}

.section-middle .text-red {
    background: #E4281C;
    color: #fff;
    padding: 0 0.2em;
    -webkit-box-decoration-break: clone;
    box-decoration-break: clone;
    box-shadow: -5px 5px 0px #E4281C;
}

.section-middle .text-blue {
    background: #5170FF;
    color: #fff;
    padding: 0 0.2em;
    position: relative;
    -webkit-box-decoration-break: clone;
    box-decoration-break: clone;
    box-shadow: -5px -5px 0px #5170FF;
}

.section-middle  {
    overflow: hidden;
    margin-bottom: -1px;
    margin-top: -1px;
    position: relative;
}

.section-middle a {
    color: #151515;
    display: block;
    font-family: "Bricolage Grotesque";
    font-size: 50px;
    font-style: normal;
    font-weight: 800;
    line-height: normal;
    text-transform: uppercase;
    text-decoration: none;
    padding: 90px 208px;
    width: 100%;
}

.hay-vacantes footer {
    background: #9D1519;
    color: white;
    padding: 4rem;
}

.hay-vacantes footer nav {
    margin-top: 40px;
    margin-bottom: 15px;
}

.hay-vacantes footer nav a {
    color: #FFF;
    font-family: "Bricolage Grotesque", sans-serif;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 26px;
    /* 185.714% */
    text-decoration: none;
}

.hay-vacantes footer .logos {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 40px;
}

.hay-vacantes footer .logos img:first-child {
    max-width: 220px;
}

.hay-vacantes footer .logos img:last-child {
    max-width: 480px;
}

.hay-vacantes footer .container {
    align-items: center;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    max-width: 1200px;
    margin: 0 auto;
}

.hay-vacantes p:has(label[class="checkbox"]),
.hay-vacantes .mt-0 {
    margin-top: 0 !important;
}

.hay-vacantes p:has(label[for="discapacidad"]),
.hay-vacantes .mb-0 {
    margin-bottom: 0 !important;
}


.hay-vacantes .formulario {
    background: #E4281C;
    color: white;
    padding: 2.813rem 2rem 0 2rem;
}

.hay-vacantes .formulario .container .wrap-text {
    padding-top: 100px;
    position: relative;
}
.hay-vacantes .formulario .container .wrap-text * {
    position: relative;
    z-index: 1;
}
.hay-vacantes .formulario .container .wrap-text:before {
    background-color: #9D1519;
    bottom: -110px;
    content: "";
    display: block;
    position: absolute;
    right: 12px;
    transform: rotate(-2.783deg);
    top: 35px;
    width: 100vw;
    z-index: 0;
}
.hay-vacantes .formulario .container .wrap-image .show-mobile {
    display: none;
}
.hay-vacantes .formulario .container .wrap-image {
    margin-top: -10px;
    position: relative;
    flex: 1;
    display: flex;
    align-items: flex-end;
    justify-content: center;
}
.hay-vacantes .formulario .container .wrap-image:before {
    background-color: #9D1519;
    bottom: 0px;
    content: "";
    display: block;
    position: absolute;
    left: 18.5%;
    right: 23%;
    top: 0;
    z-index: 0;
    max-width: 377px;
    margin: auto;
}
.hay-vacantes .formulario .container img {
    position: relative;
    z-index: 1;
}

.hay-vacantes .formulario .container {
    display: flex;
    gap: 2rem;
    max-width: 1440px;
    margin: 0 auto;
    flex-wrap: wrap;
}

/* Columna izquierda */
.hay-vacantes .formulario .container>div:first-child {
    flex: 0 0 45.5%;
    display: flex;
    flex-direction: column;
}

/* Columna derecha */
.hay-vacantes .formulario form {
    flex: 1;
    display: flex;
    flex-direction: column;
    max-width: 564px;
}

.hay-vacantes .formulario label {
    display: flex;
    flex-direction: column;
    color: #FFF;
    font-family: "Bricolage Grotesque";
    font-size: 20px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    /* 162.5% */
}
.hay-vacantes .formulario-texto {
    flex: 0 0 42.64%;
}
.hay-vacantes .formulario .column-form {
    flex: 1;
    padding-top: 95px;
}

.hay-vacantes .formulario input[type="date"],
.hay-vacantes .formulario input[type="text"],
.hay-vacantes .formulario input[type="email"],
.hay-vacantes .formulario input[type="tel"],
.hay-vacantes .formulario input[type="radio"],
.hay-vacantes .formulario input[type="checkbox"] {
    border: none;
    border-radius: 4px;
    color: #838383;
    font-family: "Bricolage Grotesque";
    font-size: 20px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    margin-top: 0.5rem;
    padding: 9px 24px;
}

.hay-vacantes input::placeholder,
.hay-vacantes textarea::placeholder {
    color: #838383;
    font-family: "Bricolage Grotesque";
    font-size: 20px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
}

.hay-vacantes .formulario input[type="radio"] {
    margin-right: 0.5rem;
    accent-color: #fff;
}

.hay-vacantes .formulario a {
    color: white;
    text-decoration: underline;
}

.hay-vacantes .formulario button {
    /* margin-top: 1rem; */
    padding: 16px 12px;
    background: #5170FF !important;
    color: #ffff !important;
    border: none;
    cursor: pointer;
    align-self: flex-start;
    transition: background 0.3s;
    text-align: center;
    font-family: "Bricolage Grotesque", sans-serif;
    font-size: 16px;
    font-style: normal;
    font-weight: 700;
    line-height: 24px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    padding: 12px 16px;
    border-radius: 12px;
}

.hay-vacantes .formulario button img {
    padding: 0;
    margin-top: 0 !important;
}

.hay-vacantes .formulario button:hover {
    background: #f2f2f2;
}


.hay-vacantes .formulario form p>label br {
    display: none;
}

.hay-vacantes .formulario-texto .wrap-text div {
    margin: 0 auto;
    max-width: 304px;
}

.hay-vacantes .formulario-texto h2 {
    color: #FFF;
    font-family: "Bricolage Grotesque";
    font-size: 39px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    margin-bottom: 25px;
    text-transform: uppercase;
}

.hay-vacantes .formulario p {
    margin-bottom: 35px;
}

.hay-vacantes .formulario-texto p {
    color: #FFF;
    font-family: "Bricolage Grotesque";
    font-size: 25px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    margin-bottom: 0;
    max-width: 277px;
}

.hay-vacantes .screen-reader-response {
    display: none;
}

.hay-vacantes .grid-submit>p,
.hay-vacantes .grid-submit {
    column-gap: 1px;
    display: flex;
    justify-content: space-between;
    margin-top: 25px;
    align-items: center;
    width: 100%;
}

.formulario label.checkbox {
    display: flex;
    flex-direction: row;
    background: white;
    margin-top: 0.5rem;
    padding: 9px 24px;
    border: none;
    border-radius: 4px;
    color: #C82E38;
    font-family: "Open Sans";
    font-size: 16px;
    gap: 10px;
    align-items: center;
    margin-top: -8px;
}

.hay-vacantes .formulario label.checkbox input {
    margin: 0;
}

.hay-vacantes .no-bg {
    background: transparent !important;
}

.hay-vacantes .formulario label.checkbox.no-bg span {
    color: white;
}

/* Oculta el checkbox real */
.hay-vacantes .formulario label.checkbox input[type="checkbox"] {
    display: none;
}

/* Estilo visual */
.hay-vacantes .formulario label.checkbox {
    position: relative;
    padding-left: 16px;
    cursor: pointer;
    user-select: none;
}

/* Posicionar correctamente la etiqueta externa */
.hay-vacantes .checkbox .wpcf7-list-item label {
    position: relative;
    padding-left: 30px;
    cursor: pointer;
    display: inline-block;
    user-select: none;
}

/* Ocultar el checkbox original */
.hay-vacantes .checkbox .wpcf7-list-item input[type="checkbox"] {
    position: absolute;
    opacity: 0;
    cursor: pointer;
}

.hay-vacantes .checkbox .wpcf7-list-item-label {
    color: #838383 !important;
}

.hay-vacantes .checkbox.no-bg .wpcf7-list-item-label {
    color: #FFF !important;
}

/* Cuadro personalizado para el checkbox */
.hay-vacantes .checkbox .wpcf7-list-item-label::before {
    content: "";
    position: absolute;
    left: 0;
    top: 3px;
    width: 20px;
    height: 20px;
    border: 1.5px solid #838383;
    border-radius: 4px;
    background: #fff;
    box-sizing: border-box;
}

/* ✔️ Agregar el check cuando está marcado */
.hay-vacantes .checkbox .wpcf7-list-item input[type="checkbox"]:checked+.wpcf7-list-item-label::after {
    content: "";
    position: absolute;
    left: 6px;
    top: 4px;
    width: 6px;
    height: 12px;
    border: solid #C82E38;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

.hay-vacantes .formulario label.checkbox.no-bg .wpcf7-list-item-label::before {
    content: "";
    position: absolute;
    left: 0;
    top: 3px;
    width: 20px;
    height: 20px;
    border: 1.5px solid #FFF;
    border-radius: 4px;
    background: transparent;
    box-sizing: border-box;
}

.hay-vacantes .formulario label.checkbox.no-bg .checkmark {
    border: 1px solid #FFF;
    background: transparent;
}

.hay-vacantes .formulario label.checkbox.no-bg {
    padding: 0;
}

.hay-vacantes .formulario label.checkbox.no-bg .wpcf7-list-item input[type="checkbox"]:checked+.wpcf7-list-item-label::after {
    content: "";
    position: absolute;
    left: 6px;
    top: 4px;
    width: 6px;
    height: 12px;
    border: solid #FFF;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

.hay-vacantes .formulario label.checkbox.no-bg input:checked+.checkmark::after {
    content: "";
    position: absolute;
    left: 5px;
    top: 1px;
    width: 6px;
    height: 12px;
    border: solid white;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

.hay-vacantes .formulario .wpcf7-form-control {
    width: 100%;
    box-sizing: border-box;
    /* importante para que respete el padding sin desbordarse */
}

.hay-vacantes span.wpcf7-not-valid-tip {
    color: white;
}

.hay-vacantes label.checkbox span.wpcf7-not-valid-tip {
    position: absolute;
    bottom: -28px;
    color: white;
    left: 0;
}


@media (max-width: 1024px) {
    .formulario {
        max-width: 100%;
    }
}


/* Responsive */
@media (max-width: 992px) {
    .hay-vacantes .benefits {
        padding: 3.44rem 0;
    }
    .hay-vacantes .benefits .container.grid-3 {
        gap: 2rem;
        grid-template-columns: repeat(1, 1fr);
        justify-content: center;
        text-align: center;
    }

    .hay-vacantes .benefit {
        padding: 0;
        border-bottom: 1px solid rgba(255, 255, 255, 0.2);
    }

    .hay-vacantes .benefit:last-child {
        border-bottom: none;
    }

    .hay-vacantes .benefit p {
        font-size: 16px;
        margin-bottom: 2rem;
    }

    .hay-vacantes .benefit h3 {
        font-size: 25px;
        margin-bottom: 15px;
    }

    .section-middle::before {
        left: -230px;
    }

    .section-middle::after {
        right: -176px;
        top: -200px;
    }

    .section-middle a {
        font-size: 30px;
        line-height: 1.34;
        padding: 52px 65px 52px 48px;
    }

    .hay-vacantes footer .logos {
        flex-direction: column;
    }

    .hay-vacantes .formulario .container {
        flex-direction: column-reverse;
    }

    .hay-vacantes .formulario .container>div:first-child,
    .hay-vacantes .formulario form {
        width: 100%;
    }

    .hay-vacantes footer .logos {
        flex-direction: column;
        align-items: flex-start;
    }

    .hay-vacantes .formulario form {
        max-width: 100%;
    }

    .hay-vacantes .formulario .column-form {
        padding-top: 40px;
    }

    .hay-vacantes .formulario button {
        align-self: stretch;
        text-align: center;
    }

    .hay-vacantes .formulario-texto {
        flex: 0 0 100%;
    }

    .hay-vacantes .formulario-texto p br,
    .hay-vacantes .formulario-texto h2 br {
        display: none;
    }
}

@media (max-width: 768px) {
    .hero-section .show-desktop {
        display: none;
    }
    .hero-section .show-mobile {
        display: block;
    }
    .hay-vacantes .benefits {
        padding: 3rem 0;
    }
    .hay-vacantes .benefits .container.grid-3 {
        grid-template-columns: repeat(1, 1fr);
        text-align: center;
        justify-content: center;
    }
    .hay-vacantes .benefit p {
        font-size: 14px;
        margin-bottom: 2rem;
    }

    .hay-vacantes .benefit h3 {
        font-size: 20px;
        margin-bottom: 15px;
    }
    .section-middle .text-blue-mobile {
        background: #5170FF;
        color: #fff;
        padding: 0 0.2em;
        position: relative;
        -webkit-box-decoration-break: clone;
        box-decoration-break: clone;
        box-shadow: 3px -3px 0px #5170FF;
    }

    .section-middle .text-red {
        box-shadow: 3px -3px 0px #E4281C;
    }
    .section-middle .text-blue {
        box-shadow: 3px -3px 0px #5170FF;
    }

    .hay-vacantes .formulario .container .wrap-text:before {
        right: -15px;
    }

    .hay-vacantes .formulario .container .wrap-image .show-desktop {
        display: none;
    }
    .hay-vacantes .formulario .container .wrap-image .show-mobile {
        display: block;
        margin-left: -31px;
        margin-top: -30px;
    }

    .hay-vacantes .formulario .container .wrap-image:before {
        left: 20.5%;
        max-width: 287px;
        right: 13%;
    }

    .hay-vacantes .formulario-texto h2 {
        font-size: 35px;
    }

    .hay-vacantes footer .logos img:last-child {
        max-width: 100%;
    }

    .hay-vacantes footer .container {
        gap: 5px;
    }

    .hay-vacantes footer nav {
        margin-top: 40px;
        margin-bottom: 15px;
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        width: 100%;
        gap: 1rem;
    }

    .hay-vacantes footer .logos {
        display: block;
        text-align: center;
        width: 100%;
    }

    .hay-vacantes footer .logos img:first-child {
        margin-bottom: 25px;
    }

    .hay-vacantes footer {
        padding-left: 20px;
        padding-right: 20px;
    }

    .hay-vacantes footer .logos {
        flex-direction: column;
    }

    .hay-vacantes .formulario-texto {
        flex: 0 0 100% !important;
    }

    .hay-vacantes .formulario-texto .wrap-text div {
        max-width: 255px;
    }

    .hay-vacantes .formulario button {
        margin: 0 auto;
    }
}
