body{
	font-family: 'Open Sans';
	padding-top: 6rem;
}

.loading{
	position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0,0,0,0.8);
    z-index: 10000;
    overflow: hidden;
	color: #fff;
    align-items: center;
	display:none;
}

.loading.active{
	display:flex;
}

.loading > h3{
	font-size:3em;
	font-weight:bold;
	width:100%;
}

.bg-azul{
	background-color:#003a70;
}

.bg-azul-cielo{
	background-color:#45b8f4;
}

.bg-gris{
	background-color:#f7f4f4;
}

.bg-imggris{
	background-image:url("../img/fondo/fondo-hielo.jpg");
	background-repeat:no-repeat;
	background-size:cover;
	background-position:center;
}

.bg-contacto{
	background-image:url("../img/fondo/contacto.jpg");
	background-repeat:no-repeat;
	background-size:cover;
	background-position:center;
}

.bg-gracias{
	background-image:url("../img/fondo/gracias.jpg");
	background-repeat:no-repeat;
	background-size:cover;
	background-position:center;
	height: 92vh;
	position:relative;
}

.img-navbar{
	width: 15rem;
}

.navbar-toggler:focus {
    box-shadow: 0 0 0 0.15rem #fff;
}

.navbar-nav .nav-link {
    font-weight:600;
}

.contacto-menu{
	position: absolute;
    bottom: 2rem;
    right: 10.5rem;
    color: #fff;
    font-weight: bold;
    font-size: 1rem;
}

.contacto-menu span{
	color:#45b8f4;
}

.link-menu{
	text-decoration:none;
	color:#fff;
}

.link-menu:hover,.link-menu:focus,.link-menu:active{
	text-decoration:none;
	color:#fff;
}

.carousel-caption{
    right: auto;
    bottom: auto;
    left: 50%;
    top: 50%;
	transform: translate(-50% , -50%);
    -webkit-transform: translate(-50%, -50%);
}

.caption-right{
    right: 5%;
    left: auto;
    transform: translate(0% , -50%);
    -webkit-transform: translate(0%, -50%);
}

.caption-left{
    right: auto;
    left: 5%;
    transform: translate(0% , -50%);
    -webkit-transform: translate(0%, -50%);
}

.carousel-indicators [data-bs-target] {
    width: 10px;
    height: 10px;
    border-radius: 50%;
	background-color: #003a70;
}

.carousel-control-prev-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23'%3e%3cpath d='M11.354 1.646a.5.5 0 0 1 0 .708L5.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z'/%3e%3c/svg%3e");
}

.carousel-control-next-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23'%3e%3cpath d='M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
}

.carousel-control-next, .carousel-control-prev {
    width: 5%;
}

.title-slide{
	color:#003a70;
	font-size:2rem;
	font-weight:400;
}

.title-slide span{
	font-weight:bold;
}

.btn-slider{
	background-color:#003a70;
	color:#fff;
	font-weight:bold;
	font-size:1.5rem;
}

.btn-slider:hover,.btn-slider:active,.btn-slider:focus,.btn-slider:focus-visible{
	background-color:#003a70!important;
	color:#fff!important;
}

.title-section{
	color:#003a70;
	font-size:2rem;
	font-weight:400;
}

.title-section span{
	font-weight:bold;
}

.text-section{
	color:#003a70;
	font-size:1rem;
	font-weight:600;
}

.text-section span{
	font-weight:bold;
}

.text-nosotros{
	color:#fff;
	font-size:1rem;
	font-weight:300;
}

.text-nosotros span{
	font-weight:bold;
}

.content-servicios{
	position:absolute;
	top:0;
	right:0;
}

.list-servicios{
	list-style-type:  none;
}

.list-servicios li{
	display:flex;
	color:#003a70;
	font-size:1.25rem;
	font-weight:400;
}

.list-servicios li span{
	font-weight:bold;
}

.list-servicios li img {
	height: 25px;
	width: 25px;
	margin-top: 4px;
}

.text-contacto{
	color:#003a70;
	font-size:1.25rem;
	font-weight:600;
}

.text-contacto span{
	font-weight:bold;
}

.input-contacto,.texarea-contacto{
	background-color: transparent;
    border: none;
    border-bottom: 1px solid #fff;
    border-radius: unset;
	color: #fff;
}

.texarea-contacto::placeholder {
	color:#fff;
	opacity:0.6;
}

.input-contacto::placeholder {
	color:#fff;
	opacity:0.6;
	font-size:0.8rem;
}

.form-floating>label {
    opacity:0.6;
}

.input-contacto:focus ,.texarea-contacto:focus{
    color: #fff;
    background-color: transparent;
    border-color: #fff;
    outline: 0;
    box-shadow: none;
}

.btn-contacto{
	color: #fff;
    background-color: #45b8f4;
	font-size:2rem;
	font-weight:bold;
	border-radius:unset;
}

.btn-contacto:focus,.btn-contacto:active,.btn-contacto:hover,.btn-contacto:focus-visible,.btn-contacto:visited{
	color: #fff!important;
    background-color: #45b8f4!important;
}

.text-ubicacion{
	color:#fff;
	font-size:1rem;
	font-weight:300;
	cursor: pointer;
}

.text-ubicacion span{
	font-weight:bold;
}

.link-telefono{
	color: #fff;
    text-decoration: none;
    font-size: 2rem;
    font-weight: bold;
}

.link-telefono:hover,.link-telefono:active,.link-telefono:focus,
.link-footer:hover,.link-footer:active,.link-footer:focus,
.link-ja:hover,.link-ja:active,.link-ja:focus{
	color: #fff;
    text-decoration: none;
}

.text-footer{
	color: #fff;
    text-decoration: none;
    font-size: 0.8rem;
    font-weight: 400;
}

.link-ja{
	color: #fff;
    text-decoration: none;
}

.link-footer{
	color: #fff;
    text-decoration: none;
    font-size: 1rem;
    font-weight: bold;
}

.title-tecnologia{
	color:#003a70;
	font-size:2.25rem;
	font-weight:400;
}

.title-tecnologia span{
	font-weight:bold;
}

.mapa{
	height:25rem
}

label small{
	font-size:0.6rem;
}

.content-whats{
	position:fixed;
	top:7rem;
	right:0em;
	z-index:100;
	cursor:pointer;
}

.logo-whats{
	width: 4rem;
}

.content-telf{
	position:fixed;
	top:13rem;
	right:0em;
	z-index:100;
	cursor:pointer;
}

.error-input{
	color:#fff;
}

.caption-gracias{
	position:absolute;
	bottom:3rem;
	left:3rem;
}

.title-gracias{
	color:#fff;
	font-size:5rem;
	font-weight:bold;
}

.text-gracias{
	color:#fff;
	font-size:2rem;
	font-weight:bold;
}

.label-contacto{
	float: left;
    padding-left: 0.5rem;
    opacity: 0.6;
}

.nav-icon{
	width: 3rem;
}

@media (max-width: 1399.98px) {
	.list-servicios li {
		font-size: 1rem;
	}
	
	.list-servicios li img {
		height: 20px;
		width: 20px;
	}
}

@media (max-width: 1199.98px) {
	.title-slide,.title-section,.title-tecnologia{
		font-size:2rem;
	}

	.btn-slider{
		font-size:1.5rem;
	}
	
	.list-servicios li{
		font-size:1rem;
	}
	
	.list-servicios li img {
		height: 20px;
		width: 20px;
	}
}

@media (max-width: 991.98px) {
	body{
		padding-top: 6.2rem;
	}
	.img-navbar {
		width: 15rem;
	}
	
	.title-slide{
		font-size:1.75rem;
	}

	.btn-slider{
		font-size:1.25rem;
	}
	
	.text-section,.text-nosotros{
		font-size:1rem;
	}
	
	.text-contacto{
		font-size:1.25rem;
	}
	
	.list-servicios li{
		font-size:0.8rem;
	}
	
	.list-servicios li img {
		height: 15px;
		width: 15px;
	}
	
	.link-telefono {
		font-size: 1.5rem;
	}
	
	.title-gracias{
		font-size:4rem;
	}

	.text-gracias{
		font-size:1.5rem;
	}
}

@media (max-width: 767.98px) {
	.title-slide,.title-section,.title-tecnologia{
		font-size:1.5rem;
	}

	.btn-slider{
		font-size:1rem;
	}
	
	.content-servicios{
		top: auto;
		bottom: 0;
	}
	
	.arrow-galeria{
		width: 1.5rem;
	}
	
	.contacto-menu{
		position:initial;
	}
}

@media (max-width: 575.98px) {
	body {
		padding-top: 4.9rem;
	}
	
	.img-navbar {
		width: 10rem;
	}
	
	.title-slide{
		font-size:0.8rem;
	}
	
	.title-tecnologia{
		font-size:0.8rem;
	}

	.btn-slider{
		font-size:0.6rem;
	}
	
	.carousel-indicators {
		margin-bottom: 0rem;
	}
	
	.text-section, .text-nosotros{
		font-size:0.7rem;
	}
	
	.text-contacto{
		font-size:0.7rem;
	}
	
	.mapa{
		height:20rem
	}
	
	.link-telefono {
		font-size: 1rem;
	}
	
	.text-footer {
		font-size: 0.6rem;
	}
	
	.link-footer {
		font-size: 0.7rem;
	}
	
	.logo-whats {
		width: 2.5em;
	}
	
	.content-whats {
		top: 7rem;
	}
	
	.content-telf{
		top:10rem;
	}
	
	.contacto-menu {
		font-size: 0.8rem;
	}
	
	.title-gracias{
		font-size:3rem;
	}

	.text-gracias{
		font-size:1rem;
	}
	
	.bg-contacto{
		background-image:url("../img/fondo/contacto_movil.jpg");
	}
	
	.text-ubicacion {
		font-size: 0.7rem;
	}
	
	.content-servicios {
		bottom: 3rem;
	}
}