/******* Do not edit this file *******
Simple Custom CSS and JS - by Silkypress.com
Saved: Mar 24 2026 | 03:47:08 */
/* =================================================
   1. VARIABLES & TOKENS
================================================= */

/* =================================================
   2. BASE / RESETS UI
================================================= */

*,
*::before,
*::after {
  box-sizing: border-box;
  margin: initial;
  padding: initial;
}

html,
body {
  font-family: var(--e-global-typography-f48ca31-font-family), sans-serif;
}

h1,
h2,
h3,
h4,
h5,
h6,
p,
figure,
blockquote,
dl,
dd {
  margin: 0;
  padding: 0;
}

ul,
ol {
  list-style: none;
  padding: 0;
}

a {
  text-decoration: none;
  color: inherit;
}

img,
picture,
video,
canvas,
svg {
  display: block;
  max-width: 100%;
  width: 100%;
  height: auto;
}

img {
  display: block !important;
  vertical-align: initial;
}

input,
textarea,
select,
button {
  font: inherit;
  color: inherit;
  border: none;
  outline: none;
  background: none;
  padding: 0;
}

button {
  cursor: pointer;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

/* =================================================
   3. UTILITIES
================================================= */
/* ---------- Texto ---------- */
.ui_text--clamp {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.ui_text--1line {
  -webkit-line-clamp: 1;
}

.ui_text--2lines {
  -webkit-line-clamp: 2;
}

.ui_text--3lines {
  -webkit-line-clamp: 3;
}

.ui_text--4lines {
  -webkit-line-clamp: 4;
}

/* ---------- Generales ---------- */

/* ---------- Posicionamiento base ---------- */
.ui_pos-rel {
  position: relative;
}

.ui_pos-abs {
  position: absolute;
  inset: 0;
}

@media (max-width: 767px) {
  .ui_pos-abs>div {
    height: 100%;
  }

}


/* ---------- Media (imagen / video) ---------- */
.ui_pos-abs img,
.ui_pos-abs video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

/* ---------- Caso especial (si realmente lo necesitas) ---------- */
.ui_video {
  position: absolute;
  inset: 0;
}

/* ---------- Overlays ---------- */
.ui_ov {
  position: absolute;
  inset: 0;
}

.ui_ov-000000 {
  background-color: #000000;
}

.ui_ov--0 {
  opacity: 0;
}

.ui_ov--4 {
  opacity: 0.4;
}

.ui_ov--5 {
  opacity: 0.5;
}

.ui_ov--10 {
  opacity: 0.1;
}

.ui_ov--15 {
  opacity: 0.15;
}

.ui_ov--20 {
  opacity: 0.2;
}

.ui_ov--25 {
  opacity: 0.25;
}

.ui_ov--30 {
  opacity: 0.3;
}

.ui_ov--40 {
  opacity: 0.4;
}

.ui_ov--50 {
  opacity: 0.5;
}

.ui_ov--75 {
  opacity: 0.75;
}

.ui_ov--100 {
  opacity: 1;
}

/* ---------- Espaciados ---------- */
/* ===================== */
/* PADDING - BASE */
/* ===================== */

/* General */
.ui_p-20 { padding: 20px; }
.ui_p-26 { padding: 26px; }

/* Horizontal (x) */
.ui_px-38 { padding-inline: 38px; }
.ui_px-58 { padding-inline: 58px; }
.ui_px-88 { padding-inline: 88px; }

/* Vertical (y) */
.ui_py-10 { padding-block: 10px; }
.ui_py-14 { padding-block: 14px; }
.ui_py-20 { padding-block: 20px; }
.ui_py-24 { padding-block: 24px; }
.ui_py-30 { padding-block: 30px; }
.ui_py-34 { padding-block: 34px; }
.ui_py-38 { padding-block: 38px; }
.ui_py-60 { padding-block: 60px; }
.ui_py-70 { padding-block: 70px; }
.ui_py-102 { padding-block: 102px; }

/* Top */
.ui_pt-20 { padding-top: 20px; }
.ui_pt-32 { padding-top: 32px; }
.ui_pt-34 { padding-top: 34px; }
.ui_pt-50 { padding-top: 50px; }
.ui_pt-58 { padding-top: 58px; }
.ui_pt-64 { padding-top: 64px; }
.ui_pt-80 { padding-top: 80px; }
.ui_pt-110 { padding-top: 110px; }
.ui_pt-146 { padding-top: 146px; }
.ui_pt-170 { padding-top: 170px; }
.ui_pt-520 { padding-top: 520px; }

/* Bottom */
.ui_pb-30 { padding-bottom: 30px; }
.ui_pb-40 { padding-bottom: 40px; }
.ui_pb-50 { padding-bottom: 50px; }
.ui_pb-58 { padding-bottom: 58px; }
.ui_pb-78 { padding-bottom: 78px; }
.ui_pb-84 { padding-bottom: 84px; }
.ui_pb-94 { padding-bottom: 94px; }
.ui_pb-132 { padding-bottom: 132px; }

/* Left */
.ui_pl-24 { padding-left: 24px; }
.ui_pl-62 { padding-left: 62px; }
.ui_pl-78 { padding-left: 78px; }

/* Right */
.ui_pr-24 { padding-right: 24px; }
.ui_pr-34 { padding-right: 34px; }
.ui_pr-66 { padding-right: 66px; }
.ui_pr-104 { padding-right: 104px; }


/* ===================== */
/* MEDIA QUERY ≤1200px */
/* ===================== */

@media (max-width: 1200px) {
  .ui_pr-104 { padding-right: 60px; }
}


/* ===================== */
/* MEDIA QUERY ≤1024px */
/* ===================== */

@media (max-width: 1024px) {

  /* General */
  .ui_p-26 { padding: 20px; }

  /* Horizontal */
  .ui_px-38 { padding-inline: 24px; }
  .ui_px-58 { padding-inline: 40px; }
  .ui_px-88 { padding-inline: 48px; }

  /* Vertical */
  .ui_py-14 { padding-block: 12px; }
  .ui_py-20 { padding-block: 16px; }
  .ui_py-24 { padding-block: 20px; }
  .ui_py-30 { padding-block: 20px; }
  .ui_py-34 { padding-block: 24px; }
  .ui_py-38 { padding-block: 28px; }
  .ui_py-60 { padding-block: 45px; }
  .ui_py-70 { padding-block: 50px; }
  .ui_py-102 { padding-block: 60px; }

  /* Top */
  .ui_pt-20 { padding-top: 16px; }
  .ui_pt-32,
  .ui_pt-34 { padding-top: 24px; }
  .ui_pt-58 { padding-top: 40px; }
  .ui_pt-64 { padding-top: 48px; }
  .ui_pt-110 { padding-top: 80px; }
  .ui_pt-146 { padding-top: 110px; }
  .ui_pt-170 { padding-top: 120px; }
  .ui_pt-520 { padding-top: 320px; }
  .ui_pt-50 { padding-top: 35px; }

  /* Bottom */
  .ui_pb-30 { padding-bottom: 20px; }
  .ui_pb-40 { padding-bottom: 30px; }
  .ui_pb-50 { padding-bottom: 35px; }
	.ui_pb-58 {
    padding-bottom: 40px;
  }
  .ui_pb-78 { padding-bottom: 56px; }
  .ui_pb-84,
  .ui_pb-94 { padding-bottom: 60px; }
  .ui_pb-132 { padding-bottom: 90px; }

  /* Left */
  .ui_pl-24 { padding-left: 16px; }
  .ui_pl-62 { padding-left: 30px; }
  .ui_pl-78 { padding-left: 56px; }

  /* Right */
  .ui_pr-24 { padding-right: 16px; }
  .ui_pr-66 { padding-right: 40px; }
  .ui_pr-104 { padding-right: 40px; }
}


/* ===================== */
/* MEDIA QUERY ≤767px */
/* ===================== */

@media (max-width: 767px) {

  /* General */
  .ui_p-26 { padding: 16px; }

  /* Horizontal */
  .ui_px-38 { padding-inline: 16px; }
  .ui_px-58 { padding-inline: 28px; }
  .ui_px-88 { padding-inline: 20px; }

  /* Vertical */
  .ui_py-14 { padding-block: 10px; }
  .ui_py-20 { padding-block: 12px; }
  .ui_py-24 { padding-block: 16px; }
  .ui_py-30 { padding-block: 15px; }
  .ui_py-34 { padding-block: 16px; }
  .ui_py-70 { padding-block: 35px; }
  .ui_py-102 { padding-block: 30px; }

  /* Top */
  .ui_pt-20 { padding-top: 12px; }
  .ui_pt-32,
  .ui_pt-34 { padding-top: 16px; }
  .ui_pt-58 { padding-top: 24px; }
  .ui_pt-64 { padding-top: 32px; }
  .ui_pt-110 { padding-top: 0; }
  .ui_pt-520 { padding-top: 180px; }
  .ui_pt-50 { padding-top: 20px; }

  /* Bottom */
  .ui_pb-30 { padding-bottom: 15px; }
  .ui_pb-40 { padding-bottom: 20px; }
  .ui_pb-50 { padding-bottom: 20px; }
	.ui_pb-58 {
    padding-bottom: 24px;
  }
  .ui_pb-78,
  .ui_pb-84,
  .ui_pb-94 { padding-bottom: 40px; }
  .ui_pb-132 { padding-bottom: 60px; }

  /* Left */
  .ui_pl-24 { padding-left: 12px; }
  .ui_pl-62 { padding-left: 15px; }
  .ui_pl-78 { padding-left: 32px; }

  /* Right */
  .ui_pr-24 { padding-right: 12px; }
  .ui_pr-66 { padding-right: 20px; }
  .ui_pr-104 { padding-right: 16px; }
}

/* Margin */
.ui_mb-4 {
  margin-bottom: 4px;
}

/* ---------- Gap ---------- */

.ui_gap-4 {
  gap: 4px;
}

.ui_gap-8 {
  gap: 8px !important;
}

.ui_gap-10 {
  gap: 10px;
}

.ui_gap-12 {
  gap: 12px;
}

.ui_gap-14 {
  gap: 14px;
}

.ui_gap-16 {
  gap: 16px;
}

.ui_gap-20 {
  gap: 20px;
}

.ui_gap-22 {
  gap: 22px;
}

.ui_gap-28 {
  gap: 28px;
}

.ui_gap-30 {
  gap: 30px;
}

.ui_gap-38 {
  gap: 38px;
}

.ui_gap-40 {
  gap: 40px;
}

.ui_gap-44 {
  gap: 44px;
}

.ui_gap-50 {
  gap: 50px;
}

.ui_gap-62 {
  gap: 62px;
}

.ui_gap-64 {
  gap: 64px;
}

.ui_gap-66 {
  gap: 66px;
}

.ui_gap-74 {
  gap: 74px;
}

.ui_gap-82 {
  gap: 82px;
}

.ui_gap-94 {
  gap: 94px;
}

.ui_gap-102 {
  gap: 102px;
}

@media (max-width: 1200px) {
  .ui_gap-74 {
    gap: 40px;
  }

  .ui_gap-94 {
    gap: 72px;
  }
}

@media (max-width: 1024px) {
  .ui_gap-10 {
    gap: 8px;
  }

  .ui_gap-16 {
    gap: 12px;
  }

  .ui_gap-20 {
    gap: 16px;
  }

  .ui_gap-22 {
    gap: 18px;
  }


  .ui_gap-28 {
    gap: 20px;
  }

  .ui_gap-30 {
    gap: 24px;
  }

  .ui_gap-38 {
    gap: 28px;
  }

  .ui_gap-40 {
    gap: 28px;
  }

  .ui_gap-44 {
    gap: 30px;
  }

  .ui_gap-50 {
    gap: 30px;
  }

  .ui_gap-62 {
    gap: 40px;
  }

  .ui_gap-64 {
    gap: 44px;
  }

  .ui_gap-66 {
    gap: 44px;
  }

  .ui_gap-74 {
    gap: 30px;
  }

  .ui_gap-82 {
    gap: 50px;
  }

  .ui_gap-94 {
    gap: 48px;
  }

  .ui_gap-102 {
    gap: 60px;
  }
}

@media (max-width: 767px) {
  .ui_gap-10 {
    gap: 5px;
  }

  .ui_gap-16 {
    gap: 8px;
  }

  .ui_gap-20 {
    gap: 12px;
  }

  .ui_gap-22 {
    gap: 14px;
  }

  .ui_gap-28 {
    gap: 16px;
  }

  .ui_gap-30 {
    gap: 18px;
  }

  .ui_gap-38 {
    gap: 18px;
  }

  .ui_gap-40 {
    gap: 16px;
  }

  .ui_gap-44 {
    gap: 20px;
  }

  .ui_gap-50 {
    gap: 20px;
  }

  .ui_gap-62 {
    gap: 20px;
  }

  .ui_gap-64 {
    gap: 28px;
  }

  .ui_gap-66 {
    gap: 26px;
  }

  .ui_gap-74 {
    gap: 20px;
  }

  .ui_gap-82 {
    gap: 30px;
  }

  .ui_gap-102 {
    gap: 30px;
  }
}

/* ---------- Bordes / Radio ---------- */
.ui_divider--inset {
  border: 1px solid rgba(0, 0, 0, 0.1);
}

.ui_divider {
  border: 0 solid rgba(0, 0, 0, 0.1);
}

.ui_divider--top {
  border-top-width: 1px;
}

.ui_divider--bottom {
  border-bottom-width: 1px;
}

.ui_divider--left {
  border-left-width: 1px;
}

.ui_divider--right {
  border-right-width: 1px;
}

/* ---------- Overflows ---------- */
.ui_of-hidden {
  overflow: hidden !important;
}

/* ---------- Border Radius ---------- */
.ui_br-4 {
  border-radius: 4px;
}

/* ---------- Imágenes ---------- */
.ui_img-box {
  position: relative;
}

.ui_img-box--cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.ui_img-box--contain img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain;
  display: block;
}

.ui_img-box--h-10 {
  height: 10px;
}

.ui_img-box--h-14 {
  height: 14px;
}

.ui_img-box--h-16 {
  height: 16px;
}

.ui_img-box--h-18 {
  height: 18px;
}

.ui_img-box--h-32 {
  height: 32px;
}

.ui_img-box--h-300 {
  height: 300px;
}

.ui_img-box--h-350 {
  height: 350px;
}

.ui_img-box--h-585 {
  height: 585px;
}

@media (max-width: 1200px) {
  .ui_img-box--h-350 {
    height: 320px;
  }

  .ui_img-box--h-585 {
    height: 520px;
  }
}

@media (max-width: 1024px) {
  .ui_img-box--12 {
    height: 10px;
  }

  .ui_img-box--h-16 {
    height: 14px;
  }

  .ui_img-box--h-18 {
    height: 16px;
  }

  .ui_img-box--h-32 {
    height: 28px;
  }

  .ui_img-box--h-300 {
    height: 220px;
  }

  .ui_img-box--h-350 {
    height: 280px;
  }

  .ui_img-box--h-585 {
    height: 420px;
  }
}

@media (max-width: 767px) {
  .ui_img-box--12 {
    height: 8px;
  }

  .ui_img-box--h-16 {
    height: 12px;
  }

  .ui_img-box--h-18 {
    height: 14px;
  }

  .ui_img-box--h-32 {
    height: 24px;
  }

  .ui_img-box--h-300 {
    height: 160px;
  }

  .ui_img-box--h-350 {
    height: 240px;
  }

  .ui_img-box--h-585 {
    height: 300px;
  }
}

/* ---------- Alturas / Anchos ---------- */
.ui_max-w-170 {
  max-width: 170px;
  width: 100%;
  flex: none !important;
}

.ui_max-w-248 {
  max-width: 248px;
  width: 100%;
  flex: none !important;
}

.ui_max-w-266 {
  max-width: 266px;
  width: 100%;
  flex: none !important;
}

.ui_max-w-742 {
  max-width: 742px;
  width: 100%;
}

.ui_h--100--2 {
  height: 100px;
  width: 100px;
}

.ui_h--180 {
  height: 180px;
}

@media (max-width: 1024px) {}

@media (max-width: 767px) {}

/* Círculo base */
.ui_circulo_180 {
  position: relative;
  width: 180px;
  height: 180px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.ui_svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  transform: rotate(-90deg);
}

.ui_base {
  fill: none;
  stroke: rgba(255, 255, 255, 0.30);
  stroke-width: 2;
}

.ui_progress {
  fill: none;
  stroke: #ffffff;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-dasharray: 301;
  stroke-dashoffset: 301;
}

.ui_progress.animate {
  animation: circleFill 5s linear forwards;
}

@keyframes circleFill {
  to {
    stroke-dashoffset: 0;
  }
}

/* 🔥 Esto permite pausar sin reiniciar */
.ui_circulo_180:hover .ui_progress {
  animation-play-state: paused;
}

.ui_arrow {
  position: relative;
  z-index: 2;
  width: 32px;
}

@media (max-width: 1024px) {
  .ui_circulo_180 {
    width: 150px;
    height: 150px;
  }
}

@media (max-width: 767px) {
  .ui_circulo_180 {
    width: 90px;
    height: 90px;
  }
}

/* =================================================
   4. LAYOUT / CONTENEDORES
================================================= */
.ui_grupo_secciones {
  padding-left: 50px;
  padding-right: 50px;
  width: 100% !important;
  max-width: 100%;
}

.ui_seccion {
  position: relative;
  left: -50px;
  width: calc(100% + 100px);
  padding-right: 50px;
  padding-left: 50px;
}

.ui_seccion--0 {
  padding-left: 0px;
  padding-right: 0px;
}

@media (max-width: 1024px) {
  .ui_grupo_secciones {
    padding-left: 20px;
    padding-right: 20px;
  }

  .ui_seccion {
    left: -20px;
    width: calc(100% + 40px);
    padding: 0 20px;
  }

  .ui_seccion--0 {
    padding: 0;
  }
}

@media (max-width: 767px) {
  .ui_grupo_secciones {
    padding-left: 20px;
    padding-right: 20px;
  }

  .ui_seccion {
    left: -20px;
    width: calc(100% + 40px);
    padding: 0 20px;
  }

  .ui_seccion--0 {
    padding: 0;
  }
}

/* =================================================
   5. COMPONENTES
================================================= */
/* HEADER */
.ui_header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 3;
  background-color: #fff;
}

/* Botones */
.ui_boton {
  max-width: max-content;
  display: -webkit-flex;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 100px;
  gap: 8px;
  padding: 0 24px;
  cursor: pointer;
  border: 1px solid rgba(0, 0, 0, 0.2);
  transition: all 0.3s linear;
}

.ui_boton--lineal {
	background-color: transparent;
	color: #000;
	border: 1px solid #000;
}

/* Altura para los botones */
.ui_boton--h-42 {
  height: 42px;
}

@media (max-width: 1024px) {
  .ui_boton {
    padding: 0 20px;
    gap: 6px;
  }
}

@media (max-width: 767px) {
  .ui_boton {
    padding: 0 18px;
  }
}

/* SEO */
.ui_seo__gray {
  position: absolute;
  top: -102px;
  left: 0;
  width: 50%;
  height: calc(100% + 204px);
  background-color: #F4F4F4;
}

.ui_seo__gray::after {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  z-index: 0;
  width: 10000%;
  height: 100%;
  background-color: #F4F4F4;
}

@media (max-width: 767px) {
  .ui_seo__gray {
    display: none;
  }
}

/* FOOTER */

.ui_footer_logotipo_absolute {
  position: absolute;
  bottom: calc(100% - 10px);
  left: 0;
}

@media (max-width: 1200px) {
  .ui_gap-38 {
    gap: 8px;
  }
}

@media (max-width: 767px) {


  .ui_footer .ui_max-w-248 {
    max-width: 100%;
  }

  .ui_footer .ui_pl-62 {
    padding-left: 0px;
  }

  .ui_footer .ui_pr-34 {
    padding-right: 0px;
  }

  .ui_footer .ui_max-w-170 {
    max-width: 100%;
  }

  .ui_footer .ui_gap-66 {
    gap: 10px;
  }

  .ui_footer_logotipo_absolute {
    position: relative;
  }

  .ui_footer .ui_max-w-266 {
    max-width: 180px;
  }
}

/* =================================================
   6. EFECTOS & ANIMACIONES
================================================= */

/* =================================================
   7. SECCIONES / PÁGINAS
================================================= */
/* INICIO - SECCION NOSOTROS*/

.ui_inicio_bg_nosotros {
  position: relative;
}

.ui_inicio_bg_nosotros::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 10000%;
  height: 100%;
  background-position: center;
  background-repeat: repeat;
  background-image: url("/wp-content/uploads/2026/03/inicio-textura-nosotros.webp");
}

/* BLOG */



/* =================================================
   8. PLUGINS (Swiper, JetEngine, etc)
================================================= */

/* =================================================
   9. FORMULARIOS
================================================= */
/* --- Estructura base --- */
.ui_contacto {
  display: flex;
  flex-direction: column;
}

.ui_contacto {
  gap: 10px;
}

.ui_contacto label,
.ui_form_text_13 {
  font-family: var(--e-global-typography-2e8d700-font-family), Sans-serif;
  font-size: var(--e-global-typography-2e8d700-font-size);
  line-height: var(--e-global-typography-2e8d700-line-height);
}

/* --- Filas y campos --- */
.ui_form__row {
  display: flex;
  gap: 20px;
}

.ui_form__col {
  width: 100%;
}

.ui_form__col p {
  display: -webkit-flex;
  display: flex;
  flex-direction: column;
}

.ui_form__buscar input {
  border: none !important;
  outline: none !important;
}

.ui_form__buscar .jet-ajax-search__submit-icon {
  width: 11px;
  height: 11px;
  background-image: url('/wp-content/uploads/2026/03/icono_buscar.svg');
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}

.ui_form__buscar .jet-ajax-search__submit-icon svg {
  display: none;
}

body input[type="search"]:focus,
body select:focus {
  outline: none !important;
  border: none !important;
}

.ui_form__row p {
  display: -webkit-flex;
  display: flex;
  width: 100%;
  gap: 16px;
  height: auto;
}

.ui_form__row--column p {
  flex-direction: column;
}

.ui_form__row p span {
  width: 100%;
}

.ui_form__row br {
  display: none;
}

.ui_form__row .wpcf7-form-control {
  display: -webkit-flex;
  display: flex;
}

.ui_form__row .wpcf7-form-control span {
  max-width: max-content;
}

.ui_form__row .wpcf7-form-control label {
  display: -webkit-flex;
  display: flex;
  align-items: center;
}

.ui_form__row .wpcf7-form-control input {
  position: relative;
  top: 0;
  left: 0;
  width: initial;
  flex: initial;
}

.ui_blog_pagination .prev .jet-filters-pagination__link,
.ui_blog_pagination .next .jet-filters-pagination__link {
  width: 5px;
  height: 12px;
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  font-size: 0px !important;
  color: transparent;
  padding: 0px !important;
}

.ui_blog_pagination .prev .jet-filters-pagination__link {
  background-image: url('/wp-content/uploads/2026/03/icono_paginacion_left.svg');
}

.ui_blog_pagination .next .jet-filters-pagination__link {
  background-image: url('/wp-content/uploads/2026/03/icono_paginacion_right.svg');
}

@media (max-width: 1024px) {
  .ui_form__row {
    gap: 16px;
  }
}

/* --- Inputs, selects, textareas --- */
body input,
body form select,
body form textarea {
  width: 100%;
  height: 40px;
  border: none !important;
  outline: none;
  padding: 10px 16px !important;
  border-radius: 50px !important;
  border: 1px solid rgba(0, 0, 0, 0.3) !important;
  font-family: var(--e-global-typography-472e64d-font-family), Sans-serif;
  font-size: var(--e-global-typography-472e64d-font-size);
  line-height: var(--e-global-typography-472e64d-line-height);
  color: var(--e-global-color-d490cd1);
  text-transform: initial;
  resize: vertical;
  transition: border 0.2s ease;
  flex: 0 0 100%;
}

body form textarea {
  height: 80px;
  border-radius: 16px !important;
}

input:focus,
textarea:focus,
select:focus {
  border: 1px solid #000 !important;
}

input[type="search"]:focus {
  border: none !important;
}

body .ui_form--libro input,
body .ui_form--libro select,
body .ui_form--libro textarea {
  height: 46px;
}

body input[type="submit"] {
  border: none !important;
  color: #fff;
  text-align: center;
}

body input[type="submit"]:hover {
  color: var(--e-global-color-5f3de8d);
}

body input[type="file"] {
  height: auto;
  border-bottom: none !important;
}

/* --- Radio --- */
body input[type="radio"] {
  border-radius: 50%;
  vertical-align: middle;
}

body input[type="radio"]:checked::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 12px;
  height: 12px;
  background: var(--color-violet-eggplant-600);
  border-radius: 50%;
  transform: translate(-50%, -50%);
}

.ui_boton--h-40 {
  height: 40px;
}


body select {
  background-image: url('/wp-content/uploads/2026/03/icono_select.svg')!important;
  background-repeat: no-repeat!important;
  background-position: right 12px center!important;
  background-size: 8px!important;
	appearance: none;         /* estándar */
  	-webkit-appearance: none; /* Chrome/Safari */
  	-moz-appearance: none;    /* Firefox */
  	background: none;         /* opcional: elimina fondo */
}

/* Boton */
.ui_boton_form {
  position: relative;
}

.ui_boton_form--full {
  width: 100%;
}

.ui_boton_form--full .ui_boton {
  width: 100%;
  max-width: 100%;
}

.ui_boton_form input {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  max-width: 100%;
  opacity: 0;
}

/* 🔥 LA MAGIA */
.ui_boton.is-hover {
  background: #000 !important;
}

.ui_boton-100 {
  max-width: 100%;
}

/* --- Textarea grande --- */
.ui_textarea {
  min-height: 64px;
}

/* --- Campo archivo --- */
.ui_form__field.ui_form__field--file {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-direction: row;
  gap: 12px;
  padding: 18px 24px;
  background-color: rgba(100, 80, 68, 0.05);
  border-radius: 50px;
}

body .ui_form__field--file input[type="file"] {
  background: transparent;
  border: none;
  outline: none;
  padding: 0;
  cursor: pointer;
}

body .ui_form__field--file input[type="file"]::-webkit-file-upload-button,
body .ui_form__field--file input[type="file"]::file-selector-button {
  background: transparent;
  border: none;
  padding: 0;
  cursor: pointer;
}

/* --- Checkbox --- */
body .wpcf7-list-item {
  padding-left: 0px;
  margin: 0px;
  font-family: var(--e-global-typography-4f2d98a-font-family), Sans-serif;
  font-size: var(--e-global-typography-4f2d98a-font-size);
  line-height: var(--e-global-typography-4f2d98a-line-height);
  color: var(--e-global-color-d490cd1);
}

body .wpcf7-list-item label {
  position: relative;
  display: -webkit-flex;
  gap: 8px;
  width: 100%;
}

body .wpcf7-list-item label input {
  position: absolute;
  left: 0;
  top: -4px;
}

body .wpcf7-list-item a {
  text-decoration: underline;
  color: var(--color-645044);
}

body .wpcf7-list-item a:hover {
  color: var(--color-645044);
}

/* Checkbox base */
body .wpcf7-list-item input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;

  width: 16px !important;
  height: 16px !important;
  border-radius: 0px !important;
  border: 1px solid #B3B3B3 !important;
  padding: 0px !important;
  flex: 0 0 auto;

  background: transparent;
  cursor: pointer;

  position: relative;
  /* IMPORTANTE */
  display: inline-block;
  /* IMPORTANTE */
  vertical-align: middle;
}

/* error */
body .wpcf7-not-valid-tip {
  font-family: var(--e-global-typography-472e64d-font-family), Sans-serif;
  font-size: var(--e-global-typography-472e64d-font-size);
  line-height: var(--e-global-typography-472e64d-line-height);
  color: #000 !important;
}

/* Hover */
body .wpcf7-list-item input[type="checkbox"]:hover {
  border-color: #B3B3B3 !important;
}

/* Check */
body .wpcf7-list-item input[type="checkbox"]:checked::after {
  content: "";
  position: absolute;
  left: 4px;
  top: 2px;
  width: 5px;
  height: 9px;
  border: solid #000;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}


/* Overrides en modo libro */
.ui_form--libro input[type="radio"],
.ui_form--libro .ui_checkbox_group input[type="checkbox"] {
  border-color: var(--color-645044);
}

.ui_form--libro input[type="radio"]:checked::before {
  background-color: var(--color-645044);
}

.ui_form__file {
  display: -webkit-flex;
  display: flex;
  align-items: center;
}

.ui_form__file * {
  color: var(--color-645044);
}

.ui_form__file input {
  height: auto;
  text-transform: uppercase;
}

/* --- CF7 --- */
body .wpcf7-spinner {
  display: none;
  position: absolute;
  left: calc(100% - 20px);
  width: 15px;
  height: 15px;
  overflow: hidden;
}

body .wpcf7-not-valid-tip,
body .wpcf7 form .wpcf7-response-output {
  font-family: var(--e-global-typography-2e8d700-font-family), Sans-serif;
  font-size: var(--e-global-typography-2e8d700-font-size);
  line-height: var(--e-global-typography-2e8d700-line-height);
  color: #101010;
}

body .wpcf7 form .wpcf7-response-output {
  margin: 0;
  padding: 10px;
  border: 1px solid var(--color-645044) !important;
  font-family: var(--e-global-typography-2e8d700-font-family), Sans-serif;
  font-size: var(--e-global-typography-2e8d700-font-size);
  line-height: var(--e-global-typography-2e8d700-line-height);
  color: #101010;
}

body .wpcf7 form .wpcf7-mail-sent-ok {
  border-color: #40C02B;
  color: #40C02B;
}

/* --- Responsive --- */
@media (max-width: 1024px) {

  body .ui_input,
  body .ui_select,
  body .ui_textarea,
  .ui_form select {
    height: 42px;
  }
}

@media (max-width: 767px) {

  body .ui_input,
  body .ui_select,
  body .ui_textarea,
  .ui_form select {
    height: 40px;
  }

  .ui_form--libro {
    gap: 30px;
  }

  .ui_form__buscar.ui_pl-24 {
    padding-left: 0px;
    border: none;
  }

  .ui_pr-24 {
    padding-right: 0px;
  }

}

/* Newsletter */
.ui_newsletter {
  position: relative;
}

/* .ui_newsletter::before {
	content: '';
	position: absolute;
	left:100%;
	top:0;
	width: 100%;
	height: 100%;
	background-color: #F2F2F2;
}

.ui_newsletter::after {
	content: '';
	position: absolute;
	right:100%;
	top:0;
	width: 100%;
	height: 100%;
	background-color: #F2F2F2;
} */

.ui_contacto.newsletter .ui_form__row p {
  display: -webkit-flex;
  display: flex;
  align-items: flex-end;
}

.ui_contacto.newsletter>div:first-child p .wpcf7-form-control-wrap::before {
  content: 'Correo electrónico*';
  position: absolute;
  bottom: calc(100% + 3px);
  left: 0;
  display: block;
  font-family: var(--e-global-typography-2e8d700-font-family), Sans-serif;
  font-size: var(--e-global-typography-2e8d700-font-size);
  line-height: var(--e-global-typography-2e8d700-line-height);
  color: #000;
}

.ui_contacto.denuncia .ui_text {
  font-family: var(--e-global-typography-5508ca2-font-family), Sans-serif;
  font-size: var(--e-global-typography-5508ca2-font-size);
  line-height: var(--e-global-typography-5508ca2-line-height);
  color: #000;
}

.ui_contacto.denuncia .ui_upload_box span {
  font-family: var(--e-global-typography-5508ca2-font-family), Sans-serif;
  font-size: var(--e-global-typography-5508ca2-font-size);
  line-height: var(--e-global-typography-5508ca2-line-height);
  color: #4D4D4D;
}

body .wpcf7-acceptance .wpcf7-list-item-label {
  cursor: pointer;
}

.ui_newsletter_single .ui_form__row {
  flex-direction: column;
}

.ui_newsletter_single .ui_boton {
  max-width: 100%;
  width: 100%;
  justify-content: center;
}

.ui_newsletter_single .ui_boton p {
  max-width: max-content;
}

@media (max-width: 1024px) {
  .ui_contacto.newsletter .ui_form__row {
    flex-direction: column;
  }

  .ui_contacto.newsletter .ui_form__row p {
    display: block;
  }

  .ui_contacto.newsletter .ui_form__row .ui_boton {
    width: 100%;
    max-width: 100%;
  }

}


/* SINGLE POST */
.ui_li_seo_paragraph ul li {
  position: relative;
  padding-left: 16px;
}

.ui_li_seo_paragraph ul li::after {
  content: "";
  position: absolute;
  left: 0;
  top: 8px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background-color: #000;
}

.ui_li_seo_paragraph.border>* {
  padding-left: 24px;
  padding-right: 24px;
}

.ui_li_seo_paragraph.border {
  position: relative;
}

.ui_li_seo_paragraph.border::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  width: 1px;
  height: 100%;
  background: #E6E6E6;
  transform: translateX(-50%);
}

.ui_li_seo_paragraph h2 {
  font-size: var(--e-global-typography-b320fab-font-size);
  line-height: var(--e-global-typography-b320fab-line-height);
  color: var(--e-global-color-e919e2a);
}

.ui_li_seo_paragraph h3,
.ui_li_seo_paragraph h4,
.ui_li_seo_paragraph h5,
.ui_li_seo_paragraph h6 {
  font-family: var(--e-global-typography-652337f-font-family), Sans-serif;
  font-size: var(--e-global-typography-652337f-font-size);
  line-height: var(--e-global-typography-652337f-line-height);
  color: var(--e-global-color-e919e2a);
}

.ui_li_seo_paragraph .jet-listing-grid>div {
  padding-bottom: 16px !important;
  padding-top: 16px !important;
  border-bottom: 1px solid #E6E6E6;
}

.ui_li_seo_paragraph .jet-listing-grid>div:last-child {
  border-bottom: none;
}

/* Espacio entre párrafos */
.ui_li_seo_paragraph p+p {
  margin-top: 1em;
}

/* Espacio entre título y párrafo (incluye elementos intermedios como <span>) */
.ui_li_seo_paragraph h1~p,
.ui_li_seo_paragraph h2~p,
.ui_li_seo_paragraph h3~p,
.ui_li_seo_paragraph h4~p,
.ui_li_seo_paragraph h5~p,
.ui_li_seo_paragraph h6~p {
  margin-top: 0.75em;
  /* espacio arriba del párrafo que sigue a un título */
}

/* Espacio entre párrafo y título (maneja spans intermedios) */
.ui_li_seo_paragraph p~h1,
.ui_li_seo_paragraph p~h2,
.ui_li_seo_paragraph p~h3,
.ui_li_seo_paragraph p~h4,
.ui_li_seo_paragraph p~h5,
.ui_li_seo_paragraph p~h6 {
  margin-top: 1.5em;
  /* espacio arriba del título que sigue a un párrafo */
}

/* Espacio entre títulos consecutivos */
.ui_li_seo_paragraph h1~h1,
.ui_li_seo_paragraph h2~h2,
.ui_li_seo_paragraph h3~h3,
.ui_li_seo_paragraph h4~h4,
.ui_li_seo_paragraph h5~h5,
.ui_li_seo_paragraph h6~h6 {
  margin-top: 1.5em;
}

/* Espacio entre imágenes y otros elementos */
.ui_li_seo_paragraph img {
  display: block;
  margin: 1.5em 0;
}

/* Espacio entre listas y otros elementos */
.ui_li_seo_paragraph ul,
.ui_li_seo_paragraph ol {
  margin: 1em 0;
  /* espacio arriba y abajo de la lista */
  padding-left: 1.5em;
  /* indentación de la lista */
}

/* Espacio entre párrafo y lista */
.ui_li_seo_paragraph p+ul,
.ui_li_seo_paragraph p+ol {
  margin-top: 1em;
  /* espacio arriba de la lista que sigue a un párrafo */
}

/* Espacio entre lista y párrafo */
.ui_li_seo_paragraph ul+p,
.ui_li_seo_paragraph ol+p {
  margin-top: 1em;
  /* espacio arriba del párrafo que sigue a una lista */
}

/* Espacio entre listas consecutivas */
.ui_li_seo_paragraph ul+ul,
.ui_li_seo_paragraph ol+ol,
.ui_li_seo_paragraph ul+ol,
.ui_li_seo_paragraph ol+ul {
  margin-top: 1em;
  /* espacio entre listas consecutivas */
}

@media (max-width: 1024px) {
  .ui_li_seo_paragraph.border::before {
    display: none;
  }
}

/* Social Blog */
.ui_social_single {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background-color: #f4f4f4;
}

.ui_tabla_contenido .elementor-toc__header {
  padding-bottom: 16px;
}

.ui_tabla_contenido .elementor-toc__body {
  padding-top: 24px;
  padding-bottom: 24px;
}

/* =================================================
   10. MEDIA QUERIES GLOBALES
================================================= */



/* TABS PROYECTO HOME */
/* =========================
   WRAPPER
========================= */
.proyectos-wrapper {
  width: 100%;
  padding: 60px 20px;
  box-sizing: border-box;
}

.proyectos-grid {
  display: -webkit-flex;
	display: flex;
	align-items: stretch;
  gap: 60px;
  align-items: center;
}

/* =========================
   IMAGEN
========================= */
.proyectos-imagen {
  position: relative;
  overflow: hidden;
  border-radius: 20px;
}

#imagen-activa {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 20px;
  transition: opacity 0.5s ease, transform 0.6s ease;
}

/* animación suave */
.proyectos-imagen.animando #imagen-activa {
  opacity: 0;
  transform: scale(1.05);
}

/* =========================
   LISTA
========================= */
.proyectos-lista {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* =========================
   ITEM
========================= */
.proyecto-item {
  border-bottom: 1px solid #e5e5e5;
  padding-bottom: 20px;
  cursor: pointer;
}

/* =========================
   HEADER
========================= */
.proyecto-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.titulo-box {
  display: flex;
  flex-direction: column;
  gap: 4px;
	align-items: flex-start;
	position: relative;
}

.titulo-box h3 {
	font-family: var(--e-global-typography-2ac25fb-font-family), Sans-serif;
    font-size: var(--e-global-typography-2ac25fb-font-size);
    line-height: var(--e-global-typography-2ac25fb-line-height);
}

/* NUMERO */
.numero {
  font-family: var(--e-global-typography-eb480b6-font-family), Sans-serif;
    font-size: var(--e-global-typography-eb480b6-font-size);
    line-height: var(--e-global-typography-eb480b6-line-height);
  color: #101010;
	position: absolute;
	left:0;
}

/* TITULO */
.proyecto-item h3 {
  font-size: 22px;
  margin: 0;
  transition: all 0.3s ease;
}

/* DISTRITO */
.distrito {
  font-family: var(--e-global-typography-2e8d700-font-family), Sans-serif;
    font-size: var(--e-global-typography-2e8d700-font-size);
    line-height: var(--e-global-typography-2e8d700-line-height);
  color: #101010;
  margin: 0;
	text-transform: uppercase;
}

/* =========================
   ESTADO (SOLO ACTIVO)
========================= */
.estado-top {
  display: none;
  font-size: 12px;
  color: #000;
  opacity: 0;
	background-color: #FFC629;
	font-family: var(--e-global-typography-31c7e28-font-family), Sans-serif;
    font-size: var(--e-global-typography-31c7e28-font-size);
    line-height: var(--e-global-typography-31c7e28-line-height);
  transform: translateY(-6px);	
	width: auto;
	padding: 3px 12px;
	border-radius: 50px;
	text-transform: uppercase;
}

/* SOLO CUANDO ESTA ACTIVO */
.proyecto-item.active .estado-top {
  display: inline-block;
  opacity: 1;
  transform: translateY(0);
  animation: fadeEstado 0.3s ease;
}

/* animación */
@keyframes fadeEstado {
  from {
    opacity: 0;
    transform: translateY(-6px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* =========================
   CIRCULO (SOLO ACTIVO)
========================= */
.circulo {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: #000;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;

  opacity: 0;
  transform: scale(0.6) rotate(-90deg);
  transition: all 0.3s ease;
}

.proyecto-item.active .circulo {
  opacity: 1;
  transform: scale(1) rotate(0deg);
}

/* =========================
   BODY (SIN OCUPAR ESPACIO)
========================= */
.proyecto-body {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: all 0.4s ease;
}

/* SOLO ACTIVO */
.proyecto-item.active .proyecto-body {
  max-height: 300px;
  opacity: 1;
  margin-top: 15px;
}

/* =========================
   DATOS
========================= */
.datos {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
	color: #101010;
	font-family: var(--e-global-typography-eb480b6-font-family), Sans-serif;
    font-size: var(--e-global-typography-eb480b6-font-size);
    line-height: var(--e-global-typography-eb480b6-line-height);
}

.dato {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  color: #333;
}

.icono img {
  width: 18px;
  height: 18px;
  object-fit: contain;
}

/* PRECIO */
.precio {
  flex-direction: column;
  align-items: flex-start;
}

.precio .label {
  font-size: 12px;
  color: #999;
}

.precio .valor {
  font-size: 16px;
  font-weight: 600;
}

/* =========================
   HOVER
========================= */
.proyecto-item:hover h3 {
  transform: translateX(6px);
}

/* =========================
   RESPONSIVE TABLET
========================= */
@media (max-width: 1024px) {

  .proyectos-grid {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  .proyectos-imagen {
    order: -1;
  }

}

/* =========================
   RESPONSIVE MOBILE
========================= */
@media (max-width: 768px) {

  .proyectos-wrapper {
    padding: 40px 15px;
  }

  .proyecto-item h3 {
    font-size: 18px;
  }

  .datos {
    flex-direction: column;
    gap: 12px;
  }

  .circulo {
    width: 34px;
    height: 34px;
    font-size: 12px;
  }

}

/* =========================
   RESPONSIVE SMALL
========================= */
@media (max-width: 480px) {

  .proyecto-item {
    padding-bottom: 15px;
  }

  .numero {
    font-size: 12px;
  }

  .distrito {
    font-size: 12px;
  }

  .precio .valor {
    font-size: 14px;
  }

}