/* ------ large and medium devices (dekstops and laptops, 1800px and up) -----*/
@media (min-width: 1800px) {
  html {
    font-size: 62.5%;
  }
  .container {
    max-width: 138.2rem;
  }
  .container_xl {
    max-width: calc(172.8rem - 6.5rem);
  }
}

/* ------ large and medium devices (dekstops and laptops, 1800px and up) -----*/
@media (min-width: 992px) and (max-width: 1799.98px) {
  html {
    font-size: 0.5787037037vw;
  }
  .container {
    max-width: 138.2rem;
  }
  .container_xl {
    max-width: calc(172.8rem - 6.5rem);
  }
}

/* ------ large and medium devices (dekstops and laptops, 991px and up) -----*/
@media (min-width: 991px) {
  .brand_slider_main_wrapper .col-3 {
    width: 22%;
  }

  .brand_slider_main_wrapper .col-9 {
    width: 78%;
  }

  .brand_slider_wrap {
    transform: translateX(-3rem);
  }
}

/* ------ Medium devices (tablets, 991px and down) -----*/
@media (max-width: 991px) {
  html {
    font-size: 50%;
  }

  .container {
    padding: 0;
  }

  .container-fluid,
  .menu_container {
    width: 720px;
  }

  .col-md-0 {
    width: 0;
    padding: 0;
  }

  /* =========== Header area ========== */
  .primary_menu {
    position: fixed;
    width: 100%;
    height: 100%;
    top: 0;
    justify-content: flex-end;
    align-content: space-between;
    padding: 0;
    pointer-events: none;
    overflow: auto;
    left: 50%;
    transform: translateX(-50%);
  }

  .primary_menu::-webkit-scrollbar {
    scrollbar-width: 0;
    display: none;
  }

  .menu_active .primary_menu {
    pointer-events: all;
  }

  .main_menu {
    flex-direction: column;
    gap: 3rem;
    align-items: flex-start !important;
  }

  .main_menu li a {
    font-size: 3.2rem;
    letter-spacing: -0.03em;
    line-height: 1;
  }

  body.menu_active {
    overflow: hidden !important;
  }

  .menu_overlay {
    width: 200vw;
    height: 200vh;
    content: "";
    background: rgb(255, 255, 255);
    position: fixed;
    left: -200vw;
    top: 50%;
    transform: translateY(-50%);
    border-radius: 0 50% 50% 0;
    transition: all 1.5s cubic-bezier(0.68, 0, 0.27, 1.55); /* elastic wave effect */
    z-index: 1;
  }

  .menu_active .menu_overlay {
    left: -50vw;
  }

  .menu_container {
    transition: 0.25s ease;
    transform: translateX(-2rem);
    opacity: 0;
    pointer-events: none;
  }

  .menu_active .menu_container {
    transform: translateX(0);
    opacity: 1;
    pointer-events: all;
    transition-delay: 1.05s;
  }

  /* ============== Hamburger ============= */
  .hamburger img {
    width: 2.8rem;
    position: absolute;
    transition: 0.35s ease;
  }

  .hamburger .close_icon {
    width: 2.8rem;
    opacity: 0;
    transform: scale(0.5);
    filter: brightness(0) saturate(100%) invert(6%) sepia(49%) saturate(2769%)
      hue-rotate(246deg) brightness(84%) contrast(96%);
  }

  .hamburger {
    width: 2.8rem;
    height: 2.8rem;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    z-index: 999;
  }

  .menu_active .hamburger .close_icon {
    opacity: 1;
    transform: scale(1);
    filter: brightness(0) saturate(100%) invert(7%) sepia(18%) saturate(5515%)
      hue-rotate(241deg) brightness(95%) contrast(97%);
  }

  .menu_active .hamburger .Hamburger_icon {
    opacity: 0;
    transform: scale(0.5);
  }

  .sticky .hamburger .Hamburger_icon {
    filter: brightness(0) saturate(100%) invert(6%) sepia(49%) saturate(2769%)
      hue-rotate(246deg) brightness(84%) contrast(96%) !important;
  }

  body.menu_active .logo img {
    filter: brightness(0) saturate(100%) invert(7%) sepia(18%) saturate(5515%)
      hue-rotate(241deg) brightness(95%) contrast(97%);
  }

  /* ================= */
  .menu_bottom .hero_right {
    justify-content: space-between;
    padding: 4rem 0 12rem;
  }

  .menu_bottom {
    flex-direction: column;
    border-top: 0.1rem solid #1c112f;
  }

  .menu_bottom .fbr_bottom {
    padding-top: 0;
  }

  .menu_bottom .social_links a img {
    filter: brightness(0) saturate(100%) invert(4%) sepia(35%) saturate(6491%)
      hue-rotate(256deg) brightness(85%) contrast(93%);
  }

  .menu_bottom .fbr_bottom p {
    font-size: 1.4rem;
    line-height: 2.8rem;
  }

  .main_menu {
    padding: 12rem 0 5rem 0;
  }

  .menu_bottom {
    padding-bottom: 4.5rem;
  }

  .menu_link img {
    width: 2.5rem;
    display: none !important;
  }

  .menu_link.active img {
    display: block !important;
  }

  .menu_link {
    display: flex;
  }

  .site_header.sticky .main_menu li a.active {
    filter: brightness(0) saturate(100%) invert(83%) sepia(53%) saturate(5758%)
      hue-rotate(213deg) brightness(98%) contrast(97%);
  }

  .main_menu li a:hover,
  .main_menu li a.active {
    color: #b18cf5 !important;
    filter: brightness(0) saturate(100%) invert(64%) sepia(33%) saturate(3087%)
      hue-rotate(214deg) brightness(100%) contrast(93%);
  }

  /* ================= solution_area ================== */
  .solution_box {
    padding: 2.4rem;
  }

  .solution_row .col-lg-4:nth-child(3) .solution_box.line1_lg {
    border-top: 0.1rem solid var(--tp_60);
  }

  .solution_box .title_28 {
    font-size: 2.4rem;
    line-height: 2.4rem;
    padding: 4.4rem 0 1.5rem;
  }

  .text_lg {
    font-size: 1.6rem;
    line-height: 2.4rem;
  }

  .solution_area .mt_55 {
    margin-top: 4.8rem;
  }

  .solution_area {
    padding: 10rem 0 13.5rem;
  }

  /* ==================== expertize_area ================= */
  .expertize_area {
    padding: 0 0 13.5rem;
  }

  .expertize_area .section_top {
    padding: 9.7rem 0 6.5rem;
  }

  .title_56 {
    font-size: 3.6rem;
    line-height: 3.8rem;
  }

  .expertize_box {
    padding: 3.6rem 3.6rem 4.2rem 3.6rem;
    width: 27.6rem;
    height: 23.2rem;
  }

  .expertize_icon .expertize1 {
    width: 5.4rem;
  }

  .expertize_icon .expertize4 {
    width: 5rem;
  }

  .expertize_icon .expertize3 {
    width: 5rem;
  }

  .title_28 {
    font-size: 2.1rem;
    line-height: 2.4rem;
  }

  .expertize_area .title_28 {
    padding-top: 5.5rem;
  }

  .expertize_icon {
    height: 5.2rem;
  }

  /* ==================== triangle_area =================== */
  .triangle_area {
    padding: 9.6rem 0 3.6rem;
  }

  .triangle_img {
    max-width: 88%;
  }

  /* ================ insights_area =============== */
  .insights_area {
    padding: 0 1rem;
  }

  /* =================== payment_area ================= */
  .payment_area {
    margin-bottom: 0;
  }
}

/*----- sm devices (tablets, 767px and down) -----*/
@media (max-width: 767px) {
  /* ============ default styles ============ */
  html {
    font-size: 55%;
  }

  .primary_menu,
  .container-fluid,
  .menu_container {
    width: 540px;
  }

  .logo img {
    width: 3.5rem;
  }

  .send_mail input {
    width: 100%;
  }

  /* =================== Hero area =================== */
  .brand_left {
    font-size: 1.28rem;
    line-height: 1.8rem;
    letter-spacing: -0.03em;
  }

  .brand_icon span {
    width: 0.64rem;
    height: 0.64rem;
  }

  .brand_icon {
    width: 1.28rem;
    height: 1.28rem;
  }

  .brand_slider .partner2 {
    width: 9.1rem;
  }

  .brand_slider .partner1 {
    width: 4.4rem;
  }

  .brand_slider .partner3 {
    width: 8.8rem;
  }

  .brand_slider img {
    margin: 0 1.2rem;
  }

  .hero_area .container {
    padding: 0;
  }

  .hero_bottom h2 {
    padding: 2.5rem 2.9rem;
  }

  .hero_bottom {
    padding: 2.4rem 0;
  }

  .title_48 {
    font-size: 3.6rem;
    line-height: 3.8rem;
  }

  /* ============== payment_area =============== */
  .payment_area p.pl_60 {
    padding-left: 0;
    font-size: 1.6rem;
  }

  .payment_area {
    padding: 3.2rem 0 3.5rem;
  }

  /* ============== Solution_area =============== */
  .solution_box {
    border-right: 0;
  }

  .solution_row .col-lg-4:nth-child(2) .solution_box.line1_lg {
    border-top: 0.1rem solid var(--tp_60);
  }

  /* ============== triangle_area =============== */
  .triangle_img {
    max-width: 100%;
  }

  .triangle_area .row {
    --bs-gutter-y: 5.6rem;
  }

  .triangle_area .content .title_56 {
    padding: 3rem 0 4rem;
  }

  .triangle_area .button.mt_55 {
    margin-top: 4.8rem;
  }

  .triangle_area .section_top.pb_32 {
    padding-bottom: 0;
  }

  /* ================= triangle_area ================= */
  .triangle_area .content .title_56 {
    padding: 3rem 0 4.8rem;
  }

  .title_sm p {
    font-size: 1.6rem;
    padding-top: 0.15rem;
  }

  .title_sm {
    align-items: center;
  }

  /* ================= results_area ================= */

  .results_area .section_top.pb_32 {
    padding-bottom: 4.8rem;
  }

  .results_area .content .title_sm {
    margin-bottom: 3rem;
  }

  .results_list li {
    padding: 2.4rem 0;
    flex-direction: column;
    gap: 2.5rem;
    align-items: flex-start !important;
  }

  .results_list li .text_xl {
    text-align: left;
  }

  .results_list li .title_56 {
    margin-left: auto;
    font-size: 5.6rem;
    line-height: 1;
  }

  .results_area {
    padding: 10rem 0 13.5rem;
  }

  /* ================= testimonial_area ================= */
  .testimonial_slider_wrap {
    padding: 0;
  }

  .testimonial_area {
    padding: 13.5rem 0;
  }

  .testimonial_slide .title_56 {
    padding-bottom: 4rem;
  }

  .testimonial_slide a img {
    width: 3.2rem;
    height: 3.2rem;
  }

  .testimonial_slide a {
    font-size: 1.6rem;
    gap: 1.6rem;
  }

  .swiper-pagination {
    margin-top: 4rem;
  }

  /* ==================== insights_area ===================== */
  .insights_area {
    padding: 0;
    position: relative;
  }

  .insights_inner_wrap {
    padding: 14.2rem 0 20.8rem;
    border-radius: 0;
  }

  .slider_navigation {
    gap: 2.4rem;
    position: absolute;
    bottom: 13.5rem;
    left: 50%;
    transform: translateX(-50%);
  }

  .insights_box {
    height: 34.5rem;
    padding: 1.6rem 1.6rem 2.8rem 1.6rem;
  }

  .insights_area .swiper-slide {
    width: 32.8rem;
  }

  .insights_badge p {
    font-size: 1.2rem;
  }

  .insights_badge {
    height: 2.4rem;
    padding: 0 0.9rem;
    border-radius: 0.375rem;
  }

  .insights_top h2 {
    font-size: 2.6rem;
    line-height: 3.4rem;
    padding: 4.9rem 0 2rem;
  }

  .insights_bottom p {
    font-size: 1.8rem;
  }

  .insights_bottom img {
    width: 1.6rem;
  }

  .section_top.pb_55 {
    padding-bottom: 3.2rem;
  }

  /* ================== faq_area =================== */
  .faq_area {
    padding: 13.5rem 0;
  }

  .faq_area .title_sm.mb_40 {
    margin-bottom: 3.6rem;
  }

  .section_bottom {
    flex-direction: column;
    align-items: flex-start !important;
    gap: 2.4rem;
  }

  .section_bottom h3 {
    font-size: 3.2rem;
  }

  .accordion {
    padding: 4.8rem 0 4rem;
  }

  .accordion_button {
    padding: 4rem 0;
  }

  .accordion_button h4 {
    text-align: left;
    font-size: 2rem;
    line-height: 2.6rem;
    padding-right: 2.9rem;
  }

  .plus_minus img {
    width: 2.4rem;
  }

  .accordion-body {
    padding-bottom: 4.8rem;
  }

  /* =================== footer_section ==================== */
  .footer_section {
    padding: 9.5rem 0 4.5rem;
  }

  .footer_box_left p {
    font-size: 1.5rem;
    line-height: 2.4rem;
  }

  .footer_box_left > p {
    padding: 2.4rem 0 4rem;
  }

  .subscribe_later p {
    line-height: 1;
    font-weight: 800;
  }

  .send_mail input {
    height: 6.4rem;
    padding-left: 1.6rem;
    width: 100%;
    padding-right: 0.8rem;
    border-radius: 1rem;
  }

  .send_mail {
    width: 100%;
  }

  .subscribe_later .button_icon {
    width: 4.8rem;
    height: 4.8rem;
    border-radius: 0.5rem;
  }

  .subscribe_later .button_icon img {
    width: 1.6rem;
  }

  .footer_favicon {
    display: none;
  }

  .footer_box_right .title_48 {
    font-size: 3.1rem;
    line-height: 4.2rem;
    padding-top: 6rem;
  }

  .footer_box_right .title_48 br {
    display: none;
  }

  .footer_box_right .row.pt_80 {
    padding-top: 5.5rem;
  }

  .footer_links h3 {
    font-size: 1.6rem;
    padding-bottom: 3.2rem;
  }

  .footer_links ul li a {
    font-size: 1.6rem;
  }

  .fbr_bottom {
    padding-top: 6.4rem;
  }

  .send_mail input::placeholder,
  .send_mail input {
    font-size: 1.6rem;
    color: var(--tp_60);
  }

  /* progress */
  .progress-wrap {
    right: 2rem;
    bottom: 2rem;
  }
}

/*----- xs devices (landscape phones, 575px and down) -----*/
@media (max-width: 575px) {
  html {
    font-size: 2.54vw;
  }

  /* menu */
  .primary_menu,
  .container-fluid {
    width: calc(100%);
  }

  .container {
    padding: 0 2.9rem;
  }

  .menu_container {
    width: 34.5rem;
  }
}
