/**** Reset ***/
html {
	scroll-behavior: smooth;
}

body,
html,
div,
blockquote,
img,
label,
p,
h1,
h2,
h3,
h4,
h5,
h6,
pre,
ul,
ol,
li,
dl,
dt,
dd,
form,
a,
fieldset,
input,
th,
td {
	margin: 0;
	padding: 0;
	border: 0;
	outline: none;
}

/*
==============================================
Variables CSS
==============================================
*/

:root {
	--color-negro: #434343;
	--color-rojo: #ed3237;
	--color-verde: #00ada9;
	--color-gris-claro: #bebebe;
}

.h1,
.h2,
.h3,
.h4,
.h5,
.h6,
h1,
h2,
h3,
h4,
h5,
h6 {
	font-weight: 600;
}

.f6 {
	font-size: 6px;
}

/****  Fin Reset ***/
body {
	font-family: 'Times New Roman', Times, serif;
	font-weight: 500;
	font-style: normal;
	color: var(--color-negro);
}

p {
	margin-bottom: 20px;
	font-weight: 400;
	font-size: 17px;
}

img {
	max-width: 100%;
}


.titleStyle {
	color: var(--color-negro);
	text-align: center;
	font-size: 55px;
	font-weight: bold;
	font-family: 'Times New Roman', Times, serif;
}

.titleStyle span {
	display: block;
	color: var(--color-negro);
	font-weight: 500;
	font-size: 30px;
}

.subtitleStyle {
	text-align: center;
	font-size: 40px;

}

.texto-resaltado {
	text-align: center;
	font-size: 23px;
	color: var(--color-rojo);
}

.titleStyle-blog {
	color: var(--color-negro);
	text-align: center;
	font-size: 50px;
	font-weight: bold;
	font-family: 'Times New Roman', Times, serif;

	&:hover {
		color: var(--color-rojo);
		text-decoration: none;

	}
}

.linkDecoration {
	text-decoration: none;

	&:hover {
		text-decoration: none;
	}
}

.blanco {
	color: #fff !important;
}

.negro {
	color: var(--color-negro) !important;
}

.rojo {
	color: var(--color-rojo) !important;
}

.verde {
	color: var(--color-verde) !important;
}

/*Alertas Ajax*/
#alertLoad {
	position: fixed;
	bottom: 8px;
	right: 6px;
	background: #27ae60;
	border: 2px solid #27ae60;
	z-index: 9999;
	padding: 2px 8px;
	border-radius: 3px;
	border: 2px solid #209143;
	display: none;
}

#alertLoad span {
	color: #FFF;
	font-size: 21px;
	display: inline-block;
	float: left;
	margin-top: 13px;
}

#alertLoad img {
	width: 48px;
}

.alertFail,
.alertOk {
	display: none;
	position: fixed;
	bottom: 15px;
	width: 80%;
	left: 0px;
	right: 0px;
	margin: auto;
	background: #c0392b;
	z-index: 99999999;
	padding: 2px 8px;
	border-radius: 3px;
	padding: 11px;
	border: 1px solid rgb(119, 0, 0);
}

.alertFail {
	visibility: visible;
}

.alertOk {
	background: #27AE60;
	border: 1px solid #3B694F;
}

.alertFail span,
.alertOk span {
	color: #FFF;
	font-size: 21px;
	display: block;
	text-align: center;
}

.woowRequireFail {
	border: 1px solid #D60000 !important;
	box-shadow: inset 0px 0px 9px -3px #FF0303 !important;
	-webkit-box-shadow: inset 0px 0px 9px -3px #FF0303 !important;
	-moz-box-shadow: inset 0px 0px 9px -3px #FF0303 !important;
	-ms-box-shadow: inset 0px 0px 9px -3px #FF0303 !important;
	-o-box-shadow: inset 0px 0px 9px -3px #FF0303 !important;
}

.woowNavBreadcrumb {
	overflow: auto;
	margin: 0px;
	margin-bottom: 15px;
	padding: 2px 0px;
}

.woowNavBreadcrumb ol li {
	float: left;
	list-style: none;
}

.woowNavBreadcrumb ol li:after {
	content: '❯';
	padding: 0px 8px;
	color: var(--color-rojo);
	font-weight: 600;
}

.woowNavBreadcrumb ol li:last-child:after {
	content: '';
	display: none;
}

.woowNavBreadcrumb ol li a span {
	font-size: 14px;
	color: var(--color-negro);
}

.woowNavBreadcrumb ol li a span:hover {
	color: var(--color-rojo);
	text-decoration: none;
	transform: scale(1.1);
}

.woowNavBreadcrumb ol li b {
	opacity: 0;
	position: absolute;
}

.woowTheContent {
	height: auto;
	font-size: 1.2rem;
}

.woowTheContent h1 {
	font-size: 32px;
	margin: 25px 0px 0px;
}

.woowTheContent h2 {
	font-size: 26px;
	margin: 25px 0px 15px;
	font-weight: 600;
}

.woowTheContent h3 {
	font-size: 24px;
	margin: 25px 0px 0px;
}

.woowTheContent h4 {
	font-size: 22px;
	margin: 25px 0px 0px;
}

.woowTheContent h5 {
	font-size: 20px;
	margin: 25px 0px 0px;
}

.woowTheContent h6 {
	font-size: 18px;
	margin: 25px 0px 0px;
}

.woowTheContent p {
	margin: 8px 0px 10px;
}

.woowTheContent img {
	max-width: 100%;
	height: auto;
}

.woowTheContent ul,
.woowTheContent ol {
	padding-left: 40px;
}

.woowTheContent ul {
	list-style: inherit;
}

.woowTheContent ol {
	list-style: auto;
}

.woowTheContent ul li,
.woowTheContent ol li {
	padding-bottom: 15px;
}

.woowTheContent blockquote {
	border-color: var(--color-azul-claro);
	border-left-style: solid;
	border-left-width: 7px;
	padding-left: 20px;
	margin-bottom: 1em;
	margin-right: 1em;
	line-height: 1.5em;
	color: #919191;
}

.woowTheContent a {
	color: var(--color-link);
	text-decoration: underline;
}

.centerVertical {
	position: relative;
	top: 50%;
	transform: translateY(-50%);
}

/* ANIMACIONES */
.bounce {
	animation: bounce 2s ease infinite;
}

@keyframes bounce {
	70% {
		transform: translateY(0%);
	}

	80% {
		transform: translateY(-15%);
	}

	90% {
		transform: translateY(0%);
	}

	95% {
		transform: translateY(-7%);
	}

	97% {
		transform: translateY(0%);
	}

	99% {
		transform: translateY(-3%);
	}

	100% {
		transform: translateY(0);
	}
}

@keyframes border-transform {

	0%,
	100% {
		border-radius: 63% 37% 54% 46% / 55% 48% 52% 45%;
	}

	14% {
		border-radius: 40% 60% 54% 46% / 49% 60% 40% 51%;
	}

	28% {
		border-radius: 54% 46% 38% 62% / 49% 70% 30% 51%;
	}

	42% {
		border-radius: 61% 39% 55% 45% / 61% 38% 62% 39%;
	}

	56% {
		border-radius: 61% 39% 67% 33% / 70% 50% 50% 30%;
	}

	70% {
		border-radius: 50% 50% 34% 66% / 56% 68% 32% 44%;
	}

	84% {
		border-radius: 46% 54% 50% 50% / 35% 61% 39% 65%;
	}
}

/*
==============================================
Header
==============================================
*/
.navNuevo {
	position: absolute;
	z-index: 999;
	width: 100%;
	background-image: linear-gradient(0deg, rgba(122, 145, 153, 0) 25%, rgba(0, 0, 0, 0.5813624030114395) 75%, rgba(0, 0, 0, 0.6) 79%);
}

.navNuevo .navbar-toggler {
	border-color: #777;
}

.navNuevo .navbar-nav {
	text-align: center;
	padding: 0px 20px;
}

.navNuevo .navbar-nav li {
	padding: 0px 12px;
	border-right: solid 1px #fff;

	&:last-child {
		border-right: none;
	}
}

.navNuevo .navbar-nav .menu-item a {
	color: #fff;
	font-weight: 500;
	font-size: 15px;
	text-transform: uppercase;
}


.navNuevo .navbar-nav .menu-item.current-menu-item a,
.navNuevo .navbar-nav .menu-item a:hover {
	color: #fff;
	background: var(--color-rojo);
}

.navbar-collapse.show {
	transition: background-color 0.3s ease-in;
	background: rgb(0, 0, 0);
	background: linear-gradient(0deg, rgba(0, 0, 0, 0.639093137254902) 11%, rgba(0, 0, 0, 0.7875525210084033) 26%, rgba(0, 0, 0, 0.4318102240896359) 62%, rgba(0, 0, 0, 0.014443277310924318) 97%);


}

/*
==============================================
Footer
==============================================
*/

.footerMenu ul {
	list-style: none;
}

.footerMenu ul li {
	display: inline-block;
	text-transform: uppercase;
}

.footerMenu ul li.current_page_item a {
	color: var(--color-rojo);
}

.footerMenu ul li a {
	color: #777;
	padding: 0px 10px;
	font-size: 13px;
	font-weight: 500;
}

.footerHome {
	background: #efefef;
}

.footerDatos {
	color: #434343;
	font-weight: bold;
}

.footerDatos article {
	font-size: 13px;
}

.footerDatos article strong {
	font-size: 16px;
	font-weight: 600;
	display: block;
	padding-bottom: 5px;
}

.footerDatos article .listSimple {
	list-style: none;
}

.footerDatos article .listSimple li {
	display: block;
	padding: 0px 10px 8px;
}

.footerDatos article .listSimple li a {
	color: var(--color-dorado);
	font-size: 15px;
}

.footerDatos article .listSimple li span {
	font-weight: 600;
}

/*
==============================================
Home
==============================================
*/

.swiperHome .swiper-button-prev:after,
.swiperHome .swiper-button-next:after {
	color: #fff;
}

.swiperHome .swiper-pagination-bullet-active {
	background: #fff;
}

.swiperHome .swiper-slide {
	position: relative;
}

.swiperHome .swiper-slide .textos-banner {
	position: absolute;
	top: 50%;
	left: 7%;
	bottom: 0;
	z-index: 2;
	color: #fff;

	& h2 {
		color: #fff;
		text-align: left;
	}

	& p {
		font-size: 20px;
		font-weight: bold;
		font-family: 'Times New Roman', Times, serif;
	}

}

.wow-Home-nosotros-texto {
	position: relative;
}

.wow-Home-nosotros-texto a {
	position: absolute;
	bottom: -50%;
	right: 2%;
	color: #fff;
	font-size: 25px;
	text-decoration: none;
	font-style: italic;

	&::after {
		content: "➜";
		font-style: normal;
		background-color: #fbb03b;
		border-radius: 5px;
		font-size: 17px;
		padding: 4px;
		margin-left: 12px;
	}
}

.wow-Home-nosotros-contadores .wow-num-contadores {
	font-size: 100px;
	color: #fff;

	& .counter {
		position: relative;

		&::before {
			content: "+";
			font-size: 60px;
			position: absolute;
			top: 0;
			left: -40px;
			font-weight: bold;
		}
	}
}

.wow-Home-nosotros-contadores .btnLink {
	color: var(--color-verde);
	font-size: 20px;
	font-weight: 500;
	cursor: pointer;
	border: 2px solid var(--color-verde);
	border-radius: 7px;
	padding: 7px 20px;
	transition: 0.4s ease all;
	display: inline-block;
}

.btnLink i {
	font-size: 20px;
	font-weight: 600;
}

.btnLink:hover {
	color: inherit;
	text-decoration: none;
	border-radius: 15px;
}

.linkSimple {
	color: var(--color-verde);
	font-size: 20px;
	font-weight: 500;
	cursor: pointer;
	display: inline-block;
}

.linkSimple i {
	font-size: 22px;
	font-weight: 600;
	vertical-align: middle;
}

.linkSimple:hover {
	color: inherit;
	text-decoration: none;
	border-radius: 15px;
}

.textura {
	background-position: center center;
	background-size: contain;
	background-repeat: no-repeat;
}

.woow-slider-soluciones {
	position: relative;
}

.woow-slider-soluciones .swiper-button-prev {
	top: 50%;
	transform: translateY(-50%);
	left: -5%;
}

.woow-slider-soluciones .swiper-button-next {
	top: 50%;
	transform: translateY(-50%);
	right: -5%;
}

.woow-slider-soluciones .swiper-button-prev:after,
.woow-slider-soluciones .swiper-button-next:after {
	color: var(--color-negro);
}

.cardServicio {
	position: relative;
	transition: 1s ease all;
}

.cardServicio * {
	transition: 1s ease all;
}

.cardServicio .wrap {
	position: absolute;
	width: 100%;
	z-index: 999;
	height: 100%;
	top: 0px;
	bottom: 0px;
	max-height: 100%;
	text-align: center;
	border-radius: 180px;
	transition: border-radius ease 1s !important;

	&.woow-fondo-card-dinamico {
		/* Color dinámico definido en línea */
		background-color: var(--base-color);
	}
}

.cardServicio:hover {
	& .wrap {
		border-radius: 80px;

		&.woow-fondo-card-dinamico {
			background-color: var(--hover-color);
		}
	}

	& .woow-img-tintada {
		border-radius: 80px;
	}
}


.cardServicio .wrap .titleWrap {
	color: #fff;
	font-size: 25px;
	font-weight: 600;
}

.cardServicio .wrap .titleWrap p {
	display: none;
	font-size: 16px;
	font-weight: 400;
	color: #fff;
	max-width: 80%;
	margin: 0px auto;
	padding-top: 10px;
}

.cardServicio .contentLink {
	display: none;
	left: 0px;
	right: 0px;
}

.cardServicio .contentLink .btnLink {
	background: var(--color-rojo);
	color: #fff;
	padding: 7px 15px;
	font-size: 14px;
}

.cardServicio .contentLink .btnLink i {
	font-size: 14px;
}

.cardServicio .woow-img-tintada {
	border-radius: 180px;
	height: 100%;
	width: 100%;
	transition: all ease 1s !important;
	max-height: 500px;
}

.CTA-Home {
	font-weight: 400;
	font-size: 22px;
	font-style: italic;
	color: var(--color-rojo);

	& a {
		text-decoration: none;
		color: var(--color-rojo);
	}

	& span {
		color: #FFF;
		background-color: #fbb03b;
		border-radius: 5px;
		font-style: normal;
		font-size: 17px;
		padding: 4px;
		margin-left: 12px;
	}

}


.cardEquipo {
	text-align: center;
}

.cardEquipo img {
	border-radius: 50%;
	display: inline-block;
	margin-bottom: 20px;
}

.cardEquipo strong {
	display: block;
	text-align: center;
}

.cardEquipo span {
	display: block;
	text-align: center;
	font-weight: 400;
}

.noticias {}

.noticias .captionImg {
	position: relative;
	text-align: center;
}

.noticias .captionImg img {
	width: 100%;
	min-height: 300px;
	object-fit: cover;
}



.noticias .captionImg .titleCap {
	text-align: center;
	font-size: 20px;
	font-weight: bold;
	padding-top: 15px;
	line-height: 25px;
}

.noticias .captionImg a {
	color: inherit;
	text-align: center;
}

.BTN-noticias {
	color: #959595 !important;
	font-size: 20px;
	text-decoration: none;

	& span {
		color: black;
	}

	&:hover {
		text-decoration: none;
		color: var(--color-rojo);
	}
}


.woow-slider-clientes {
	position: relative;
}

.woow-slider-clientes {
	top: 50%;

	& .swiper-button-prev {
		left: -5%;
	}

	& .swiper-button-next {
		right: -5%;
	}
}


.woow-slider-clientes .swiper-button-prev:after,
.woow-slider-clientes .swiper-button-next:after {
	content: "\f060";
	font-family: "Font Awesome 5 Pro";
	color: var(--color-negro);
	font-size: 32px;
}

.woow-slider-clientes .swiper-button-next:after {
	content: "\f061";
}


/*
==============================================
page servicios
==============================================
*/
.woow-banner-servicios {
	position: relative;
}

.woow-banner-servicios .banner-servicios-img img {
	width: 100%;
}

.woow-banner-servicios .banner-servicios-text {
	position: absolute;
	top: 30%;
	width: 35%;
	left: 6%;
	color: #fff;
	font-family: "Times New Roman";

	& p {
		font-size: 20px;
	}

	& .font-weight-bold {
		font-size: 30px;
	}

	& .wow-num-contadores {
		font-size: 120px;
		font-weight: bold;
		margin-left: 50px;
		position: relative;
	}

	& .sufijoCounter {
		content: "";
		font-size: 60px;
		position: absolute;
		top: 0;
		left: -40px;
		font-weight: bold;
	}
}

.woow-servicios .swiperWoowSoluciones .cardServicio {
	transform: scale(0.65);
}

.woow-servicios .swiperWoowSoluciones .cardServicio * {
	transition: background-color 0s ease;
}

.woow-servicios .swiperWoowSoluciones .swiper-slide-active .wrap {
	background: none;
	transition: none;
	position: initial;
	border-radius: 180px;
}

.woow-servicios .swiperWoowSoluciones .swiper-slide-active .cardServicio {
	transform: scale(0.8);

	& img {
		filter: drop-shadow(-2.862px 14.724px 20px rgba(0, 0, 0, 0.25));
	}
}

.woow-servicios .swiperWoowSoluciones .swiper-slide-active .wrap .centerVertical {
	background: none;
	transform: translateY(0);

	& img {
		display: none;
	}

	& .titleWrap {
		font-size: 34px;
		color: #434343;
		font-weight: bold;
		text-align: center;
		width: 1000px;
		margin-left: -315px;
		margin-top: 50px;
	}
}



/*
==============================================
page nosotros
==============================================
*/
.woow-nosotros-sec-presencia .woow-cont-mapa {
	margin-top: -8%;
}

/*
==============================================
page blog
==============================================
*/
.woow-banner-blog {
	position: relative;
}

.woow-banner-blog .banner-blog-img img {
	width: 100%;
	max-height: 350px;
	object-fit: cover;
	position: relative;
}

.woow-banner-blog.woow-banner-single-blog .banner-blog-img {
	position: relative;
	object-fit: cover;

	&::after {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		background: var(--color-rojo);
		opacity: 0.6;
	}
}

.woow-banner-blog.woow-banner-single-blog .banner-blog-text {
	top: 50%;
	translate: 0 -50%;
}

.woow-banner-blog .banner-blog-text {
	position: absolute;
	top: 50%;
	width: 50%;
	left: 25%;
	color: #fff;
	font-family: "Times New Roman";

	& p {
		font-size: 20px;
	}

	& .font-weight-bold {
		font-size: 30px;
	}

	& .wow-num-contadores {
		font-size: 120px;
		font-weight: bold;
		margin-left: 50px;
	}

	& .counter {
		position: relative;

		&::before {
			content: "+";
			font-size: 60px;
			position: absolute;
			top: 0;
			left: -40px;
			font-weight: bold;
		}
	}
}





/*
==============================================
page nuestros proyectos
==============================================
*/

.cont-proyectos {
	& .nav-tabs {
		border: none;

		& .nav-item {

			& .nav-link.active {
				border: none;
				border-radius: 0px;
				color: var(--color-rojo);
				font-size: 18px;
				border-bottom: solid 2px var(--color-rojo);
			}

			& .nav-link {
				color: var(--color-negro);
			}

		}
	}

	& .tab-content .tab-pane {
		& .cardContect {
			border: none;
			border-radius: 0px;
			/* min-height: 810px; */
			background-color: #f0f0f0;
			cursor: pointer;

			&:hover {
				transform: scale(1.03);
				transition: transform 0.3s ease;
				box-shadow: 10px 10px 20px -13px rgba(0, 0, 0, 0.75);
			}

			& img {
				object-fit: cover;
			}

			& .card-header-proyecto {
				color: var(--color-verde);
				text-transform: uppercase;
				font-weight: normal;
				text-wrap: balance;
				min-height: 90px;

				& h4 {
					font-size: 18px;
				}
			}
		}
	}
}

.swiperClientes {
	position: relative;
}

.swiperClientes .swiper-button-prev {
	position: absolute;
	top: 50%;
	left: -35px;
}

.swiperClientes .swiper-button-next {
	position: absolute;
	top: 50%;
	right: -35px;
}

.swiperClientes .swiper-button-prev:after {
	background-image: url(../images/pages/quienes-somos/Flecha.png);
	color: transparent;
	background-size: contain;
}

.swiperClientes .swiper-button-next:after {
	background-image: url(../images/pages/quienes-somos/Flecha.png);
	color: transparent;
	transform: rotate(180deg);
	background-size: contain;

}

.swiperClientes .swiper-slide {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	height: 200px;
	width: 100%;

	& img {
		object-fit: contain;
	}

}

.popup-servicios {

	& .modal-title {
		color: var(--color-verde);
		text-wrap: pretty;
	}

	& .modal-footer {
		border: none;
		background-image: url(../images/pages/servicios/Fondo-texto-descriptivo.jpg);

		& .btn {
			background-color: var(--color-rojo);
			border: none;

			&:hover {
				transform: scale(1.2);
				transition: transform 0.3s ease;
			}
		}
	}

}

/*
==========================================
 Page sigle blog
==========================================
*/

.noticias {
	& .blog-img-otr-noticias {
		min-height: 350px;
		object-fit: cover;
	}
}

/*
==========================================
 Page contactanos
==========================================
*/


.FormCotactato {
	background-color: #fff;
	border-radius: 10px;
	-webkit-box-shadow: 0px 0px 20px 1px rgba(0, 0, 0, 0.2);
	-moz-box-shadow: 0px 0px 20px 1px rgba(0, 0, 0, 0.2);
	box-shadow: 0px 0px 20px 1px rgba(0, 0, 0, 0.2);
}

.FormCotactato input {
	border: none;
	border-radius: 1rem;
	box-shadow: 0 0.4rem 10px 2px #dfd9d98b;
	cursor: pointer;

	&::placeholder {
		text-align: center;
		color: var(--color-negro);
		font-size: 1.2rem;
		font-weight: 400;
		transition: 0.4s ease all;
		opacity: 0.5;
	}

	&:focus {
		outline-color: #ffc107;
		box-shadow: 0 0.4rem 10px .2rem #ffc10740;
	}
}

/* From Uiverse.io by PriyanshuGupta28 */
.form-check input[type="checkbox"] {
	display: none;
}

.form-check .terms-label {
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
}

.form-check .terms-label .label-text {
	margin-left: 10px;

}

.form-check .checkbox-svg {
	width: 20px;
	height: 20px;
}

.form-check .checkbox-box {
	fill: #ffc107;
	stroke: #000;
	stroke-dasharray: 800;
	stroke-dashoffset: 800;
	transition: stroke-dashoffset 0.6s ease-in;
}

.form-check .checkbox-tick {
	stroke: #000;
	stroke-dasharray: 172;
	stroke-dashoffset: 172;
	transition: stroke-dashoffset 0.6s ease-in;
}

.form-check input[type="checkbox"]:checked+.terms-label .checkbox-box,
.form-check input[type="checkbox"]:checked+.terms-label .checkbox-tick {
	stroke-dashoffset: 0;
}

.woow-slider-categoria-proyectos {
	position: relative;
}

.woow-slider-categoria-proyectos {
	top: 50%;

	& .swiper-button-prev {
		left: -5%;
	}

	& .swiper-button-next {
		right: -5%;
	}
}


.woow-slider-categoria-proyectos .swiper-button-prev:after,
.woow-slider-categoria-proyectos .swiper-button-next:after {
	color: var(--color-negro);
	font-size: 32px;
}

.woow-slider-categoria-proyectos .swiper-slide img {
	object-fit: cover;
	max-height: 390px;
}