@charset "utf-8";
* {
    scroll-behavior: smooth;
}

/****** TIPOGRAFIA ******/
html {
  font-family: 'Montserrat', sans-serif;
  font-weight: 400;
  overflow-x: hidden;
}
body {
  font-family: 'Montserrat', sans-serif;
  color: #142329;
  line-height: 1.75;
  font-weight: 400;
  font-size: .9rem;
  overflow-x: hidden;
}
.bebas {
	font-family: 'Bebas Neue', sans-serif;
}
.montserrat {
	font-family: 'Montserrat', sans-serif;
}
.tooltip, .popover {
  font-family: 'Montserrat', sans-serif;
}
h2 {
	font-size: 3.5rem;
	font-family: 'Bebas Neue', sans-serif;
	letter-spacing: -.1rem;
	line-height: .9;
}
h3 {
	font-size: 2.75rem;
	font-family: 'Bebas Neue', sans-serif;
	letter-spacing: -.05rem;
	line-height: .9;
}
h4 {
	font-size: 2.5rem;
	font-family: 'Bebas Neue', sans-serif;
	letter-spacing: -.025rem;
	line-height: .9;
}
h5 {
	font-size: 1.5rem;
	font-family: 'Bebas Neue', sans-serif;
	line-height: .9;
}
h6 {
	font-size: 1rem;
}
p {
	font-size: .9rem;
}
.fw-400 {
	font-weight: 400;
}
i, em, .oblicua {
	font-style: oblique;
}
.fw-800, b, strong {
	font-weight: 800;
}
.fst-normal {
	font-style: normal;
}

/****** NUEVOS ******/
.fs-100 {
	font-size: 1rem;
}
.fs-110 {
	font-size: 1.1rem;
}
.fs-150 {
	font-size: 1.5rem;
}
.fs-14 {
	font-size: 14px;
}
.fs-13 {
	font-size: 13px;
}
.fs-12 {
	font-size: 12px;
}
.fs-10 {
	font-size: 10px;
}
.align-sub {
	vertical-align: sub;
}
.text-black {
	color: rgba(0,0,0,1);
}
.lh-50 {
	line-height: .5 !important;
}
.lh-75 {
	line-height: .75 !important;
}
.lh-90 {
	line-height: .9 !important;
}
.lh-100 {
	line-height: 1 !important;
}
.lh-125 {
	line-height: 1.25 !important;
}
.lh-150 {
	line-height: 1.5 !important;
}
.lh-200 {
	line-height: 2 !important;
}
.ls-0 {
	letter-spacing: 0;
}
.ls-1 {
	letter-spacing: .025rem;
}
.ls-2 {
	letter-spacing: .05rem;
}
.ls-3 {
	letter-spacing: .1rem;
}
.ls-n1 {
	letter-spacing: -.025rem;
}
.ls-n2 {
	letter-spacing: -.05rem;
}
.ls-n3 {
	letter-spacing: -.1rem;
}

/**** NAVBAR *****/
#navPpal {
	background: rgba(255,255,255,1);
	box-shadow: 0 0 1rem 0 rgba(0,0,0,.25);
	transition: all ease .25s;
}
#navPpal .navbar-brand img {
	padding-top: 15px;
	padding-bottom: 15px;
  max-width: 260px
}
.navbar-toggler:focus,
.navbar-toggler:active {
	outline: none;
}
#navPpal .nav-item {
	position: relative;
}
#navPpal .nav-link {
	color: #22222D;
	background-color: #fff;
	line-height: 1;
	position: relative;
	padding: 1.9rem 1.4rem 1.5rem;
	margin: 0;
	font-size: 1.25rem;
	overflow: hidden;
	border-bottom: 4px solid transparent;
	transition: all ease .25s;
}
#navPpal .nav-link:hover,
#navPpal .nav-link.active {
	background-color: #DDE227;
	color: #fff;
	border-bottom-color: #22222D;
	transition: all ease .25s;
}
#navPpal .nav-link:before {
	content: "";
	width: 0;
	height: 0;
	border-left: 12px solid transparent;
	border-right: 12px solid transparent;
	border-bottom: 12px solid transparent;
	position: absolute;
	bottom: -15px;
	left: calc(50% - 12px);
	transition: all ease .25s;
}
#navPpal .nav-link:hover:before,
#navPpal .nav-link.active:before {
	bottom: -3px;
	border-bottom-color: #22222D;
	transition: all ease .25s;
}
.navbar-nav {
	text-align: center;
}
/**** BTN HAMBURGER *****/
.icon-bar {
	width: 22px;
	height: 2px;
	background-color: #B6B6B6;
	display: block;
	transition: all ease .5s;
	margin-top: 4px
}
.navbar-toggler {
	border: none;
	background: transparent !important;
	padding: 0.25rem 0.25rem 0.25rem 0.75rem;
}
.navbar-toggler:focus,
.navbar-toggler:active {
	outline: none;
}
.drawer-open .navbar-toggler .top-bar {
	transform: rotate(45deg);
	transform-origin: 10% 10%;
}
.drawer-open .navbar-toggler .middle-bar {
	opacity: 0;
}
.drawer-open .navbar-toggler .bottom-bar {
	transform: rotate(-45deg);
	transform-origin: 10% 90%;
}
.navbar-toggler .top-bar {
	transform: rotate(0);
}
.navbar-toggler .middle-bar {
	opacity: 1;
}
.navbar-toggler .bottom-bar {
	transform: rotate(0);
}
.collapse:not(.show) {
	display: block;
}
.centrar-xy {
	position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
	width: 100%;
}
/*************************/
main {
	margin-top: 80px;
}
.carousel-indicators li {
	width: 10px;
	height: 10px;
	border: 3px solid #fff;
	border-radius: 50%;
}
.carousel-indicators .active {
	border: 3px solid #E2E64A;
	background-color: transparent;
}
.bg-yellow {
	background-color: #DDE227;
}
.text-yellow {
	color: #DDE227;
}
.link-yellow {
	color: #B6BB00;
	text-decoration: underline;
	transition: all ease .25s;
}
.link-yellow:hover {
	color: #0D0D0F;
	text-decoration: none;
	transition: all ease .25s;
}
.bg-black {
	background-color: #0D0D0F;
}
.bg-transparent {
	background-color: transparent !important;
}
.bg-title {
	background: url(../images/bg-title.jpg) center center no-repeat;
	background-size: cover;
}
.btn-producto {
	width: 100%;
	padding-top: 78.125%;
	display: block;
	position: relative;
	overflow: hidden;
	transition: all ease .25s;
}
.btn-producto .imagen {
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	width: 100%;
	height: 100%;
	display: block;
	position: absolute;
	top: 0;
}
.btn-producto .cover {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	background-color: rgba(4,2,2,.5);
	transition: all ease .25s;
}
.btn-producto .cover:after {
	content: '';
	top: 30px;
	bottom: 30px;
	left: 30px;
	right: 30px;
	border: 1px solid #DDE227;
	position: absolute;
	transition: all ease .25s;
}
.btn-producto .texto {
	width: calc(100% - 80px);
}
.btn-producto .texto h3:after {
	content: '';
	position: absolute;
	width: 44px;
	height: 3px;
	bottom: 0px;
	left: calc(50% - 22px);
	background-color: #DDE227;
	transition: all ease .25s;
}
.btn-experiencia {
	display: block;
}
.btn-experiencia figure .fas {
	font-size: 50px;
	color: #fff;
	transition: all ease .25s;
}
.btn-experiencia figure img {
	opacity: 1;
	transition: all ease .25s;
}
.btn-experiencia:hover figure img {
	opacity: .8;
	transition: all ease .25s;
}
.btn-experiencia:hover figure .fas {
	color: #DDE227;
	transition: all ease .25s;
}
.btn-experiencia:hover {
	text-decoration: none;
}
.card-historia {
	background-color: #000;
	width: 100%;
	padding-top: 113.75%;
	display: block;
	position: relative;
}
.card-historia .imagen {
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	width: 100%;
	height: 100%;
	display: block;
	position: absolute;
	opacity: .5;
	top: 0;
	transition: all ease .25s;
}
.card-historia .texto {
	width: calc(100% - 40px);
}
.card-historia .texto h3 {
	position: relative;
	margin-bottom: 0;
}
.card-historia .texto h3:after {
	content: '';
	position: absolute;
	width: 44px;
	height: 3px;
	bottom: -6px;
	left: calc(50% - 22px);
	background-color: #DDE227;
	transition: all ease .25s;
}
.card-historia .texto p {
	font-size: .75rem;
	line-height: 1.5;
	margin-top: 15px;
	margin-bottom: 0;
}
.card-historia .texto .detalle {
	height: 100%;
	overflow: hidden;
	transition: all ease .25s;
}
.btn-primary {
	background-color: #DDE227;
	border-color: #DDE227;
	color: #000;
  }
  .btn-primary:hover,
  .btn-primary.disabled, .btn-primary:disabled,
  .btn-primary:not(:disabled):not(.disabled):active, .btn-primary:not(:disabled):not(.disabled).active,
  .show > .btn-primary.dropdown-toggle {
	background-color: #ffff33;
	border-color: #ffff33;
	color: #000;
  }
  .btn-primary:focus, .btn-primary.focus,
  .btn-primary:not(:disabled):not(.disabled):active:focus, .btn-primary:not(:disabled):not(.disabled).active:focus,
  .show > .btn-primary.dropdown-toggle:focus {
	box-shadow: 0 0 2rem 2rem rgba(255, 240, 200, 0);
	color: #000;
  }


/********** FORMULARIO ***************/
#response{
  background: #44CCBE;
  color: #fff;
  text-align: center;
  padding: 25px 0px
}
.fx-fading-circle {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 100;
  width: 100%;
  height: 100%;
  background:#ffffffad url(../images/loading.gif) center no-repeat;
}
.loading {
    display: none;
}
label {
	font-size: .7rem;
	font-weight: 800;
	color: #a7bec7;
	text-transform: uppercase;
	margin-bottom: .25rem;
}
.form-control {
	font-size: .9rem;
	font-weight: 300;
	height: calc(1.5em + .75rem + 10px)
}
.invisible {
	display: none;
}
.custom-file-input,
.custom-file-label,
.custom-file {
	height: calc(1.5em + .75rem + 10px);
}
.custom-file-label::after {
	height: calc(1.5em + .75rem + 8.5px);
}
.custom-file-label,
.custom-file-label::after {
	line-height: 2.25;
	font-size: .9rem;
	color: #6c757d;
}
.custom-file-label {
	text-transform: none;
}

/************** FOOTER ***************/
footer {
	background: #0D0D0F;
	color: #A3AFB2;
}
.sub-footer {
	background: #000;
}
footer hr {
	border-top: 1px solid rgba(255,255,255,.1);
}
footer a, footer button.btn-link {
	color: #A3AFB2;
	transition: all ease .25s;
}
footer a:hover, footer button.btn-link:hover {
	color: #DDE227;
	transition: all ease .25s;
}
.icon-circle {
	border: 1px solid #dde227;
    border-radius: 50px;
    width: 50px;
    height: 50px;
    line-height: 50px !important;
    text-align: center;
    color: #dde227;
}
footer .media .media-body a i {
	margin-left: 5px;
	transition: all ease .25s;
}
footer .media .media-body a:hover i {
	margin-left: 10px;
	transition: all ease .25s;
}




/****** MEDIA QUERYS *******/
/****** XS HASTA MD *******/
@media (max-width: 991px) {
	.navbar-collapse {
		position: fixed;
		top: 0;
		bottom: 0;
		width: 300px;
		height: 100vh !important;
		left: -300px;
		overflow-x: hidden;
		overflow-y: auto;
		z-index: 2;
		background-color: #fff;
		transition: all .25s ease;
	}
	.drawer-open .navbar-collapse {
		left: 0px;
		transition: all .25s ease;
	}
	.navbar-collapse.collapsing {
		height: 100vh !important;
	}
	body .fixed-top:before {
		content: '';
		width: 0vw;
		height: 200vh;
		background-color: rgba(0,0,0,0.8);
		position: fixed;
		opacity: 0;
		display: block;
		transition: all .25s ease;
	}
	body.drawer-open .fixed-top:before {
		width: 100vw;
		opacity: 1;
		transition: all .25s ease;
	}
	body.drawer-open {
		overflow-y: hidden;
	}
	#navPpal .nav-item,
	#navPpal .nav-link {
		width: 100%;
	}
	#navPpal .rrss {
		margin-top: 1rem;
	}
	#navPpal .navbar-nav li > a {
		color: #142329;
	}
}

/****** SM *******/
@media (min-width: 576px) {
}

/****** MD *******/
@media (min-width: 768px) {
	.btn-producto-half {
		padding-top: 39%;
	}
	h2 {
		font-size: 4.5rem;
	}
	h3 {
		font-size: 3.75rem;
	}
	h6 {
		font-size: 1.25rem;
	}
}

/****** LG *******/
@media (min-width: 992px) {
	.btn-producto-half {
		padding-top: 78.125%;
	}
	.btn-producto .cover {
		background-color: rgba(4,2,2,0);
		transition: all ease .25s;
	}
	.btn-producto .cover:after {
		top: -1px;
		bottom: -1px;
		left: -1px;
		right: -1px;
		transition: all ease .25s;
	}
	.btn-producto .texto h3:after {
		background-color: transparent;
		width: 0;
		left: 50%;
		bottom: -30px;
		transition: all ease .25s;
	}
	.btn-producto:hover .cover {
		background-color: rgba(4,2,2,.5);
		transition: all ease .25s;
	}
	.btn-producto:hover .cover:after {
		top: 30px;
		bottom: 30px;
		left: 30px;
		right: 30px;
		transition: all ease .25s;
	}
	.btn-producto:hover .texto h3:after {
		background-color: #DDE227;
		width: 44px;
		left: calc(50% - 22px);
		bottom: 0;
		transition: all ease .25s;
	}
	.card-historia .imagen {
		opacity: 1;
		transition: all ease .25s;
	}
	.card-historia:hover .imagen {
		opacity: .5;
		transition: all ease .25s;
	}
	.card-historia .texto h3:after {
		width: 0px;
		bottom: -26px;
		left: 50%;
		background-color: transparent;
		transition: all ease .25s;
	}
	.card-historia:hover .texto h3:after {
		width: 44px;
		bottom: -6px;
		left: calc(50% - 22px);
		background-color: #DDE227;
		transition: all ease .25s;
	}
	.card-historia .texto .detalle {
		height: 0;
		transition: all ease .25s;
	}
	.card-historia:hover .texto .detalle {
		height: 130px;
		transition: all ease .25s;
	}
	#navPpal .nav-link:after {
		content:'';
		position: absolute;
		top: 20px;
		right: 0;
		width: 1px;
		height: 40px;
		display: block;
		background-color: #CDD0DB;
	}
	#navPpal .nav-item:last-child .nav-link:after,
	#navPpal .nav-link:hover:after,
	#navPpal .nav-link.active:after {
		background-color: transparent;
		transition: all ease .25s;
	}
	#navPpal .nav-link {
		padding: 1.9rem 1rem;
	}
}

/****** XL *******/
@media (min-width: 1200px) {
	#navPpal .nav-link {
		padding: 1.9rem 1.4rem;
	}
}

.whatsapp-desktop, .whatsapp-mobile {
    position: fixed;
    z-index: 700;
	bottom: 1rem;
	right: 1rem;
	opacity:.9;
	transition: all ease .25s;
}
.whatsapp-desktop {
    width: 207px;
	height: 57px;
}
.whatsapp-mobile {
    width: 56px;
	height: 56px;
}
.whatsapp-desktop:hover, .whatsapp-mobile:hover {
	opacity:1;
	transition: all ease .25s;
}
