/*
Theme Name: Flatsome Child
Description: This is a child theme for Flatsome Theme
Author: TUCHO Development Team
Template: flatsome
Version: 1.0
*/

/* tipografia */
@font-face {
	font-family: 'Outfit';
	src: url('/wp-content/themes/flatsome-child/fonts/Outfit.woff2') format('woff2 supports variations'),
       url('/wp-content/themes/flatsome-child/fonts/Outfit.woff2') format('woff2-variations');
	font-weight: 100 1000;
	font-stretch: 25% 151%;
	font-display: swap;
}

body, input, textarea, select, button, p {
    font-synthesis: none;
    -moz-font-feature-settings: 'kern';
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    direction: ltr;
    text-align: justify;
	font-family: 'Outfit';
}
h1, h2, h3, h4, h5, h6, .widget-title {
	font-family: 'Outfit';
}
.center-section p {
	text-align: center;
}
@media (min-width: 1100px) {
	h1 {
    font-size: 2.8rem;
	}
	h2 {
	font-size: 2.2rem;
	}
	h3 {
	font-size: 1.8rem;
	}
}
@media (min-width: 110px) and (max-width: 1024px){
	h2 {
		font-size: 1.6rem;
	}
	h3 {
		font-size: 1.3rem;
	}
}

/* general */
body {
	font-size: 18px;
	overflow-x: clip;
}
:root {
  --secondary-color: #10848a;
}
.ux-search-submit {
	background: var(--secondary-color)!important;
}
.title {
	font-size: 4rem;
	font-weight: 500;
}
.subtitle {
	font-size: 2rem;
	font-weight: 300;
	line-height: 2.2em;
	background-color: rgba(255,255,255,.4);
	padding: 4px 40px;
	color: var(--primary-color);
	border-radius: 10px;
}
p.destacado-cluster {
	font-size: 22px;
	font-weight: 300;
	color: var(--secondary-color);
	text-align: center;
}
.cta-title {
	font-family: 'Outfit';
	font-size: 2.8rem;
	font-weight: 500;
}
.cta-subtitle {
	font-size: 1.6rem;
	font-weight: 300;
}
.img-fondo-blanco {
	border: 2px solid var(--secondary-color);
	border-radius: 10px;
}
@media (max-width: 768px) {
	.title {
		font-size: 2.2rem;
	}
	.subtitle {
		font-size: 1.2rem;
	}
	p.destacado-cluster {
		font-size: 14px;
	}
	.cta-title {
		font-size: 2rem;
	}
	.cta-subtitle {
		font-size: 1.2rem;
	}
}

/* cabecera */
.header-wrapper.stuck .header-bg-color {
	background: rgba(7, 31, 96, 0.65);
	-webkit-backdrop-filter: blur(10px);
	backdrop-filter: blur(10px);
}
.header-shadow .header-wrapper, .header-wrapper.stuck, .layout-shadow #wrapper {
	box-shadow: 0 1px 0 #00000020!important;
}
.header.transparent:not(.stuck) .primary, input[type=submit], input[type=submit].button {
	background-color: var(--fs-color-secondary);
}

.off-canvas-right.mfp-ready .mfp-content, .nav-sidebar.nav-vertical>li.menu-item.active, .nav-sidebar.nav-vertical>li.menu-item:hover {
	background-color: var(--fs-color-primary)!important;
}
.main-menu-overlay {
	background-color: #01426a80!important;
	opacity: 1!important;
	-webkit-backdrop-filter: blur(20px);
	backdrop-filter: blur(20px);
}
.mfp-close {
	mix-blend-mode: unset!important;
}
.mfp-close, .toggle {
	opacity: 1!important;
}
.nav-sidebar.nav-vertical>li {
    border-bottom: 1px solid #fff!important;
}
.no-link > a {
    cursor: default;
}
@keyframes pulse {
  0% {
    box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.5);
  }
  70% {
    box-shadow: 0 0 0 15px rgba(255, 255, 255, 0);
  }
  100% {
    box-shadow: 0 0 0 0 rgba(255, 255, 255, 0);
  }
}
.header-button .icon {
  position: relative;
  overflow: visible;
}
.header-button .icon::after {
  content: '';
  position: absolute;
  top: -2px;
  left: -2px;
  right: -2px;
  bottom: -2px;
  border-radius: 50%;
  animation: pulse 3s infinite;
}
.header-button .icon:hover::after {
  animation: none;
}

/* efectos */
#finisher-canvas {
	z-index: 0!important;
}
.rounded img, .box-blog-post img {
    border-radius: 10px;
}
.banner, .rounded-col .col-inner,
.rounded-col-top .col-inner {
	border-radius: 10px;
	overflow: hidden;
}
.banner.has-hover.hero-home {
	border-radius: 0!important;
}
.rounded-col-top .col-inner {
	padding-top: 0px!important; // fix para col
}
.big-number {
	font-size: 2rem;
	font-family: 'Outfit';
	font-weight: 700;
	color: var(--primary-color);
	margin-bottom: 1rem;
	display: inline-flex;
	position: relative;
}
.lead-subtitle {
	font-size: 1.3em;
	color: var(--primary-color);
	font-weight: 600;
	margin: -57px 0 20px 20px;
} 

@media (min-width: 768px){
	.pegado {
		position: sticky;
		top: 110px;
	}
	.big-number::before {
		content: attr(data-n);
		position: absolute;
		opacity: 0.1;
		width: 100%;
		transform: scale(3.5) translateX(-10px);
	}
}

/* Waves */
.waves {
  position:relative;
  width: 100%;
  height: 10vh;
  margin-bottom: -10px; /*Fix for safari gap*/
  min-height: 100px;
  max-height: 150px;
}
/* Animation */
.parallax > use {
  animation: move-forever 25s cubic-bezier(.55,.5,.45,.5)     infinite;
}
.parallax > use:nth-child(1) {
  animation-delay: -2s;
  animation-duration: 7s;
}
.parallax > use:nth-child(2) {
  animation-delay: -3s;
  animation-duration: 10s;
}
.parallax > use:nth-child(3) {
  animation-delay: -4s;
  animation-duration: 13s;
}
.parallax > use:nth-child(4) {
  animation-delay: -5s;
  animation-duration: 20s;
}
@keyframes move-forever {
  0% {
   transform: translate3d(-90px,0,0);
  }
  100% { 
    transform: translate3d(85px,0,0);
  }
}
/*Shrinking for mobile*/
@media (max-width: 768px) {
  .waves {
    height:60px;
    min-height:60px;
  }
}

/* cluster cards */
.card-scroll {
	overflow-x: scroll;
	overflow-y: hidden;
	padding-right: 2rem;
	border-radius: 20px 20px 0 0;
}
.card-scroll::-webkit-scrollbar {
	height: 4px;
	width: 4px;
}
.card-scroll::-webkit-scrollbar-track {
	border-radius: 0px;
	background-color: #fff;
}
.card-scroll:hover::-webkit-scrollbar-thumb {
	border-radius: 0px;
	background-color: var(--secondary-color);
}
.card-scroll > div {
	min-width: 380px;
}
.card-scroll > div:first-child {
	margin-left: 2rem!important;
	min-width: 280px;
}
@media (max-width: 768px) {
	.card-scroll > div:first-child {
		margin-left: 2rem!important;
		min-width: 260px;
	}
	.card-scroll > div {
		min-width: 320px;
	}
}
.card {
	border: 1rem solid transparent;
    border-radius: 10px;
    box-shadow: 0 0 20px rgba(0,0,0,0.2);
	margin-top: 2rem!important;
	margin-bottom: 2rem!important;
	transition: 1s;
	transform-origin: center center;
	transform: scale(0.8);
}
.card:hover {
	border-color: rgba(16, 132, 138, 0.2);
	box-shadow: 0 0 20px rgba(255,255,255,0.2);
}
.card.shown {
	transform: scale(1);
}

/* pie */
footer ul.menu>li ul {
	border-left: none;
}
.absolute-footer {
    display: none;
}
#nav_menu-2.col, #nav_menu-3.col, #nav_menu-4.col {
	padding: 0;
	width: 300px;
}
#nav_menu-2.widget, #nav_menu-3.widget, #nav_menu-4.widget {
	margin-bottom: 0;
	font-size: 1rem;
	line-height: 1.8em;
}
#nav_menu-2 ul.menu>li>a, #nav_menu-3 ul.menu>li>a, #nav_menu-4 ul.menu>li>a {
	padding: 4px 0;
}
.columna-logos .stack {
    max-width: 80%;
}
.columna-copyright div.col-inner {
	display: flex;
	justify-content: space-between;
}
.ue-texto {
	font-size: 0.8rem;
	padding-top: 10px;
	padding-left: 5px;
}
ul#menu-servicios li, ul#menu-servicios-en li {
	border-top: none!important;
}
.columna-contacto a, ul#menu-servicios a, ul#menu-servicios-en a {
	color: var(--primary-color)!important;
}
@media (min-width: 768px){
	#nav_menu-3.col, #nav_menu-4.col {
		width: fit-content!important;
	}
	#nav_menu-3 #menu-footer-menu, #nav_menu-3 #menu-footer-menu-en {
		display: flex;
		justify-content: space-between;
		width: 420px;
	}
	#nav_menu-4 #menu-footer-menu, #nav_menu-4 #menu-footer-menu-en {
		display: inline-flex!important;
		width: fit-content!important;
	}
	#nav_menu-3 ul.menu>li+li, #nav_menu-4 ul.menu>li+li {
		border-top: 0px!important;
	}
	.footer-stack small {
		text-align: left;
	}
}

@media (max-width: 767px){
	.columna-copyright div.col-inner {
		flex-direction: column;
	}
	#nav_menu-3 ul.menu>li+li, #nav_menu-4 ul.menu>li+li {
		border-top: 0px!important;
	}
	#nav_menu-3 #menu-footer-menu, #nav_menu-3 #menu-footer-menu-en {
		display: flex;
		flex-direction: column;
		align-items: center;
	}
	.foot-logos div.img {
		padding-left: 10%;
		width: 78%!important;
	}
	.columna-logos .col-inner a.ux-logo-link.block.image- {
		padding: 0 0 15px!important;
	}
	.columna-logos div.img-inner.dark {
		margin: 0 20px 0 0!important;
	}
	.columna-contacto .col-inner, .columna-contacto .col-inner .text, .columna-logos .col-inner {
		display: flex;
		flex-direction: column;
		align-items: center;
	}
	.columna-logos .stack {
		max-width: 100%!important;
		padding: 1rem 0 0 1rem;
	}
	.columna-contacto .col-inner .text {
		width: 380px;
	}
	.code-widget div {
		text-align: center!important;
		padding-top: 2rem;
	}
	.footer-stack {
		display: flex;
		flex-direction: column-reverse;
	}
	.footer-stack small {
		margin-top: 20px!important;
	}
}

/* página de contacto */
div.metodo-contacto {
	font-size: .95rem;
	font-weight: 700;
	line-height: 1.1;
	letter-spacing: .05em;
	text-transform: uppercase;
	margin-bottom: 8px;
}

/* contact form */
.form-placeholder input:not([type="submit"]) {
	height: 50px;
	padding: 21px 257px 20px 15px;
	border-radius: 10px;
	background-color: transparent;
	border-top: none;
	border-left: none;
	border-right: none;
	border: 1px solid var(--primary-color);
	box-shadow: none!important;
}
.form-placeholder textarea, .form-flat select {
	background-color: transparent;
	border-radius: 10px;
	border-top: none;
	border-left: none;
	border-right: none;
	border: 1px solid var(--primary-color);
	box-shadow: none!important;
}
.flex-1col input {
	margin-bottom: 20px;
}
.form-placeholder textarea {
	margin-bottom: 0!important
}
.flex-1col input[type="submit"] {
	width: 160px;
	height: 50px;
	margin: 2px 0 20px!important;
	border-radius: 10px;
	background-color: var(--primary-color)!important;
	font-size: 1.2rem!important;
	font-weight: 500;
	float: right;
	text-transform: capitalize!important;
}
.flex-1col input[type="checkbox"] {
    vertical-align: middle;
    margin-top: 10px;
}
.form-placeholder .dark input[type="submit"] {
    color: #333;
}
.form-placeholder label {
    font-size: 1rem;
    font-weight: 500;
    display: block;
    text-align: left;
}

/* WPML Switcher */
.wpml-ls-legacy-list-horizontal {
	border: 0;
    background: hsla(0,0%,100%,.1);
    border-radius: 5px;
	padding: 15px 10px;
	margin-left: 20px;
}
.wpml-ls-legacy-list-horizontal a {
	padding: 2px 10px 6px!important;
}
.wpml-ls-legacy-list-horizontal a span {
    color: #fff;
}
.wpml-ls-current-language {
	background: #fff;
    border-radius: 5px;
}
.wpml-ls-current-language a span {
    color: var(--primary-color)!important;
	font-weight: 700;
}
span.wpml-ls-native {
	font-size: 14px;
}