.elementor-64 .elementor-element.elementor-element-1978747{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;border-style:none;--border-style:none;box-shadow:40px 0px 10px 39px rgba(0, 0, 0, 0);}.elementor-64 .elementor-element.elementor-element-1978747:not(.elementor-motion-effects-element-type-background), .elementor-64 .elementor-element.elementor-element-1978747 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-image:url("https://stage.speonz.net/wp-content/uploads/2026/01/Background-scaled.png");background-size:cover;}.elementor-64 .elementor-element.elementor-element-0d07892{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-64 .elementor-element.elementor-element-0d07892:not(.elementor-motion-effects-element-type-background), .elementor-64 .elementor-element.elementor-element-0d07892 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#0F0F0FFA;background-image:url("https://stage.speonz.net/wp-content/uploads/2026/01/Background-2-scaled.png");background-repeat:no-repeat;background-size:cover;}.elementor-64 .elementor-element.elementor-element-3b6f84f{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}body.elementor-page-64:not(.elementor-motion-effects-element-type-background), body.elementor-page-64 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#000000;}/* Start custom CSS for html, class: .elementor-element-dfd1409 */.background {
  position: relative;
  display: grid;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
}

.hero_image {
  grid-area: overflow-content;
  max-width: 100vw;
  max-height: 100vh;
  z-index: -1;
}

.hero_image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  opacity: 0;
}

.testo-animato {
  font-size: 70px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  font-weight: 500;
  
  grid-area: overflow-content;
  text-align: left;
  padding: 0 5vw;
}

.parole {
  display: inline-block;
  overflow: hidden;
  height: 1em;
  vertical-align: bottom;
  position: relative;
  margin-left: 15px;
  color: #8710EA;
  text-shadow: 0px 0px 5px #7F18E2;
  line-height: 1em;
}

.parole span {
  display: block;
  animation: slideUp 8s infinite;
}

@keyframes slideUp {
  0% {
    transform: translateY(0%);
  }

  25% {
    transform: translateY(-100%);
  }

  50% {
    transform: translateY(-200%);
  }

  75% {
    transform: translateY(-300%);
  }

  100% {
    transform: translateY(0%);
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-fc77191 */.flexbox {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    justify-content: center;
    align-items: stretch;
    width: 100%;
    max-width: 1200px;
    margin: 40px auto auto;
    padding: 20px;
    box-sizing: border-box;
    opacity: 0;
}

.box {
    position: relative;
    padding: 20px;
    border: 3px solid rgba(135, 16, 234, 0.25);
    border-radius: 36px;
    background-color: rgba(255, 255, 255, 0.01);
    font-size: clamp(18px, 2vw, 24px);
    box-sizing: border-box;
    min-height: 150px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
}

.box-icon {
    position: absolute;
    top: 10px;
    left: 10px;
    z-index: 2;
}

.box-icon img {
    display: block;
    width: 35px !important;
    height: 35px !important;
}

.box-text {
    padding: 20px;
    color: white;
    font-weight: 500;
    z-index: 1;
}

.tall {
    flex: 1 1 100%;
    max-width: 380px;
    height: auto;
}

.right {
    display: flex;
    flex-direction: column;
    gap: 20px;
    flex: 2 1 600px;
    width: 100%;
    box-sizing: border-box;
}

.row {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
}

.small {
    flex: 1 1 260px;
    min-width: 220px;
    height: auto;
    aspect-ratio: 16 / 9;
}

.wide {
    flex: 1 1 100%;
    min-width: 300px;
    height: auto;
    aspect-ratio: 16 / 6;
}

.flex-title {
    color: rgb(255, 255, 255);
    text-align: center;
    text-shadow: rgb(255, 255, 255) -4px -4px 40px, rgb(255, 255, 255) 8px 8px 40px;
    font-size: 60px;
    margin-bottom: 40px;
    width: 100%;
    opacity: 0;
}

.container {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-top: 80px;
    z-index: 1 !important;
}

@keyframes slideInRight {
    0% {
        opacity: 0;
        transform: translateX(100%);
    }

    100% {
        opacity: 1;
        transform: translateX(0px);
    }
}

@keyframes slideInUp {
    0% {
        opacity: 0;
        transform: translateY(100%);
    }

    100% {
        opacity: 1;
        transform: translateY(0px);
    }
}

.flex-title.animate {
    animation: 0.8s ease-out 0.5s 1 normal forwards running slideInRight;
}

.flexbox.animate {
    animation: 0.8s ease-out 0.5s 1 normal forwards running slideInUp;
}

.box-title {
    font-size: 25px;
}

.box-para {
    font-size: 20px;
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-0d07892 */.elementor-64 .elementor-element.elementor-element-0d07892{
    height: 900px;
}/* End custom CSS */