@charset "utf-8";

:focus {
    outline: 0;
}
* {
    scroll-behavior: smooth;
}
html, .tooltip, .popover {
	font-family: 'Poppins', sans-serif;
}
body {
	font-family: 'Poppins', sans-serif;
	color: #000000;
	line-height: 1.75;
	font-size: 16px;
	overflow-x: hidden;
}
h2 {
	font-size: 2rem;
}
h3 {
	font-size: 2rem;
}
h4 {
	font-size: 1.25rem;
}
h5 {
	font-size: 1rem;
}
h6 {
	font-size: 0.75rem;
}
p {
	font-size: 0.875rem;
	font-weight: 300;
}
h1,h2,h3,h4,h5,h6 {
	line-height: 1;
	margin-bottom: 1rem;
}
b, strong {
	font-weight: bold;
}
.fw-300 {
	font-weight: 300;
}
.fw-400 {
	font-weight: 400;
}
.fw-700, b, strong {
	font-weight: 700;
}
.text-black {
	color: rgba(0,0,0,1);
}
.lh-75 {
	line-height: .75;
}
.lh-100 {
	line-height: 1;
}
.lh-125 {
	line-height: 1.25;
}
.lh-150 {
	line-height: 1.5;
}
.lh-175 {
	line-height: 1.75;
}
.lh-200 {
	line-height: 2;
}
.ls-0 {
	letter-spacing: 0;
}
.ls-1 {
	letter-spacing: .05rem;
}
.ls-2 {
	letter-spacing: .1rem;
}
.ls-3 {
	letter-spacing: .15rem;
}
.ls-4 {
	letter-spacing: .2rem;
}
.ls-5 {
	letter-spacing: .25rem;
}
.ls--1 {
	letter-spacing: -.05rem;
}
.ls--2 {
	letter-spacing: -.1rem;
}
.ls--3 {
	letter-spacing: -.15rem;
}
.ls--4 {
	letter-spacing: -.2rem;
}
.ls--5 {
	letter-spacing: -.25rem;
}
.opacity-100 {
	opacity: 1;
}
.opacity-80 {
	opacity: .8;
}
.opacity-60 {
	opacity: .6;
}
.opacity-40 {
	opacity: .4;
}
.opacity-20 {
	opacity: .2;
}
.opacity-0 {
	opacity: 0;
}
.separator-300x4 {
	width: 300px;
	height: 4px;
	border: 0;
}
.separator-50x3 {
	width: 50px;
	height: 3px;
	border: 0;
}
.bx-shw-1 {
	box-shadow: 0 1rem 1rem 0 rgba(0, 0, 0, 0.2);
}
.bx-shw-2 {
	box-shadow: 0 1rem 1rem 0 rgba(0, 0, 0, 0.1);
}
.b-rad-10 {
	border-radius: 10px;
}
.b-rad-20 {
	border-radius: 20px;
}
.b-rad-30 {
	border-radius: 30px;
}
.bg-parallax {
  background-image: url("/frontend/images/bg-parallax-globos.jpg");
  background-attachment: fixed;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}
.border-gris {
	border: 1px solid #e3e8ef;
}
.centrar-vh {
	position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
	width: 100%;
}

/****** HEADER + MENU *******/
#navPpal.scrollUp {
	background-color: rgba(0,0,0,0);
	transition: all .25s ease;
}
#navPpal.scrollDown {
	background-color: rgba(0,0,0,.9);
	transition: all .25s ease;
}
#navPpal .navbar-nav .nav-link {
	color: #fff;
	padding: 0;
	padding-top: 1rem;
	margin: 0 1.5rem;
	letter-spacing: 1px;
	display: inline-block;
	font-size:1.125rem;
	font-weight: 700;
	text-transform: uppercase;
	border-bottom: 2px solid transparent;
}
#navPpal .nav-item {
	text-align: center;
	margin: 10px 0;
}
#navPpal .navbar-nav .nav-link.active,
#navPpal .navbar-nav .nav-link:active,
#navPpal .navbar-nav .nav-link:focus,
#navPpal .navbar-nav .nav-link:hover {
	border-bottom: 2px solid #facd01;
}
.navbar-collapse.collapse.show {
	padding-bottom: 30px;
}
#navPpal .dropdown-toggle::after {
	color: #facd01;	
}
#navPpal .navbar-brand {
	padding-bottom: 0;
}
#navPpal.scrollUp .navbar-brand span:before {
	font-size: 90px;
	transition: all .25s ease;
}
#navPpal.scrollDown .navbar-brand span:before {
	font-size: 70px;
	transition: all .25s ease;
}
.icon-play {
	font-size: 40px;
	vertical-align: middle;
}

/**** BTN HAMBURGER *****/
.icon-bar {
	width: 22px;
	height: 2px;
	background-color: #B6B6B6;
	display: block;
	transition: all 0.2s ease;
	margin-top: 4px
}
.navbar-toggler {
  border: none;
  background: transparent !important;
  visibility: hidden;
}
.navbar-toggler:focus,
.navbar-toggler:active {
	outline: none;
}
.navbar-toggler[aria-expanded="true"] .top-bar {
  transform: rotate(45deg);
  transform-origin: 10% 10%;
}
.navbar-toggler[aria-expanded="true"] .middle-bar {
  opacity: 0;
}
.navbar-toggler[aria-expanded="true"] .bottom-bar {
  transform: rotate(-45deg);
  transform-origin: 10% 90%;
}

.navbar-toggler[aria-expanded="false"] .top-bar {
  transform: rotate(0);
}
.navbar-toggler[aria-expanded="false"] .middle-bar {
  opacity: 1;
}
.navbar-toggler[aria-expanded="false"] .bottom-bar {
  transform: rotate(0);
}

/****** CAROUSEL *******/
#carrusel-home-principal {
	height: 100vh;
	background-color: #000;
}
.slick-list, .slick-track {
	height: 100%;
}
.carousel-content {
	background-color: #000;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
}

/********** PRIMARY ***********/
.btn-primary {
	background-color: #facd01;
	border-color: #facd01;
	color: #000;
	border-radius: 0;
	font-weight: 700;
	padding: 1rem 2rem;
	border-width: 2px;
	box-shadow: 0;
}
.btn-primary:hover {
	background-color: #ffb400;
	border-color: #ffb400;
	color: #000;
}
.btn-primary.disabled, .btn-primary:disabled {
	background-color: #ffb400;
	border-color: #ffb400;
}
.btn-primary:not(:disabled):not(.disabled):active, .btn-primary:not(:disabled):not(.disabled).active,
.show > .btn-primary.dropdown-toggle {
	background-color: #facd01;
	border-color: #facd01;
}
.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 1rem 0 rgba(0, 0, 0, 0.2);
	color: #000;
	transition: ease-in-out all .15s;
}
.bg-primary {
 	background-color: #facd01 !important;
}
a.bg-primary:hover,
a.bg-primary:focus,
button.bg-primary:hover,
button.bg-primary:focus {
	background-color: #ffb400 !important;
}
.border-primary {
 	border-color: #facd01 !important;
}
.text-primary {
 	color: #facd01 !important;
}
a.text-primary:hover,
a.text-primary:focus,
a.hvr-primary:hover,
a.hvr-primary:focus {
 	color: #ffb400 !important;
}
.btn-primary-o {
	background-color: transparent;
	border-color: #facd01;
	color: #000;
	border-radius: 0;
	font-weight: 700;
	padding: .75rem 1.75rem;
	border-width: 2px;
	box-shadow: 0;
}
.btn-primary-o:hover {
	background-color: #facd01;
	border-color: #facd01;
	color: #000;
}
.btn-primary-o.disabled, .btn-primary-o:disabled {
	background-color: #facd01;
	border-color: #facd01;
}
.btn-primary-o:not(:disabled):not(.disabled):active, .btn-primary-o:not(:disabled):not(.disabled).active,
.show > .btn-primary-o.dropdown-toggle {
	background-color: #facd01;
	border-color: #facd01;
}
.btn-primary-o:focus, .btn-primary-o.focus, .btn-primary-o:not(:disabled):not(.disabled):active:focus, .btn-primary-o:not(:disabled):not(.disabled).active:focus,
.show > .btn-primary-o.dropdown-toggle:focus {
	box-shadow: 0 0 1rem 0 rgba(0, 0, 0, 0.2);
	color: #000;
	transition: ease-in-out all .15s;
	background-color: #facd01;
}
.transition-1 {
	transition: ease-in-out all .25s;
}
.transition-2 {
	transition: ease-in-out all .5s;
}
.transition-3 {
	transition: ease-in-out all .75s;
}
.guion-50x3 {
	width: 50px;
	height: 3px;
	vertical-align: middle;
}
.bg-oscurecido {
	background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;
	background-color: #35383f;
}
.cover:before {
		background: rgba(0,0,0,0.5);
		position: absolute;
		content: "";
		width: 100%;
		height: 100%;
		left: 0;
		top: 0;
		right: 0;
		bottom: 0;
	}
.bg-oscurecido a {
	opacity: 1;
}
.bg-capabilities {
	background: url(../images/bg-capabilities.jpg);
	background-position: right center;
	background-size: cover;
}
.bg-corporate {
	background: url(../images/bg-corporate.png);
	background-position: right top;
	background-repeat: repeat-x;
}

/****** FOOTER *******/
footer {
	padding: 50px 0 0;
	background: #000;
}
#subfooter {
	margin-top: 40px;
	padding: 25px 0;
	color: #7f7f93;
	border-top: 1px solid #1c1c1f;
}
footer .nav .nav-item .nav-link.rrss {
	font-size: 24px;
	margin-left: 12px;
	margin-right: 12px;
	color: #facd01;
	text-align: center;
	line-height: 24px;
	padding: .5rem 0;
}
footer .nav .nav-item .nav-link.rrss:hover {
	color:#fff;
	transition: all ease .25s;
}
footer .nav-footer-1 {
	display: list-item;
	column-count: 1;
	margin-top: 30px;
	text-align: center;
}
footer .nav-footer-2 {
	display: inline-flex;
}
.webmedia:hover {
	text-decoration: none;
}
.webmedia:before {
	content: 'Webmedia';
	font-size: 80%;
	color: #fff;
	vertical-align: top;
	transition: .4s all ease-out;
	text-decoration: none;
	width: 0px;
	overflow: hidden;
	position: absolute;
	transform: translateX(20px);
}
.webmedia:hover:before {
	width:70px;
}
.lista-botonera {
	padding-left: 0;
	margin: 10px 0;
}
.lista-botonera li {
	list-style: none;
	margin-bottom: 12px;
	line-height: 1.2;
	font-size: 1.125rem;
	font-weight: 300;
	letter-spacing: .05rem;
}
.lista-botonera li,
.lista-botonera li a {
	color: #fff;
}
.lista-2-cols {
	column-count: 2;
}
.bg-title {
	background: url(../images/bg-title.jpg) center center no-repeat #222;
	background-size: cover;
}
.bg-leadership {
	background: url(../images/bg-leadership.jpg) center center no-repeat #222;
	background-size: cover;
}
.bg-gris-f4 {
	background: #f4f4f4;
}
.box-shadow-1 {
	box-shadow: 0 0 20px 0 rgba(0,0,0,.15);
}
.text-black-25 {
	color: rgba(0,0,0,.25)
}
.b-b-gris {
	border-bottom: 1px solid #eee;
}

/********* TIMELINE ***********/
.timeline {
	list-style: none;
	padding: 0;
	margin: 0;
}
.timeline:before {
  position: absolute;
  left: 26px;
  top: 0;
  content: ' ';
  display: block;
  width: 6px;
  height: 100%;
  margin-left: -3px;
  background: #f0f1f4;
}
.timeline li:before {
	position: absolute;
	top: 18px;
	content: ' ';
	display: block;
	width: 30px;
	height: 30px;
	background: #e0e3e9;
	z-index: 5;
	border-radius: 50%;
	border: 5px solid #fff;
	box-shadow: 0 0 0 1px #e0e3e9;
}
.timeline li:nth-child(1n):before {
	left: -55px;
}
.timeline li:nth-child(2n):before {
	left: -55px;
}
.timeline li:after {
    content: "";
    position: absolute;
    top: 22px;
    height: 0;
    width: 0;
	border-bottom: 11px solid transparent;
}
.timeline li:after,
.timeline li:nth-child(2n):after {
	left: -15px;
	border-left: 0;
	border-right: 16px solid #fff;
	border-top: 11px solid transparent;
}
.timeline li {
	width: calc(100% - 50px);
	background: #fff;
	padding: 20px;
	margin-bottom: 30px;
	position: relative;
	border: 1px solid #e0e3e9;
	border-radius: 5px;
}
.timeline li:last-child {
	margin-bottom: 0;
}
.timeline li:hover,
.timeline li:active,
.timeline li:focus {
	box-shadow: 0 0 30px 0 rgba(0,0,0,.15);
	transition: ease all .25s;
}
.timeline li:nth-child(1n) {
	margin-left: auto;
}
.timeline li:nth-child(2n) {
	margin-left: auto;
}
.timeline li:nth-child(1n) p {
	text-align: right;
}
.timeline li:nth-child(2n) p {
	text-align: left;
}
.timeline li p:after {
    content: "";
    position: absolute;
    top: 22px;
    height: 0;
    width: 0;
    border-top: 11px solid transparent;
	border-left: 16px solid #e0e3e9;
	border-bottom: 11px solid transparent;
}
.timeline li:nth-child(1n) p:after {
	right: inherit;	
	left: -16px;
	transform: rotate(180deg);
}
.timeline li:nth-child(2n) p:after {
	left: -16px;
	border-right: 16px solid #e0e3e9;
	border-left: 0;
	transform: rotate(0deg);
}

/****** MODAL *******/
.modal-modern .modal-dialog,
.modal-modern.modal {
	border: 0;
} 
.modal-modern .modal-content {
	border-radius: 0;
	border: 0;
}
.modal-modern .modal-header {
	padding: 2rem 2rem 0;
	border: 0;
}
.modal-modern .modal-body {
	padding: 1rem 2rem 2rem;
	border: 0;
}

/******** GALLERY ********/
.gallery.card-columns {
	column-gap: 1rem;
}
.gallery .card {
	border: 0;
	margin-bottom: 1rem;
}
.gallery .card a img {
	padding: 5px;
	border-radius: 0;
	border: 1px solid #ddd;
	opacity: .9;
}
.gallery .card a:hover img {
	opacity: 1;
	transition: ease all .25s;
	padding: 5px;
	border-color: #fff;
}
.gallery .card .hvr-grow-shadow:hover,
.gallery .card .hvr-grow-shadow:focus,
.gallery .card .hvr-grow-shadow:active {
	transform: scale(1.025);
	box-shadow: 0 0 30px -10px rgba(0, 0, 0, 0.5)
}

/************ CONTACTO ************/
.icono-contact {
	font-size: 2rem;
	padding: 24px;
	border: 1px solid #e0e3e9;
}
.formulario label {
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: .05rem;
	margin-bottom: 0;
}
.formulario .form-control {
	border: 2px solid #e0e3e9;
	border-radius: 0;
	padding: 1.5rem 1rem;
}
.form-control:focus {
	box-shadow: 0 0 0 0 rgba(0,0,0,0);
	border: 2px solid #facd01;
}
#loading,
#response {
    background-color: rgba(255,255,255,.75);
    bottom: 0;
    left: 0;
    position: absolute;
    right: 0;
    top: 0;
    z-index: 10;
}

/****** MEDIA QUERYS *******/
/****** SM *******/
@media (min-width: 576px) {
	h2 {
		font-size: 3rem;
	}
	.card-columns {
		column-count: 2;
	}
}

/****** MD *******/
@media (min-width: 768px) {
	h2 {
		font-size: 4rem;
	}
	h3 {
		font-size: 2.25rem;
	}
	h4 {
		font-size: 1.5rem;
	}
	h5 {
		font-size: 1.125rem;
	}
	h6 {
		font-size: 0.875rem;
	}
	p {
		font-size: 1rem;
	}
	.icon-play {
		font-size: 60px;
	}
	.bg-capabilities {
		background-position: center center;
	}
	.bg-oscurecido a {
		opacity: 0;
	}
	.bg-oscurecido:hover a {
		opacity: 1;
		transition: all ease 1s;
	}
	.cover:before {
		background: rgba(0,0,0,0.0);
	}
	.bg-oscurecido:hover .cover:before {
		background: rgba(0,0,0,0.75);
		transition: all ease .5s;
	}
	.cover:after {
		position: absolute;
		content: "";
		display: block;
		border: 2px solid transparent;
		left: 0;
		top:  0;
		bottom: 0;
		right: 0;
	}
	.bg-oscurecido:hover .cover:after {
		border-color: #facd01;
		left: 40px;
		top: 40px;
		bottom: 40px;
		right: 40px;
		transition: all ease-in-out .5s;
	}
	.timeline:before {
		left: 50%;
		top: 0;
	}
	.timeline li {
		width: calc(50% - 40px);
	}
	.timeline li:nth-child(1n) {
		margin-left: 0;
	}
	.timeline li:nth-child(2n) {
		margin-left: auto;
	}
	.timeline li:nth-child(1n):before {
		right: -55px;
		left: inherit;
	}
	.timeline li:nth-child(2n):before {
		left: -55px;
		right: inherit;
	}
	.timeline li:after {
		right: -15px;
		border-top: 11px solid transparent;
		border-right: 16px solid #fff;
		left: inherit;
		transform: rotate(180deg)
	}
	.timeline li:nth-child(2n):after {
		transform: rotate(0deg)
	}
	.timeline li:nth-child(1n) p:after {
		right: -16px;
		left: inherit;
		transform: rotate(0deg);
	}
	.timeline li:nth-child(2n) p:after {
		left: -16px;
		right: inherit;
		transform: rotate(0deg);
	}
	.card-columns {
		column-count: 3;
	}
	.formulario label {
		font-size: 0.875rem;
	}
}

/****** LG *******/
@media (min-width: 992px) {
	.card-columns {
		column-count: 4;
	}
}

/****** XL *******/
@media (min-width: 1200px) {
	
}
