:root {
  --color-blue: #0d3e67;  
  --color-green: #48B081;
  --color-black: #000;
  --color-white: #fff;
  --color-gray: #f3f3f3;
  
  --bs-primary: #0d6efd;  
  --bs-secondary: #6c757d;
  --bs-success: #198754;
  --bs-info: #0dcaf0;
  --bs-warning: #ffc107;
  --bs-danger: #dc3545;
  --bs-light: #f8f9fa;
  --bs-dark: #212529; 
}

html,
body {
  width: 100%;
  height: 100%;
  background-color: rgb(250, 251, 252);
  font-family: 'Montserrat-Regular', 'Arial', 'sans-serif';
  color: var(--color-blue);
}

.container-fluid {
	margin: 0;
	padding: 0;
	padding-bottom: 30px;
}

.container-fluid .row {
	margin: 0;
	padding: 0;
}

a {
  color: #fdcc52;
  -webkit-transition: all .35s;
  -moz-transition: all .35s;
  transition: all .35s;
}

a:hover, a:focus {
  color: rgb(128, 189, 93);
}

hr {
  max-width: 100px;
  margin: 50px auto 0;
  border-width: 1px;
  border-color: #000;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: 'Montserrat-Bold', 'Arial', 'sans-serif';
  font-weight: 200;
  letter-spacing: 1px;
}

b {
  font-family: 'Montserrat-Bold', 'Arial', 'sans-serif';
  font-weight: 400;
}

audio, canvas, progress, video {
  display: inline-block;
  vertical-align: baseline;
}

audio, video {
  display: inline-block;
}

video {
  object-fit: cover;
  overflow-clip-margin: content-box;
  overflow: clip;
}

@media (min-aspect-ratio: 16 / 9) {
  video {
      height: 300%;
      top: -100%;
  }
}

#mainNav {
  border-color: rgba(34, 34, 34, 0.05);
  background-color: white;
  -webkit-transition: all .35s;
  -moz-transition: all .35s;
  transition: all .35s;  
}

.navbar {
	/*padding-left: 0px !important;*/
}

#mainNav .navbar-brand {
  color: rgb(29, 58, 94);
}

#mainNav .navbar-brand:hover, #mainNav .navbar-brand:focus {
  color: rgb(128, 189, 93);
}

#mainNav a img {
  height: 50px;
}

#mainNav .navbar-toggler {
  font-size: 12px;
  padding: 8px 10px;
  color: rgb(128, 189, 93);
}

#mainNav .navbar-nav > li > a {
    font-family: 'Montserrat-Bold', 'Arial', 'sans-serif';
    font-size: 18px;
    text-transform: uppercase;
    color: var(--color-blue);
}

#mainNav .navbar-nav > li > a.active {
  background-color: transparent;  
  color: var(--color-green);
}

#mainNav .navbar-nav > li > a.active:hover {
  background-color: transparent;
}

#mainNav .navbar-nav > li > a:focus {
  color: var(--color-green);
}

#mainNav .navbar-nav > li > a:hover,
#mainNav .navbar-nav > li > a:focus:hover {
    text-decoration: none;
    color: var(--color-green);
}

@media (min-width: 992px) {
 
}

/* Header */
#bgvideo-home {
  position: absolute;
  top: 37px;
  left: 0;
  min-width: 100%;
  min-height: 100%;
  height: 100%;
  width: 100%;
  z-index: -100;
}

header.masthead {
  position: relative;
  height: 100vh;
  overflow: hidden;
  background-image: none;
  z-index: 5;
  /*position: relative;
  width: 100%;
  height: 100%;*/
  padding-top: calc(8rem + 75px);    
  /*color: #000;
  background: url("../img/banner_home.jpg");  
  background-attachment: fixed;
  background-repeat: no-repeat;
  
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
  
  background-position-x: right;
  background-position: right;
  
  -webkit-transition: all 250ms linear;
  -moz-transition: all 250ms linear;
  -ms-transition: all 250ms linear;
  -o-transition: all 250ms linear;
  transition: all 250ms linear;*/
}

/* Extra small devices (phones, 600px and down) */
@media only screen and (max-width: 600px) {
	header.masthead {
		/*position: relative;
		width: 100%;
		height: 100%;*/  
		padding-top: calc(8rem + 75px);		
		/*background: url("../img/banner_home.gif");  
		background-position-x: right;
		background-position: right;
		background-repeat: no-repeat;
  
	    -webkit-background-size: cover;
	    -moz-background-size: cover;
	    -o-background-size: cover;
	    background-size: cover;*/
	}
}

header.masthead .header-content {    
  float: left;
  color: #fff;
}

header.masthead .header-content h1 {
  font-family: 'Montserrat-Bold', 'Arial', 'sans-serif';
  font-size: 40px;
  overflow: hidden;
  letter-spacing: 1;
  padding: 0;
  padding-bottom: 10px;
  margin: 0;
}

header.masthead .header-content h2 {
  font-family: 'Montserrat-Regular', 'Arial', 'sans-serif';
  font-size: 30px;
  overflow: hidden;
  letter-spacing: 1;
  padding: 0;
  padding-top: 10px;
  margin: 0;
}

header.masthead .header-content button {
    font-size: 12px;
    font-family: 'Montserrat-Regular', 'Arial', 'sans-serif'; 	
	padding: 20px 40px;
}

header.masthead .header-content button:hover,
header.masthead .header-content button:focus {
	background: rgb(128, 189, 93) !important;
}

.header-info img {
    margin: 25px 0;
}

@media (max-height: 600px) {    
    header.masthead {
      height: 600px !important;  	
	  padding-top: calc(100px + 75px);	  	  
    }
}

@media (min-height: 1024px) {    
    header.masthead {        	
	  padding-top: calc(16rem + 75px);	  	  
    }
}

/* Secciones */

section {
  padding: 0;
  padding-top: 100px;
  padding-bottom: 100px;
}

@media only screen and (max-width: 600px) {  
  section {    
    padding-top: 50px !important;
    padding-bottom: 50px !important;
  }
}

section .section-heading {
  padding: 0;
}

section .section-heading h2 {
    font-size: 38px;
    font-family: 'Montserrat-ExtraBold', 'Arial', 'sans-serif'; 
	  padding: 10px 0 50px 0;	
    text-transform: uppercase; 
}

section .section-heading h4 {
    font-size: 14px;
    font-family: 'Montserrat-Regular', 'Arial', 'sans-serif';
    text-transform: uppercase; 
}

@media (min-width: 992px) {	
	section .section-heading h2 {
	}
	
	section .section-heading h4 {
	}    
}

/* Nosotros */

section.aboutus .container {
    padding-bottom: 100px;
}

section.aboutus .masthead {
  position: relative;
  width: 100%;  
  height: 350px;
  margin-bottom: 0;
  margin-top: 75px;
  color: #fff;
  background: url("../img/banner_nosotros.png");   
  background-attachment: fixed;
  background-repeat: no-repeat;
  
   -webkit-background-size: cover;
  -moz-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
  
  background-position-x: center;
  background-position-y: bottom;
  background-position: bottom center;

  -webkit-transition: all 250ms linear;
  -moz-transition: all 250ms linear;
  -ms-transition: all 250ms linear;
  -o-transition: all 250ms linear;
  transition: all 250ms linear;
}

/* Extra small devices (phones, 600px and down) */
@media only screen and (max-width: 600px) {
	section.aboutus .masthead {
		position: relative;
		width: 100%;
		height: 100%;  
		padding-top: calc(8rem + 75px);
		color: #000;
		background: url("../img/banner_nosotros.gif");  
		background-position-x: right;
		background-position: right;
		background-repeat: no-repeat;
  
	    -webkit-background-size: cover;
	    -moz-background-size: cover;
	    -o-background-size: cover;
	    background-size: cover;
	}
}

section.aboutus .item-service {
    padding: 25px 0;
}

section.aboutus .item-service h2{
    font-family: 'Montserrat-Medium', 'Arial', 'sans-serif'; 
	font-size: 16px;
}

section.aboutus .logo-aboutus {
    position: relative; 
	  width:90%; 
    padding: 0 0 0 10%;
  	float: right; 
}

@media (max-width: 600px) {	
	section.aboutus .logo-aboutus {
    width:70%; 
    padding: 0;
    margin-left: 15%;
    margin-top: 30px;
  	float: left;
	}  
}

#bgvideo-aboutus {
  position: relative;
  top: 0;
  left: 0;
  min-width: 100%;
  min-height: 100%;
  height: 100%;
  width: 100%;  
}

section.aboutus .image-aboutus {	
    position: relative;
    width: 100%;
    min-height: 400px;
    /*background: url("../img/aboutus/nosotros_image.jpg");      
    background-repeat: no-repeat;
    
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
    
    background-position-x: center;
    background-position-y: bottom;
    background-position: bottom center;

    
    -webkit-transition: all 250ms linear;
    -moz-transition: all 250ms linear;
    -ms-transition: all 250ms linear;
    -o-transition: all 250ms linear;
    transition: all 250ms linear;*/
}

/* Products */

section.products img {
  width: 98%;
  margin: 10px 1%;
}

section.products a {
	width: 100%;
	float: left;
	cursor: pointer;
	border: 2px solid rgb(29, 58, 94);
	padding: 10px 0;
	margin-bottom: 10px;
	-webkit-border-radius: 4px;
	-moz-border-radius: 4px;
	border-radius: 4px;
}

section.products a:hover {
	color: rgb(128, 189, 93) !important;
}

section.products span {
    font-size: 14px;
    font-family: 'Montserrat-Regular', 'Arial', 'sans-serif'; 
}

section.products .owl-item span {
  font-family: 'Montserrat-Bold', 'Arial', 'sans-serif';
  text-transform: uppercase;
}

section.products .masthead {
  position: relative;
		width: 100%;		
		padding-top: 600px;
		
		background: url("../img/banner_products.jpg");  
		background-position-x: right;
		background-position: right;
		background-repeat: no-repeat;
  
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
}

/* Extra small devices (phones, 600px and down) */
@media only screen and (max-width: 600px) {
	section.products .masthead {
		position: relative;
		width: 100%;
		height: auto !important;  
		padding-top: calc(8rem + 75px);
		
		background: url("../img/banner_products.jpg");  
		background-position-x: center;
		background-position: center;
		background-repeat: no-repeat;
  
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
	}

  section.products .row-products h2 {
    font-size: 34px;
    font-family: 'Montserrat-ExtraBold', 'Arial', 'sans-serif'; 
	  padding: 10px 0 50px 0;	
    text-transform: uppercase; 
}
}

section.products #carousel {
	  margin: 0px auto;
    min-height: 150px;
}

section.products #carousel .item {
    width: 60%;
    margin: 0 20%;
    cursor: pointer;
}

section.products #carousel .item img {
  display: block;
  width: 100%;
  height: auto;
}

section.products #carousel .owl-buttons {
  margin-top: -200px !important;  
}

/* Extra small devices (phones, 600px and down) */
@media only screen and (max-width: 600px) {
  section.products #carousel .owl-buttons {
    margin-top: -250px !important;  
  }
}

section.products .row-pictures {
    padding: 50px 0 !important;
}

section.products .row-pictures img {
    width: 100%;
}

section.products .row-pictures img {
    width: 100%;
}

/* Contacto */

section.contact {
	margin-bottom: 75px;
}

section.contact label {
    font-size: 16px;
    font-family: 'Montserrat-Regular', 'Arial', 'sans-serif';  
	  width: 100%;
}

section.contact i {
  font-size: 16px;
  border: 1px solid var(--bs-light) !important;
  border-radius: 5px;
}

section.contact h4 {
    font-size: 12px;
    font-family: 'Montserrat-Regular', 'Arial', 'sans-serif'; 
	  width: 100%;	
}

section.contact a {
	text-decoration: none !important;
}

section.contact a:visited {
	text-decoration: none;
}

section.contact .col-message label {
	font-size: 16px;
  width: 25%;
  text-align: right;
}

/* Extra small devices (phones, 600px and down) */
@media only screen and (max-width: 600px) {
  section.contact .col-message label {    
    text-align: left !important;
  }
}

section.contact input[type=text],
section.contact textarea {
    font-size: 12px;
    font-family: 'Montserrat-Regular', 'Arial', 'sans-serif';
    width: 70%;
    border-radius: 2px;
    border: 0px solid rgb(85, 85, 85);
    line-height: 18px;
    padding: 5px;
}

section.contact input[type=button] {
    font-size: 12px;
    font-family: 'Montserrat-Regular', 'Arial', 'sans-serif'; 
	  padding: 10px 20px;
    border: 1px solid #fff;;
}

/*section.contact input[type=button]:hover{
    background: rgb(128, 189, 93) !important;
}*/

/* Footer */

footer {
	padding: 0;
	margin: 0;
	background: rgb(13,29,49);
	background: -moz-linear-gradient(90deg, rgba(13,29,49,1) 0%, rgba(29,58,94,1) 70%);
	background: -webkit-linear-gradient(90deg, rgba(13,29,49,1) 0%, rgba(29,58,94,1) 70%);
	background: linear-gradient(90deg, rgba(13,29,49,1) 0%, rgba(29,58,94,1) 70%);
	filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#0d1d31",endColorstr="#1d3a5e",GradientType=1);
}

footer .container {
	padding: 50px 0;
}

footer .footer-brand img {
	float: left;	
}

footer .footer-company img {
	float: right;
}

footer label {
	float: left;  
  text-align: center;
  width: 100%;	
	font-size: 14px;
}

/* Extra small devices (phones, 600px and down) */
@media only screen and (max-width: 600px) {
  footer .footer-brand img {
    float: left;    
    width: 100% !important;    
  }

  footer label {    
    text-align: center; 
    margin-top: -15px !important;   
  }
  
  footer .footer-company img {
    float: left;    
    width: 100% !important;    
  }
}

/* Modal */

.modal input[type=button] {
    font-size: 12px;
    font-family: 'Montserrat-Regular', 'Arial', 'sans-serif'; 
	  padding: 20px 40px;	    
}

.modal .col-message label {
	font-size: 16px;
}

.modal input[type=text],
.modal textarea {
    font-size: 12px;
    font-family: 'Montserrat-Regular', 'Arial', 'sans-serif';
	width: 100%;
	border-radius: 2px;
	border: 1px solid rgb(85, 85, 85);
	line-height: 22px;
	padding: 5px;
}

/* Otros */

.bg-primary {
  background: var(--color-green) !important;
}

.bg-hover-primary:hover,
.bg-hover-primary:focus {
  background: var(--color-blue) !important;
}

.bg-secundary {
  background: var(--color-blue) !important;
}

.bg-hover-secundary:hover,
.bg-hover-secundary:focus {
  background: var(--color-blue) !important;
}

.bg-gray {
  background: var(--color-gray) !important;
}

.bg-darkgray {
  background: rgb(85, 85, 85) !important;
}

.bg-green {
  background: var(--color-green) !important;
}

.text-primary {
  color: var(--color-blue) !important;
}

.text-secundary {
  color: var(--color-green) !important;
}

.text-gray {
  color: rgb(250, 250, 250) !important;
}

.text-darkgray {
  color: rgb(85, 85, 85) !important;
}

.text-white {
  color: #fff !important;
}

.no-gutter > [class*='col-'] {
  padding-right: 0;
  padding-left: 0;
}

.btn {
  border-radius: 300px;
  letter-spacing: 2px;
  text-transform: uppercase;
}

