.elementor-3812 .elementor-element.elementor-element-ef7b9f0{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-3812 .elementor-element.elementor-element-470647a{--display:flex;}.elementor-3812 .elementor-element.elementor-element-7ff7d26{--spacer-size:90px;}.elementor-3812 .elementor-element.elementor-element-09d1387{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-3812 .elementor-element.elementor-element-b8876b3 > .elementor-widget-container{padding:0px 0px 0px 0px;}.elementor-3812 .elementor-element.elementor-element-a61d984{--display:flex;}.elementor-3812 .elementor-element.elementor-element-1dd204f{--spacer-size:90px;}/* Start custom CSS for html, class: .elementor-element-088d428 */.endpoint-hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: #0b0b0f;
}

/* SPLIT */
.endpoint-bg-left {
  position: absolute;
  left: 0;
  top: 0;
  width: 45%;
  height: 100%;
  background: #0b0b0f;
  z-index: 0;
}

.endpoint-bg-right {
  position: absolute;
  right: 0;
  top: 0;
  width: 55%;
  height: 100%;
  background: linear-gradient(135deg, #ed2839, #000000);
  z-index: 0;
}


.endpoint-container {
  position: relative;
  z-index: 2;
  max-width: 1300px;
  margin: 0 auto;
  width: 100%;
  padding: 80px 20px;

  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
}


.endpoint-content {
  color: white;
}


.endpoint-title {
  font-family: "Merriweather", serif;
  font-size: 4rem;
  font-weight: 700;
  line-height: 1.1;
  margin-bottom: 20px;
  letter-spacing: -1px;

  opacity: 0;
  transform: translateY(40px);
}

.endpoint-title span {
  color: #ed2839;
}

.endpoint-sub {
  font-family: "Open Sans", sans-serif;
  max-width: 500px;
  font-size: 1.1rem;
  color: #c6c6c6;
  line-height: 1.6;

  opacity: 0;
  transform: translateY(40px);
}

/* IMAGEN (Fondo de la imagen principal). */
.endpoint-visual {
  display: flex;
  justify-content: center;
  position: relative;

  opacity: 0;
  transform: translateX(40px);
}


/* OVERLAY */
.endpoint-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    120deg,
    transparent 40%,
    rgba(237,40,57,0.15),
    transparent 60%
  );
  opacity: 0;
  z-index: 1;
}

/* ANIMACIONES */
.endpoint-hero.active .endpoint-title {
  animation: fadeUp 0.8s ease forwards;
}

.endpoint-hero.active .endpoint-sub {
  animation: fadeUp 0.8s ease 0.2s forwards;
}

.endpoint-hero.active .endpoint-visual {
  animation: fadeRight 0.8s ease 0.3s forwards;
}

.endpoint-hero.active .endpoint-overlay {
  animation: fadeIn 1.2s ease forwards;
}

@keyframes fadeUp {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes fadeRight {
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes fadeIn {
  to {
    opacity: 1;
  }
}

/* RESPONSIVE */
@media (max-width: 900px) {
  .endpoint-container {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .endpoint-visual img {
    width: 100%;
    margin-top: 40px;
  }

  .endpoint-title {
    font-size: 2.5rem;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-b8876b3 */.ep-intro {
  position: relative;
  padding: 100px 20px;
  background: #ffffff;
  overflow: hidden;
}


.ep-intro::before {
  content: "";
  position: absolute;
  right: -150px;
  top: -100px;
  width: 400px;
  height: 400px;
  background: radial-gradient(circle, rgba(237,40,57,0.05), transparent 70%);
  z-index: 0;
}

.ep-container {
  position: relative;
  z-index: 2;
  max-width: 1200px;
  margin: 0 auto;

  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 60px;
  align-items: center;
}

.ep-label {
  color: #ed2839;
  letter-spacing: 4px;
  font-size: 0.8rem;
  margin-bottom: 10px;
  font-family: "Open Sans", sans-serif;
}

.ep-title {
  font-size: 2.5rem;
  font-family: "Merriweather", serif;
  color: #0b132b;
  margin-bottom: 20px;
}

.ep-title span {
  color: #ed2839;
}

.ep-desc {
  color: #6b7280;
  line-height: 1.6;
  margin-bottom: 20px;
}

.ep-list {
  list-style: none;
  padding: 0;
  margin-bottom: 30px;
}

.ep-list li {
  margin-bottom: 10px;
  color: #0b132b;
  font-size: 0.95rem;
}

/* MÉTRICAS */
.ep-metrics {
  display: flex;
  gap: 40px;
}

.ep-metrics h3 {
  font-size: 2rem;
  color: #ed2839;
}

.ep-metrics span {
  font-size: 0.8rem;
  color: #6b7280;
}


.ep-right {
  position: relative;
}

.ep-right img {
  width: 100%;
  border-radius: 10px;
  box-shadow: 0 25px 50px rgba(0,0,0,0.2);
}


.ep-badge {
  position: absolute;
  bottom: -20px;
  left: 20px;
  background: #ed2839;
  color: #ffffff;
  padding: 12px 18px;
  border-radius: 8px;
}

.ep-badge h4 {
  margin: 0;
  font-size: 1.4rem;
}

.ep-badge p {
  margin: 0;
  font-size: 0.8rem;
}

@media (max-width: 768px) {
  .ep-container {
    grid-template-columns: 1fr;
  }

  .ep-title {
    font-size: 2rem;
  }

  .ep-metrics {
    flex-direction: column;
    gap: 20px;
  }
}/* End custom CSS */