/*!
Theme Name: Orbis
Theme URI: http://underscores.me/
Author: Triplevdoble
Author URI: https://www.triplevdoble.com/
Description: Creado por Triplevdoble para Orbis
Version: 1.0.0
Tested up to: 5.4
Requires PHP: 5.6
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: orbis
Tags: custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready

This theme, like WordPress, is licensed under the GPL.
Use it to make something cool, have fun, and share what you've learned.

Orbis is based on Underscores https://underscores.me/, (C) 2012-2020 Automattic, Inc.
Underscores is distributed under the terms of the GNU GPL v2 or later.

Normalizing styles have been helped along thanks to the fine work of
Nicolas Gallagher and Jonathan Neal https://necolas.github.io/normalize.css/
*/


/*--------------------------------------------------------------
>>> ESTILOS GENERALES:
---------------------------------------------------------------*/

*{
    padding: 0px;
    margin: 0px;
    box-sizing: border-box;
}

body{
    font-family: "Plus Jakarta Sans", sans-serif;
    font-optical-sizing: auto;
    font-weight: 400;
    font-style: normal;
    color: var(--oscuro);
}

h2{
    font-weight: 700;
}

a{
    text-decoration: none;
    color: inherit;
}

ul{
    padding: 0px;
    margin: 0px;
}

li{
    list-style-type: none;
}

img{
    width: 100%;
    height: auto;
}

p{
    font-size: 1rem;
    font-weight: 300;
    line-height: 1.3;
}

.page-template-page-portada .site-main p{
    font-weight: 400;
}

.mb5{
    margin-bottom: 3rem;
}

.mb8{
    margin-bottom: 5rem;
}

.mb10{
    margin-bottom: 6rem;
}

:root {
  --oscuro: #00364A;
  --claro: #73C0DB;
  --medio: #178AAE;
  --cian: #36B8E6;
  --gris: #EDEEEF;    
  --claro-1: #CFF2FF;
  --claro-2: #DEEEF3;
  --claro-3: #E4F8FF;
  --borde: 20px;
}

.boton a {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    color: #fff;
    background-color: var(--oscuro);
    border-radius: 1000px;
    padding: 5px 15px;
}

.boton a::after {
    content: "\F285";
    font-family: "bootstrap-icons";
    font-size: 14px;
    transition: 0.2s ease;
}

.boton a:hover {
    gap: 0.8rem;
    transition: 0.2s ease;
}

/*--------------------------------------------------------------
>>> HEADER:
---------------------------------------------------------------*/

header{
    padding: 2rem 0;
}

.site-branding img{
    max-width: 150px;
}

.site-header .menu > li:last-child{
    background-color: var(--oscuro);
    color: #fff;
    border-radius: 1000px;
    padding: 5px 15px;
}

.menu-desk ul{
    display: flex;
    align-items: center;
    gap: 30px;
}

.menu-desk .menu-item {
    position: relative;
    z-index: 5;
}

.menu-desk li {
    font-size: 1.1rem;
    cursor: pointer;
    font-weight: 500;
}

.menu-desk li li:hover{
    color: var(--oscuro);
}

.menu-desk .sub-menu {
    opacity: 0;
    display: none;
    flex-direction: column;
    position: absolute;
    top: 21px;
    width: max-content;
    align-items: start;
    left: 0;
    gap: 4px;
    background-color: #fff;
    color: var(--claro);
    padding: 1.5rem 1.5rem;
    border-bottom: solid 1.5px var(--claro);
    z-index: 3;
}

.menu-desk .menu-item-has-children:hover .sub-menu {
    opacity: 1;
    display: flex;
    pointer-events: auto;
}

.menu-movil i{
    font-size: 2rem;
}

.menu-movil .offcanvas-body{
    padding-top: 2rem;
}

.menu-movil ul{
    gap: 15px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.menu-movil ul ul{
    gap: 0px;
}

.menu-movil li{
    font-size: 1rem;
    color: var(--oscuro);
    text-align: center;
    margin-bottom: 5px;
}

.menu-movil li li{
    border-bottom: 0px;
    color: var(--claro);
}

.menu-movil .offcanvas.offcanvas-start{
    width: 90%;
}

.menu-movil .offcanvas-header{
    padding-top: 3rem;
    padding-bottom: 0px;
}

/*--------------------------------------------------------------
>>> FOOTER:
---------------------------------------------------------------*/

footer{
    background-color: var(--oscuro);
    padding: 2rem 0;
    color: #fff;
    margin-top: 2rem;
}

.union-europea img{
    max-width: 200px;
    margin-bottom: 5px;
}

.union-europea p,
.union-europea a{
    font-weight: 200;
    font-size: 0.9rem;
}

.union-europea p{
    margin-bottom: 0px;
}

.union-europea a{
    margin-bottom: 1rem;
    display: inline-block;
    text-decoration: underline;
}

.redes{
    display: flex;
    align-items: baseline;
    gap: 1rem;
    margin: 1rem 0 1.5rem 0;
}

.redes p{
    margin-bottom: 0px;
    font-size: 0.8rem;
}

.redes img{
    max-width: 20px;
}

/*--------------------------------------------------------------
>>> PORTADA:
---------------------------------------------------------------*/

.hero-portada{
    background-color: var(--oscuro);
    color: #fff;
    border-radius: var(--borde);
    width: 100%;
    overflow: hidden;
    position: relative;
}

.superior-hero{
    position: relative;
    padding: 1rem;
    border-radius: var(--borde);
    overflow: hidden;
}

.inferior-hero{
    padding: 1rem;
    text-align: end;
}

.inferior-hero .boton a::after {
    font-size: 1em;
}

.fondo-hero-portada{
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: 0;
}

.contenido-hero-portada{
    position: relative;
    z-index: 2;
}

.fondo-hero-portada img{
    height: 100%;
    object-fit: cover;
    opacity: 0.6;
}

.hero-portada h2 {
  text-shadow: 4px 4px 5px rgba(0, 0, 0, .4);
}

.foto-separador{
    position: relative;
    width: 100%;
}

.nombre-separador{
    position: absolute;
    bottom: 10px;
    right: 15px;
}

.nombre-separador p{
    font-size: 0.7rem !important;
    color: #fff;
    margin-bottom: 0px;
    opacity: 0.8;
}

.foto-separador img{
    max-height: 400px;
    object-fit: cover;
    min-height: 200px;
}

.about .boton a{
    background-color: var(--medio);
}

.about h2 strong{
    font-weight: 700;
    letter-spacing: 1vw;
    display: block;
}

.imagen-about img{
    border-radius: var(--borde);
}

.offers{
    overflow: hidden;
}

.SwiperOffers{
    overflow: visible;
}

.SwiperOffers .swiper-slide:nth-child(odd) {
    background-color: var(--claro-2);
    color: var(--oscuro);
}

.SwiperOffers .swiper-slide:nth-child(even) {
    background-color: var(--oscuro);
    color: #fff;
}

.SwiperOffers .swiper-slide{
    border-radius: var(--borde);
    height: auto;
    padding: 1.5rem;
}

.SwiperOffers .swiper-slide img{
    max-width: 60px;
}

.SwiperOffers .swiper-slide p{
    margin-bottom: 0px;
    line-height: 1.4;
}

.flex-vertical{
    display: flex;
    flex-direction: column;
    gap: 1rem; 
    height: 100%;
    justify-content: space-between;
}

.SwiperPositions .flex-vertical{
    gap: 0.5rem;
}

.flex-fotos{
    display: flex;  
}

.flex-foto{
    flex: 1;
}

.flex-foto img{
    height: 100%;
    object-fit: cover;
}

.positions{
    overflow: hidden;
}

.positions h2{
    text-align: center;
}

.SwiperPositions{
    overflow: visible;
}

.swiper-positions .swiper-slide{
    height: auto;
}

.caja-positions{
    position: relative;
    border-radius: var(--borde);
    height: 100%;
    padding: 1.5rem;
}

.caja-positions:hover a{
    gap: 0.8rem;
    transition: 0.2s ease;
}

.caja-positions .boton a::before{
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 1;
    content: "";
}

.theoretical{
    background-color: var(--claro-2);
}

.experimental{
    background-color: var(--gris);
}

.irp{
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1rem;
}

.irp img{
    max-width: 30px;
}

.irp p{
    color: var(--cian);
    margin-bottom: 0px;
    font-weight: 600;
    font-size: 1.3rem;
}

.lugar{
    color: var(--cian);
    margin-bottom: 0px;
    font-size: 1rem;
}

.swiper-positions .lugar{
    font-size: 1rem !important;
}

.descripcion-position{
    font-weight: 500;
}

.positions .boton p{
    color: #fff;
    background-color: var(--oscuro);
    border-radius: 1000px;
    padding: 5px 15px;
    opacity: 0.6;
    width: fit-content;
    font-size: 1rem;
}

.page-template-page-portada .positions .boton p{
    font-size: 1rem;
    line-height: 1.4;
}  

.paginador-mas{
    position: relative;
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 2rem;
}

.positions .swiper-button-next:after, 
.positions .swiper-button-prev:after{
    display: none;
}

.positions .swiper-button-next, 
.positions .swiper-button-prev{
    color: var(--oscuro);
}

.positions .swiper-button-next.swiper-button-disabled, 
.positions .swiper-button-prev.swiper-button-disabled{
    color: var(--claro);
} 

.positions .swiper-button-next{
    right: auto;
    left: 55px;
}

.paginador i{
    font-weight: 800;
    border: solid 1.3px;
    border-radius: 1000px;
    padding: 5px 10px;
    margin-bottom: 1rem;
}

.paginador-mas .boton a{
    color: var(--oscuro);
    background-color: transparent;
    font-weight: 500;
}

.phd{
    position: relative;
    width: 100%;
    color: #fff;
    padding: 2rem 1rem;
}

.fondo-phd{
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: -1;
}

.fondo-phd img{
    height: 100%;
    object-fit: cover;
}

.phd h2{
    font-weight: 500;
}

.phd .boton a{
    background-color: var(--medio);
}

.phd p{
    margin-bottom: 0px;
}

.info-orbis h2{
    text-align: center;
    letter-spacing: 1vw;
    margin-bottom: 4px;
}

.info-orbis h3{
    text-align: center;
    text-transform: uppercase;
    font-size: 1rem;
}

.info-orbis p{
    text-align: start;
}

.fila-tabla{
    display: flex;
    flex-direction: column;
}

.info-orbis .fila-tabla{
    padding: 1rem 0.5rem;
    border-bottom: solid 1px var(--medio);
    text-align: center;
}

.info-orbis .fila-tabla p{
    margin-bottom: 0px;
}

.info-orbis .tabla-info{
    border-top: solid 1px var(--medio);
    margin-top: 1rem;
}

.info-orbis .titulo-tabla{
    display: flex;
    align-items: center;
    min-width: 150px;
}

.info-orbis .titulo-tabla p{
    font-size: 0.9rem;
}

.info-orbis .tabla-info img{
    max-width: 200px;
    margin: 10px 0;
}

.page-template-page-portada .info-orbis .titulo-tabla p{
    font-size: 0.8rem;
}

/*--------------------------------------------------------------
>>> THE PROJECT:
---------------------------------------------------------------*/

.hero-interior{
    background-color: var(--oscuro);
    color: var(--oscuro);
    border-radius: var(--borde);
    width: 100%;
    overflow: hidden;
    position: relative;
    box-shadow: 0 20px 0 var(--oscuro);
    padding: 1rem;
}

.fondo-hero-interior{
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: 0;
}

.fondo-hero-interior img{
    height: 100%;
    object-fit: cover;
    opacity: 0.9;
}

.contenido-hero-interior{
    position: relative;
}

.contenido-hero-interior h1{
    margin-bottom: 0px;
    line-height: 1;
}

.hero-interior strong{
    display: block;
}

.intro-interior strong{
    color: var(--medio);
    font-weight: inherit;
}

.intro-interior h2{
    font-weight: 400;
    font-size: 1.4rem;
}

.intro-interior p{
    font-size: 1rem;
    font-weight: 300;
    line-height: 1.3;
}

.intro-interior{
    border-bottom: solid 2px var(--claro);
    padding: 4rem 0 3rem 0; 
}

.page-template-page-work-packages .intro-interior{
    border-bottom: 0px;
}

.texto-contenido h2{
    font-weight: 300;
    margin-bottom: 1rem;
}

.texto-contenido strong{
    font-weight: inherit;
    color: var(--medio);
}

.texto-contenido a{
    text-decoration: underline;
}

.foto-contenido{
    overflow: hidden;
    border-radius: var(--borde);
}

.foto-contenido img{
    height: 100%;
    object-fit: cover;
}

.frase-destacada{
    border: solid 3px var(--claro-1);
    border-radius: var(--borde);
    padding: 1rem;
}

.frase-destacada p{
    margin-bottom: 0px;
    font-weight: 400;
    font-size: 1.1rem;
    text-align: center;
}

.banner-consortium{
    text-align: center;
    display: flex;
    gap: 1rem;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    border-top: solid 2px var(--claro);
    padding: 4rem 0 3rem 0; 
}

.banner-consortium p{
    margin-bottom: 0px;
    font-weight: 400;
    font-size: 1.1rem;
    text-align: center;
}

/*--------------------------------------------------------------
>>> THE CONSORTIUM:
---------------------------------------------------------------*/

.intro-interior h2 i{
    color: var(--claro-1);
}

.page-template-page-consortium .intro-interior h2{
    margin-bottom: 1rem;
}

.lista-intro-interior li{
    border-bottom: solid 1.5px var(--claro-1);
    padding: 1rem;
    font-size: 1.2rem;
    display: flex;
    align-items: center;
    font-weight: 300;
}

.lista-intro-interior li:last-child{
    border-bottom: none;
}

.lista-intro-interior .numero{
    text-align: center;
    min-width: 50px;
    display: inline-block;
    font-size: 1.8rem;
}

.cuadricula{
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 10px;
}


.contenido-cuadricula{
    text-align: center;
    border: solid 2px var(--claro-1);
    border-radius: var(--borde);
    padding: 1rem;
}

.contenido-cuadricula img{
    max-height: 60px;
    width: auto;
    margin-bottom: 1rem;
}

.nombre-cuadricula{
    font-weight: 500;
    line-height: 1.3;
    font-size: 1rem;
    margin-bottom: 5px;
}

.nombre-cuadricula strong{
    color: #046589;
    display: block;
    font-weight: inherit;
    font-size: 0.9;
}

.lugar-cuadricula{
    font-size: 0.8rem;
}

.personas-cuadricula{
    color: var(--medio);
    font-weight: 400;
    font-size: 0.9rem;
    margin-bottom: 12px;
}

.contenido-cuadricula a:hover{
    text-decoration: underline;
}

.clases-cuadricula{
    display: flex;
    gap: 5px; 
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
}

.clases-cuadricula p{
    background-color: var(--claro-1);
    padding: 3px 9px 5px 9px;
    border-radius: 1000px;
    font-size: 0.6rem;
    margin-bottom: 5px;
}

.titulo-interior{
    margin-bottom: 1.5rem;
}

.titulo-interior h2{
    font-weight: 400;
    font-size: 1.4rem;
    margin-bottom: 1rem;
}

.titulo-interior p{
    font-size: 1rem;
    font-weight: 300;
    line-height: 1.3;
}

.titulo-interior h2 i{
    color: var(--claro-1);
}

/*--------------------------------------------------------------
>>> WORK PACKAGES:
---------------------------------------------------------------*/

.work-package{
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 10px;
    border: solid 2px var(--claro-1);
    border-radius: var(--borde);
    margin-bottom: 1rem;
    padding: 1rem;
    align-items: center;
}

.contenido-work-package h2{
    font-weight: 500;
    margin-bottom: 1rem;
}

.contenido-work-package h2 span{
    font-size: 1.3rem;
}

.contenido-work-package h3{
    color: var(--cian);
    font-size: 0.9rem;
    font-weight: 300;
    margin-bottom: 2px;
}

.contenido-work-package p{
    font-weight: 400;
}

.work-package .foto-work-package{
    display: flex;
    justify-content: center;
    align-items: center;
}

.work-package img{
    max-width: 300px;
}

.other-package{
    border: solid 2px var(--claro-1);
    border-radius: var(--borde);
    padding: 1rem;
    height: 100%;
}

.other-package img{
    max-width: 80px;
    margin-bottom: 0.5rem;
}

.other-package .contenido-work-package h2 span{
    width: 100%;
    display: block;
    font-size: 1.2rem;
}

/*--------------------------------------------------------------
>>> EVENTS:
---------------------------------------------------------------*/

.fila-event {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem; 
    border-bottom: solid 2px var(--claro-1);
    padding: 1.5rem 1rem 1.5rem 1rem;
    align-items: center;
}

.titulo-event p{
    color: var(--medio);
    font-weight: 400;
    margin-bottom: 0px;
    font-size: 1.3rem;
}

.info-event p{
    font-weight: 400;
    margin-bottom: 0.5rem;
}

.info-extra-event p{
    font-weight: 300;
    font-size: 0.8rem !important;
}

.info-extra-event strong{
    font-weight: 300;
    color: var(--medio);
}

.subtitulo-event{
    margin-top: 5px;
    margin-bottom: 0px;
}

/*--------------------------------------------------------------
>>> OPEN POSITIONS:
---------------------------------------------------------------*/

.positions-irp{
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 10px;
}

.positions-irp .boton p{
    font-size: 1rem;
    line-height: 1.4;
    color: #fff;
    background-color: var(--oscuro);
    border-radius: 1000px;
    padding: 5px 15px;
    opacity: 0.6;
    width: fit-content;
}  

.contenido-hero-position .boton p{
    font-size: 1rem;
    line-height: 1.4;
    color: #fff;
    background-color: var(--oscuro);
    border-radius: 1000px;
    padding: 5px 15px;
    opacity: 0.6;
    width: fit-content;
    display: inline-block;
    font-weight: 400;
}  

.positions-irp .boton{
    margin-bottom: 0.5rem;
}

.tipo-irp img{
    max-width: 20px;
    margin-right: 8px;
}

.tipos-irp{
    display: flex;
    flex-direction: column;
    padding-left: 27px;
    gap: 0.5rem;
    margin-bottom: 1.5rem;
}

.tipo-irp{
    display: flex;
    align-items: center;
}

.tipo-irp {
    position: relative;
}

.tipo-irp::before {
    content: "";
    position: absolute;
    top: 2px;          
    left: -25px;         
    width: 15px;
    height: 15px;
    border-radius: 50%;
    background-color: var(--gris); 
}

.tipo-theorical::before {
  background-color: var(--claro-2);
}

.tipos-irp p{
    margin-bottom: 0px;
}

.boton-open-positions{
    text-align: center;
}

.boton-open-positions a{
    background-color: var(--medio);
    padding: 10px 30px;
}

/*--------------------------------------------------------------
>>> POSITION:
---------------------------------------------------------------*/

.hero-position{
    background-color: var(--claro-2);
    border-radius: var(--borde);
    padding: 1.5rem 1rem;
}

.hero-position-experimental{
    background-color: var(--gris);
}

.identificador{
    text-transform: uppercase;
    font-weight: 600;
    margin-bottom: 0px;
    font-size: 2rem;
}

.tipo-proyecto{
    color: #77BACC;
    text-transform: uppercase;
    font-size: 0.9rem;
    font-weight: 500;
}

.hero-position h1{
    font-size: 1.3rem;
    line-height: 1.3;
    margin-bottom: 1.5rem;
    font-weight: 400;
}

.fila-position{
    display: grid;
    grid-template-columns: 1fr;
    border-bottom: solid 2px var(--claro-1);
    padding: 1.5rem 1rem 0.5rem 1rem;
}

.titulo-tabla-position p{
    color: var(--medio);
    font-weight: 400;
}

.texto-tabla-position p,
.texto-tabla-position li{
    font-size: 0.9rem;
    line-height: 1.3;
    margin-bottom: 0.8rem;
}

.texto-tabla-position ol,
.texto-tabla-position ul{
    padding-left: 15px;
}

.texto-tabla-position li{
    list-style-type: inherit;
    font-weight: 300;
}

.texto-tabla-position a{
    color: var(--cian);
}

.texto-tabla-position strong{
    font-weight: 600;
}

.navegacion-position{
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.navegacion-position p{
    margin-bottom: 0px;
    color: #C5C5C5;
    font-weight: 500;
}

.navegacion-position p,
.navegacion-position a{
    font-size: 0.8rem;
}

.position-ultima{
    opacity: 0.4;
}

.cuadro-irp{
    display: grid;
    grid-template-columns: 1fr;
    border: solid 2px var(--claro-1);
    padding: 1.5rem 1rem;
    border-radius: var(--borde);
    margin-bottom: 0.8rem;
    align-items: center;
    gap: 1rem;
    text-align: center;
}

.cuadro-irp p{
    margin-bottom: 2px;
}

.logo-cuadro-irp{
    display: flex;
    justify-content: center;
}

.cuadro-irp img {
    max-height: 50px;
    width: auto;
}

.titulo-cuadro-irp{
    font-weight: 500;
    font-size: 1.1rem !important;
}

.tipo-secondment{
    color: var(--cian);
    font-size: 0.9rem !important;
    font-weight: 600;
    margin-bottom: 0.3rem !important;
}

.lugar-cuadro-irp{
    font-size: 0.8rem !important;
    margin-bottom: 0.5rem !important;
    font-weight: 300;
}

.supervisor-cuadro-irp{
    font-size: 1rem;
    color: var(--medio);
    font-weight: 300;
}

.logo-host-institution{
    margin-bottom: 1rem;
}

.logo-host-institution img{
    max-height: 100px;
    width: 100%;
    object-fit: contain;
}

/*--------------------------------------------------------------
>>> FORMULARIO:
---------------------------------------------------------------*/

.modal-irp .modal-header{
    border-bottom: 0px;
    padding: 16px 16px 0 16px;
}

.modal-irp .logo-orbis img{
    max-width: 50px;
    margin-bottom: 0.5rem;
}

.modal-irp .modal-content{
    border: none;
}

.modal-irp .titulo-irp{
    text-align: center;
    margin-bottom: 2.5rem;
}

.titulo-irp h2{
    color: var(--cian);
    font-weight: 300;
    font-size: 1.5rem;
}

.intro-irp h2{
    font-weight: 400;
    font-size: 1.4rem;
    margin-top: 1.5rem;
}

.lista-formulario li {
    position: relative;
    padding-left: 30px;
    margin-bottom: 10px;
    font-weight: 200;
}

.lista-formulario li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 4px;
    width: 18px;
    height: 18px;
    background-image: url("/wp-content/uploads/check.png");
    background-size: contain;
    background-repeat: no-repeat;
}

.interior-form-irp{
    border: solid 1.5px var(--claro-3);
    border-radius: var(--borde);
    padding: 0 1rem 1rem 1rem;
}

.interior-form-irp h4{
    font-weight: 400;
    font-size: 1.2rem;
    margin-top: 2rem;
}

.modal-irp label{
    width: 100%;
    color: #5B94AA;
    margin: 8px 0;
}

.wpcf7-select{
    margin-top: 5px;
}

.interior-form-irp br{
    display: none;
}

.modal-irp input{
    width: 100%;
}

.modal-irp .wpcf7-date{
    width: auto;
    color: #5B94AA;
    border: solid 1px #5B94AA;
    margin-top: 8px;
    padding: 1px;
    font-weight: 300;
}

.modal-irp textarea{
    width: 100%;
    border: solid 1px #5B94AA;
    margin-top: 5px;
    margin-bottom: 1rem;
    padding: 10px;
    color: #5B94AA;
}

.modal-irp .wpcf7-form-control-wrap{
    width: 100%;
    display: block;
}

.modal-irp .wpcf7-select{
    width: 100%;
    border: none;
    border-bottom: solid 1px var(--claro-1);
    padding: 5px 0;
    border-radius: 0px;
}

.modal-irp .wpcf7-text{
    border: none;
    border-bottom: solid 1px var(--claro-1);
    padding: 5px 0;
    border-radius: 0px;
    color: #5B94AA;
}

.modal-irp input::placeholder,
.modal-irp textarea::placeholder{
    color: #5B94AA;
    font-weight: 300;
}

.modal-irp select {
    color: #5B94AA;
    font-weight: 300;
}

.modal-irp select:has(option[value=""]:checked) {
    color: #5B94AA;
    font-weight: 300;
}

.modal-irp select:focus-visible {
    border: 0px !important;
    outline: none !important;
    box-shadow: inset 0 -1px 0 var(--claro-1);
}

.modal-irp input:focus-visible {
    border: 0px !important;
    outline: none !important;
    box-shadow: inset 0 -1px 0 var(--claro-1);
}

.modal-irp .wpcf7-form-control-wrap:focus-visible {
    border: 0px !important;
    outline: none !important;
    box-shadow: inset 0 -1px 0 var(--claro-1);
}

.modal-irp textarea:focus-visible {
    border: solid 1px #5B94AA !important;
    outline: none !important;
    box-shadow: inset 0 -1px 0 var(--claro-1);
}

.flex-selector label{
    width: auto;
    display: flex;
    gap: 4px;
}

.flex-selector p {
    display: flex;
    gap: .75rem;
    width: auto;
    color: #5B94AA;
}

.flex-selector p > br {
    display: none;
}

.flex-selector .wpcf7-form-control-wrap{
    display: inline-block;
}

.flex-selector .wpcf7-radio {
    display: inline-flex;
    gap: .75rem;
}

.flex-selector .wpcf7-list-item {
    margin: 0;
}

.wpcf7-acceptance .wpcf7-list-item{
    margin: 0px;
}

.modal-irp .aceptacion{
    display: flex;
}

.modal-irp .wpcf7-form-control-wrap{
    margin-right: 8px;
    margin-top: 2px;
}

.modal-irp .aceptacion p{
    font-size: 0.8rem;
}

.modal-irp .aceptacion .wpcf7-list-item input{
    width: 12px;
    height: 12px;
}

.interior-form-irp .wpcf7-submit{
    background-color: var(--medio);
    border: solid 1px var(--medio);
    color: #fff;
    padding: 10px 20px;
    border-radius: 1000px;
    box-shadow: transparent;
    margin-top: 1.5rem;
    width: auto;
    text-align: center;
}

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

.texto-mini{
    font-size: 0.9rem !important;
}

.modal-irp .wpcf7-spinner{
    width: 100%;
}

.modal-irp .wpcf7-not-valid-tip{
    font-size: 0.8rem;
}


/*--------------------------------------------------------------
>>> MEDIA QUERIES:
---------------------------------------------------------------*/

@media (min-width: 576px) { 

    .modal-irp .modal.fade .modal-dialog{
        max-width: 80%;
    }

}

@media (min-width: 768px) {
    
    footer{
        padding: 2rem 0 3rem 0;
        margin-top: 5rem;
    }
    
    .menu-footer ul {
        display: flex;
        justify-content: flex-end;
        gap: 16px;
        padding: 0;
        margin: 0;
        list-style: none;
    }

    .menu-footer li {
        position: relative;
        padding-right: 20px;
    }

    .menu-footer li::after {
        content: "|";
        position: absolute;
        right: 0;
        color: #fff; 
    }
    
    .menu-footer li:last-child {
        padding-right: 0px;
    }

    .menu-footer li:last-child::after {
        content: none;
    }
    
    .redes{
        justify-content: flex-end;
    }
    
    .union-europea a{
        margin-bottom: 0px;
    }
    
    .triplevdoble{
        text-align: end;
    }

    .fila-tabla{
        flex-direction: row;
    }        
    
    .info-orbis .fila-tabla{
        gap: 10px;
    }
    
    .page-template-page-portada .info-orbis .fila-tabla{
        gap: 30px;
    }
        
    .titulo-intro-interior{
        padding: 0 1rem;
    }
    
    .intro-interior{
        padding: 7rem 0 5rem 0;
    }
    
    .banner-consortium{
        padding: 7rem 0 0rem 0;
    }
    
    .contenido-intro-interior{
        padding: 0 3rem;
    }

    .titulo-grande h2{
        font-size: 2.3rem;
    }
    
    .cuadricula{
        grid-template-columns: repeat(2, 1fr);
    }

    .cuadricula .cuadricula-doble{
        grid-column: span 2;
    }
    
    .contenido-cuadricula{
        padding: 3rem 0.5rem;
    }
    
    .hero-position{
        padding: 2.5rem 2rem;
    }
    
    .identificador{
        font-size: 4rem;
    }
    
    .contenido-hero-position{
        text-align: end;
    }
    
    .fila-position{
        grid-template-columns: 1fr 3fr;
        gap: 2rem;
    }
    
    .modal-irp .modal-body{
        padding: 1rem 3rem 2rem 3rem;
    }
    
    .positions-irp{
        grid-template-columns: repeat(2, 1fr);
    }
    
    .tipos-irp{
        flex-direction: row;
        gap: 50px;
    }

    .work-package{
        grid-template-columns: 1fr 3fr;
        gap: 30px;
        padding: 2rem 2rem 1.5rem 2rem;
    }
    
    .contenido-work-package h2{
        font-size: 2rem;
    }
    
    .contenido-work-package h2 span{
        font-size: 1.3rem;
    }
    
    .contenido-work-package h3{
        margin-bottom: 4px;
    }
    
    .other-package{
        padding: 2rem 2rem 1.5rem 2rem;
    }
    
    .navegacion-position p,
    .navegacion-position a{
        font-size: 1rem;
    }
    
    .fila-event {
        grid-template-columns: 6fr 4fr;
        gap: 2rem; 
    }
    
    .contenido-event{
        text-align: end;
    }
    
    .titulo-event p{
        font-size: 1.4rem;
        line-height: 1.2;
    }
    
    .subtitulo-event p{
        font-size: 1.1rem;
    }
    
    .cuadro-irp{
        grid-template-columns: 4fr 6fr;
        gap: 30px;
        padding: 2rem;
        text-align: start;
    }
    
    .cuadro-irp img {
        max-height: none;
        width: 100%;
        max-width: 130px;
    }
    
    .logo-host-institution{
        margin-bottom: 1.5rem;
    }
    
    .logo-host-institution img{
        max-height: 100px;
        width: auto;
    }
    
}

@media (min-width: 992px) { 
    
    :root {
      --borde: 40px;
    }
    
    header{
        margin-bottom: 2rem;
    }
    
    .site-branding img{
        max-width: 200px;
    }

    .page-template-page-portada .site-main p{
        font-size: 1.2rem;
        line-height: 1.4;
    }    

    .mb5{
        margin-bottom: 5rem;
    }

    .mb8{
        margin-bottom: 8rem;
    }
    
    .mb10{
        margin-bottom: 10rem;
    }
    
    .superior-hero{
        padding: 4rem 3rem;
    }
    
    .contenido-hero-portada{
        max-width: 70%;
    }
    
    .SwiperOffers .swiper-slide{
        padding: 1.5rem;
    }

    .SwiperOffers .swiper-slide img{
        max-width: 80px;
    }

    .SwiperOffers .swiper-slide p{
        font-size: 1.3rem;
        line-height: 1.3;
    }

    .flex-vertical{
        gap: 2rem; 
    }
    
    .offers h2{
        margin-bottom: 2rem;
    }
    
    .caja-positions{
        padding: 2rem;
    }
    
    .descripcion-position{
        font-weight: 500;
        font-size: 1.2rem;
        line-height: 1.3;
        margin-top: 5px;
    }
    
    .positions h2{
        margin-bottom: 2rem;
    }
    
    .phd{
        padding: 4rem 0;
    }
    
    .info-orbis .fila-tabla{
        padding: 1.5rem 1rem;
    }
    
    .info-orbis .tabla-info img{
        margin: 0px;
    }
    
    .hero-interior{
        padding: 4rem 3rem;
    }
    
    .titulo-intro-interior{
        padding: 0 3rem;
    }
    
    .intro-interior p{
        font-size: 1.1rem;
    }
    
    .texto-contenido h2{
        margin-bottom: 1.4rem;
    }
    
    .frase-destacada{
        padding: 3rem 4rem;
    }
    
    .frase-destacada p{
        font-size: 1.3rem;
    }
    
    .banner-consortium{
        flex-direction: row;
        gap: 2rem;
    }
    
    .banner-consortium p{
        font-size: 1.3rem;
    }
    
    .lista-intro-interior .numero{
        font-size: 2.8rem;
        min-width: 100px;
    }
    
    .lista-intro-interior li{
        font-size: 2rem;
    }
    
    .cuadricula{
        grid-template-columns: repeat(4, 1fr);
        gap: 15px;
    }
    
    .titulo-interior p{
        font-size: 1.1rem;
    }

    .intro-interior h2{
        font-size: 2rem;
        line-height: 1.2;
    }
    
    .titulo-intro-interior h2{
        font-size: 1.6rem;
    }
    
    .titulo-interior h2{
        font-size: 2rem;
        line-height: 1.2;
        margin-bottom: 1.5rem;
    }

    .titulo-interior{
        margin-bottom: 3rem;
        padding-left: 2rem;
    }
   
    .titulo-interior p{
        width: 90%;
    }
    
    .tipo-proyecto{
        margin-bottom: 12px;
    }
    
    .texto-tabla-position p,
    .texto-tabla-position li{
        font-size: 1rem;
        line-height: 1.4;
    }
    
    .titulo-tabla-position p{
        font-size: 1.4rem;
        line-height: 1.2;
    }
    
    .texto-tabla-position{
        padding-top: 0.3rem;
    }
    
    .interior-form-irp{
        padding: 1rem 2rem;
    }
    
    .modal-irp .modal-body{
        padding: 1rem 6rem 2rem 6rem;
    }
    
    .modal-irp .logo-orbis img{
        max-width: 70px;
    }

    .modal-irp .titulo-irp{
        max-width: 70%;
        margin: auto;
    }

    .titulo-irp h2{
        font-size: 2rem;
        margin-bottom: 3rem;
    }
    
    .positions-irp{
        grid-template-columns: repeat(3, 1fr);
        gap: 15px;
    }
    
    .boton-open-positions a{
        font-size: 1.3rem;
    }
    
    .interior .gracias{
        height: 50vh;
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
    }
    
    .titulo-event{
        font-size: 1.4rem;
        line-height: 1.2;;
    }
    
    .page-template-page-events .titulo-interior{
        padding-left: 0px;
    }
    
    .titulo-cuadro-irp{
        font-size: 1.4rem;
    }

    
}

@media (min-width: 1200px) {  
    
    footer{
        padding: 3rem 0 4rem 0;
        margin-top: 10rem;
    }
    
    .union-europea img{
        max-width: 300px;
    }
    
    .redes{
        margin: 1.5rem 0;
    }
    
    .redes img{
        max-width: 30px;
    }
    
    h2{
        font-size: 2.4rem;
        line-height: 1.1;
    }

    .contenido-hero-portada{
        max-width: 60%;
    }
    
    .hero-portada h2{
        font-size: 2.8rem;
        line-height: 1.1;
        margin-bottom: 1rem;
    }
    
    .inferior-hero a{
        font-size: 1.3rem;
    }
    
    .about h2{
        font-size: 3rem;
    }
    
    .phd{
        padding: 5rem 0;
    }
    
    .info-orbis .tabla-info{
        margin-top: 2rem;
    }
    
    .info-orbis .fila-tabla{
        padding: 1.5rem;
    }
    
    .hero-interior strong{
        font-size: 3rem;
    }
    
    .frase-destacada p{
        font-size: 1.5rem;
    }
    
    .banner-consortium p{
        font-size: 1.5rem;
    }
    
    .page-template-page-consortium .intro-interior h2{
        margin-bottom: 2rem;
    }
    
    .cuadricula-doble img{
        max-height: 80px;
    }
    
    .intro-interior h2{
        font-size: 2.3rem;
    }
    
    .titulo-intro-interior h2{
        font-size: 1.8rem !important;
        line-height: 1.3;
    }
        
    .titulo-interior h2{
        font-size: 2.3rem;
    }
    
    .titulo-interior p{
        width: 85%;
    }
    
    .hero-position {
        padding: 2.5rem 3rem;
    }
    
    .identificador {
        font-size: 7rem;
    }
    
    .hero-position h1{
        font-size: 1.8rem;
        line-height: 1.2;
    }
    
    .modal-irp .modal.fade .modal-dialog{
        max-width: 900px;
    }


}

@media (min-width: 1400px) { 


    
}
