/* VARIABLES */
:root {
	--negro: #222222;
	--blanco: #f6f6f6;
	--gris_1: #E0E0E0;
	--gris_2: #D3D3D3;
	--gris_3: #5F5F5F;
	--azul_1: #A6D6F6;
	--transicion_rapida: 0.2s;
	--transicion_lenta: 0.4s;
	--swiper-navigation-sides-offset: 80px;
}



/* GLOBAL */
* {
	box-sizing: border-box;
	scroll-behavior: smooth;
}

html,
body {
	border: none;
	padding: 0;
	margin: 0;
	width: 100%;
	height: 100%;
	background-color: var(--blanco);
}



/* FONDOS */
.fondoGris {
	background-color: var(--gris_3);
}



/* ESTILOS DE TEXTO */
h1,
h2,
h3,
h4,
h5,
h6,
p,
ul,
ol {
	margin: 0;
}

p {
	font-family: "EB Garamond", serif;
	font-size: 22px;
	line-height: 30px;
	color: #5d5d5d;
}

h1 {
	font-family: "EB Garamond", serif;
	font-style: normal;
	font-weight: 500;
	font-size: 115px;
	line-height: 150px;
}

h2,
h3,
h4 {
	font-family: "EB Garamond", serif;
	font-style: italic;
	font-weight: 450;
}

h2 {
	font-size: 64px;
	line-height: 72px;
}

h3 {
	font-size: 36px;
	line-height: 36px;
}

h4 {
	font-size: 30px;
	line-height: 30px;
}

h5 {
	font-family: "EB Garamond", serif;
	font-size: 20px;
	font-weight: 700;
}

h5 i {
	font-weight: 500;
}

a {
	outline: 0;
}

/*   <Next Prev Carrusel>   */

.swiper-button-next {
	justify-content: flex-start;
}

/* LINKS NEGROS*/
a:link {
	transition: color var(--transicion_rapida) linear;
	color: var(--negro);
	text-decoration: none;
}

a:visited {
	color: var(--negro);
	text-decoration: none;
}

p>a:link,
p>a:visited {
	text-decoration: underline;
}

a:hover {
	color: var(--gris_3);
}

/* LINKS BLANCOS*/
a.linkBlanco:link {
	color: var(--blanco);
}

a.linkBlanco:visited {
	color: var(--blanco);
}

a.linkBlanco:hover {
	color: var(--gris_2);
}

a.seccionActual,
a.seccionActual.linkBlanco {
	background-color: #c68d9599;
	text-decoration: underline;
}

a.subrayado {
	text-decoration: underline;
}



/* CONTENEDORES PRINCIPALES */
.contenedorGeneral {
	width: 100%;
	min-height: 100vh;
	display: flex;
	flex-direction: column;
	overflow: hidden;
}

.contenidoTextoImagen {
	min-width: 100vw;
	width: 100%;
	padding: 60px 15% 0 15%;
}



/* BLOQUES DE TEXTO */
.bloqueTexto_titulo {
	width: 100%;
	padding-bottom: 40px;
}

.bloqueTexto_subtitulo {
	width: 100%;
	padding-bottom: 60px;
}

.bloqueTexto_frase {
	width: 100%;
	padding-bottom: 60px;
}

.bloqueTexto_frase h3 {
	max-width: 900px;
}

.frase_noCursiva {
	font-style: normal;
}

.bloqueTexto_fraseCentro {
	width: 100%;
	padding-bottom: 90px;
	text-align: center;
}

.bloqueTexto_fraseCentro h3 {
	max-width: 1440px;
}

.bloqueTexto_parrafoUnaColumna,
.bloqueTexto_parrafoDosColumnas {
	width: 100%;
	padding: 0 10% 60px 10%;
}

.bloqueTexto_parrafoDosColumnas p {
	columns: 2;
	column-gap: 50px;
}

/*   About texto imagen   */

.bloqueTexto_parrafoConImagen {
	display: flex;
	flex-direction: column;
	gap: 40px;
	margin-bottom: 30px;
}

.itemTextoImagen {
	display: flex;
	align-items: flex-start;
	gap: 20px;
}

.itemTextoImagen img {
	width: 35%;
	height: auto;
	object-fit: cover;
	border-radius: 4px;
}

.itemTextoImagen p {
	flex: 1;
	font-size: 18px;
	line-height: 1.6;
}

.itemTextoImagen:nth-child(even) {
	flex-direction: row-reverse;
}

@media (max-width: 768px) {
	.itemTextoImagen {
		flex-direction: column;
	}

	.itemTextoImagen img {
		width: 100%;
	}
}

/*  Marco about  */

.itemTextoImagen img {
	border: 5px solid #c1b1b1;
	padding: 6px;
	background-color: #fff;
	box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
}

/*   Creditos Imagenes "Footer"   */

.seccionLogosAliados {
	width: 100%;
	background: transparent;
	padding: 38px 20px;
	margin-top: 3rem;
}

.logosAliadosContenedor {
	max-width: 100%;
	margin: 0 auto;
	display: flex;
	justify-content: center;
	align-items: center;
}

.logoAliado {
	padding: 0 22px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-right: 1px solid #333333;
}

.logoAliado:last-child {
	border-right: none;
}

.logoAliado img {
	max-height: 80px;
	width: auto;
	display: block;

}

@media (min-width: 965px) and (max-width: 1570px) {
	.logoAliado img {
		max-height: 42px;
	}

}

@media (min-width: 835px) and (max-width: 964px) {
	.logoAliado img {
		max-height: 35px;
	}

}

@media (min-width: 769px) and (max-width: 834px) {
	.logoAliado img {
		max-height: 30px;
	}

}

/* Responsive */
@media (max-width: 768px) {
	.seccionLogosAliados {
		padding: 35px 20px;
	}

	.logosAliadosContenedor {
		flex-direction: column;
		gap: 28px;
	}

	.logoAliado {
		padding: 0;
		border-right: none;
	}

	.logoAliado img {
		max-height: 48px;
	}
}

/* IMÁGENES */
.marcoImagen_base,
.marcoImagen_pass,
.marcoImagen_fondo,
.marcoImagen_img {
	width: 100%;
	height: 100%;
}

.marcoImagen_pass,
.marcoImagen_fondo,
.marcoImagen_img {
	border-radius: 8px;
}

.marcoImagen_base {
	background-color: var(--negro);
	padding: 2px;
}

.marcoImagen_pass {
	background-color: var(--blanco);
	padding: 10px;
}

.marcoImagen_img {
	object-fit: fill;
}

.intro .marcoImagen_img,
.outro .marcoImagen_img {
	opacity: 70%;
}

.imagenDerecha {
	width: 100%;
	max-width: 100%;
	display: grid;
	grid-template-columns: 2fr 1fr;
	column-gap: 25px;
	padding: 0 10% 60px 10%;
}

.imagenDerecha_img {
	width: 100%;
	max-height: 600px;
}

.pieDeFoto_derecha {
	text-align: right;
	display: flex;
	justify-content: end;
}

.pieDeFoto_derecha h5 {
	align-self: end;
}

.imagenIzquierda {
	width: 100%;
	max-width: 100%;
	display: grid;
	grid-template-columns: 1fr 2fr;
	column-gap: 25px;
	padding-bottom: 60px;
}

.imagenIzqiuerda_img {
	width: 100%;
	max-height: 600px;
}

.pieDeFoto_izquierda {
	text-align: left;
}



/* HEADER */
.headerCompleto {
	width: 100%;
	height: 120px;
	padding: 2px;
	background-color: var(--negro);
}

.headerCompleto_fondo {
	width: 100%;
	height: 100%;
	padding: 0 40px;
	display: grid;
	grid-template-columns: 2fr 3fr;
	align-items: center;
	border-radius: 8px;
}

.tituloSitio {
	align-self: center;
}

.tituloSitio h2 {
	line-height: 0;
}

.navegacionSecciones {
	display: grid;
	grid-auto-flow: column;
	column-gap: 5%;
	justify-content: end;
	align-self: center;
}

.navegacionSecciones h3 {
	font-size: 32px;
	line-height: 24px;
	text-align: right;
}

.navegacionSecciones a,
.linksMenuMovil a {
	display: inline-block;
	padding: 17px 16px;
	border-radius: 15px;
	backdrop-filter: blur(4px);
	text-decoration: none;
	transition: .25s;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
	background-color: #fea6a673;
	text-shadow: 0 2px 6px rgba(0, 0, 0, 0.45);
}

.navegacionSecciones a:hover,
.linksMenuMovil a:hover {
	background: #f29faa36;
	color: #111 !important;
}

.toggleMenuMovil {
	display: none;
}

.navegacionSeccionesMovil {
	display: none;
}

/* HOME Y CREDITOS */
.intro,
.outro {
	width: 100vw;
	height: 100vh;
	max-width: 100vw;
}

.outro {
	position: relative;
}

.textosIntro,
.textosOutro {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	padding: 40px;
	display: grid;
	grid-template-rows: 1fr 3fr 1fr;
	color: var(--blanco);
}

.textosIntro_top,
.textosOutro_top {
	width: 100%;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
}

.textosIntro_top h5,
.textosOutro_top h5 {
	text-align: end;
}

.textosIntro_titulo {
	position: relative;
	display: grid;
	grid-template-rows: 1fr;
	align-items: end;
	padding-left: 20%;
	padding-right: 20%;
}

.textosIntro_titulo h1 {
	font-size: 150px;
	line-height: 150px;
}

.textosIntro_bottom {
	display: grid;
	grid-template-columns: 1fr;
	align-items: end;
	text-align: center;
}

/* Botones flotantes */

.div-container span {
	color: #ffffff;
	font-size: 0.93rem;
	/* antes 0.72 */
	font-weight: 600;
	line-height: 1.2;
	text-align: center;
	text-shadow: 0 2px 5px rgba(0, 0, 0, 0.28);
}

.div-container-options {
	position: fixed;
	right: 0;
	top: 35%;
	z-index: 10;
	display: flex;
	flex-direction: column;
	align-items: flex-end;
}

.div-container-options a {
	text-decoration: none;
}

.div-container-options .button1,
.div-container-options .button2,
.div-container-options .button3 {
	background-color: #fea6a673;
	/*background: linear-gradient(135deg, #fea6a6d1 0%, #fea6a6d1 45%, #fea6a6d1 100%);*/
	cursor: pointer;
	border: none;
	width: 101px;
	/* antes 88 */
	height: 94px;
	/* antes 82 */
	padding: 12px 10px;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 8px 22px rgba(0, 0, 0, 0.28);
	transition: all 0.28s ease;
}

.div-container-options .button1:hover,
.div-container-options .button2:hover,
.div-container-options .button3:hover {
	width: 118px;
	transform: translateX(-10px) scale(1.03);
	background-color: #fea6a673;
	/*background: linear-gradient(135deg, #fea6a6d1 0%, #fea6a6d1 45%, #fea6a6d1 100%);*/
	box-shadow: 0 14px 34px rgba(0, 0, 0, 0.42);
}

.button1,
.button2 {
	border-bottom: 1px solid rgba(255, 255, 255, 0.25) !important;
}

.div-container-options .button1 {
	border-top-left-radius: 22px;
}

.div-container-options .button3 {
	border-bottom-left-radius: 22px;
}

.div-container-options .button1:hover,
.div-container-options .button2:hover,
.div-container-options .button3:hover {
	width: 108px;
	transform: translateX(-8px);
	background-color: #fea6a673;
	/*background: linear-gradient(135deg, #fea6a6d1 0%, #fea6a6d1 45%, #fea6a6d1 100%);*/
	box-shadow: 0 12px 30px rgba(0, 0, 0, 0.38);
}

.div-container-options button:focus {
	outline: none;
}


/* SLIDER HOME */
.sliderSecciones {
	position: relative;
	width: 100%;
}

.swiper {
	width: 85%;
	height: 750px;
	margin: 90px 0 0 0;
	scroll-margin-top: 90px;
}

.swiper-wrapper {
	height: 93% !important;
}

.swiper-horizontal>.swiper-pagination-bullets,
.swiper-pagination-bullets .swiper-pagination-horizontal {
	bottom: 0 !important;
}

.swiper-pagination-bullets .swiper-pagination-bullet-active {
	background-color: var(--negro);
}

.sliderSecciones .marcoImagen_base {
	max-height: 90%;
	margin-bottom: 20px;
}

.swiper-slide .marcoImagen_img {
	transition: opacity var(--transicion_rapida) linear;
	opacity: 1;
}

.sliderSecciones a:hover {
	.marcoImagen_img {
		opacity: 0.85;
	}
}

.slide-title {
	text-align: center;
	color: var(--negro);
}

.swiper-button-next,
.swiper-button-prev {
	color: var(--negro) !important;
}



/* CREDITOS */
.creditosRoles {
	width: 100%;
	display: grid;
	grid-template-columns: 1fr 2fr;
	column-gap: 80px;
	row-gap: 25px;
	grid-auto-rows: max-content;
	padding-bottom: 60px;
}

.creditosRoles_nombres h4 {
	font-style: normal;
	padding-bottom: 10px;
}

.creditosLogos {
	width: 100%;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	column-gap: 50px;
	padding-bottom: 60px;
}

.creditosLogos img {
	max-width: 100%;
	margin: 0 auto;
}

/*   Creditos Roda   */

.creditosRoda {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 70px;
	margin-top: 40px;
}

.creditosRoda_columna {
	display: flex;
	flex-direction: column;
	gap: 18px;
}

.creditosRoda h2 {
	font-family: 'EB Garamond', serif;
	font-size: 1.8rem;
	font-weight: 600;
	margin: 28px 0 8px;
	border-bottom: 1px solid rgba(0, 0, 0, 0.25);
	padding-bottom: 8px;
}

.creditoItem h4 {
	font-family: 'EB Garamond', serif;
	font-size: 1.2rem;
	font-weight: 500;
	margin: 2px 0;
}

.creditoItem p,
.descripcionCredito,
.subtituloCredito {
	font-family: 'EB Garamond', serif;
	font-size: 1.05rem;
	line-height: 1.5;
	margin: 4px 0 16px;
}

.descripcionCredito {
	font-style: italic;
}

.agradecimientos h4 {
	margin-bottom: 6px;
}

@media (max-width: 768px) {
	.creditosRoda {
		grid-template-columns: 1fr;
		gap: 30px;
	}
}


/* EMBEDS */
.embedExterno {
	width: 100%;
	min-height: 100vh;
	flex-grow: 1;
}

.embedExterno_iframe {
	min-height: 100vh;
	height: 100vh;
	min-width: 100vw;
	width: 100vw;
}



/* RESPONSIVE QUERIES */
/* Portátiles Pequeños */
@media only screen and (max-width: 1440px) {
	:root {
		--swiper-navigation-sides-offset: 40px;
	}


	/* ESTILOS DE TEXTO */
	h1 {
		font-size: 120px;
		line-height: 120px;
	}

	h2 {
		font-size: 50px;
		line-height: 56px;
	}

	h3 {
		font-size: 30px;
		line-height: 32px;
	}

	h5 {
		font-size: 18px;
	}

	.tituloSitio h2 {
		line-height: 48px;
	}

	.navegacionSecciones h3 {
		font-size: 30px;
		line-height: 32px;
	}

	.headerCompleto .navegacionSecciones h3 {
		font-size: 24px;
		line-height: 24px;
	}


	/* HOME */
	.swiper {
		height: 450px;
	}
}



/* Tablets */
@media only screen and (max-width: 810px) {
	:root {
		--swiper-navigation-sides-offset: 15px;
	}

	/* HEADER */
	.headerCompleto {
		transition: height var(--transicion_lenta) linear;
		height: 85px;
	}

	.headerSencillo,
	.headerCompleto_fondo {
		grid-template-columns: 3fr 0.5fr;
		grid-template-rows: 1fr 3fr;
		padding: 15px;
	}

	.headerCompleto .navegacionSecciones {
		display: none;
	}



	/* MENU MOVIL */
	.toggleMenuMovil {
		display: block;
		text-align: center;
		cursor: pointer;
	}

	.toggleMenuMovil h3 {
		padding-top: 10px;
		text-align: center;
	}

	.toggleMenuMovil .linkBlanco {
		color: var(--blanco);
	}

	.navegacionSeccionesMovil {
		display: block;
		grid-column-start: 1;
		grid-area: 2 / 1 / 2 / 3;
		color: var(--blanco);
		text-align: left;
		transition: opacity var(--transicion_rapida) linear;
		opacity: 0.0;
	}

	.navegacionSeccionesMovil h3 {
		padding: 5px 0;
	}


	/* BLOQUES DE TEXTO */
	.bloqueTexto_parrafoUnaColumna,
	.bloqueTexto_parrafoDosColumnas {
		width: 100%;
		padding: 0 0 40px 0;
	}

	.bloqueTexto_parrafoDosColumnas p {
		columns: 1;
	}

	.creditosTresColumnas {
		grid-template-columns: 1fr;
		row-gap: 34px;
	}


	/* HOME */
	.swiper {
		height: 750px;
	}
}

/*   IMG Home Responsive   */
.marcoImagen_img_movil {
	display: none;
}

/* Movil */
@media only screen and (max-width: 480px) {
	:root {
		--swiper-navigation-sides-offset: 0;
	}

	.marcoImagen_img {
		display: none;
	}

	.marcoImagen_img_movil {
		display: block;
	}

	.fondoGris {
		background-image: url(../recursos/img/roda-responsive.png);
		background-size: contain;
		background-position: center center;
		background-repeat: no-repeat;
		position: relative;
		overflow: hidden;
	}

	/* ESTILOS DE TEXTO */
	p {
		font-size: 20px;
		line-height: 30px;
	}

	h1 {
		font-size: 60px;
		line-height: 50px;
	}

	h2 {
		font-size: 36px;
		line-height: 40px;
	}

	h3 {
		font-size: 24px;
		line-height: 30px;
	}

	h5 {
		font-size: 12px;
	}



	/* CONTENEDORES PRINCIPALES */
	.contenidoTextoImagen {
		padding: 40px 5%;
		background-color: var(--blanco);
	}



	/* BLOQUES DE TEXTO */
	.bloqueTexto_frase {
		padding-bottom: 40px;
	}

	.bloqueTexto_fraseCentro {
		padding-bottom: 60px;
	}

	.bloqueTexto_parrafoUnaColumna,
	.bloqueTexto_parrafoDosColumnas {
		width: 100%;
		padding: 0 0 40px 0;
	}

	.bloqueTexto_parrafoDosColumnas p {
		columns: 1;
	}

	.creditosRoles {
		grid-template-columns: 1fr;
		row-gap: 20px;
	}

	.creditosRoles h4 {
		font-size: 24px;
		line-height: 24px;
	}

	.creditosRoles_nombres h4 {
		padding-bottom: 20px;
	}

	.creditosRoles_nombres {
		padding-bottom: 10px;
	}

	.creditosLogos {
		grid-template-columns: 1fr;
		row-gap: 50px;
	}



	/* IMAGENES */
	.imagenDerecha,
	.imagenIzquierda {
		grid-template-columns: 1fr;
		row-gap: 15px;
		padding: 0 0 30px 0;
	}

	.pieDeFoto_derecha,
	.pieDeFoto_izquierda {
		text-align: left;
		justify-content: start;
		grid-row: 2;
	}



	/* HEADER */
	.headerCompleto {
		transition: height var(--transicion_lenta) linear;
		height: 85px;
	}

	.headerSencillo,
	.headerCompleto_fondo {
		grid-template-columns: 3fr 0.5fr;
		grid-template-rows: 1fr 3fr;
		padding: 15px;
	}

	.headerCompleto .navegacionSecciones {
		display: none;
	}



	/* MENU MOVIL */
	.toggleMenuMovil {
		display: block;
		text-align: center;
		cursor: pointer;
	}

	.toggleMenuMovil h3 {
		padding-top: 10px;
		text-align: center;
		color: #fff;
	}

	.toggleMenuMovil .linkBlanco {
		color: var(--blanco);
	}

	.navegacionSeccionesMovil {
		display: block;
		grid-column-start: 1;
		grid-area: 2 / 1 / 2 / 3;
		color: var(--blanco);
		text-align: center;
		transition: opacity var(--transicion_rapida) linear;
		opacity: 0.0;
	}

	.navegacionSeccionesMovil h3 {
		padding: 5px 0;
		margin-right: 10px;
	}

	/*   ////   */

	#linksMenuMovil {
		display: flex !important;
		opacity: 1;
		flex-wrap: wrap;
		justify-content: center;
	}

	.navegacionSeccionesMovil a {
		display: inline-block;
		padding: 17px 16px;
		border-radius: 15px;
		backdrop-filter: blur(4px);
		text-decoration: none;
		transition: .25s;
		box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
		background-color: #f29faa6e;
		text-shadow: 0 2px 6px rgba(0, 0, 0, 0.45);
	}

	.navegacionSeccionesMovil a:hover {
		background: #f29faa6e;
		color: #111 !important;
	}

	#linksMenuMovil {
		display: none;
	}



	/* HOME"*/
	.textosIntro,
	.textosOutro {
		padding: 25px;
		grid-template-rows: repeat(3, 1fr);
	}

	.textosIntro_titulo h1 {
		font-size: 60px;
		line-height: 60px;
	}

	.swiper {
		margin: 40px 0 0 0;
		height: 500px;
	}

	.sliderSecciones .marcoImagen_base {
		margin-bottom: 15px;
	}
}