body {
	font-family: "Montserrat";
	font-size: 14px;
	color: #4f4b6c;
	line-height: 1.15;
	/*background: #eceff5;*/
	background: #fff;
	overflow-x: hidden;
}

h1, h2, h3,h4, h5, h6 {
	margin: 0px;
	font-family: "Montserrat";
}

p {
	margin: 0px;
	font-size: 14px;
	line-height: 24px;
}

.header-nav {
	width: 100%;
	/*min-height: 80px;*/
	z-index: 90;
	position: fixed;
	top: 0px;
	transition: all .3s;
	display: flex;
	align-items: center;
	justify-content: center;
}

.header-nav img {
	width: auto;
   height: auto;
	transition: all .3s;
}

.header-nav-lg {
	min-height: 80px;
   background: transparent;
}

/* .header-nav-lg img {
   display: none;
} */

.header-nav-sm {
   min-height: 80px;
   background: #fff;
   box-shadow: 0px 10px 25px -5px rgba(99,116,139,.4);
}

.header-nav-sm img {
   /* height: 40px; */
}

.header-nav-sm .login {
   border-radius: 0px!important;
}

.nav-options {
	font-family: "Montserrat";
	font-size: 13px;
	font-weight: 700;
	list-style: none;
	margin: 0px;
	padding: 0px;
	display: flex;
	align-items: center;
}

.nav-options a {
	margin-left: 10px;
	text-decoration: none;
	transition: all .3s;
   padding: 10px;
   border: 1px solid transparent;
   border-radius: 3px;
   transition: all .3s;
}

.header-nav-lg .nav-options a {
   color: #fff;
}

.header-nav-lg .nav-options a:hover {
   border: 1px solid #fff;
}

.header-nav-sm .nav-options a {
   color: #4f4b6c;
}

.header-nav-sm .nav-options a:hover {
   border: 1px solid #ff3131;
   color: #ff3131;
}

.nav-options .login {
	background: #4285f4;
	padding: 15px 15px;
	border-radius: 3px;
	transition: all .3s;
	margin-left: 25px;
	cursor: pointer;
}

	.nav-options .login:hover {
		background: #3f51b4;
		color: #fff;
	}

.nav-submenu {
	position: relative;
}

.submenu-login {
	width: 500px;
	min-height: 100px;
	background: #fff;
	border-radius: 5px;
	position: absolute;
	top: 55px;
	right: 0px;
	z-index: 99;
	display: none;
	padding: 20px 30px;
	color: initial;
	box-shadow: 0px 10px 10px -5px rgba(99,116,139,.4);
}

.submenu-login .separador {
	width: 1px;
	height: 100%;
	position: absolute;
	right: 0px;
	top: 0px;
	z-index: 999;
	background: #ccc;
}

.submenu-login .flecha {
	color: #fff;
	position: absolute;
	top: -15px;
	right: 30px;
	font-size: 30px;
	transform: rotate(-90deg);
}

.submenu-layer {
	width: 100%;
	height: 100%;
	position: fixed;
	background: transparent;
	z-index: 95;
	top: 0px;
	left: 0px;
	display: none;
}

/* MENU MOVIL */
.header-nav-movil {
	width: 100%;
	height: 100%;
	position: fixed;
	top: 0px;
	left: -1000px;
	background: #4f4b6c;
	z-index: 999;
	padding: 40px 20px;
	overflow: auto;
	transition: all .5s;
}

.header-nav-movil .nav-options-movil {
	list-style: none;
	padding: 0px;
}

.header-nav-movil .nav-options-movil a {
	list-style: none;
	padding: 0px;
	color: #fff;
	font-size: 16px;
   font-weight: 600;
	text-align: center;
	text-decoration: none;
	transition: all .3s;
}

.header-nav-movil .nav-options-movil a:hover {
	color: #ff3131;
}

.header-nav-movil .nav-options-movil a li {
	margin: 20px 0px;
	font-family: "Montserrat";
}

.header-nav-movil .categoria-menu {
	text-align: center;
	color: #fff;
	opacity: .3;
	font-size: 14px;
	font-family: "Montserrat";
	font-weight: 600;
}

.btn-cerrar-menu {
	position: absolute;
	top: 20px;
	right: 20px;
	cursor: pointer;
	color: #fff;
	font-size: 36px!important;
}

.btn-abrir-menu {
	color: #fff;
	cursor: pointer;
	display: none;
	margin-left: 20px;
	font-size: 36px!important;
}

@media (max-width: 768px) {
   .btn-abrir-menu {
     color: #ff3131;
   }
}

.show-menu {
	left: 0px!important;
}

.overlay {
	width: 100%;
	height: 100vh;
	position: fixed;
	top: 0px;
	left: 0px;
	background: rgba(0,0,0,.5);
	display: none;
	z-index: 99;
}

.transparent {
	background: transparent;
}

.no-scroll {
	overflow: hidden;
}

/*//////////////// BANNER PRINCIPAL ///////////////*/
.banner-principal {
   position: relative;
   width: 100%;
   height: auto;
   /* margin-top: 40px; */
}

@media (max-width: 992px) {
   .banner-principal {
      /* margin-top: 40px; */
   }
}

@media (max-width: 768px) {
	.banner-principal {
      margin-top: 0px;
	}

   .img-principal {
      max-width: 100%;
   }
}

.banner-principal .titulo {
   font-size: 40px;
   font-weight: 700;
   margin-bottom: 20px;
}

.banner-principal .subtitulo {
   font-size: 18px;
   font-weight: 600;
   margin-bottom: 20px;
}

.pleca-top {
   position: absolute;
   top: 0px;
   right: 0px;
   transition: all .3s;
}

.pleca-top-2 {
   position: absolute;
   top: 0px;
   right: 0px;
   transition: all .3s;
}

@media (max-width: 1800px) {
   .pleca-top {
      top: 0px;
      right: -200px;
	}

	.pleca-top-2 {
		top: 0px;
		right: -100px;
	}
}

@media (max-width: 1400px) {
   .pleca-top {
      top: 0px;
      right: -400px;
	}

	.pleca-top-2 {
		top: 0px;
		right: -300px;
	}
}

@media (max-width: 1200px) {
   .pleca-top {
      top: 0px;
      right: -500px;
	}

	.pleca-top-2 {
		top: 0px;
		right: -400px;
	}
}

@media (max-width: 992px) {
   .pleca-top {
      top: 0px;
		right: -700px;
		display: none;
	}

	.pleca-top-2 {
		top: 0px;
		right: -500px;
	}
}

@media (max-width: 768px) {
   .pleca-top {
      display: none;
   }
}

/*//////////////// WRAPPER ///////////////*/
.wrapper {
	/* margin-top: 80px; */
	margin-top: 0px;
}

.section {
	padding: 80px 0px;
	position: relative;
}

/*////////////// SECCION INICIO ////////////////*/
.box {
	width: 100%;
	min-height: 60px;
	background: #fff;
	border-radius: 10px;
	margin-bottom: 15px;
	box-shadow: 0px 10px 25px -5px rgba(99,116,139,.4);
	transition: all .3s;
	padding: 25px 25px;
	position: relative;
}

.box.border {
	border: 1px solid #2e313f!important;
}

.box-header {
	width: 100%;
	height: auto;
	padding: 0px 20px;
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.box-body {
	width: 100%;
	height: auto;
	padding: 0px 20px;
}

.box-footer {
	width: 100%;
	height: auto;
	padding: 0px 20px;
}

/*////////////// BLOQUE NOSOTROS ////////////////*/
.info-nosotros {
   padding: 50px 120px 50px 40px;
   margin: 0px;
}

@media(max-width: 992px) {
   .info-nosotros {
      padding: 40px;
   }
}

.img-nosotros {
   /*margin-top: 40px;*/
   margin-left: -100px;
}

.video-nosotros {
   /*margin-top: 40px;*/
   /* margin-left: -100px; */
   border-radius: 10px;
   box-shadow: 0px 10px 25px -5px rgba(99,116,139,.4);
	background: #fff;
	width: 100%;
	height: auto;
	overflow: hidden;
	margin-top: 140px;
	margin-bottom: 80px;
}

@media(max-width: 992px) {
   .video-nosotros {
		margin-top: 60px;
	}
}

@media(max-width: 768px) {
   .video-nosotros {
		width: 100%;
		height: auto;
		overflow: hidden;
	}
}

/*////////////// BLOQUE PRODUCTOS ////////////////*/
.section-productos {
   padding-right: 60px;
   padding-left: 60px;
}

/* @media (max-width: 1800px) {
   .section-productos {
      padding: 0px 0px;
   }
} */

/*////////////// BLOQUE GOOGLE SUITE ////////////////*/
.section-gsuite {
	background: #f4f5f7;
}

/*////////////// BLOQUE CLIENTES ////////////////*/
.gray-hover {
   filter: grayscale(100%);
   opacity: .6;
   transition: all .3s;
}

.gray-hover:hover {
   filter: none;
   opacity: 1;
}

/*////////////// BLOQUE CONTACTOS ////////////////*/
.box-contacto {
   padding: 10px 25px;
   min-height: 20px;
   border-radius: 50px;
   margin-bottom: 10px;
   position: relative;
}

.box-contacto-textarea {
   padding: 15px 25px;
   min-height: 20px;
   border-radius: 20px;
   margin-bottom: 10px;
   position: relative;
}

.box-contacto input {
   width: 100%;
   height: 30px;
   border: none;
   color: #ff3131;
   font-weight: 600;
}

.box-contacto-textarea textarea {
   width: 100%;
   height: 100px;
   border: none;
   color: #ff3131;
   font-weight: 600;
   resize: none;
}

.box-contacto input::placeholder {
   color: #78859e;
   font-weight: 600;
}

.box-contacto-textarea textarea::placeholder {
   color: #78859e;
   font-weight: 600;
}

.box-contacto.error,
.box-contacto-textarea.error{
   /*border: 1px solid red;*/
   box-shadow: 0px 0px 15px 0px rgba(255, 49, 49, 1);
}

.campo-error {
   position: absolute;
   background: #ff3131;
   border-radius: 15px;
   color: #fff;
   font-size: 11px;
   font-weight: 600;
   display: block;
   top: 13px;
   right: 10px;
   padding: 5px 10px;
}

/*////////////// FOOTER ////////////////*/
.footer {
   padding: 100px 0px 40px 0px;
}

.redes-footer i {
   font-size: 20px;
   margin-left: 20px;
   cursor: pointer;
}

.icono-facebook {
   color: #475993;
}

.icono-twitter {
   color: #03a9f4;
}

.icono-youtube {
   color: #f44336;
}

.footer-logo-dg {
   display: flex;
   align-items: center;
   justify-content: center;
}

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

   .correo-redes p {
      margin-bottom: 10px;
   }

}

/*////////////// BOTONES ////////////////*/
a.boton {
   text-decoration: none;
}

.boton {
   display: inline-block;
   border-radius: 25px;
   padding: 6px 14px 6px 10px;
   font-size: 14px;
   font-weight: 700;
   letter-spacing : 1.3px;
   text-transform: uppercase;
   transition: all .3s;
   border: none;
   cursor: pointer;
}

.boton-sm {
	font-size: 12px;
}

.boton:hover {
   /*box-shadow: 0px 10px 25px -5px rgba(99,116,139,.4);*/
   box-shadow: 0px 10px 30px -10px rgba(255, 49, 49, 1);
}

.boton i {
   font-size: 28px;
   vertical-align: -5px;
}

.boton-sm i {
	font-size: 22px;
   vertical-align: -2px;
}

.boton-primary {
   color: #fff;
   background: -moz-linear-gradient(0% 50% 0deg,rgba(255, 49, 49, 1) 0%,rgba(246, 146, 30, 1) 100%);
   background: -webkit-linear-gradient(0deg, rgba(255, 49, 49, 1) 0%, rgba(246, 146, 30, 1) 100%);
   background: -webkit-gradient(linear,0% 50% ,100% 50% ,color-stop(0,rgba(255, 49, 49, 1) ),color-stop(1,rgba(246, 146, 30, 1) ));
   background: -o-linear-gradient(0deg, rgba(255, 49, 49, 1) 0%, rgba(246, 146, 30, 1) 100%);
   background: -ms-linear-gradient(0deg, rgba(255, 49, 49, 1) 0%, rgba(246, 146, 30, 1) 100%);
   -ms-filter: "progid:DXImageTransform.Microsoft.gradient(startColorstr='#FF3131', endColorstr='#F6921E' ,GradientType=0)";
   background: linear-gradient(90deg, rgba(255, 49, 49, 1) 0%, rgba(246, 146, 30, 1) 100%);
   filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#FF3131',endColorstr='#F6921E' , GradientType=1);
}

.boton-primary:hover {
   color: #fff;
}

.boton-group-center {
   display: block;
   text-align: center;
   margin: 0 auto;
}

@media (max-width: 768px) {
   .boton-group-sm-center {
      display: block;
      text-align: center;
      margin: 0 auto;
   }
}

@media (max-width: 992px) and (min-width: 769px) {
   .boton-group-md-center {
      display: block;
      text-align: center;
      margin: 0 auto;
   }
}

@media (max-width: 1200px) and (min-width: 993px) {
   .boton-group-lg-center {
      display: block;
      text-align: center;
      margin: 0 auto;
   }
}

@media screen and (min-width: 1201px) {
   .boton-group-xl-center {
      display: block;
      text-align: center;
      margin: 0 auto;
   }
}

.link {
	font-weight: 500;
}

.link-primary {
	color: #ff3131;
}

.link-primary:hover {
	color: #ff3131;
}

/*////////////// TEXTO ////////////////*/
.light {
	font-weight: 300;
}

.regular {
	font-weight: 400;
}

.medium {
	font-weight: 500;
}

.bold {
	font-weight: 700;
}

.text-oscuro {
	color: #4f4b6c;
}

.text-blanco {
	color: #fff;
}

.text-gris {
	color: #78859e;
}

.text-rojo {
   color: #ff3131;
}

.text-right {
	text-align: right;
}

.text-left {
	text-align: left;
}

.text-center {
	text-align: center;
}

.text-padding {
	padding: 0px 140px;
}

@media (max-width: 1200px) {
	.text-padding {
		padding: 0px 0px;
	}
}

.text-10px {
	font-size: 10px!important;
}

.text-11px {
	font-size: 11px!important;
}

.text-12px {
	font-size: 12px!important;
}

.text-13px {
	font-size: 13px!important;
}

.text-14px {
	font-size: 14px!important;
}

.text-15px {
	font-size: 15px!important;
}

.text-16px {
	font-size: 16px!important;
}

.text-18px {
	font-size: 18px!important;
}

.text-20px {
	font-size: 20px!important;
}

.text-24px {
	font-size: 24px!important;
}

.text-28px {
	font-size: 28px!important;
}

.text-32px {
	font-size: 32px!important;
}

.text-36px {
	font-size: 36px!important;
}

.text-40px {
	font-size: 40px!important;
}

.text-50px {
	font-size: 50px!important;
}

.text-60px {
	font-size: 60px!important;
}

.line-height-36px {
	line-height: 36px;
}

.line-height-32px {
	line-height: 32px;
}

.line-height-28px {
	line-height: 28px;
}

.line-height-24px {
	line-height: 24px;
}

.line-height-22px {
	line-height: 22px;
}

.line-height-20px {
	line-height: 20px;
}

.line-height-18px {
	line-height: 18px;
}

.line-height-16px {
	line-height: 16px;
}
/*////////////// FLEX ////////////////*/
.flex {
	display: flex;
}

.flex-center {
	align-items: center;
}

.flex-wrap {
	flex-wrap: wrap;
}

.flex-between {
	justify-content: space-between;
}

.flex-column {
	flex-direction: column;
}

.flex-justify-left {
	justify-content: flex-start;
}

.flex-justify-center {
	justify-content: center;
}

.flex-justify-right {
	justify-content: flex-end;
}

/*//////////////////// ESTILOS PADDING /////////////////////////*/
.padding-0px {
    padding: 0px!important;
}

.padding-20px {
    padding: 20px!important;
}

.padding-top-0px {
    padding-top: 0px!important;
}

.padding-top-10px {
    padding-top: 10px!important;
}

.padding-top-20px {
    padding-top: 20px!important;
}

.padding-bottom-0px {
    padding-bottom: 0px!important;
}

.padding-bottom-10px {
    padding-bottom: 10px!important;
}

.padding-bottom-20px {
    padding-bottom: 20px!important;
}
/*//////////////////// ESTILOS MARGIN /////////////////////////*/
.margin-0px {
    margin: 0px!important;
}

.margin-top-5px {
    margin-top: 5px!important;
}

.margin-top-10px {
    margin-top: 10px!important;
}

.margin-top-15px {
    margin-top: 15px!important;
}

.margin-top-20px {
    margin-top: 20px!important;
}

.margin-top-25px {
    margin-top: 25px!important;
}

.margin-top-30px {
    margin-top: 30px!important;
}

.margin-top-40px {
    margin-top: 40px!important;
}

.margin-top-50px {
    margin-top: 50px!important;
}

.margin-top-60px {
    margin-top: 60px!important;
}

.margin-top-70px {
    margin-top: 70px!important;
}

.margin-top-80px {
    margin-top: 80px!important;
}

.margin-top-90px {
    margin-top: 90px!important;
}

.margin-top-100px {
    margin-top: 100px!important;
}

.margin-bottom-5px {
    margin-bottom: 5px!important;
}

.margin-bottom-10px {
    margin-bottom: 10px!important;
}

.margin-bottom-15px {
    margin-bottom: 15px!important;
}

.margin-bottom-20px {
    margin-bottom: 20px!important;
}

.margin-bottom-25px {
    margin-bottom: 25px!important;
}

.margin-bottom-30px {
    margin-bottom: 30px!important;
}

.margin-bottom-40px {
    margin-bottom: 40px!important;
}

.margin-bottom-50px {
    margin-bottom: 50px!important;
}

.margin-bottom-60px {
    margin-bottom: 60px!important;
}

.margin-bottom-70px {
    margin-bottom: 70px!important;
}

.margin-bottom-80px {
    margin-bottom: 80px!important;
}

.margin-bottom-90px {
    margin-bottom: 90px!important;
}

.margin-bottom-100px {
    margin-bottom: 100px!important;
}

.margin-left-5px {
    margin-left: 5px!important;
}

.margin-left-10px {
    margin-left: 10px!important;
}

.margin-left-15px {
    margin-left: 15px!important;
}

.margin-left-20px {
    margin-left: 20px!important;
}

.margin-left-25px {
    margin-left: 25px!important;
}

.margin-left-30px {
    margin-left: 30px!important;
}

.margin-left-40px {
    margin-left: 40px!important;
}

.margin-left-50px {
    margin-left: 50px!important;
}

.margin-right-5px {
    margin-right: 5px!important;
}

.margin-right-10px {
    margin-right: 10px!important;
}

.margin-right-15px {
    margin-right: 15px!important;
}

.margin-right-20px {
    margin-right: 20px!important;
}

.margin-right-25px {
    margin-right: 25px!important;
}

.margin-right-30px {
    margin-right: 30px!important;
}

.margin-right-40px {
    margin-right: 40px!important;
}

.margin-right-50px {
    margin-right: 50px!important;
}

/*////////////// HELPERS ////////////////*/
.divider {
	width: 100%;
	height: 1px;
	background: #dce3e8;
}

.cursor-pointer {
	cursor: pointer;
}

.overflow-hidden {
	overflow: hidden;
}

.uppercase {
	text-transform: uppercase;
}

.rotate-180 {
	transform: rotate(180deg);
}

.opacity-50 {
	opacity: .5;
}

@media (max-width: 768px) {
   .list-style-sm-none {
      list-style: none;
      padding-left: 0px;
   }
}

/* ///////////////////// MODAL ////////////////////*/
.modal-dialog {
	max-width: 500px;
	margin: 30px auto;
}

.modal-content {
	border: none;
}

.modal-lg {
	max-width: 1000px;
	margin: 30px auto;
}

.modal-md {
   max-width: 800px;
   margin: 30px auto;
}

.modal-sm {
   max-width: 600px;
   margin: 30px auto;
}

.modal-body-custom {
	padding: 20px 20px 20px 20px;
}

.modal-footer-custom {
	padding-right: 20px;
	padding-left: 20px;
}

.modal-header-custom {
	padding: 20px 20px 0px 20px;
}

.modal-modulo {
	width: 100%;
	height: 560px;
	display: flex;
	align-items: center;
}

.modal-modulo .img-modulo {
	width: 300px;
	height: auto;
	overflow: hidden;
	border-top-left-radius: 5px;
	border-bottom-left-radius: 5px;
}

.modal-modulo .info-modulo {
	width: calc(100% - 300px);
	height: 85%;
	overflow: auto;
	padding: 0px 40px;
}

.modal-close {
	position: absolute!important;
	top: 20px;
	right: 20px;
	font-size: 30px!important;
	cursor: pointer;
	opacity: .7;
	transition: all .3s;
}

	.modal-close:hover {
		opacity: 1;
	}

@media (max-width: 1200px) {
	.modal-lg {
		max-width: 80%;
		margin: 30px auto;
	}
}

@media (max-width: 992px) {
	.modal-lg {
		max-width: 90%;
		margin: 30px auto;
	}

   .modal-md {
      max-width: 70%;
      margin: 30px auto;
   }
}

@media (max-width: 768px) {
	.modal-modulo .info-modulo {
		width: 100%;
		height: auto;
		overflow: initial;
		padding: 30px;
	}

	.modal-modulo {
		height: auto;
	}

   .modal-md {
      max-width: 90%;
      margin: 30px auto;
   }

   .modal-sm {
      max-width: 90%;
      margin: 30px auto;
   }
}

/*////////////// BOTON SCROLL HACIA ARRIBA ////////////////*/

.scrollup {
	width: 50px;
	height: 50px;
	background: #ff3131;
	position: fixed;
	bottom: 40px;
	right: 40px;
	z-index: 999;
	border-radius: 5px;
	display: none;
	cursor: pointer;
	transition: all .3s;
}

/*	.scrollup:hover {
		background: #eb800e;
	}*/

.scrollup div {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
}

@media (max-width: 600px) {
	.scrollup {
		bottom: 20px;
		right: 20px;
	}
}

/* /////////// ACCORDEON ///////////// */
.accordion-separate .card {
  margin-bottom: 10px;
  /* border-bottom-width: 1px; */
}

.accordion-separate > .card:not(:last-of-type) {
  border-bottom: 1px solid rgba(0, 0, 0, 0.125);
  border-bottom-left-radius: 3px;
  border-bottom-right-radius: 3px;
}

.accordion .card {
  border-radius: 3px;
}

.accordion p {
	margin-bottom: 16px;
}

.accordion .card-header {
  background: var(--color-claro);
  cursor: pointer;
  padding: 0px;
  border-bottom: none;
}

.accordion .card-header .titulo-acordeon {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-weight: 600;
  cursor: pointer;
  margin-bottom: 0px;
  font-size: 14px;
  user-select: none;
  padding: 12px;
}

.titulo-acordeon i.flecha {
  font-size: 16px;
  transition: all .3s;
}

.titulo-acordeon.collapsed i.flecha {
  transform: rotate(-180deg);
}

.collapsed .titulo-acordeon i.flecha {
  transform: rotate(-180deg);
}

.accordion .card-body {
  padding: 30px;
}

.accordion .card-body p {
  font-size: 12px;
  line-height: 24px;
}

.accordion .card-body p:last-child {
  margin-bottom: 0px;
}

/* /////////// CLIENTES ///////////// */
.clientes-container {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
}

.clientes-container img {
	width: 14%;
	height: 60px;
	margin-bottom: 70px;
	object-fit: contain;
	filter: grayscale(100%);
   opacity: .6;
   transition: all .3s;
}

.clientes-container img:hover {
	filter: none;
   opacity: 1;
}

@media(max-width: 992px) {
	.clientes-container img {
		width: 20%;
	}
}

@media(max-width: 768px) {
	.clientes-container img {
		width: 25%;
	}
}

@media(max-width: 575px) {
	.clientes-container img {
		width: 50%;
	}
}