/*
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: 'Sentient';
	src: url('/wp-content/themes/flatsome-child/fonts/Sentient.woff2') format('woff2-variations');
	font-weight: 100 1000;
	font-stretch: 75% 125%;
	font-style: normal;
	font-display: swap;
}
@font-face {
	font-family: 'Satoshi';
	src: url('/wp-content/themes/flatsome-child/fonts/Satoshi.woff2') format('woff2-variations');
	font-weight: 100 1000;
	font-stretch: 75% 125%;
	font-style: normal;
	font-display: swap;
}

body, input, textarea, select, button, p, ul {
    font-synthesis: none;
    -moz-font-feature-settings: 'kern';
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    direction: ltr;
    //text-align: justify;
	font-family: 'Satoshi', sans-serif;
}

h1, h2, h3, h4, h5, h6, .widget-title {
	font-family: 'Sentient', serif;
	text-align: left;
}
.centered h1, .centered h2, .centered p {
	text-align: center;
}
b, strong {
	font-weight: 500;
}

@media (max-width: 768px) {
	h1 {
		font-size: 48px;
		line-height: 58px;
	}
}
@media (min-width: 1100px) {
	h1 {
		font-size: 62px;
		line-height: 72px;
	}
	h3 {
		font-size: 20px;
		font-weight: 500;
	}
	body, input, textarea, select, button, p, ul {
		text-align: justify;
	}
}

/* general */
body {
	font-size: 18px;
	font-weight: 300;
	overflow-x: clip;
}
html::-webkit-scrollbar,
body::-webkit-scrollbar {
	width: 10px;
	height: 10px;
}
html::-webkit-scrollbar-track,
body::-webkit-scrollbar-track {
	background: #272727;
	border-radius: 0;
}
html::-webkit-scrollbar-thumb,
body::-webkit-scrollbar-thumb {
	background: linear-gradient(180deg, #acb58c, #acb58c);
	border-radius: 10px;
	border: 2px solid #272727;
}
html::-webkit-scrollbar-thumb:hover,
body::-webkit-scrollbar-thumb:hover {
	background: linear-gradient(180deg, #c9f1a1, #c9f1a1);
}

.col-no-padding .col {
	padding: 0 15px 10px!important;
}
.text-color {
	color: var(--fs-color-primary);
}
.mini-img img {
	height: 280px;
	width: 340px;
	object-fit: cover;
}
.p-ct p {
	font-family: 'Sentient', serif;
	font-size: max(1.5rem, 1.7vw);
	font-weight: 500;
	line-height: 1.125;
	margin-bottom: 0!important;
}
.mapa-st p {
	margin-bottom: -8px!important;
}
@media (min-width: 769px) {
	.col-0 .col {
		padding: 0 15px 15px 0!important;
	}
	.main-title {
		width: 800px;
	}
	.mini-text p {
		width: 400px;
		margin: 0 -100px 0 100px;
	}
}

/* cabecera */
.header-main .nav>li>a {
    font-size: 1rem;
	font-weight: 500;
}
.header .stuck .header-bg-color {
	background-color: rgba(39,39,39,0.85)!important;
}
.no-link>a {
	cursor: default;
}
.nav-dropdown {
	min-width: 340px!important;
	margin-top: 20px;
	font-size: 16px!important;
}
.nav-dropdown.nav-dropdown-default>li>a  {
	border-bottom: none!important;
	font-weight: 500;
}
.header-nav-main {
	gap: 20px;
}
.header-nav .button.is-outline {
	border: 1px solid!important;
}
.header-nav a.button.is-outline {
	line-height: 2.4em!important;
	font-weight: 600;
}
.header-button .primary.is-outline:hover {
	border: 1px solid var(--fs-color-secondary)!important;
	background-color: var(--fs-color-secondary)!important;
	color: #272727;
}

@media (max-width: 768px) {
	a.btn-mb {
		font-size: 27px!important;
	}
}

/* pie */
.absolute-footer {
	display: none !important;
}
#nav_menu-2 ul.menu>li+li, #nav_menu-3 ul.menu>li+li {
	border-top: none!important;
}
#nav_menu-2 ul.menu>li>a, #nav_menu-3 ul.menu>li>a {
	padding: 0!important;
}
.ue-logos div {
	max-width: fit-content;
}
.ue-logos img {
	max-height: 40px;
	object-fit: contain;
	object-position: left;
}
.texto-ue {
	font-size: 14.4px;
	margin-top: 10px;
}
.menu-legal ul {
	display: flex;
    flex-direction: row;
	gap: 20px;
	font-size: 14.4px;
}
.menu-servicios ul {
	column-count: 2;
	column-gap: 20px;
}
.menu-legal .col, .menu-servicios .col {
	padding: 0 0 30px!important;
}
.menu-legal .widget, .menu-servicios .widget {
	margin-bottom: 0!important;
}
.widget-title {
	font-size: 20px;
	padding-bottom: 20px;
}
.menu-servicios a, .datos-contacto p {
	font-size: 16px!important;
}
@media (max-width: 768px) {
	.texto-ue, .widget-title {
		text-align: center;
	}
	.widget-title:after {
		top: 16px!important;
		left: 130px!important;
	}
	.datos-contacto .icon-box {
		width: auto;
	}
	.fila-legal {
		display: flex;
		flex-direction: column-reverse;
	}
	.tuchonet-footer {
		text-align: center;
	}
}

/* botones */
.button.secondary {
	color: #272727!important;
	box-shadow: unset!important;
}
.button.secondary:hover {
	background-color: #dcffb8;
	border: 1px solid #dcffb8;
}
.button.primary.is-outline i.icon-angle-right, .button.secondary i.icon-angle-right {
    transform: translate3d(0%, 0px, 0px) scale3d(1, 1, 1) rotateX(0deg) rotateY(0deg) rotateZ(0deg) skew(0deg, 0deg);
    transform-style: preserve-3d;
	transition: all .3s;
}
.button.primary.is-outline:hover i.icon-angle-right, .button.secondary:hover i.icon-angle-right {
    transform: translate3d(110%, 0px, 0px) scale3d(1, 1, 1) rotateX(0deg) rotateY(0deg) rotateZ(0deg) skew(0deg, 0deg);
    transform-style: preserve-3d;
}

/* deco */
.deco .col-inner .uxb-wrapper {
	width: auto;
}
.decor-line {
	justify-content: center;
	align-items: center;
	width: 53px;
	height: 53px;
	display: flex;
	position: relative;
	transform: translate3d(0px, 0px, 0px) scale3d(1, 1, 1) rotateX(0deg) rotateY(0deg) rotateZ(90deg) skew(0deg, 0deg);
	transform-style: preserve-3d;
}
.horizontal_card .decor-line::after {
	content: "Saber más";
	font-size: 0.85rem;
	font-weight: 500;
	text-transform: uppercase;
	text-align: center;
	text-wrap: nowrap;
	transform: rotate(-90deg) translateY(0px);
	opacity: 0;
	transition: 0.5s;
	padding-top: 10px;
}
.horizontal_card:hover .decor-line::after {
	transform: rotate(-90deg) translateY(35px);
	opacity: 1;
	transition: 0.5s;
}
.decor-line-horizontal {
	background-color: #fff;
	width: 23px;
	height: 1px;
	position: absolute;
}
.line-dark .decor-line-horizontal, .line-dark .decor-line-vertical {
	background-color: #272727!important;
}
.decor-line-horizontal.left {
	inset: auto auto auto 0%;
}
.decor-line-horizontal.right {
	inset: auto 0% auto auto;
}
.decor-line-vertical {
	background-color: #fff;
	width: 1px;
	height: 23px;
	position: absolute;
}
.decor-line-vertical.top {
	inset: 0% auto auto;
}
.decor-line-vertical.bottom {
	inset: auto auto 0%;
}

/* deco titulos */
.label-shape {
    color: var(--fs-color-primary);
    letter-spacing: .05em;
    text-transform: uppercase;
    font-size: max(.8rem, .8vw);
    font-weight: 500;
    line-height: 1.2;
}
.label-shape:before {
	content: "";
    display: inline-block;
    position: relative;
    bottom: 2px;
    left: 0;
	background-color: var(--fs-color-primary);
	width: 5px;
	height: 5px;
	margin-right: 5px;
}
.shape-white {
    color: var(--fs-color-secondary);
    letter-spacing: .05em;
    text-transform: uppercase;
    font-size: max(.8rem, .8vw);
    font-weight: 500;
    line-height: 1.2;
}
.shape-white:before {
	content: "";
    display: inline-block;
    position: relative;
    bottom: 2px;
    left: 0;
	background-color: var(--fs-color-secondary);
	width: 5px;
	height: 5px;
	margin-right: 5px;
}
.shape-dark {
    color: #272727;
    letter-spacing: .05em;
    text-transform: uppercase;
    font-size: max(.8rem, .8vw);
    font-weight: 500;
    line-height: 1.2;
}
.shape-dark:before {
	content: "";
    display: inline-block;
    position: relative;
    bottom: 2px;
    left: 0;
	background-color: #272727;
	width: 5px;
	height: 5px;
	margin-right: 5px;
}
.h2-big h2 {
	font-size: 46px!important;
	line-height: 46px!important;
	margin-bottom: 0!important;
}
.h2-sm h2 {
	font-size: max(1.5rem, 1.7vw);
	font-weight: 500;
	line-height: 1.125;
}
.h2-sm h2:before {
	content: "";
	display: inline-block;
	width: 2px;
	height: 18px;
	transform: skew(-0.06turn, 18deg);
	background: #272727;
	margin-right: 20px;
}
.h2-sm h2:after {
	content: "";
	display: inline-block;
	position: absolute;
	top: 4px;
	left: 6px;
	width: 2px;
	height: 18px;
	transform: skew(-0.06turn, 18deg);
	background: #272727;
}
.widget-title:before {
	content: "";
	display: inline-block;
	width: 1px;
	height: 16px;
	transform: skew(-0.06turn, 18deg);
	background: #fff;
	margin-right: 20px;
}
.widget-title:after {
	content: "";
	display: inline-block;
	position: absolute;
	top: 36px;
	left: 6px;
	width: 1px;
	height: 16px;
	transform: skew(-0.06turn, 18deg);
	background: #fff;
}
@media (max-width: 768px) {
	.bigtxt {
		font-size: 24px!important;
	}
	.h2-big h2 {
		font-size: 40px!important;
		line-height: 40px!important;
	}
}

/* caja servicios */
.horizontal_card .col-inner {
	background-color: #eee;
	border-radius: 3px;
	padding: 30px;
}

/* ContactForm 7 */
form.wpcf7-form{
	background: #272727;
	padding: 2rem 2rem 1rem;
	border-radius: 3px;
}
form.wpcf7-form * {
	transition: 225ms;
}
form.wpcf7-form label {
	display: block;
	width: 100%;
	cursor: pointer;
	color: #acacac;
	font-weight: 500;
}
form.wpcf7-form input,
form.wpcf7-form select,
form.wpcf7-form textarea {
	display: block;
	width: 100%;
	padding: .5em 0;
	margin-bottom: 2rem;
	border: 0;
	border-bottom: 1px solid #acacac;
	border-radius: 0;
	background: transparent;
	font-size: 1rem;
	color: #fff;
	box-shadow: none;
	padding: 0 10px;
}
form.wpcf7-form input:hover,
form.wpcf7-form select:hover,
form.wpcf7-form textarea:hover {
	cursor: pointer;
	border-bottom: 1px solid var(--fs-color-secondary);
}
form.wpcf7-form input:focus,
form.wpcf7-form select:focus,
form.wpcf7-form textarea:focus {
	border-bottom: 1px solid var(--fs-color-secondary);
	box-shadow: none;
	outline: none;
	background: transparent;
	color: #fff;
}

form.wpcf7-form input[type="submit"] {
	padding: 0.5em;
	margin-bottom: 0;
	box-shadow: none;
	background: var(--fs-color-secondary);
	color: #272727;
	line-height: 1.2em;
    display: inline-block;
    margin-right: 1em;
	font-weight: 700;
	border-radius: 3px!important;
	border-bottom: none;
}
form.wpcf7-form input[type="submit"]:hover {
	background: #dcffb8;
	color: #272727;
}
.wpcf7-list-item-label a {
	color: var(--fs-color-primary);!important;
}
span.wpcf7-not-valid-tip {
	position: relative;
	top: -1em;
	color: var(--fs-color-secondary);
}
div.wpcf7-response-output {
	padding: 1em !important;
	margin: 0 !important;
	border-width: 1px!important;
	border-color: var(--fs-color-primary)!important;
	border-radius: 3px!important;
	color: #fff!important;
}
form.wpcf7-form .wpcf7-acceptance label {
	display: inline-flex;
}
form.wpcf7-form .wpcf7-acceptance label input {
	max-width: 50px;
}
/* columnas CF7 */
.cf7-row {
	display: flex;
	flex-wrap: wrap;
	gap: 1.5rem;
}

.cf7-row .cf7-col {
	flex: 1 1 0;
}

@media (max-width: 767px) {
	.cf7-row {
		flex-direction: column;
		gap: 0;
	}
}

div.wpcf7 .ajax-loader {
	display:none;
	background: none;
	-webkit-animation: spin 1s ease-in-out infinite;
	animation: spin 1s cubic-bezier(0.36, 0.09, 0.27, 0.97) infinite;
	border: 3px solid #dedede;
	border-top: 3px solid #000000;
	border-radius: 50%;
	height: 1em;
	width: 1em;
	margin: 0;
	vertical-align: middle;
}
@-webkit-keyframes spin {
  50% {
	border-top-color: #a7005d;
  }
  100% {
	border-top-color: #000000;
	-webkit-transform: rotate(360deg);
	transform: rotate(360deg);
  }
}
@keyframes spin {
  50% {
	border-top-color: #a7005d;
  }
  100% {
	border-top-color: #000000;
	-webkit-transform: rotate(360deg);
	transform: rotate(360deg);
  }
}
.wpcf7-list-item {
	display: block!important;
}