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

/* tipografia */

h1, h2, h3, h4, h5, h6, .widget-title {
	font-weight: 600;
}
p, ul {
	text-align: justify;
}
b, strong {
	font-weight: 600;
}
.center-section p {
	text-align: center;
}
@media (min-width: 1100px) {
	h1, h2.h1-size {
    font-size: 2.8rem!important;
	}
	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;
	font-weight: 300;
	overflow-x: clip;
}

/* cabecera */


/* helpers */
:root {
  --secondary-color: #EC4213;
}
.highlight {
	/*background: linear-gradient(135deg, rgb(82,244,161), var(--secondary-color));
	text-fill-color: transparent;
	background-clip: text;
	background: -webkit-linear-gradient(135deg, rgb(82,244,161), var(--secondary-color));
	-webkit-text-fill-color: transparent;
	-webkit-background-clip: text;*/
	color: rgb(74,194,240);
}
.rounded img {
	border-radius: 25px;
}

/* tarjetas */
.card {
	padding: 1rem;
	background: #fff;
	border-radius: 25px;
	transition: 0.5s;
}
.card:hover {
	transition: 0.5s;
	transform: scale(1.02);
	box-shadow: 0px 2px 8px rgba(14, 44, 106, 0.15);
}
@media (min-width: 768px) {
	.page-id-251 .card {
		height: 390px;
	}
}

/* efectos */
::-webkit-scrollbar {
	width: 6px;
	background-color: var(--primary-color);
}
::-webkit-scrollbar-thumb {
	background-color: var(--secondary-color);
	border-radius: 4px;
}
svg #wheel {
	animation: scroll ease 2s infinite;
}
@keyframes scroll {
	0% {
		transform: translateY(0);
	}
	30% {
		transform: translateY(60px);
	}
}

/* fixes */
.accordion-title.active {
    background-color: rgb(238 249 254);
    font-weight: 600;
}
.cta-block {
	overflow: hidden;
}
.absolute-footer {
	display: none;
}
.pegado-cta {
	margin-bottom: -120px;
	z-index: 1;
}

/* footer */
.pie {
	font-size: 1rem;
}
.columna-pie {
	padding: 0 15px!important;
}
div#nav_menu-2.col {
	padding: 0!important;
}

#menu-legal.menu {
	display: flex;
	justify-content: space-between;
}
#menu-legal.menu li {
	padding-right: 10px;
}
.widget>ul>li+li, ul.menu>li+li {
	border-top: none!important;
}
.menu-zonas {
	display: flex;
	flex-direction: row;
	align-items: flex-start;
	justify-content: flex-start;
}
.ue-texto {
	font-size: 0.99rem;
	padding-top: 10px;
}
@media (max-width: 768px) {
	#menu-legal.menu {
		display: flex;
		flex-direction: column;
	}

	#menu-legal.menu li {
		text-align: center;
	}
}

/* ContactForm 7 */
form.wpcf7-form{
	background: #eef9fe;
	padding: 2rem 2rem 0;
	border-radius: 25px;
}
form.wpcf7-form * {
	transition: 225ms;
}
form.wpcf7-form label {
	display: block;
	width: 100%;
	cursor: pointer;
}
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 var(--primary-color);
	border-radius: 0;
	background: transparent;
	font-size: 1rem;
	color: var(--primary-color);
	box-shadow: none;
}
form.wpcf7-form input:hover,
form.wpcf7-form select:hover,
form.wpcf7-form textarea:hover {
	cursor: pointer;
	border-bottom: 1px solid var(--secondary-color);
}
form.wpcf7-form input:focus,
form.wpcf7-form select:focus,
form.wpcf7-form textarea:focus {
	border-bottom: 2px solid var(--secondary-color);
	box-shadow: none;
	outline: none;
}

form.wpcf7-form input,
form.wpcf7-form textarea{
	background: rgba(0,0,0,.03));
}

form.wpcf7-form input[type="submit"] {
	padding: 0.5em;
	margin-bottom: 0;
	box-shadow: none;
	background: var(--primary-color);
	color: #fff;
	line-height: 1.2em;
    display: inline-block;
    margin-right: 1em;
	font-weight: 700;
}
form.wpcf7-form input[type="submit"]:hover {
	background-color: var(--secondary-color);
}
span.wpcf7-not-valid-tip {
	position: relative;
	top: -1em;
	color: #EC4213;
}
div.wpcf7-response-output {
	padding: 1em !important;
	margin: 0 !important;
}
form.wpcf7-form .wpcf7-acceptance label {
	display: inline-flex;
}
form.wpcf7-form .wpcf7-acceptance label input {
	max-width: 50px;
}
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: #EC4213;
  }
  100% {
    border-top-color: #000000;
   -webkit-transform: rotate(360deg);
           transform: rotate(360deg);
  }
}
@keyframes spin {
  50% {
    border-top-color: #EC4213;
  }
  100% {
    border-top-color: #000000;
   -webkit-transform: rotate(360deg);
           transform: rotate(360deg);
  }
}
.wpcf7-form-control.g-recaptcha.wpcf7-recaptcha {
    opacity: .75;
}
.wpcf7-list-item {
	display: block!important;
}

/* Datos de contacto */
.datos-contacto .icon-box-left .icon-box-img+.icon-box-text {
	padding-top: .6rem;
}
.titulo-contacto {
	font-size: 1em;
	font-weight: 600;
	letter-spacing: .05em;
	text-transform: uppercase;
	font-family: 'Poppins';
	margin-bottom: 0.25em;
}


/* CLASE LIST-CHECK listados */
/* Elimina el estilo por defecto */
.list-check {
	list-style: none;
	margin: 0;
	padding: 0;
  }
  
  /* Cada elemento de la lista */
  .list-check li {
	position: relative;
	padding-left: 1.8em;
	margin-bottom: 0.8em;
	line-height: 1.4;
  }
  
  /* Inserta un icono de check antes de cada ítem */
  .list-check li::before {
	content: "✔";               /* Unicode para check */
	position: absolute;
	left: 0;
	top: 0;
	font-size: 1.2em;
	color: #EC4213;             /* color principal del branding */
	line-height: 1;
  }
  
  /* Opcional: transición suave al cambiar color */
  .list-check li:hover::before {
	color: #459FB2;
	transition: color 0.3s ease;
  }

/* Aplica naranja solo a los enlaces e iconos del top‑bar que NO sean el botón */
#top-bar .nav a:not(.button),
#top-bar .nav a:not(.button) i {
  color: #EC4213 !important;
}

.box-text-inner h3 {
	font-size: 1.4rem !important;      /* Ajusta a tu gusto */
	line-height: 1.2;
  }

  /* Aseguramos que los <li> de los botones ocupen el 100% y centren su contenido */
.sidebar-menu .nav-sidebar li.html.header-button-1,
.sidebar-menu .nav-sidebar li.html.header-button-2 {
  width: 100%;
  text-align: center;
}

/* Convertimos el contenedor del botón en inline‑block para que el centrado funcione */
.sidebar-menu .header-button {
  display: inline-block;
}

/* Opcional: ajusta márgenes si quieres más espacio arriba/abajo */
.sidebar-menu .html.header-button-1,
.sidebar-menu .html.header-button-2 {
  margin: 1em 0;
}