/*
Theme Name: Hello Elementor Child
Theme URI: https://sharpinfos.com/
Description: Hello Elementor Child is a child theme of Hello Elementor, created by Elementor team
Author: Elementor Team
Author URI: https://sharpinfos.com/
Template: hello-elementor
Version: 1.0.1
Text Domain: hello-elementor-child
License: GNU General Public License v3 or later.
License URI: https://www.gnu.org/licenses/gpl-3.0.html
Tags: flexible-header, custom-colors, custom-menu, custom-logo, editor-style, featured-images, rtl-language-support, threaded-comments, translation-ready
*/

/*
    Add your custom styles here
*/

    .pillars-wrapper {
      position: relative;
      width: 95%;
      text-align: center;
    }

    .pillars-container {
      display: flex;
      justify-content: center;
      align-items: flex-end;
      gap: 80px;
/*       margin-top: 60px; */
    }

    .pillar.active {
      width: 200px;
    }

    .pillar {
      position: relative;
      display: inline-block;
      cursor: pointer;
      width: 125px;
      overflow: hidden;
      transition: transform 0.4s ease;
    }

    .pillar img {
      width: 100%;
      display: block;
      transform-origin: bottom;
      transform: scaleY(0.5);
      transition: transform 0.6s ease-in-out;
    }

    .pillar.active img {
      transform: scaleY(1);
    }

    /* Info box */
    .info-box {
    position: absolute;
    top: 30% !important;
    transform: translateY(-50%) scale(0.95);
    width: 420px;
    min-height: 200px;
    text-align: left;
}
.footer-box .elementor-icon {
    background: radial-gradient(139.15% 157.03% at 0% 50.2%, #485DFF 0%, #7395FF 50%, #5199FE 100%) /* warning: gradient uses a rotation that is not supported by CSS and may not behave as expected */;
}
.footer-box .elementor-widget-icon-list .elementor-icon-list-icon svg {
    fill: none !important;
}

    .info-box.visible {
      opacity: 1;
      pointer-events: auto;
      transform: translateY(-50%) scale(1);
    }

    /* Arrow line + dot */
    .info-box::before {
      content: "";
      position: absolute;
      top: 11%;
      width: 35px;
      height: 1px;
      background: black;
    }
    .info-box::after {
      content: "";
      position: absolute;
      top: calc(11% - 4px);
      width: 8px;
      height: 8px;
      background: black;
      border-radius: 50%;
    }

    /* left side arrow */
    .info-box.left::before { right: -40px; }
    .info-box.left::after { right: -48px; }

    /* right side arrow */
    .info-box.right::before { left: -40px; }
    .info-box.right::after { left: -48px; }

    .info-title {
    font-size: 22px;
    margin-bottom: 12px;
    transform: translateY(10px) !important;
	font-family: 'Brutal Milk No 2';
	margin-top: -3px;
}

    .info-text {
      font-size: 15px;
      line-height: 1.6;
      color: #555;
      opacity: 0;
      transform: translateY(10px);
      transition: opacity 0.4s ease 0.1s, transform 0.4s ease 0.1s;
	  font-family: 'Plus Jakarta Sans';
    }

    .info-box.visible .info-title,
    .info-box.visible .info-text {
      opacity: 1;
      transform: translateY(0);
    }

    .info-title span {
      color: #3366ff;
    }

/* buttons */
a.elementor-size-sm,
button.elementor-size-sm {
    background: linear-gradient(89.99deg, #485DFF 0.01%, #779BFF 56.36%, #5199FE 102.41%);
    background-size: 200% 100%;
    background-position: left center;
    transition: background-position 0.5s ease;
    color: white;
    border: none;
    border-radius: 16px;
    cursor: pointer;
}

a.elementor-size-sm:hover,
button.elementor-size-sm:hover {
    background-position: right center;
}

.cta-btn .elementor-size-sm {
    background-color: #fff !important;
    font-weight: 600;
    display: inline-block;
    transition: all 0.3s ease;
    background: #fff;
    color: #000;
	transition: background 0.4s ease, color 0.4s ease, border 0.4s ease;
}
.cta-btn .elementor-size-sm:hover {
  background: linear-gradient(89.99deg, #485DFF 0.01%, #779BFF 56.36%, #5199FE 102.41%);
  color: #ffffff !important;
  border-color: transparent;
}

.hero{
    background: #050010;
}
.elementor-heading-title span{
    background: linear-gradient(89.99deg, #485DFF 0.01%, #779BFF 56.36%, #5199FE 102.41%);
    -webkit-text-fill-color: transparent;
    background-clip: text;
    color: transparent;
	font-weight: 600;
}
.why span.elementor-icon {
    background: radial-gradient(139.15% 157.03% at 0% 50.2%, #485DFF 0%, #7395FF 50%, #5199FE 100%) /* warning: gradient uses a rotation that is not supported by CSS and may not behave as expected */;
    padding: 20px;
    border-radius: 16px;
}
.how-it-work figure.elementor-image-box-img {
    background: radial-gradient(139.15% 157.03% at 0% 50.2%, #485DFF 0%, #7395FF 50%, #5199FE 100%) /* warning: gradient uses a rotation that is not supported by CSS and may not behave as expected */;
    border-radius: 16px;
}
.how-it-work img.attachment-full.size-full {
    width: 100%;
    padding: 20px;
}
.e-n-accordion-item {
    background: #EFEFF1;
    border-radius: 16px;
    padding: 0 24px;
    border: 1px solid #DADDE3;
}
span.e-n-accordion-item-title-icon {
    padding: 6px;
    background: #fff;
    border-radius: 12px;
}
.login-btn .elementor-size-sm {
    background-color: transparent !important;
    border: 3px solid #4D94FF;
    font-weight: 600;
    display: inline-block;
    transition: all 0.3s ease;
    background: #fff;
    color: #000;
	transition: background 0.4s ease, color 0.4s ease, border 0.4s ease;
}
.login-btn .elementor-size-sm:hover {
  background: linear-gradient(89.99deg, #485DFF 0.01%, #779BFF 56.36%, #5199FE 102.41%);
  color: #ffffff !important;
  border-color: transparent;
}
.signup-btn {
    background: linear-gradient(269.88deg, #5199FE 0.06%, #769BFF 53.3%, #4A60FF 106.54%) !important;
    border-radius: 15px;
}
.e--pointer-double-line .elementor-item:after, .e--pointer-double-line .elementor-item:before, .e--pointer-overline .elementor-item:after, .e--pointer-overline .elementor-item:before, .e--pointer-underline .elementor-item:after, .e--pointer-underline .elementor-item:before {
    width: 50%;
    left: 50%;
    transform: translateX(-50%);
}
.add-bg {
    background: radial-gradient(139.15% 157.03% at 0% 50.2%, #485DFF 0%, #7395FF 50%, #5199FE 100%) /* warning: gradient uses a rotation that is not supported by CSS and may not behave as expected */;
}
.add-bg .elementor-icon-box-wrapper {
    padding: 30px;
}
.sticky-header {
  transition: box-shadow 0.3s ease;
}

.sticky-header.scrolled {
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
}


.elementor-button span.elementor-button-icon {
    font-size: 12px !important;
	margin-left: 6px;
}
.who pre {
    font-size: 15px;
    font-family: 'Brutal Milk No 2';
    background: linear-gradient(89.99deg, #485DFF 0.01%, #779BFF 56.36%, #5199FE 102.41%);
    -webkit-text-fill-color: transparent;
    background-clip: text;
    color: transparent;
	margin-bottom: 0;
}

/* Common base */
.how-it-work h3.elementor-image-box-title {
  position: relative;
  display: inline-block;
  padding-bottom: 20px;
  width: 100%;
}

.how-it-work h3.elementor-image-box-title::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  height: 1px;
  width: 100%;
  background: #343A54; /* base line */
}

.how-it-work h3.elementor-image-box-title::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -1px;
  height: 3px;
  background: #5199FE; /* progress color */
}

/* Individual step progress widths */
#step-1 h3.elementor-image-box-title::after {
  width: 25%;
}
#step-2 h3.elementor-image-box-title::after {
  width: 50%;
}
#step-3 h3.elementor-image-box-title::after {
  width: 75%;
}
#step-4 h3.elementor-image-box-title::after {
  width: 100%;
}

.why .swiper-slide .elementor-element.e-con {
    display: flex;
    flex-direction: column;
    height: 100%;
}
.why .swiper-slide {
    display: flex
;
    align-items: stretch;
}


    /* Mobile responsive */
    @media (max-width: 768px) {
      .pillars-container {
        flex-wrap: nowrap;
        overflow-x: hidden;        /* no scroll */
        justify-content: space-between;
        gap: 8px;
        padding: 0 5px;
      }

      .pillar {
/*         flex: 1 1 20%; */
        width: auto;
        min-width: auto;
      }

      .pillar img {
        transform: scaleY(0.7);
      }

      .info-box {
        position: static;
        transform: none;
        width: 100%;
        margin-top: 120px;
        opacity: 1;
        pointer-events: auto;
        text-align: center;
      }

      .info-box::before,
      .info-box::after {
        display: none;
      }

      .info-title, .info-text {
        opacity: 1;
        transform: none;
      }
    }