.tm-soluciones {
  position: relative;
  overflow: hidden;
  margin: 0;
  background: #f4f4f4;
  box-shadow: 0 6px 10px rgba(0, 0, 0, 0.415);
}

.tm-soluciones__background {
  position: absolute;
  inset: 0;
  background: url('/static/img/soluciones/fondo_section.png') center center / cover no-repeat;
  z-index: 0;
}

.tm-soluciones__content {
  position: relative;
  z-index: 1;
  max-width: 1366px;
  min-height: clamp(430px, 48vw, 660px);
  margin: 0 auto;
}

.tm-soluciones__title {
  position: absolute;
  padding-top: 10rem;
  padding-bottom: 200rem;
  padding-left: 0.75rem;
  padding-right: 0.75rem;
  margin: 0;
  color: #2d31a3;
  font-size: clamp(1.3rem, 2.8vw, 3rem);
  font-weight: 700;
  line-height: 1.06;
}

.tm-soluciones__band {
  position: absolute;
  left: 0;
  top: 43.8%;
  width: 60.2%;
  height: 16.9%;
}

.tm-soluciones__list-wrap {
  position: absolute;
  top: 36%;
  width: 46%;
  z-index: 2;
}

.tm-soluciones__list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.tm-soluciones__item {
  display: flex;
  align-items: center;
  gap: clamp(0.35rem, 0.7vw, 0.8rem);
}

.tm-soluciones__item + .tm-soluciones__item {
  margin-top: clamp(0.3rem, 0.65vw, 0.7rem);
}

.tm-soluciones__item-icon {
  width: clamp(1rem, 1.7vw, 1.75rem);
  height: clamp(1rem, 1.7vw, 1.75rem);
  flex: 0 0 auto;
}

.tm-soluciones__item-text {
  color: #fff;
  font-size: clamp(0.76rem, 1.55vw, 1.12rem);
  line-height: 1.15;
}

.tm-soluciones__cta {
  position: absolute;
  left: 5.8%;
  top: 56.1%;
  display: inline-flex;
  width: clamp(92px, 10.4vw, 142px);
  filter: drop-shadow(0 10px 8px rgba(0, 0, 0, 0.35));
  z-index: 2;
}

.tm-soluciones__cta img {
  display: block;
  width: 100%;
  height: auto;
}

.tm-soluciones__line {
  position: absolute;
  background: #3433a5;
  z-index: 1;
}

.tm-soluciones__line--top {
  left: 0;
  top: 42.4%;
  width: 4.2%;
  height: 0.85%;
}

.tm-soluciones__line--bottom {
  left: 41.7%;
  top: 54.4%;
  width: 10.7%;
  height: 0.85%;
}

.tm-soluciones__media {
  position: absolute;
  right: -1.2%;
  top: -5.2%;
  width: 50.8%;
  aspect-ratio: 1;
}

.tm-soluciones__media-backdrop {
  position: absolute;
  left: 8%;
  bottom: 4.8%;
  width: 36%;
  aspect-ratio: 1;
  border-radius: 50%;
  background: rgba(138, 206, 238, 0.42);
}

.tm-soluciones__circle {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: clamp(10px, 1.55vw, 22px) solid #3433a5;
  overflow: hidden;
  background: #d7d7d7;
}

.tm-soluciones__circle::before {
  content: "";
  position: absolute;
  left: 50.9%;
  top: 0;
  width: 1px;
  height: 100%;
  transform: rotate(43deg);
  transform-origin: top center;
  box-shadow: 0 0 0 1px rgba(17, 167, 219, 0.9);
  opacity: 0.9;
}

.tm-soluciones__circle::after {
  content: "";
  position: absolute;
  left: -1.2%;
  top: 28.7%;
  width: 5%;
  height: 21.5%;
  border-radius: 999px;
  background: #fff;
  z-index: 4;
}

.tm-soluciones__circle-ring {
  position: absolute;
  inset: clamp(12px, 1.35vw, 20px);
  border: 2px solid rgba(255, 255, 255, 0.95);
  border-radius: 50%;
  z-index: 3;
}

.tm-soluciones__circle-cut {
  position: absolute;
  left: -4.5%;
  top: 22.8%;
  width: 42%;
  height: 66%;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.98);
  z-index: 2;
}

.tm-soluciones__photo {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
}

@media (max-width: 1100px) {
  .tm-soluciones__content {
    min-height: clamp(420px, 53vw, 590px);
  }

  .tm-soluciones__title {
    width: 35%;
    font-size: clamp(1.15rem, 2.5vw, 2.5rem);
  }

  .tm-soluciones__band {
    width: 61%;
  }

  .tm-soluciones__list-wrap {
    width: 48%;
  }

  .tm-soluciones__item-text {
    font-size: clamp(0.68rem, 1.35vw, 1rem);
  }

  .tm-soluciones__cta {
    width: clamp(82px, 9.5vw, 130px);
  }

  .tm-soluciones__media {
    width: 51%;
    top: -3%;
    right: -2%;
  }
}

@media (max-width: 768px) {
  .tm-soluciones__content {
    min-height: 520px;
  }

  .tm-soluciones__photo {
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center center;
    }

  .tm-soluciones__title {
    top: -6%;
    width: 40%;
    font-size: clamp(1rem, 2.7vw, 1.85rem);
  }

  .tm-soluciones__band {
    top: 43.2%;
    width: 63%;
    height: 17.5%;
  }

  .tm-soluciones__list-wrap {
    left: 1.4%;
    top: 40.5%;
    width: 50%;
  }

  .tm-soluciones__item-text {
    font-size: clamp(0.64rem, 1.55vw, 0.88rem);
  }

  .tm-soluciones__cta {
    top: 58.8%;
    width: 96px;
  }

  .tm-soluciones__line--bottom {
    top: 55.5%;
  }

  .tm-soluciones__media {
    top: 0;
    right: -5%;
    width: 55%;
  }
}

@media (max-width: 520px) {
  .tm-soluciones__content {
    min-height: 470px;
  }

  .tm-soluciones__title {
    width: 44%;
  }

  .tm-soluciones__band {
    top: 44.5%;
    width: 66%;
    height: 19%;
  }

  .tm-soluciones__photo {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
  }

  .tm-soluciones__list-wrap {
    left: 1.4%;
    top: 40.5%;
    width: 54%;
  }

  .tm-soluciones__item {
    gap: 0.3rem;
  }

  .tm-soluciones__item + .tm-soluciones__item {
    margin-top: 0.25rem;
  }

  .tm-soluciones__item-icon {
    width: 0.92rem;
    height: 0.92rem;
  }

  .tm-soluciones__item-text {
    font-size: 0.63rem;
  }

  .tm-soluciones__cta {
    top: 60.8%;
    width: 86px;
  }

  .tm-soluciones__line--bottom {
    left: 41.5%;
    width: 11.5%;
  }

  .tm-soluciones__media {
    top: 2.5%;
    right: -10%;
    width: 63%;
  }

  .tm-soluciones__media-backdrop {
    width: 32%;
  }
}
