@charset "UTF-8";
/*!
Theme Name: پایتخت فوم
Author: محمدرضا موسوی <info@hoovision.ir>
Author URI: https://hoovision.ir/
Version: 1.0.2
Description: قالب معرفی / فروش عمده فوم
 */
/*--------------------------------------------------------------
>>> global:
----------------------------------------------------------------*/
*:where(:not(html,iframe,canvas,img,svg,video,audio):not(svg *,symbol *)) {
    all: unset;
    display: revert
}

input, button, textarea, select {
    font: inherit
}

*, *::before, *::after {
    box-sizing: border-box
}

a, button {
    cursor: revert
}

ol, ul, menu {
    list-style: none
}

img {
    max-width: 100%
}

table {
    border-collapse: collapse;
    width: 100%
}

input, textarea {
    -webkit-user-select: auto
}

textarea {
    white-space: revert
}

meter {
    -webkit-appearance: revert;
    -moz-appearance: revert;
    appearance: revert
}

::-webkit-input-placeholder {
    color: unset
}

::-moz-placeholder {
    color: unset
}

:-ms-input-placeholder {
    color: unset
}

::-ms-input-placeholder {
    color: unset
}

::placeholder {
    color: unset
}

:where([hidden]) {
    display: none
}

:where([contenteditable]:not([contenteditable="false"])) {
    -moz-user-modify: read-write;
    -webkit-user-modify: read-write;
    overflow-wrap: break-word;
    -webkit-line-break: after-white-space;
    -webkit-user-select: auto
}

:where([draggable="true"]) {
    -webkit-user-drag: element
}

:after, :before {
    text-decoration: inherit;
    vertical-align: inherit
}

:root, [data-theme="light"] {
    --c-primary: #02757D;
    --c-primary-50: #f0f0f5;
    --c-primary-100: #f6f5fa;
    --c-primary-150: #edecf5;
    --c-primary-200: #eae9f3;
    --c-primary-250: #a9a6c1;
    --c-primary-300: #938ec4;
    --c-primary-350: #6d6991;
    --c-primary-400: #1900ff;
    --c-primary-500: #0f0099;
    --c-primary-600: #090066;
    --c-primary-700: #07004c;
    --c-primary-800: #16171f;
    --c-primary-850: #03001a;
    --c-green: #57CBB2;
    --c-green-200: #EEFFF9;
    --c-green-100: #F7FBFF;
    --c-secondary: #cd6c58;
    --c-neutral: #fefefe;
    --c-neutral-600: #676F71;
    --c-neutral-900: #292C2D;
    --c-subtext: #9E9E9E;
    --c-white: #fff;
    --bg-white: #fff;
    --c-black: #000;
    --ease1: cubic-bezier(0.68, -0.6, 0.32, 1.6);
    --ease2: cubic-bezier(0.5, 1, 0.89, 1);
    --ease3: cubic-bezier(0.62, 0.05, 0.01, 0.99);
    --ease4: cubic-bezier(0.25, 0.1, 0.25, 1);
    --ease5: cubic-bezier(0.24, 0.43, 0.15, 0.97);
    --ease6: cubic-bezier(0.23, 1, 0.32, 1);
    --ease7: cubic-bezier(0.12, 0, 0.39, 0);
    --c-danger: #f40259;
    --c-success: #0acd58;
    --c-info: #0288d1;
    --ff-main: 'Lahzeh';
    --ff-en: 'Poppins';
    --ff-icon: 'VisionIcon';
    --space-xs: 3rem;
    --space-sm: 6rem;
    --space-md: min(8.5rem, 12vw);
    --space-lg: min(12rem, 12vw);
    --space-xl: min(15rem, 18vw);
    --space-xxl: min(20rem, 25vw);
    --fs-10: 1.3rem;
    --fs-11: 1.4rem;
    --fs-12: 1.5rem;
    --fs-13: 1.5rem;
    --fs-14: 1.6rem;
    --fs-15: 1.6rem;
    --fs-16: 1.7rem;
    --fs-18: 1.9rem;
    --fs-20: 2rem;
    --fs-22: 2.2rem;
    --fs-24: 2.4rem;
    --fs-26: 2.6rem;
    --fs-28: 2.8rem;
    --fs-30: 3rem;
    --fs-32: 3.2rem;
    --fs-34: 3.4rem;
    --fs-36: 3.6rem;
    --fs-38: 3.8rem;
    --fs-40: 4rem;
    --fs-42: 4rem;
    --fw-100: "wght" 100;
    --fw-150: "wght" 150;
    --fw-200: "wght" 200;
    --fw-250: "wght" 250;
    --fw-300: "wght" 300;
    --fw-350: "wght" 350;
    --fw-400: "wght" 400;
    --fw-450: "wght" 450;
    --fw-500: "wght" 500;
    --fw-600: "wght" 600;
    --gutter-container: 80px; /*2rem*/
    --p-nav: 4rem;
    --gutter-x: 3rem;
    --heading_h1_fontsize: 2.8rem;
    --swiper-pagination-bullet-width: 1.2rem;
    --swiper-pagination-bullet-height: 1.2rem;
    --swiper-pagination-bullet-border-radius: 50%;
    --swiper-pagination-color: currentColor;
    --swiper-pagination-bullet-inactive-color: currentColor;
    --swiper-pagination-bullet-horizontal-gap: 0.5rem;
    --swiper-pagination-bullet-inactive-opacity: 0.5;
    --swiper-pagination-bullet-opacity: 1;
    --swiper-navigation-size: 1.3rem;
    --swiper-navigation-sides-offset: -5rem;
    --swiper-preloader-color: var(--c-primary);
    --padding-section-base: 0rem;
    --br-30: 12px;
    --br-16: 8px;
    --t-ease: 0.5s;
}

/* Lahzeh Light */
@font-face {
    font-family: 'Lahzeh';
    src: url('assets/fonts/Lahzeh-Light.otf') format('opentype'),
    url('assets/fonts/Lahzeh-FaNum-Light.ttf') format('truetype');
    font-weight: 100;
    font-style: normal;
    font-display: swap;
}

/* Lahzeh Regular */
@font-face {
    font-family: 'Lahzeh';
    src: url('assets/fonts/Lahzeh-Regular.otf') format('opentype'),
    url('assets/fonts/Lahzeh-FaNum-Regular.ttf') format('truetype');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

/* Lahzeh Medium */
@font-face {
    font-family: 'Lahzeh';
    src: url('assets/fonts/Lahzeh-Medium.otf') format('opentype'),
    url('assets/fonts/Lahzeh-FaNum-Medium.ttf') format('truetype');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

/* Lahzeh SemiBold */
@font-face {
    font-family: 'Lahzeh';
    src: url('assets/fonts/Lahzeh-SemiBold.otf') format('opentype'),
    url('assets/fonts/Lahzeh-FaNum-SemiBold.ttf') format('truetype');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

/* Lahzeh Bold */
@font-face {
    font-family: 'Lahzeh';
    src: url('assets/fonts/Lahzeh-Bold.otf') format('opentype'),
    url('assets/fonts/Lahzeh-FaNum-Bold.ttf') format('truetype');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

/* Lahzeh ExtraBold */
@font-face {
    font-family: 'Lahzeh';
    src: url('assets/fonts/Lahzeh-ExtraBold.otf') format('opentype'),
    url('assets/fonts/Lahzeh-FaNum-ExtraBold.ttf') format('truetype');
    font-weight: 800;
    font-style: normal;
    font-display: swap;
}

/* Lahzeh Black */
@font-face {
    font-family: 'Lahzeh';
    src: url('assets/fonts/Lahzeh-Black.otf') format('opentype'),
    url('assets/fonts/Lahzeh-FaNum-Black.ttf') format('truetype');
    font-weight: 900;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "VisionIcon";
    src: url('assets/fonts/VisionIcon.ttf') format("truetype"), url('assets/fonts/VisionIcon-ATF.woff') format("woff"), url('assets/fonts/VisionIcon-ATF.svg') format("svg");
    font-weight: 400;
    font-style: normal;
    font-display: swap
}

html {
    font-size: 2.1vw;
    font-size: min(2.1vw, 7px);
    scroll-behavior: smooth;

}

body {
    position: relative;
    direction: rtl;
    font-family: 'Lahzeh' !important;
    font-size: clamp(1.3rem, 1.2vw, 2.4rem);
    line-height: 3rem;
    min-height: 100vh;
    overflow-x: hidden;
    color: var(--c-primary);
    background-color: #fafafa;
    font-variation-settings: var(--fw-400);
    font-feature-settings: "kern" on, "liga" on, "dlig" on;
    -moz-font-feature-settings: "kern" on, "liga" on, "dlig" on;
    -webkit-font-feature-settings: "kern" on, "liga" on, "dlig" on;
    -ms-font-feature-settings: "kern" on, "liga" on, "dlig" on;
    -o-font-feature-settings: "kern" on, "liga" on, "dlig" on;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    height: 100%;
}

body, html {
    -ms-scroll-chaining: none;
    overscroll-behavior: none;
    width: 100%;
    height: 100vh;
    overflow-x: hidden !important;
}

body.single-product {
    background: #FAFAFA;
}

[class^="ic-"]::after, [class*="ic-"]::after, [class^="ic-"]::before, [class*="ic-"]::before {
    font-family: "WebsimaIcon";
    speak: never;
    font-style: normal;
    font-weight: 400;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale
}

* {
    outline: 0;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    -webkit-tap-highlight-color: transparent
}

::-moz-selection {
    color: var(--c-neutral-500);
    background: #cadefe
}

::selection {
    color: var(--c-neutral-500);
    background: #cadefe
}

*:focus-visible {
    outline: none;
    outline-offset: 4px
}

[role="button"] {
    cursor: pointer
}

canvas {
    pointer-events: none
}


:target {
    scroll-margin-top: 14rem
}

i, svg {
    display: inline-block;
    line-height: 1;
    vertical-align: middle
}

input {
    font-family: var(--ff-main), Arial
}

img {
    max-width: 100%;
    height: auto;
    display: block;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -webkit-user-drag: none;
    -webkit-filter: saturate(1.2);
    filter: saturate(1.2)
}

video {
    width: 100%;
    display: block;
    overflow: hidden;
    height: auto
}

a {
    transition: var(--t-ease) var(--ease4);
    color: currentColor;
    text-decoration: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none
}

ins {
    text-decoration: none
}

input::-webkit-outer-spin-button, input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0
}

input[type="number"] {
    -moz-appearance: textfield
}

input[type="search"]::-webkit-search-decoration, input[type="search"]::-webkit-search-cancel-button, input[type="search"]::-webkit-search-results-button, input[type="search"]::-webkit-search-results-decoration {
    -webkit-appearance: none
}

del {
    text-decoration: line-through
}

#overlay {
    position: fixed;
    z-index: 25;
    background: #0000007a;
    -webkit-backdrop-filter: blur(0);
    backdrop-filter: blur(0);
    inset: 0;
    height: 100%;
    overflow: hidden;
    width: 100%;
    opacity: 0;
    visibility: hidden
}

@-webkit-keyframes fadeEffect {
    0% {
        opacity: 0
    }
    100% {
        opacity: 1
    }
}

@keyframes fadeEffect {
    0% {
        opacity: 0
    }
    100% {
        opacity: 1
    }
}

button {
    cursor: pointer
}

.swiper-horizontal.swiper-rtl > .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
    transition: 0.6s transform, 0.6s right
}

html.lenis, html.lenis body {
    height: auto
}

.lenis.lenis-smooth [data-lenis-prevent] {
    -ms-scroll-chaining: none;
    overscroll-behavior: contain
}

.lenis.lenis-stopped {
    overflow: clip
}

.lenis.lenis-smooth iframe {
    pointer-events: none
}

.sw--portfolio:not(.swiper-initialized) .swiper-slide {
    margin-left: 20px
}

.splitting .word {
    display: inline-block
}

.splitting .char {
    position: relative
}

.splitting {
    --word-center: calc((var(--word-total) - 1) / 2);
    --char-center: calc((var(--char-total) - 1) / 2);
    --line-center: calc((var(--line-total) - 1) / 2)
}

.splitting .word {
    --word-percent: calc(var(--word-index) / var(--word-total));
    --line-percent: calc(var(--line-index) / var(--line-total))
}

.splitting .char {
    --char-percent: calc(var(--char-index) / var(--char-total));
    --char-offset: calc(var(--char-index) - var(--char-center));
    --distance: calc(
            (var(--char-offset) * var(--char-offset)) / var(--char-center)
    );
    --distance-sine: calc(var(--char-offset) / var(--char-center));
    --distance-percent: calc((var(--distance) / var(--char-center)))
}

#preloader__img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    transform-origin: bottom;
    background: #0500333a;
    z-index: 0
}

#preloader__bg {
    z-index: 0;
    background-color: var(--c-white);
    transform-origin: 50% 0;
    border-bottom-right-radius: 0;
    border-bottom-left-radius: 0;
    width: 100%;
    height: 100%;
    position: absolute;
    inset: 0%;
    transform: scale(1)
}

#preloader {
    position: fixed;
    inset: 0;
    z-index: 99999;
    width: 100%;
    height: 100vh
}

#ws-logo-circle {
    width: 5.6rem;
    height: 5.6rem;
    border-radius: 50%;
    background-color: var(--c-secondary);
    transform: scale(0) translateY(0rem);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    flex: none
}

#logo-circle--inside {
    position: absolute;
    background: var(--c-white);
    border-radius: 50%;
    width: 86%;
    height: 86%;
    transform: scale(0)
}

#circle--logo {
    position: absolute;
    width: 73%;
    display: flex;
    align-items: center;
    justify-content: center;
    transform: scale(0)
}

#circle--logo img {
    width: 100%;
    margin-right: 2px
}

.bg--black {
    --section-bg: var(--c-neutral-700);
    --section-color: var(--c-white);
    background-color: var(--section-bg);
    color: var(--section-color)
}

.bg--gradient-light {
    --section-bg: var(--c-primary-50);
    --section-color: var(--c-primary);
    background: linear-gradient(to bottom, var(--section-bg), transparent)
}

.bg--primary {
    --section-bg: var(--c-primary);
    --section-color: var(--c-white);
    background-color: var(--section-bg);
    color: var(--section-color)
}

.bg--white {
    --section-bg: var(--c-white);
    --section-color: var(--c-primary);
    background: var(--section-bg)
}

.inner-page .modular-page {
    padding-top: 4rem
}

.section {
    flex-direction: column;
    display: flex;
    position: relative;
    overflow: hidden
}


.hidden-svg {
    position: absolute;
    display: block;
    pointer-events: none
}

.svg-dots {
    width: 100%
}

.sw-auto .swiper-slide {
    height: auto
}

.empty-error {
    color: var(--c-danger);
    background-color: var(--bg-danger);
    padding: 1rem 2rem;
    border-radius: var(--br-32);
    font-size: var(--fs-16)
}

.gutter-b {
    margin-bottom: var(--gutter-x)
}

.text-justify {
    text-align: justify
}

.btns--box {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    -moz-column-gap: 2rem;
    column-gap: 2rem;
    row-gap: 1rem;
    margin-top: min(2rem, 4vw)
}

.icon-plus {
    display: flex;
    position: relative;
    align-items: center;
    justify-content: center
}

.icon-plus::after {
    transform: rotate(-90deg);
    transition: var(--t-ease) 0.1s var(--ease2)
}

.icon-plus::before {
    transform: rotate(0.1deg);
    transition: var(--t-ease) var(--ease2)
}

.icon-plus::after, .icon-plus::before {
    content: "";
    background-color: var(--c);
    width: 2.8px;
    height: 1.6rem;
    transform-origin: center;
    display: block;
    border-radius: 5px;
    position: absolute;
    z-index: 2
}

.open .icon-plus::after {
    transform: rotate(-45deg)
}

.open .icon-plus::before {
    transform: rotate(45deg)
}

.sw {
    position: relative
}

.accordion-content {
    height: 0;
    overflow: hidden;
    overflow: hidden
}

.line-2 {
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical
}

.line-3 {
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical
}

.line-4 {
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical
}

.line-1 {
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical
}


.swiper-button-lock {
    display: none !important
}

.pt-xs {
    padding-top: var(--space-xs)
}

.pt-sm {
    padding-top: var(--space-sm)
}

.pt-md {
    padding-top: var(--space-md)
}

.pt-lg {
    padding-top: var(--space-lg)
}

.pt-xl {
    padding-top: var(--space-xl)
}

.pt-xxl {
    padding-top: var(--space-xxl)
}

.main-page {
    padding: 11rem 0 0
}

.mb-1 {
    margin-bottom: 1rem
}

.pb-xs {
    padding-bottom: var(--space-xs)
}

.pb-sm {
    padding-bottom: var(--space-sm)
}

.pb-md {
    padding-bottom: var(--space-md)
}

.pb-lg {
    padding-bottom: var(--space-lg)
}

.pb-xl {
    padding-bottom: var(--space-xl)
}

.pb-xxl {
    padding-bottom: var(--space-xxl)
}

.fs-14 {
    font-size: var(--fs-14)
}

.fs-15 {
    font-size: var(--fs-15)
}

.fs-16 {
    font-size: var(--fs-16)
}

.fs-18 {
    font-size: var(--fs-18)
}

.fs-20 {
    font-size: var(--fs-20);
    line-height: 1.8
}

.fs-22 {
    font-size: var(--fs-22);
    line-height: 1.6
}

.fs-24 {
    font-size: var(--fs-24);
    line-height: 1.5
}

.fs-26 {
    font-size: var(--fs-26);
    line-height: 1.5
}

.fs-28 {
    font-size: var(--fs-28);
    line-height: 1.5
}

.fs-30 {
    font-size: var(--fs-30);
    line-height: 1.5
}

.fs-32 {
    font-size: var(--fs-32);
    line-height: 1.5
}

.fs-36 {
    font-size: var(--fs-36);
    line-height: 1.5
}

.fs-38 {
    font-size: var(--fs-38);
    line-height: 1.45
}

.fs-40 {
    font-size: var(--fs-40);
    line-height: 1.4
}

.fs-42 {
    font-size: var(--fs-42);
    line-height: 1.4
}

.fw-300 {
    font-variation-settings: var(--fw-300)
}

.fw-200 {
    font-variation-settings: var(--fw-200)
}

.fw-250 {
    font-variation-settings: var(--fw-250)
}

.fw-350 {
    font-variation-settings: var(--fw-350)
}

.fw-400 {
    font-variation-settings: var(--fw-400)
}

.fw-500 {
    font-variation-settings: var(--fw-500)
}

.fw-600 {
    font-variation-settings: var(--fw-600)
}

::-webkit-scrollbar {
    width: 4px;
    height: 4px
}

::-webkit-scrollbar-track {
    background: transparent
}

::-webkit-scrollbar-thumb {
    background: var(--c-neutral-400);
    cursor: pointer;
    border-radius: 9rem
}

.hide-scrollbar::-webkit-scrollbar {
    display: none !important
}

.hide-scrollbar {
    -ms-overflow-style: none !important;
    scrollbar-width: none !important
}

.heading--center {
    margin: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center
}

.heading-base .entitle {
    margin-bottom: 1rem;
    font-family: var(--ff-en);
    text-transform: capitalize
}

.heading-base .subtitle {
    margin-top: 2rem;
    font-size: var(--fs-18);
    line-height: 1.8
}

.heading-base .entitle, .heading-base .title, .heading-base .subtitle {
    text-align: center
}

.heading-base .typography {
    margin-bottom: 3.4rem;
    max-width: calc(100% - 4rem)
}

.heading--between {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    -moz-column-gap: 20rem;
    column-gap: 20rem;
    row-gap: 2rem
}

.heading-base {
    margin-bottom: 5rem
}

.heading--between .btns--box {
    margin-top: 0
}

.heading--between-right {
    flex: 1
}

.heading--right .typography, .heading--between-right .typography {
    margin-right: auto;
    margin-left: auto
}

.section--tabs-wrapper {
    display: flex;
    justify-content: space-between;
    flex-direction: column-reverse;
    gap: 2rem;
    padding: 0 calc(var(--padding-section-base) * 7);
    margin-bottom: 4rem;
    align-items: center
}

.section--tabs {
    display: flex;
    flex-wrap: wrap;
    -moz-column-gap: 1rem;
    column-gap: 1rem;
    row-gap: 1rem;
    align-items: center;
    flex: auto;
    white-space: nowrap;
    justify-content: center;
    width: 100%
}

.section--hero.is-wave {
    padding-bottom: 6vw
}

.section--portfolio.is-wave {
    padding-top: 0
}

.section--history.is-wave {
    padding-top: 0
}

.wbswave {
    width: 100%;
    height: min(35rem, 26vw);
    position: absolute;
    bottom: -1px;
    right: 0;
    left: 0;
    z-index: 5
}

.is-wave {
    padding-bottom: min(30rem, 34vw)
}

.is-wave-prev {
    padding-top: 5rem
}

.is-wave.current-wtype3 {
    padding-bottom: min(30rem, 34vw)
}

.current-wtype2.is-wave {
    padding-bottom: 0
}

.btn--ws-phone {
    font-size: var(--fs-16)
}

.section-wrapper.grid {
    position: relative;
    z-index: 2
}

@media (min-width: 36em) {
    a:is(:hover,:focus-visible) {
        text-decoration: none
    }
}

@media (min-width: 50em) {
    .section--hero.is-wave {
        padding-bottom: 0
    }

    .section--tabs {
        -moz-column-gap: 3rem;
        column-gap: 3rem;
        width: auto
    }

    .section--tabs-wrapper {
        flex-direction: row
    }

    .heading--center {
        width: 53%
    }

    :root {
        --padding-section-base: 2rem;
        --br-30: 3rem;
        --br-16: 1.6rem;
        --fs-10: 1rem;
        --fs-12: 1.2rem;
        --fs-13: 1.3rem;
        --fs-14: 1.4rem;
        --fs-15: 1.5rem;
        --fs-16: 1.6rem;
        --fs-18: 1.8rem;
        --fs-20: 2rem;
        --fs-22: 2.3rem;
        --fs-24: 2.4rem;
        --fs-26: 2.6rem;
        --fs-28: 2.8rem;
        --fs-30: 3rem;
        --fs-32: 3.2rem;
        --fs-34: 3.4rem;
        --fs-36: 3.6rem;
        --fs-38: 3.8rem;
        --fs-40: 4rem;
        --fs-42: 4.2rem
    }

    html {
        font-size: min(0.57vw, 10px)
    }

    .heading--between {
        flex-direction: row;
        align-items: end;
        justify-content: space-between
    }

    .heading--right .typography, .heading--between-right .typography {
        margin-right: 0;
        margin-left: 0
    }

    .heading--right .subtitle {
        text-align: justify
    }

    .heading-base .entitle, .heading-base .title {
        text-align: unset
    }
}

@media (max-width: 49.99em) {
    #ws-logo-circle {
        width: 4.6rem;
        height: 4.6rem
    }
}

/*--------------------------------------------------------------
>>> icons:
----------------------------------------------------------------*/
[class*=" icon-"], [class^=icon-] {
    font-family: VisionIcon !important;
    speak: never;
    font-style: normal;
    font-weight: 400;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale
}

.ic-add-heart:before {
    content: "\e924"
}

.ic-copy:before {
    content: "\e922"
}

.ic-leap:before {
    content: "\e920"
}

.ic-service:before {
    content: "\e921"
}

.ic-map-google:before {
    content: "\e91c"
}

.ic-phone-ring:before {
    content: "\e91d"
}

.ic-send-email:before {
    content: "\e91e"
}

.ic-dribbble:before {
    content: "\e91f"
}

.ic-user-square:before {
    content: "\e919"
}

.ic-mobile-tick:before {
    content: "\e91a"
}

.ic-close:before {
    content: "\e91b"
}

.ic-twitter:before {
    content: "\e913"
}

.ic-user:before {
    content: "\e914"
}

.ic-logo:before {
    content: "\e915"
}

.ic-question:before {
    content: "\e916"
}

.ic-desktop:before {
    content: "\e903"
}

.ic-mobile:before {
    content: "\e90b"
}

.ic-arrow-left-long:before {
    content: "\e917"
}

.ic-arrow-down-short:before {
    content: "\e90c"
}

.ic-arrow-down-long:before {
    content: "\e902"
}

.ic-arrow-up-right:before {
    content: "\e909"
}

.ic-arrow-down-noline:before {
    content: "\e900"
}

.ic-jet:before {
    content: "\e918"
}

.ic-back:before {
    content: "\e901"
}

.ic-triangle:before {
    content: "\e20ba"
}

.ic-square:before {
    content: "\e21ba"
}

.ic-circle:before {
    content: "\e22ba"
}

.ic-star:before {
    content: "\e904"
}

.ic-user-heart:before {
    content: "\e905"
}

.ic-user-heart:after {
    content: "\e90d";
    margin-left: -1em
}

.ic-article:before {
    content: "\e906"
}

.ic-event:before {
    content: "\e907"
}

.ic-whitepaper:before {
    content: "\e908"
}

.ic-online:before {
    content: "\e90a"
}

.ic-instagram:before {
    content: "\e90e"
}

.ic-linkedin:before {
    content: "\e90f"
}

.ic-telegram:before {
    content: "\e910"
}

.ic-whatsapp:before {
    content: "\e911"
}

.ic-broadcast:before {
    content: "\e912"
}

.ic-qoute:before {
    content: "\e925"
}

/*--------------------------------------------------------------
>>> Hero banner:
----------------------------------------------------------------*/
/*#hero_banner .swiper-button-prev {*/
/*    position: absolute;*/
/*    top: 50%;*/
/*    right: 0 !important;*/
/*    background-image: url('assets/img/slider-btn1.svg');*/
/*    background-repeat: no-repeat;*/
/*    width: 28px;*/
/*    height: 114px;*/
/*    display: flex;*/
/*    align-items: center;*/
/*    justify-content: left;*/
/*    z-index: 110;*/
/*    transform: translateY(calc(-50% + 18px));*/
/*    opacity: 1 !important;*/
/*}*/

/*.swiper-button-prev, .swiper-rtl .swiper-button-next {*/
/*    left: var(--swiper-navigation-sides-offset, 10px);*/
/*    right: auto;*/
/*}*/

/*.swiper-button-next, .swiper-rtl .swiper-button-prev {*/
/*    right: var(--swiper-navigation-sides-offset, 10px);*/
/*    left: auto;*/
/*}*/

/*#hero_banner .swiper-button-next {*/
/*    position: absolute;*/
/*    top: 50%;*/
/*    right: calc(100% - 2px);*/
/*    background-image: url('assets/img/slider-btn2.svg');*/
/*    background-repeat: no-repeat;*/
/*    height: 114px;*/
/*    width: 33px;*/
/*    display: flex;*/
/*    align-items: center;*/
/*    justify-content: left;*/
/*    z-index: 110;*/
/*    transform: translate(calc(100% - 2px), calc(-50% + 18px));*/
/*    opacity: 1 !important;*/
/*}*/

/*--------------------------------------------------------------
>>> Header:
----------------------------------------------------------------*/
#header {
    position: relative;
    z-index: 15;
    width: 100%
}


.header-curve {
    background-image: url('assets/img/masks/mask-header.svg');
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    width: 18rem;
    height: 5rem;
    position: absolute;
    left: 50%;
    transform: translateX(-50%) translateY(-.5px);
    top: 100%;
    z-index: 2;
    display: flex;
    align-items: end;
    justify-content: center;
    font-size: 4rem
}

.inner-page .header-curve {
    -webkit-filter: drop-shadow(0 8px 4px #07004c1a);
    filter: drop-shadow(0 8px 4px #07004c1a)
}

.header-curve .badge {
    background-image: url('assets/img/badge.svg');
    margin-bottom: .7rem;
    width: 2.2rem;
    height: 2.2rem;
    opacity: 0;
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain
}

.header-wrapper {
    background-color: var(--bg-white)
}

.inner-page .header-wrapper {
    box-shadow: 0 2px 8px #07004c1a
}

/*.ws-header {*/
/*    display: grid;*/
/*    grid-template-columns:minmax(0, 1fr) 10rem minmax(0, 1fr);*/
/*    gap: 2rem;*/
/*    padding: 2rem 0 0*/
/*}*/

.header--right {
    display: flex;
    align-items: center;
    gap: 4rem;
    opacity: 0
}

.header--left {
    display: grid;
    align-items: center;
    gap: 1rem;
    opacity: 0;
    justify-content: end;
    grid-template-columns:auto
}

.header-curve-svg {
    width: 17rem;
    height: 0.8rem;
    display: block;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    opacity: 0;
    fill: var(--c-primary)
}


.header-logo {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.5rem
}

.header-logotype img {
    width: 100%;
    height: 100%;
    -o-object-fit: contain;
    object-fit: contain
}

.header-logotype {
    width: 9.7rem;
    opacity: 0;
    display: block
}

.header--logo {
    transform: translateY(1.5rem);
    position: relative;
    z-index: 4
}

.btn--header {
    display: flex;
    font-variation-settings: var(--fw-500);
    border-radius: 100px;
    align-items: center;
    font-size: 1.4rem;
    position: relative;
    padding: 1.3rem min(2.4rem, 4vw);
    cursor: pointer;
    white-space: nowrap;
    max-height: 40px;
    min-width: auto;
    background: var(--c-green);
    color: var(--c-white);
}


.header-request {
    position: relative
}

.ws-header .menu-item {
    display: flex;
    align-items: center;
    transition: var(--t-ease) var(--ease2)
}

.ws-header .menu-item:hover {
    color: var(--c-primary-500)
}

.ws-header .menu-item::before {
    vertical-align: middle
}

.ws-header .menu-item.ic-star::before {
    font-size: 1.6rem;
    vertical-align: middle
}

.ws-header .menu-item.ic-leap::before {
    font-size: 1.4rem;
    vertical-align: middle;
    transition: var(--t-ease) var(--ease3)
}

.ws-header .ic-leap.menu-item:hover::before {
    transform: translate(.4rem, -.4rem)
}

.ws-menu i {
    font-size: 1.9rem
}

.mobile .ws-menu i {
    font-size: 2.2rem
}

.ws-menu {
    cursor: pointer;
    padding-right: 0 !important
}

.ws-menu.mobile {
    font-size: var(--fs-14);
    display: flex;
    align-items: center;
    gap: .8rem;
}

.ws-menu .mid {
    transform: translateX(-.7rem)
}

.ws-menu .last::before {
    content: "";
    position: absolute;
    width: .35rem;
    height: .35rem;
    background-color: var(--c-secondary);
    border-radius: 50%;
    display: block;
    top: 50%;
    transform: translateY(-50%);
    right: 12%
}

.ws-menu:hover .mid {
    transform: translateX(0)
}

.ws-menu:hover .last, .ws-menu:hover .first {
    transform: translateX(-.7rem);
    transform-origin: left
}

.ws-lang-link {
    display: none
}

.header-nav {
    display: flex;
    gap: 3.4rem;
    align-items: center
}

.header-nav > li > .ws-menu, .header-nav > li > a {
    display: flex;
    align-items: center;
    font-size: var(--fs-16);
    padding: 1rem;
    gap: .9rem;
    transition: unset
}

/*.header-nav > li svg {*/
/*    fill: var(--c-primary);*/
/*    transition: var(--t-ease) var(--ease2);*/
/*    stroke: var(--c-primary);*/
/*    stroke-width: 1px*/
/*}*/

/*.header-nav > li svg.animate * {*/
/*    -webkit-animation: svgStroke 800ms ease-in-out 1 forwards;*/
/*    animation: svgStroke 800ms ease-in-out 1 forwards*/
/*}*/

/*.header-nav > li svg.animate {*/
/*    -webkit-animation: svgFill 500ms ease-in-out 700ms 1 forwards;*/
/*    animation: svgFill 500ms ease-in-out 700ms 1 forwards*/
/*}*/

@-webkit-keyframes svgFill {
    100% {
        fill: var(--c-primary-500)
    }
}

@keyframes svgFill {
    100% {
        fill: var(--c-primary-500)
    }
}

@-webkit-keyframes svgStroke {
    100% {
        stroke-dashoffset: 0
    }
}

@keyframes svgStroke {
    100% {
        stroke-dashoffset: 0
    }
}

.header-nav .menu-item__leap svg {
    width: 1.2rem;
    height: 1.2rem
}

.header-nav .menu-item__portfolio svg {
    width: 1.53rem;
    height: 1.46rem
}

.header-nav .menu-item__services svg {
    width: 1.6rem;
    height: 1.6rem
}

.header--right > .ws-menu svg {
    width: 2.3rem;
    height: 2.3rem;
    fill: var(--c-primary)
}

.header-nav > li > a::before {
    color: var(--c-primary);
    margin-left: .8rem;
    font-size: 1rem;
    transition: var(--t-ease) var(--ease2)
}

.box-search-header {
    box-shadow: inset 0 3px 10px rgba(232, 239, 239, .75);
}

.box-poupup {
    position: fixed;
    top: 50%;
    right: 50%;
    transform: translate(50%, -50%);
    opacity: 0;
    transition: all 0.3s;
    min-width: 695px;
    z-index: 999999;
    visibility: hidden;
    max-height: 95vh;
    overflow: auto;
    background: #fff;
    border-radius: 25px;
    padding: 20px 48px 30px
}

.box-poupup.active {
    opacity: 1;
    visibility: visible;
}

/*#wrapper .fadeModal{*/
/*    background: rgba(255, 255, 255, 0.25);*/
/*    backdrop-filter: blur(14px) saturate(120%);*/
/*    -webkit-backdrop-filter: blur(14px) saturate(120%);*/
/*    border: 1px solid rgba(255,255,255,0.2);*/
/*}*/
/*.header-nav > li > button:hover svg, .header-nav > li > a:hover svg {*/
/*    fill: var(--c-primary-500)*/
/*}*/
.humburger-menu-wrapper {
    position: fixed;
    background: var(--c-primary);
    color: var(--c-white);
    width: 100%;
    right: 0;
    z-index: 99;
    top: 0;
    --p: 2rem;
    overflow: hidden;
    transform-origin: top left;
    visibility: hidden;
    opacity: 0;
    -webkit-clip-path: inset(0% 0% 100% 0%);
    clip-path: inset(0% 0% 100% 0%);
    height: 100%;
    display: flex;
    flex-direction: column
}

.breadcrumbs-wrapper {
    background: linear-gradient(90deg, #011B5E 0%, #02757D 100%);
    padding: 2.7rem 3.3rem;
    color: #FAFAFA;
    border-radius: 3.7rem;
    font-size: var(--fs-10);
    position: relative;
    white-space: nowrap;
    display: none;
    margin-bottom: 55px;
}

.breadcrumb_last {
    color: var(--c-white)
}


.breadcrumbs-wrapper::after {
    content: "کیفیت مهم است";
    color: rgba(250, 250, 250, 0.15);
    position: absolute;
    left: 5rem;
    top: calc(50% + 0.5rem);
    transform: translate(0, -50%);
    height: 3.1rem;
    font-size: 11px;
}


.breadcrumbs-wrapper .ic-arrow-down-long {
    font-size: .7rem;
    transform: rotate(90deg)
}

.breadcrumbs-wrapper > span {
    display: flex;
    align-items: center;
    gap: 1rem;
    position: relative
}

.breadcrumbs-wrapper .ic-arrow1 {
    font-size: 1rem;
    margin: 0 .3rem
}

.breadcrumbs-wrapper a:hover {
    color: var(--c-white)
}

@media (min-width: 36em) {
    .ws-lang-link {
        display: block
    }
}

@media (min-width: 50em) {
    .header--left {
        grid-template-columns:1fr -webkit-min-content;
        grid-template-columns:1fr min-content;
        justify-content: center
    }

    .inner-page .header-wrapper {
        box-shadow: none
    }

    .header-curve .badge {
        width: 4.5rem;
        height: 2.8rem
    }

    .header-curve {
        width: 27rem;
        height: 6.5rem
    }


    .ws-header {
        grid-template-columns:minmax(0, 1fr) 16rem minmax(0, 1fr);
        padding: 1.8rem var(--p-nav) 0
    }

    .ws-menu.mobile {
        display: none;
    }

    .breadcrumbs-wrapper {
        display: block
    }

    .header-logotype {
        width: 11.7rem
    }
}

/*--------------------------------------------------------------
>>> buttons:
----------------------------------------------------------------*/
.btn {
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    line-height: 1.8;
    font-family: inherit;
    position: relative;
    transition: var(--t-ease);
    white-space: nowrap;
    cursor: pointer;
    height: 4.6rem;
    user-select: none;
    border-radius: 2.8rem;
    position: relative;
    padding: 1rem 2.6rem;
    overflow: hidden;
    border: 1px solid var(--btc);
    font-size: var(--fs-14)
}

.btn b {
    font-variation-settings: var(--fw-500);
    font-size: var(--fs-18);
    line-height: 1;
    font-family: var(--ff-en);
    font-weight: 700
}

.btn--primary {
    --btc: var(--c-primary);
    --h-bg: var(--c-white);
    --h-c: var(--btc);
    background-color: var(--btc);
    color: var(--c-white)
}

.btn--primary-500 {
    --btc: var(--c-primary-500);
    --h-bg: var(--c-white);
    --h-c: var(--btc);
    background-color: var(--btc);
    color: var(--c-white)
}

.btn--green {
    --btc: var(--c-green);
    --h-bg: var(--c-white);
    --h-c: var(--btc);
    background-color: var(--btc);
    color: var(--c-white)
}

.btn--outline-white {
    --btc: var(--c-white);
    --h-bg: var(--btc);
    --h-c: var(--c-primary);
    color: var(--btc)
}

.btn--outline-primary {
    --btc: var(--c-primary);
    --h-bg: var(--btc);
    --h-c: var(--c-white);
    color: var(--btc)
}

.btn--outline-primary-400 {
    --btc: var(--c-primary-400);
    --h-bg: var(--btc);
    --h-c: var(--c-white);
    color: var(--btc)
}

.btn--outline-primary-500 {
    --btc: var(--c-primary-500);
    --h-bg: var(--btc);
    --h-c: var(--c-white);
    color: var(--btc)
}

.btn--white {
    --btc: var(--c-white);
    --h-bg: var(--c-primary);
    --h-c: var(--c-white);
    background-color: var(--btc);
    color: var(--c-primary)
}

.bg--black .btn.btn--white {
    --h-bg: var(--c-primary-800)
}

.btn--linear-dark {
    background: linear-gradient(to top, #26292f, #43464c);
    color: var(--c-neutral-350)
}

.btn--linear-light {
    background: linear-gradient(to top, #dfdee7, #ffffff);
    color: var(--c-primary)
}

.btn.btn--link {
    padding: 0;
    border-radius: 0;
    color: var(--c-primary-500);
    font-variation-settings: var(--fw-350);
    height: auto
}

.btn.btn--link .btn__text {
    height: auto
}

.btn__text {
    height: 4.6rem;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform var(--t-ease) var(--ease2);
    position: relative;
    z-index: 2
}

.btn::after {
    content: "";
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    transform: translateY(101%);
    background: var(--h-bg);
    border-radius: 50% 50% 0 0;
    transition: transform var(--t-ease) var(--ease2), border-radius var(--t-ease) var(--ease2)
}

.btn__text::before {
    content: attr(data-text);
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--h-c)
}

.btn:hover::after {
    border-radius: 0;
    transform: translateY(0);
    transition-duration: 0.5s, 0.9s
}

.btn:hover .btn__text {
    transform: translateY(-100%)
}

.btn:hover {
    transform: scaleX(1.02);
    transition: transform 0.6s cubic-bezier(.34, 5.56, .64, 1)
}

.btn--arrow-up {
    min-width: 14.9rem;
    box-shadow: 0 4px 6px #cd6c5821;
    padding: 0 1.5rem
}

.btn--arrow-up i {
    transform: rotateY(180deg);
    font-size: 1.5rem;
    margin-right: auto;
    transition: var(--t-ease) var(--ease2);
    z-index: 2;
    position: relative;
    overflow: hidden
}

.btn--arrow-up:hover i {
    color: var(--h-c)
}

/*--------------------------------------------------------------
>>> editor:
----------------------------------------------------------------*/
.mejs-container {
    direction: ltr;
    border-radius: 12px;
    overflow: hidden
}

.editor-content em {
    font-style: italic
}

.editor-content code, .editor-content pre {
    display: block;
    overflow-x: auto;
    direction: ltr;
    text-align: left;
    background: #1e1e1e;
    color: var(--c-white);
    border-radius: var(--br-20);
    padding: 1rem 2.4rem;
    white-space: pre;
    font-size: var(--fs-14);
    font-family: monospace;
    box-shadow: 0 19px 24px 0 #0000001a;
    line-height: 1.8
}

code {
    direction: ltr;
    width: 100%;
    text-align: left;
    display: block
}

.editor-content img:not(.img_gallery,.bg-cta-m) {
    max-width: 100%;
    border-radius: 8px;
    -webkit-clip-path: url(#editorCurve);
    clip-path: url(#editorCurve)
}

.section--editor #websima-cta-content:only-child {
    margin-top: 0;
    margin-bottom: 0
}

.sw-gallery .swiper-slide {
    height: auto
}

.gallery_item {
    position: relative;
    display: block;
    overflow: hidden;
    border-radius: 8px
}

.gallery_item + p {
    text-align: center;
    margin-top: 1.4rem;
    font-size: var(--fs-15);
    font-variation-settings: var(--fw-400)
}

.gallery_item a:after {
    opacity: 0;
    content: "\e92c";
    font-family: var(--ff-icon);
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    transition: var(--t-ease);
    z-index: 1;
    position: absolute;
    color: var(--c-white);
    font-size: 2.5rem;
    line-height: 1;
    text-decoration: initial
}

.gallery_item a:before {
    opacity: 0;
    content: "";
    position: absolute;
    height: 100%;
    background: #0000001c;
    opacity: 0;
    left: 0;
    right: 0;
    transition: var(--t-ease);
    z-index: 1;
    border-radius: 8px
}

.sw--gallery:not(.swiper-initialized) .swiper-slide {
    flex-shrink: unset;
    margin-left: 22px;
    width: 144px;
    flex: 0 0 144px
}

.gallery_item:hover a:after {
    opacity: 1
}

.gallery_item:hover a::before {
    opacity: .6
}

.grid-cols.cols--gallery .swiper-wrapper {
    grid-auto-columns: min(16rem, 100%)
}

.gl--box {
    margin: 2rem 0 4rem !important
}

.alignleft {
    float: left;
    margin: 0 3rem 3rem 0
}

.alignright {
    float: right;
    margin-left: 3rem
}

.aligncenter {
    text-align: center;
    display: block;
    margin-inline: auto;
    margin-bottom: 2rem
}

.blockquote {
    position: relative
}


img.alignnone {
    margin: auto
}

.comment-single li::marker {
    content: none
}


hr {
    border: 1px solid #ccc
}

.gallery_item img {
    transition: all var(--t-ease);
    height: 100%;
    width: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    border-radius: 8px;
    aspect-ratio: 1/1;

}

.editor-content .wp-video {
    display: block;
    border-radius: 8px;
    margin-inline: auto;
    max-width: 100% !important;
    overflow: hidden
}

.editor-content .wp-video video {
    width: min(85rem, 100%);
    margin-right: auto;
    margin-left: auto;
    border-radius: 8px;
    -webkit-clip-path: url(#editorCurve);
    clip-path: url(#editorCurve)
}

.editor-content table:not(.acf-table) th, .editor-content table:not(.acf-table) td {
    white-space: nowrap;
    border-bottom: none;
    padding: 1rem 1.5rem;
    font-size: inherit;
    line-height: 2;
    vertical-align: middle
}

.editor-content table:not(.acf-table) tr:first-child {
    border-bottom: none
}

.editor-content table:not(.acf-table) tr:first-child td, .editor-content table:not(.acf-table) tr:first-child th {
    white-space: nowrap;
    padding: 1rem 2rem;
    background: var(--c-primary-150)
}

.editor-content table:not(.acf-table) tr:first-child td:first-child, .editor-content table:not(.acf-table) tr:first-child th:first-child {
    border-radius: 0 8px 8px 0
}

.editor-content table:not(.acf-table) tr:first-child td:last-child, .editor-content table:not(.acf-table) tr:first-child th:last-child {
    border-radius: 8px 0 0 8px
}

.editor-content table:not(.acf-table) :is(tbody,thead) {
    display: table;
    width: 100%
}

.editor-content table:not(.acf-table) {
    border-collapse: collapse;
    display: block;
    border-radius: 8px;
    width: 100%;
    overflow-x: auto;
    display: block;
    -webkit-overflow-scrolling: auto;
    border-bottom: 0;
    background: #fff;
    padding: 1.6rem
}

.editor-content table:not(.acf-table) tr {
    border-bottom: 2px solid var(--c-primary-150)
}

.editor-content table:not(.acf-table) th {
    font-variation-settings: var(--fw-500)
}

.editor-content table:not(.acf-table):not(.acf-table)::-webkit-scrollbar {
    height: 4px !important;
    width: 3px !important
}

.editor-content table:not(.acf-table)::-webkit-scrollbar-track {
    background: #eae8e4 !important;
    height: 4px !important
}

.editor-content table:not(.acf-table)::-webkit-scrollbar-thumb {
    background: rgb(123, 123, 123) !important;
    height: 4px !important
}

.editor-content table:not(.acf-table)::-webkit-scrollbar-thumb:hover {
    background: var(--c-primary) !important
}

.editor-content table::-webkit-scrollbar {
    height: 8px;
    width: 8px
}

.editor-content table::-webkit-scrollbar-track {
    border-radius: 0 0 4px 4px;
    background-color: #ececec
}

.editor-content table::-webkit-scrollbar-thumb {
    background: #aca9a9;
    border-radius: 0 0 4px 4px
}

.editor-content table::-webkit-scrollbar-thumb:hover {
    background: var(--c-primary)
}

.editor-content table {
    scrollbar-color: var(--c-primary);
    scrollbar-width: thin;
    height: auto !important
}

@media (max-width: 50em) {
    .alignleft, .alignright {
        float: none;
        margin-inline: auto;
        margin-bottom: 2rem
    }

    .main-text {
        font-size: var(--fs-16)
    }
}

/*--------------------------------------------------------------
>>> footer:
----------------------------------------------------------------*/


#footer {
    position: relative;
    margin-top: 45vw;
    overflow-x: clip;
    border-bottom: 8rem solid var(--c-white)
}

.desktop #footer {
    position: relative;
    margin-top: min(30rem, 28vw)
}

#footer svg {
    position: absolute;
    width: 100%;
    bottom: 100%;
    transform: scale(1.1);
    transform-origin: bottom
}

.footer-wrapper {
    background-color: var(--c-primary);
    color: var(--c-white)
}

.footer--details {
    display: grid;
    grid-template-columns:100%;
    margin-bottom: 7rem
}

.footer-about--info {
    display: flex;
    align-items: center;
    justify-content: space-between;
    line-height: 1;
    margin-top: 3rem
}

.footer-about__phone {
    color: var(--c-secondary);
    font-size: 3.5rem;
    line-height: 1
}

.footer-about__phone:hover {
    -webkit-filter: saturate(1.5);
    filter: saturate(1.5)
}

.footer-about--info .socials {
    display: flex;
    align-items: center;
    gap: 2rem;
    font-size: 2.5rem
}

.footer-about--info .socials a:hover {
    color: var(--c-secondary)
}

.footer__desc {
    text-align: justify;
    font-size: var(--fs-16)
}

.footer__named {
    display: flex;
    align-items: center;
    gap: 1rem;
    font-size: var(--fs-12);
    margin-bottom: 1.5rem
}

.footer-named__img {
    width: 3rem;
    flex: none;
    -webkit-filter: brightness(0) invert(1);
    filter: brightness(0) invert(1)
}

.footer-named__img img {
    -o-object-fit: contain;
    object-fit: contain
}

.footer__menu a, .footer-named__title {
    color: var(--c-primary-300);
    font-size: var(--fs-14)
}

.footer__menu a:hover {
    color: var(--c-white)
}

#footer-wave {
    position: absolute;
    width: 100%;
    pointer-events: none;
    bottom: calc(100% - 1px);
    height: min(18.5rem, 11vw)
}

.footer-ul li a {
    font-size: 14px;
    color: #676F71;
    line-height: 32px;
}

.footer-menu .title {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem 0;
    font-size: var(--fs-16)
}

.footer-menu .title i {
    font-size: 10px
}

.mobile .footer-menu .title::after {
    content: "\e900";
    font-family: var(--ff-icon);
    margin-right: auto;
    transition: var(--t-ease) var(--ease2)
}

.footer-menu.open .title::after {
    transform: rotateX(180deg);
}

.footer-menu .title .icon {
    font-size: 1rem;
}

.footer-namads {
    margin-top: 4.5rem;
}

.footer__menu {
    padding-bottom: 2rem;
    line-height: 1.5;
}

[data-icon] .footer__menu {
    padding-right: 2rem;
}

.footer__menu li:not(:last-child) {
    margin-bottom: 1.4rem;
}

.footer--bottom-wave img {
    width: 100%;
    height: 8rem;
}

.copyright-text {
    text-align: center;
    color: var(--c-primary);
    position: absolute;
    z-index: 2;
    font-size: var(--fs-12);
    left: 0;
    right: 0;
    margin: auto;
    line-height: 1.5;
    height: 8rem;
    display: flex;
    align-items: center;
    justify-content: center
}

.faravance-logos {
    display: flex;
    direction: ltr;
    position: relative;
    width: 95%;
    margin-right: auto;
    justify-content: center;
    padding-left: var(--gutter-container)
}

.faravance-logos .inner {
    display: flex;
    gap: 2rem;
    position: relative;
    z-index: 3;
    margin: auto;
    padding: 0 8rem 5vw;
    transform: translateY(-2.4rem)
}

.faravance-logos .inner a:hover {
    transform: translateY(-.5rem)
}

.faravance-logos img {
    max-height: 4rem;
    -o-object-fit: contain;
    object-fit: contain
}

.faravance-logos::before {
    content: "";
    background-color: #020019;
    -webkit-mask-image: url('assets/img/masks/curve-footer-logos.svg');
    mask-image: url('assets/img/masks/curve-footer-logos.svg');
    position: absolute;
    width: 100%;
    height: 5rem;
    left: var(--gutter-container);
    bottom: 100%;
    pointer-events: none;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    -webkit-mask-size: 100%;
    mask-size: 100%
}

.faravance-logos::after {
    content: "";
    background-color: #020019;
    position: absolute;
    right: 0;
    left: 0;
    height: 100%;
    bottom: 0;
    z-index: 0;
    pointer-events: none
}

.footer__img {
    margin: 2rem auto 2rem;
    max-width: 19rem;
    padding-top: 6vw
}

.footer-about {
    margin-bottom: 3rem
}

.mobile .footer-menu .title + div {
    height: 0
}

.h-auto {
    height: auto !important;
    transition: 0.2s all linear;
}

.text-center {
    text-align: center;
}

@media (min-width: 50em) {
    #footer::before {
        top: -18rem;
        width: 33rem;
        height: 18rem
    }

    .footer--details {
        grid-template-columns:41% repeat(3, 1fr) -webkit-max-content;
        grid-template-columns:41% repeat(3, 1fr) max-content;
        gap: 3rem;
        margin-bottom: 15rem
    }

    .footer-about {
        padding-right: 18rem;
        padding-left: 9rem;
        margin-bottom: 0
    }

    .footer__img {
        max-width: 27rem;
        margin: 0 0 2.4rem 0;
        padding-top: 0
    }

    .footer-menu {
        border-bottom: unset
    }

    .footer-menu .title {
        padding: 0
    }

    .footer__menu {
        margin-top: 1.6rem;
        padding-bottom: 0
    }

    .footer--bottom-wave img {
        height: 47rem
    }

    #footer {
        border-bottom: 1rem solid var(--c-white)
    }

    .faravance-logos {
        width: 50%
    }

    .faravance-logos::before {
        height: 6rem
    }

    .faravance-logos .inner {
        gap: 6rem;
        padding: 0 8vw 1rem
    }

    .copyright-text {
        bottom: .7vw;
        z-index: 2;
        width: unset;
        text-align: right;
        margin: unset;
        right: var(--gutter-container);
        left: auto;
        height: auto
    }
}

/*--------------------------------------------------------------
>>> hamburger menu:
----------------------------------------------------------------*/
.offcanvas {
    --offcanvas-width: calc(100% - 4rem);
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    z-index: 25;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    max-width: 100%;
    color: var(--c-white);
    visibility: hidden;
    background-color: var(--c-primary);
    -webkit-transition: var(--t-ease) var(--ease4);
    transition: var(--t-ease) var(--ease4);
    width: var(--offcanvas-width)
}

.offcanvas--wrapper {
    transform: translateX(100%)
}

.offcanvas.active {
    transform: none;
    visibility: visible
}

.offcanvas--sub {
    background: var(--c-primary-500);
    background: linear-gradient(180deg, var(--c-primary-500) 0, var(--c-primary-600) 100%);
    border-top-right-radius: 1rem;
    z-index: 3;
    right: auto;
    left: 0;
    width: var(--offcanvas-width);
    transform: translateX(-100%)
}

.offcanvas--main {
    z-index: 2;
    background-color: var(--c-primary);
    height: 100%;
    display: flex;
    flex-direction: column
}

.offcanvas-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 4rem 4rem 6rem 4rem;
    min-height: 17rem;
    flex: none
}

.offcanvas__logo {
    width: 21rem
}

.offcanvas__logo img {
    object-fit: contain;
    width: 100%;
    height: 100%
}

.offcanvas__close {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 4.5rem;
    height: 4.5rem;
    background: var(--c-white);
    border-radius: 50%;
    color: var(--c-primary);
    font-size: 1.8rem;
    line-height: 1
}

.offcanvas__close i {
    transition: var(--t-ease) var(--ease3)
}

.offcanvas__close:hover i {
    transform: rotate(-90deg)
}

.offcanvas .nav-link-icon {
    display: flex;
    position: relative;
    align-items: center;
    justify-content: center;
    --c: var(--c-white);
    width: 3rem;
    height: 3rem;
    border: 1.6px solid var(--c);
    border-radius: 50%;
    margin-right: auto;
    transition: 0.3s var(--ease2)
}

.offcanvas .nav-link-icon::after, .offcanvas .nav-link-icon::before {
    width: .22rem;
    height: 1.3rem
}

.nav-link.open .nav-link-icon {
    --c: var(--c-secondary)
}

.level--menu {
    margin: 0 4.5rem 4rem;
    border-bottom: 1px solid var(--c-primary-500);
    padding-bottom: 4rem
}

.flat--menu {
    margin: 0 6rem 4rem 4.5rem
}

.flat--menu .nav-link {
    display: flex;
    align-items: center;
    font-size: var(--fs-16);
    gap: 1rem;
    line-height: 1.8
}

.flat--menu .nav-link:hover {
    color: var(--c-secondary)
}

.flat--menu .icon {
    margin-right: auto;
    font-size: 1.1rem;
    transform: rotate(-90deg);
    transition: var(--t-ease) var(--ease2)
}

.flat--menu .nav-link:hover .icon {
    transform: rotate(-135deg)
}

.flat--menu .nav-item {
    margin-bottom: 2rem
}

.flat--menu .nav-item:last-child {
    margin-bottom: 0
}

.offcanvas-body {
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    flex: 1
}

.level--menu .nav-link {
    display: flex;
    width: 100%
}

.level--menu .nav-item {
    margin-bottom: 2.4rem
}

.level--menu .nav-item:last-child {
    margin-bottom: 0
}

.offcanvas .nav-link__title {
    display: flex;
    align-items: baseline;
    gap: 1rem
}

.offcanvas .nav-link__title .title {
    display: flex;
    flex-direction: column;
    line-height: 1.8;
    font-variation-settings: var(--fw-600);
    transition: 0.3s var(--ease2)
}

.offcanvas .nav-link__title .en {
    font-size: var(--fs-15);
    font-variation-settings: var(--fw-100);
    text-transform: uppercase;
    color: var(--c-white)
}

.offcanvas .nav-link__title .icon {
    font-size: 1.6rem;
    transition: 0.3s var(--ease2)
}

.offcanvas .navbar-nav .nav-link.open .icon, .offcanvas .navbar-nav .nav-link:hover .icon {
    color: var(--c-secondary)
}

.offcanvas .navbar-nav .nav-link.open .title, .offcanvas .navbar-nav .nav-link:hover .title {
    color: var(--c-secondary)
}

.offcanvas .main-menu-banner {
    margin-top: auto
}

.offcanvas .main-menu-banner img {
    width: 100%
}

.offcanvas .submenu-item-title {
    --btc: var(--c-primary-700);
    --h-bg: var(--c-white);
    --h-c: var(--btc);
    background-color: var(--btc);
    color: var(--c-white);
    gap: 1rem;
    font-size: var(--fs-18);
    font-variation-settings: var(--fw-600);
    padding: 1rem 2rem;
    margin-bottom: 3rem
}

.offcanvas .submenu-item-title i {
    transition: var(--t-ease) var(--ease2);
    position: relative;
    z-index: 2
}

.offcanvas .submenu-item-title:hover {
    color: var(--btc)
}

.offcanvas .submenu-links {
    margin: 0 5rem 4rem
}

.offcanvas .submenu-list {
    margin-right: 2rem;
    font-size: var(--fs-18);
    font-variation-settings: var(--fw-600)
}

.offcanvas .submenu-item {
    margin-bottom: 2rem
}

.offcanvas .submenu-item:last-child {
    margin-bottom: 0
}

.offcanvas .submenu-link:hover {
    color: var(--c-secondary)
}

.offcanvas .submenu-banner.bottom {
    margin-top: auto
}

.offcanvas .submenu-banner {
    margin: 0 4rem 4rem
}

.offcanvas .submenu-banner img {
    width: 100%
}

.hamburger-menu--footer {
    margin-top: auto
}

.hamburger-btns {
    display: flex;
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
    align-items: center;
    gap: 1rem;
    padding: 1.2rem;
    background: var(--c-primary-600);
    border-radius: 3.2rem;
    margin: 2rem auto 2.5rem;
    position: relative;
    -webkit-filter: drop-shadow(0 4px 6px #00000021);
    filter: drop-shadow(0 4px 6px #00000021)
}

.hamburger-btns .curve {
    background-color: var(--c-primary-600);
    -webkit-mask-image: url(../../../../../../../../../themes/websima/assets/img/masks/curve-bottom1.svg);
    mask-image: url(../../../../../../../../../themes/websima/assets/img/masks/curve-bottom1.svg);
    width: 8rem;
    height: 1rem;
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%) translateY(-1px);
    z-index: -1
}

.hamburger-btns .curve::before {
    content: "";
    background-color: var(--c-secondary);
    width: 51%;
    height: .2rem;
    display: block;
    margin: auto;
    border-radius: 14px;
    margin-top: 1px
}

.hamburger-btns .btn {
    flex: 1;
    min-width: 15rem;
    justify-content: center;
    padding: .8rem 2rem;
    height: 4rem;
    line-height: 1
}

.hamburger-btn__request {
    background: var(--c-primary-400);
    font-size: var(--fs-15);
    font-variation-settings: var(--fw-600)
}

.hamburger-btn__phone {
    background: var(--c-primary-500);
    font-size: var(--fs-22)
}

.hamburger-logos {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    pointer-events: none
}

.hamburger-logos img {
    width: 10rem;
    height: auto;
    transform: translateY(1px)
}

@media (min-width: 36em) {
    .ws-lang-link {
        display: block;
    }
}

@media (min-width: 50em) {
    .offcanvas--sub {
        right: var(--offcanvas-width);
        left: auto;
        z-index: 1;
        transform: translateX(100%);
        border-top-right-radius: 0;
        border-top-left-radius: 1rem
    }

    .offcanvas {
        --offcanvas-width: 51rem
    }

    .offcanvas__close.submenu {
        display: none
    }
}

.iland--logo-wrap {
    width: 5rem;
    height: 5rem;
    background: var(--c-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    flex: none;
    margin-right: auto
}

.iland--logo-inner {
    background-color: var(--c-secondary);
    width: 70%;
    height: 70%;
    position: absolute;
    z-index: 1
}

.iland--logo-white {
    position: absolute;
    width: 60%;
    height: 60%;
    background: var(--c-primary);
    z-index: 2
}

.iland--logo-img img {
    -webkit-filter: brightness(0) invert(1);
    filter: brightness(0) invert(1);
    width: 100%;
    height: 100%;
    -o-object-fit: contain;
    object-fit: contain
}

.iland--logo-img {
    position: absolute;
    width: 50%;
    height: 50%;
    z-index: 4;
    transform: scale(0)
}

.iland-wrapper {
    background-color: #ffffff8a;
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
    position: fixed;
    width: 6rem;
    justify-content: space-between;
    bottom: 1rem;
    left: 39%;
    transform: translateX(-50%) translateY(120%) scale(.7);
    opacity: 0;
    border-radius: 52px;
    box-shadow: 0 4px 6px #00000014;
    padding: .3rem;
    border: 1px solid var(--c-primary-150);
    gap: 4rem;
    font-size: var(--fs-15)
}

.iland-wrapper .iland--nav {
    display: flex;
    gap: 3rem;
    align-items: center;
    flex: 1;
    justify-content: space-between;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 3rem;
    white-space: nowrap;
    font-size: var(--fs-14)
}

.iland-wrapper .iland--nav li {
    opacity: 0;
    transform: translateX(-1rem)
}

#iland {
    display: none
}

.iland-request {
    position: fixed;
    bottom: 1rem;
    color: var(--c-white);
    left: 50%;
    transform: translate(-50%, 120%);
    z-index: 20
}

.iland-request--box {
    background: var(--c-white);
    padding: .9rem;
    border-radius: 32px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, .3);
    display: flex;
    align-items: center;
    min-width: 32rem;
    position: relative;
    gap: 1rem
}

.iland-request--head {
    background: var(--c-primary-500);
    display: flex;
    align-items: center;
    width: 76%;
    margin-right: auto;
    margin-left: 5rem;
    padding: .3rem 2rem;
    font-size: 1.2rem;
    border-radius: 14px 14px 0 0;
    gap: 1rem
}

.iland-request--head .title {
    font-variation-settings: var(--fw-400)
}

.iland-request--head .subtitle {
    opacity: .7
}

.iland-request__btn {
    font-size: 1.3rem;
    padding: 2rem
}

.iland-request__call {
    font-size: 1.6rem;
    background: var(--c-primary);
}

.iland-request__img {
    position: absolute;
    left: 2rem;
    width: 9rem;
    bottom: 0
}

@media (min-width: 36em) {
    .ws-lang-link {
        display: block
    }
}

@media (min-width: 50em) {
    #humburger-menu .ws-menu svg {
        width: 1.8rem;
        height: 1.8rem
    }

    #iland {
        display: block
    }

    .humburger-menu-wrapper {
        border-radius: 30px;
        width: 40%;
        right: var(--gutter-container);
        --p: 3.5rem;
        height: auto;
        top: 3.5rem
    }

    .humburger-menu--header {
        gap: 4rem;
        padding: 1.5rem calc(var(--p-nav) + 0rem) 2.5rem 4rem;
        align-items: center;
        flex-direction: row
    }

    .humburger-nav-container > ul > li.menu-item-has-children > a::after, .humburger-nav-container > ul > li:not(.menu-item-has-children) > a::after {
        margin-right: 3rem
    }

    .header-nav-container--humburger {
        width: auto
    }

    .header-nav--humburger {
        justify-content: unset
    }

    .header-nav--humburger > li > a {
        padding: 1rem
    }

    .humburger-nav-container > ul > li > ul > li > a::after {
        content: "\e909";
        font-family: var(--ff-icon);
        font-size: .8rem;
        color: var(--c-secondary);
        transform: rotate(-90deg) translate(-.6rem, .6rem);
        transition: var(--t-ease) var(--ease2);
        opacity: 0;
        margin-right: 1rem
    }
}

/*!
Theme Name: ÙØ±Ø§ÙˆÙ†Ø³
Author: Ù…Ø­Ù…Ø¯Ø±Ø¶Ø§ Ù…ÙˆØ³ÙˆÛŒ <mousavi@hoovision.com>
Author URI: https://hoovision.com
Version: 1.0.3
Description: Ù‚Ø§Ù„Ø¨ Ø´Ø±Ú©ØªÛŒ / Ø®Ø¯Ù…Ø§ØªÛŒ
*/
*, body {
    -moz-osx-font-smoothing: grayscale
}

img, video {
    display: block;
    height: auto
}

a, ins {
    text-decoration: none
}

#preloader__bg, body {
    background-color: var(--c-white)
}

#circle--logo, #logo-circle--inside {
    position: absolute;
    transform: scale(0)
}

.icon-plus::after, .lead-form--close:hover i {
    transform: rotate(-90deg)
}

.input-group, .input-group select {
    text-overflow: ellipsis;
    width: 100%
}

.hidden-svg, .lead-form-curve, .lenis.lenis-smooth iframe, canvas {
    pointer-events: none
}

.input-group.textarea textarea, .sw-auto .swiper-slide, html.lenis, html.lenis body, img, video {
    height: auto
}

:where(:not(html,iframe,canvas,img,svg,video,audio):not(svg *,symbol *)) {
    all: unset;
    display: revert
}

button, input, select, textarea {
    font: inherit
}

*, ::after, ::before {
    box-sizing: border-box
}

a, button {
    cursor: revert
}

.btn-request, [role=button], button {
    cursor: pointer
}

menu, ol, ul {
    list-style: none
}

table {
    border-collapse: collapse;
    width: 100%
}

input, textarea {
    -webkit-user-select: auto
}

textarea {
    white-space: revert
}

meter {
    -webkit-appearance: revert;
    -moz-appearance: revert;
    appearance: revert
}

::-webkit-input-placeholder {
    color: unset
}

::-moz-placeholder {
    color: unset
}

:-ms-input-placeholder {
    color: unset
}

::-ms-input-placeholder {
    color: unset
}

::placeholder {
    color: unset
}

:where([hidden]) {
    display: none
}

:where([contenteditable]:not([contenteditable=false])) {
    -moz-user-modify: read-write;
    -webkit-user-modify: read-write;
    overflow-wrap: break-word;
    -webkit-line-break: after-white-space;
    -webkit-user-select: auto
}

#overlay, .section, video {
    overflow: hidden
}

:where([draggable=true]) {
    -webkit-user-drag: element
}

:after, :before {
    text-decoration: inherit;
    vertical-align: inherit
}

:root, [data-theme=light] {
    --c-primary: #050033;
    --c-primary-50: #f0f0f5;
    --c-primary-100: #f6f5fa;
    --c-primary-150: #edecf5;
    --c-primary-200: #eae9f3;
    --c-primary-250: #a9a6c1;
    --c-primary-300: #938ec4;
    --c-primary-350: #6d6991;
    --c-primary-400: #1900ff;
    --c-primary-500: #0f0099;
    --c-primary-600: #090066;
    --c-primary-700: #07004c;
    --c-primary-800: #16171f;
    --c-primary-850: #03001a;
    --c-secondary: #cd6c58;
    --c-neutral-100: #fefefe;
    --c-neutral-150: #f5f5f7;
    --c-neutral-200: #f1f1f1;
    --c-neutral-250: #dddce5;
    --c-neutral-300: #d1d1d1;
    --c-neutral-350: #b3b3b3;
    --c-neutral-400: #9c9c9c;
    --c-neutral-500: #333333;
    --c-neutral-600: #2b2b2b;
    --c-neutral-700: #171719;
    --c-white: #fff;
    --c-black: #000;
    --c-brand2: #02757D;
    --ease1: cubic-bezier(0.68, -0.6, 0.32, 1.6);
    --ease2: cubic-bezier(0.5, 1, 0.89, 1);
    --ease3: cubic-bezier(0.62, 0.05, 0.01, 0.99);
    --ease4: cubic-bezier(0.25, 0.1, 0.25, 1);
    --ease5: cubic-bezier(0.24, 0.43, 0.15, 0.97);
    --ease6: cubic-bezier(0.23, 1, 0.32, 1);
    --ease7: cubic-bezier(0.12, 0, 0.39, 0);
    --c-danger: #f40259;
    --c-success: #0acd58;
    --c-info: #0288d1;
    --ff-main: YekanBakh;
    --ff-en: Poppins;
    --ff-icon: VisionIcon;
    --space-xs: 3rem;
    --space-sm: 6rem;
    --space-md: min(8.5rem, 12vw);
    --space-lg: min(12rem, 12vw);
    --space-xl: min(15rem, 18vw);
    --space-xxl: min(20rem, 25vw);
    --fs-10: 1.3rem;
    --fs-11: 1.4rem;
    --fs-12: 1.5rem;
    --fs-13: 1.5rem;
    --fs-14: 1.6rem;
    --fs-15: 1.6rem;
    --fs-16: 1.7rem;
    --fs-18: 1.9rem;
    --fs-20: 2rem;
    --fs-22: 2.2rem;
    --fs-24: 2.4rem;
    --fs-26: 2.6rem;
    --fs-28: 2.8rem;
    --fs-30: 3rem;
    --fs-32: 3.2rem;
    --fs-34: 3.4rem;
    --fs-36: 3.6rem;
    --fs-38: 3.8rem;
    --fs-40: 4rem;
    --fs-42: 4rem;
    --fw-100: "wght" 100;
    --fw-150: "wght" 150;
    --fw-200: "wght" 200;
    --fw-250: "wght" 250;
    --fw-300: "wght" 300;
    --fw-350: "wght" 350;
    --fw-400: "wght" 400;
    --fw-450: "wght" 450;
    --fw-500: "wght" 500;
    --fw-600: "wght" 600;
    --gutter-container: 1rem;
    --p-nav: 4rem;
    --gutter-x: 3rem;
    --heading_h1_fontsize: 2.8rem;
    --swiper-pagination-bullet-width: 1.2rem;
    --swiper-pagination-bullet-height: 1.2rem;
    --swiper-pagination-bullet-border-radius: 50%;
    --swiper-pagination-color: currentColor;
    --swiper-pagination-bullet-inactive-color: currentColor;
    --swiper-pagination-bullet-horizontal-gap: 0.5rem;
    --swiper-pagination-bullet-inactive-opacity: 0.5;
    --swiper-pagination-bullet-opacity: 1;
    --swiper-navigation-size: 1.3rem;
    --swiper-navigation-sides-offset: -5rem;
    --swiper-preloader-color: var(--c-primary);
    --padding-section-base: 0rem;
    --br-30: 12px;
    --br-16: 8px;
    --t-ease: 0.5s
}


@font-face {
    font-family: VisionIcon;
    src: url('assets/fonts/VisionIcon.ttf') format("truetype");
    font-weight: 400;
    font-style: normal;
    font-display: swap
}

body {
    position: relative;
    direction: rtl;
    font-family: var(--ff-main), sans-serif;
    font-size: clamp(1.3rem, 1vw, 2.4rem);
    line-height: 2;
    min-height: 100vh;
    overflow-x: hidden;
    color: var(--c-primary);
    font-variation-settings: var(--fw-400);
    font-feature-settings: "kern" on, "liga" on, "dlig" on;
    -moz-font-feature-settings: "kern" on, "liga" on, "dlig" on;
    -webkit-font-feature-settings: "kern" on, "liga" on, "dlig" on;
    -ms-font-feature-settings: "kern" on, "liga" on, "dlig" on;
    -o-font-feature-settings: "kern" on, "liga" on, "dlig" on;
    -webkit-font-smoothing: antialiased;
    font-smoothing: antialiased;
    text-rendering: optimizeLegibility
}

.form-step1-footer--head, .home {
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none
}

a, img {
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none
}

html {
    font-size: 2.1vw;
    font-size: min(2.1vw, 7px);
    scroll-behavior: smooth
}

[class*=ic-]::after, [class*=ic-]::before, [class^=ic-]::after, [class^=ic-]::before {
    font-family: VisionIcon;
    speak: never;
    font-style: normal;
    font-weight: 400;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale
}

* {
    outline: 0;
    -webkit-font-smoothing: antialiased;
    -webkit-tap-highlight-color: #fff0
}

::-moz-selection {
    color: var(--c-neutral-500);
    background: #cadefe
}

::selection {
    color: var(--c-neutral-500);
    background: #cadefe
}

.bg--black, .bg--primary {
    color: var(--section-color)
}

:focus-visible {
    outline: 0;
    outline-offset: 4px
}

body, html {
    -ms-scroll-chaining: none;
    overscroll-behavior: none;
    width: 100%
}

:target {
    scroll-margin-top: 14rem
}

i, svg {
    display: inline-block;
    line-height: 1;
    vertical-align: middle
}

input {
    font-family: var(--ff-main), Arial
}

img {
    max-width: 100%;
    user-select: none;
    -webkit-user-drag: none;
    -webkit-filter: saturate(1.2);
    filter: saturate(1.2)
}

video {
    width: 100%
}

a {
    transition: var(--t-ease) var(--ease4);
    color: currentColor;
    user-select: none
}

input::-webkit-inner-spin-button, input::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0
}

input[type=number] {
    -moz-appearance: textfield
}

input[type=search]::-webkit-search-cancel-button, input[type=search]::-webkit-search-decoration, input[type=search]::-webkit-search-results-button, input[type=search]::-webkit-search-results-decoration {
    -webkit-appearance: none
}

del {
    text-decoration: line-through
}

#overlay {
    position: fixed;
    z-index: 25;
    background: #0000007a;
    -webkit-backdrop-filter: blur(0);
    backdrop-filter: blur(0);
    inset: 0;
    height: 100%;
    width: 100%;
    opacity: 0;
    visibility: hidden
}

@-webkit-keyframes fadeEffect {
    0% {
        opacity: 0
    }

    100% {
        opacity: 1
    }
}

@keyframes fadeEffect {
    0% {
        opacity: 0
    }

    100% {
        opacity: 1
    }
}

.swiper-horizontal.swiper-rtl > .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
    transition: transform .6s, right .6s
}

.lenis.lenis-smooth [data-lenis-prevent] {
    -ms-scroll-chaining: none;
    overscroll-behavior: contain
}

.lenis.lenis-stopped {
    overflow: clip
}

.sw--portfolio:not(.swiper-initialized) .swiper-slide {
    margin-left: 20px
}

.splitting .word {
    display: inline-block;
    --word-percent: calc(var(--word-index) / var(--word-total));
    --line-percent: calc(var(--line-index) / var(--line-total))
}

.splitting .char {
    position: relative;
    --char-percent: calc(var(--char-index) / var(--char-total));
    --char-offset: calc(var(--char-index) - var(--char-center));
    --distance: calc((var(--char-offset) * var(--char-offset)) / var(--char-center));
    --distance-sine: calc(var(--char-offset) / var(--char-center));
    --distance-percent: calc((var(--distance) / var(--char-center)))
}

.splitting {
    --word-center: calc((var(--word-total) - 1) / 2);
    --char-center: calc((var(--char-total) - 1) / 2);
    --line-center: calc((var(--line-total) - 1) / 2)
}

#preloader__img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    transform-origin: bottom;
    background: #0500333a;
    z-index: 0
}

#preloader__bg {
    z-index: 0;
    transform-origin: 50% 0;
    border-bottom-right-radius: 0;
    border-bottom-left-radius: 0;
    width: 100%;
    height: 100%;
    position: absolute;
    inset: 0%;
    transform: scale(1)
}

#preloader {
    position: fixed;
    inset: 0;
    z-index: 99999;
    width: 100%;
    height: 100vh
}

#ws-logo-circle, .section {
    display: flex;
    position: relative
}

#ws-logo-circle {
    width: 5.6rem;
    height: 5.6rem;
    border-radius: 50%;
    background-color: var(--c-primary-700);
    transform: scale(0) translateY(0);
    align-items: center;
    justify-content: center;
    flex: none
}

#logo-circle--inside {
    background: var(--c-white);
    border-radius: 50%;
    width: 86%;
    height: 86%
}

#circle--logo {
    width: 73%;
    display: flex;
    align-items: center;
    justify-content: center
}

#circle--logo img {
    width: 100%;
    margin-right: 2px
}

.bg--black {
    --section-bg: var(--c-neutral-700);
    --section-color: var(--c-white);
    background-color: var(--section-bg)
}

.bg--gradient-light {
    --section-bg: var(--c-primary-50);
    --section-color: var(--c-primary);
    background: linear-gradient(to bottom, var(--section-bg), transparent)
}

.bg--primary {
    --section-bg: var(--c-primary);
    --section-color: var(--c-white);
    background-color: var(--section-bg)
}

.bg--white {
    --section-bg: var(--c-white);
    --section-color: var(--c-primary);
    background: var(--section-bg)
}

.inner-page .modular-page {
    padding-top: 4rem
}

.section {
    flex-direction: column
}

.container {
    width: 100%;
    padding: 0 var(--gutter-container);
    margin: 0 auto;
    max-width: 1440px;
}

.hidden-svg {
    position: absolute;
    display: block
}

.icon-plus, .menu-item-has-children, .relative, .sw {
    position: relative
}

.svg-dots {
    width: 100%
}

.empty-error {
    color: var(--c-danger);
    background-color: var(--bg-danger);
    padding: 1rem 2rem;
    border-radius: var(--br-32);
    font-size: var(--fs-16)
}

.gutter-b {
    margin-bottom: var(--gutter-x)
}

.text-justify {
    text-align: justify
}

.btns--box {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    -moz-column-gap: 2rem;
    column-gap: 2rem;
    row-gap: 1rem;
    margin-top: min(2rem, 4vw)
}

.icon-plus {
    display: flex;
    align-items: center;
    justify-content: center
}

.line-1, .line-2, .line-3, .line-4 {
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical
}

.icon-plus::after {
    transition: var(--t-ease) .1s var(--ease2)
}

.icon-plus::before {
    transform: rotate(.1deg);
    transition: var(--t-ease) var(--ease2)
}

.icon-plus::after, .icon-plus::before {
    content: "";
    background-color: var(--c);
    width: 2.8px;
    height: 1.6rem;
    transform-origin: center;
    display: block;
    border-radius: 5px;
    position: absolute;
    z-index: 2
}

.open .icon-plus::after {
    transform: rotate(-45deg)
}

.open .icon-plus::before {
    transform: rotate(45deg)
}

.accordion-content {
    height: 0;
    overflow: hidden
}

.line-2 {
    -webkit-line-clamp: 2
}

.line-3 {
    -webkit-line-clamp: 3
}

.line-4 {
    -webkit-line-clamp: 4
}

.line-1 {
    -webkit-line-clamp: 1
}

.position-static {
    position: static
}

.text-center {
    text-align: center
}

.text-left {
    text-align: left
}

.swiper-button-lock {
    display: none !important
}

.pt-xs {
    padding-top: var(--space-xs)
}

.pt-sm {
    padding-top: var(--space-sm)
}

.pt-md {
    padding-top: var(--space-md)
}

.pt-lg {
    padding-top: var(--space-lg)
}

.pt-xl {
    padding-top: var(--space-xl)
}

.pt-xxl {
    padding-top: var(--space-xxl)
}

.main-page {
    padding: 11rem 0 0
}

.pb-xs {
    padding-bottom: var(--space-xs)
}

.pb-sm {
    padding-bottom: var(--space-sm)
}

.pb-md {
    padding-bottom: var(--space-md)
}

.pb-lg {
    padding-bottom: var(--space-lg)
}

.pb-xl {
    padding-bottom: var(--space-xl)
}

.pb-xxl {
    padding-bottom: var(--space-xxl)
}

.fs-14 {
    font-size: var(--fs-14)
}

.fs-15 {
    font-size: var(--fs-15)
}

.fs-16 {
    font-size: var(--fs-16)
}

.fs-18 {
    font-size: var(--fs-18)
}

.fs-20 {
    font-size: var(--fs-20);
    line-height: 1.8
}

.fs-22 {
    font-size: var(--fs-22);
    line-height: 1.6
}

.fs-24, .fs-26, .fs-28, .fs-30, .fs-32, .fs-36 {
    line-height: 1.5
}

.fs-24 {
    font-size: var(--fs-24)
}

.fs-26 {
    font-size: var(--fs-26)
}

.fs-28 {
    font-size: var(--fs-28)
}

.fs-30 {
    font-size: var(--fs-30)
}

.fs-32 {
    font-size: var(--fs-32)
}

.fs-36 {
    font-size: var(--fs-36)
}

.fs-38 {
    font-size: var(--fs-38);
    line-height: 1.45
}

.fs-40, .fs-42 {
    line-height: 1.4
}

.fs-40 {
    font-size: var(--fs-40)
}

.fs-42 {
    font-size: var(--fs-42)
}

.fw-300 {
    font-variation-settings: var(--fw-300)
}

.fw-200 {
    font-variation-settings: var(--fw-200)
}

.fw-250 {
    font-variation-settings: var(--fw-250)
}

.fw-350 {
    font-variation-settings: var(--fw-350)
}

.fw-400 {
    font-variation-settings: var(--fw-400)
}

.fw-500 {
    font-variation-settings: var(--fw-500)
}

.fw-600 {
    font-variation-settings: var(--fw-600)
}

::-webkit-scrollbar {
    width: 4px;
    height: 4px
}

::-webkit-scrollbar-track {
    background: 0 0
}

::-webkit-scrollbar-thumb {
    background: var(--c-neutral-400);
    cursor: pointer;
    border-radius: 9rem
}

.hide-scrollbar::-webkit-scrollbar {
    display: none !important
}

.hide-scrollbar {
    -ms-overflow-style: none !important;
    scrollbar-width: none !important
}

.heading--center {
    margin: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center
}

.heading-base .entitle {
    margin-bottom: 1rem;
    font-family: var(--ff-en);
    text-transform: capitalize
}

.heading-base .subtitle {
    margin-top: 2rem;
    font-size: var(--fs-18);
    line-height: 1.8
}

.heading-base .entitle, .heading-base .subtitle, .heading-base .title {
    text-align: center
}

.heading-base .typography {
    margin-bottom: 3.4rem;
    max-width: calc(100% - 4rem)
}

.heading--between {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    -moz-column-gap: 20rem;
    column-gap: 20rem;
    row-gap: 2rem
}

.heading-base {
    margin-bottom: 5rem
}

.heading--between .btns--box {
    margin-top: 0
}

.heading--between-right {
    flex: 1
}

.heading--between-right .typography, .heading--right .typography {
    margin-right: auto;
    margin-left: auto
}

.section--tabs-wrapper {
    display: flex;
    justify-content: space-between;
    flex-direction: column-reverse;
    gap: 2rem;
    padding: 0 calc(var(--padding-section-base) * 7);
    margin-bottom: 4rem;
    align-items: center
}

.section--tabs {
    display: flex;
    flex-wrap: wrap;
    -moz-column-gap: 1rem;
    column-gap: 1rem;
    row-gap: 1rem;
    align-items: center;
    flex: auto;
    white-space: nowrap;
    justify-content: center;
    width: 100%
}

.section--hero.is-wave {
    padding-bottom: 6vw
}

.section--history.is-wave, .section--portfolio.is-wave {
    padding-top: 0
}

.wbswave {
    width: 100%;
    height: min(35rem, 26vw);
    position: absolute;
    bottom: -1px;
    right: 0;
    left: 0;
    z-index: 5
}

.lead-form-box, .lead-form-inner {
    height: 100%;
    position: relative
}

.is-wave, .is-wave.current-wtype3 {
    padding-bottom: min(30rem, 34vw)
}

.is-wave-prev {
    padding-top: 5rem
}

.current-wtype2.is-wave {
    padding-bottom: 0
}

.btn--ws-phone {
    font-size: var(--fs-16)
}

.section-wrapper.grid {
    position: relative;
    z-index: 2
}

@media (min-width: 36em) {
    a:is(:hover,:focus-visible) {
        text-decoration: none
    }
}

@media (max-width: 49.99em) {
    #ws-logo-circle {
        width: 4.6rem;
        height: 4.6rem
    }
}

#lead-form-wrapper {
    position: fixed;
    top: 14rem;
    right: 0;
    bottom: 5rem;
    left: 0;
    z-index: 50;
    --bg-form: var(--c-white);
    display: none
}

.lead-form-box {
    display: flex;
    align-items: center;
    justify-content: center
}

.lead-form--bg {
    position: fixed;
    background-color: rgba(139, 139, 139, 0.7);
    inset: 0
}

.lead-form--icons {
    display: flex;
    align-items: end;
    color: var(--c-primary);
    justify-content: center;
    z-index: 3;
    -webkit-mask-image: url('assets/img/masks/curve-top2.svg');
    mask-image: url('assets/img/masks/curve-top2.svg');
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    width: 31rem;
    height: 4.9rem;
    bottom: calc(100% - 1px);
    background: var(--bg-form);
    --icon-color-default: var(--c-primary);
    --icon-color-active: var(--c-primary-400)
}

.lead-form--close, .lead-form-badge {
    position: fixed;
    left: 50%;
    transform: translateX(-50%);
    z-index: 2
}

.lead-form--icons i {
    color: var(--icon-color-default)
}

.lead-form--icons .ic-square {
    -webkit-animation: 2s infinite icon1-cycle;
    animation: 2s infinite icon1-cycle
}

.lead-form--icons .ic-circle {
    -webkit-animation: 2s infinite icon2-cycle;
    animation: 2s infinite icon2-cycle
}

.lead-form--icons .ic-triangle {
    -webkit-animation: 2s infinite icon3-cycle;
    animation: 2s infinite icon3-cycle
}

@-webkit-keyframes icon1-cycle {
    0%, 33% {
        color: var(--icon-color-active)
    }

    100%, 33.0001% {
        color: var(--icon-color-default)
    }
}

@keyframes icon1-cycle {
    0%, 33% {
        color: var(--icon-color-active)
    }

    100%, 33.0001% {
        color: var(--icon-color-default)
    }
}

@-webkit-keyframes icon2-cycle {
    0%, 100%, 33%, 66.0001% {
        color: var(--icon-color-default)
    }

    33.0001%, 66% {
        color: var(--icon-color-active)
    }
}

@keyframes icon2-cycle {
    0%, 100%, 33%, 66.0001% {
        color: var(--icon-color-default)
    }

    33.0001%, 66% {
        color: var(--icon-color-active)
    }
}

@-webkit-keyframes icon3-cycle {
    0%, 66% {
        color: var(--icon-color-default)
    }

    100%, 66.0001% {
        color: var(--icon-color-active)
    }
}

@keyframes icon3-cycle {
    0%, 66% {
        color: var(--icon-color-default)
    }

    100%, 66.0001% {
        color: var(--icon-color-active)
    }
}

@-webkit-keyframes changeColor {
    0%, 100%, 33%, 34%, 66%, 67% {
        color: var(--icon-color)
    }
}

@keyframes changeColor {
    0%, 100%, 33%, 34%, 66%, 67% {
        color: var(--icon-color)
    }
}

.lead-form--close {
    top: 4rem;
    width: 4rem;
    height: 4rem;
    background: var(--c-white);
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    font-size: 1.6rem
}

.lead-form--close i {
    transition: .5s var(--ease3);
    display: block
}

.lead-form-badge {
    bottom: 0;
    max-width: 18.9rem
}

.lead-form {
    width: min(41rem, 94%);
    max-height: 100%;
    margin-inline: auto;
    background-color: var(--bg-form);
    display: flex;
    flex-direction: column;
    position: relative;
    border-radius: 3rem
}

.input-group, .menu-item-has-children:hover .sub-menu, .step1-active .form-step1-footer {
    display: block
}

.input-group {
    padding: .5rem 1.5rem;
    height: 4.4rem;
    background-color: var(--c-white);
    border: 1px solid var(--c-neutral-250);
    transition: .3s var(--ease2);
    position: relative;
    border-radius: 12px;
    font-size: var(--fs-16);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .8rem
}

.input-group i {
    font-size: 1.8rem
}

.input-group .ic-arrow-down-noline {
    font-size: var(--fs-10)
}

.error .input-group {
    background-color: #f4025b16
}

.input-group input, .input-group select, .input-group textarea {
    flex: 1;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -webkit-user-drag: none
}

.input-group textarea::-webkit-input-placeholder {
    color: #9E9E9E;
    font-size: var(--fs-12);
}

.input-group textarea::-moz-placeholder {
    color: #9E9E9E;
    font-size: var(--fs-12);
}

.input-group textarea:-ms-input-placeholder {
    color: #9E9E9E;
    font-size: var(--fs-12)
}

.input-group textarea::-ms-input-placeholder {
    color: #9E9E9E;
    font-size: var(--fs-12)
}

.input-group textarea::placeholder {
    color: #9E9E9E;
    font-size: var(--fs-12)
}

.input-group input::-webkit-input-placeholder {
    color: #9E9E9E;
    font-size: var(--fs-12)
}

.input-group input::-moz-placeholder {
    color: #9E9E9E;
    font-size: var(--fs-12)
}

.input-group input:-ms-input-placeholder {
    color: #9E9E9E;
    font-size: var(--fs-12)
}

.input-group input::-ms-input-placeholder {
    color: #9E9E9E;
    font-size: var(--fs-12)
}

.input-group input::placeholder {
    color: #9E9E9E;
    font-size: var(--fs-12)
}

.input-group:focus-within {
    border-color: #EEF8FF;
}

.input-group select {
    cursor: pointer;
    white-space: nowrap
}

.input-group select:invalid {
    color: var(--c-primary-350);
    font-size: var(--fs-12)
}

.input-group.textarea {
    height: 10rem;
    border-radius: 2rem;
    align-items: start;
    padding-top: 1rem
}

.input-group input:-webkit-autofill, .input-group input:-webkit-autofill:active, .input-group input:-webkit-autofill:focus, .input-group input:-webkit-autofill:hover {
    -webkit-animation-name: autofill;
    -webkit-animation-delay: 1s;
    -webkit-animation-fill-mode: both;
    border: none;
    -webkit-box-shadow: 0 0 0 30px var(--c-white) inset !important;
    -webkit-box-shadow: none;
    -webkit-transition: background-image 5000s ease-in-out;
    transition: background-image 5000s ease-in-out
}

.btn-request, .toggle-pages-step3 i {
    transition: .3s var(--ease2)
}

.input-container {
    margin-bottom: 2.3rem
}

.form-operation {
    margin-top: 1rem;
    text-align: center
}

.btn-request {
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1.8;
    font-family: inherit;
    white-space: nowrap;
    height: 4rem;
    user-select: none;
    border-radius: 3rem;
    position: relative;
    padding: 1rem 1.8rem;
    overflow: hidden;
    font-size: var(--fs-12);
    margin-top: 1rem
}

.btn-request:disabled, .btn-request[disabled] {
    opacity: .5
}

.btn-request.bg-primary {
    color: var(--c-white);
    box-shadow: 0 4px 6px #0f009959
}

.btn-request.bg-gray {
    background: var(--c-neutral-250)
}

.btn-request:not(:disabled):hover, .btn-request:not([disabled]):hover {
    opacity: .7
}

.forms-steps {
    overflow-y: auto;
    border-radius: 3rem
}

.lead-form-curve {
    position: absolute;
    width: 26rem;
    height: 3.5rem;
    bottom: calc(100% - 1px);
    fill: var(--c-white);
    left: 50%;
    transform: translateX(-50%)
}

.form-loading {
    position: absolute;
    inset: 0;
    background-color: #fff2;
    -webkit-backdrop-filter: blur(3px);
    backdrop-filter: blur(3px);
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 2;
    border-radius: 3rem
}

.lead-form-step3-wrapper, .lead-step2-wrapper, .lead-step4-wrapper, .lead-step5-wrapper {
    display: none;
    opacity: 0
}

.lead-form-step1-wrapper, .lead-form-step3-wrapper {
    --p: 3rem
}

.form-step1-header {
    text-align: center;
    padding: 2rem var(--p) 0
}

.form-step1-header__title, .form-step3-header__title, .step2-body__title, .step2-header__title, .step4-body__title, .step4-header__title {
    font-size: var(--fs-16);
    font-variation-settings: var(--fw-400)
}


.form-step1-header__subtitle {
    font-size: var(--fs-14);
    margin-top: .4rem;
    color: var(--c-primary-350);
    line-height: 1.7
}

.form-step1-body {
    padding: 0 var(--p);
    margin-top: 2rem;
    margin-bottom: 6rem
}

.lead-step4-wrapper, .lead-step5-wrapper {
    --p: 2.3rem
}

.lead-step2-wrapper {
    --p: 2.5rem
}

.step2-active .lead-form--icons, .step4-active .lead-form--icons, .step5-active .lead-form--icons {
    --icon-color-default: var(--c-white);
    --icon-color-active: var(--c-white)
}

.step2-header__curve, .step4-header__curve, .step5-header__curve {
    fill: var(--bg-form);
    width: 15rem;
    height: 1.5rem;
    position: absolute;
    top: calc(100% - 1px);
    pointer-events: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none
}

.step2-header, .step4-header, .step5-header {
    color: var(--c-white);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    text-align: center;
    padding: 2.8rem var(--p) 2rem;
    position: relative
}

.step2-body, .step4-body, .step5-body {
    background: var(--c-white);
    padding: 4.6rem var(--p) 3rem;
    text-align: center
}

.step2-header__subtitle, .step4-header__subtitle {
    font-size: var(--fs-12);
    margin-top: .4rem;
    color: var(--c-neutral-250);
    line-height: 1.7
}

.step5-header__img {
    width: 11rem;
    height: 5rem;
    -o-object-fit: contain;
    object-fit: contain
}

.step2-header__img, .step4-header__img {
    width: 5rem;
    height: 4rem;
    -o-object-fit: contain;
    object-fit: contain;
    margin-bottom: 1rem
}

.step2-body__subtitle {
    font-size: var(--fs-12);
    line-height: 1.8;
    margin-top: .5rem
}

.step2-body__btns {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 2rem;
    margin-top: .7rem
}

.step2-body .btn-request {
    flex: 1
}

.form-step3-page2 {
    display: none
}


.form-step3-header {
    text-align: center;
    padding: 2rem var(--p) 1.8rem
}

.form-step3-header__subtitle {
    font-size: var(--fs-12);
    line-height: 1.8;
    margin-top: 0
}

.form-step3-body {
    padding: 0 var(--p) 0
}

.toggle-pages-step3 {
    -webkit-mask-image: url(/wp-content/themes/faravance/assets/img/masks/curve-top3.svg);
    mask-image: url(/wp-content/themes/faravance/assets/img/masks/curve-top3.svg);
    background-image: linear-gradient(to bottom, #dddce5, #fff);
    width: 9.6rem;
    height: 5rem;
    justify-content: center;
    margin: 3rem auto 0
}

.toggle-pages-step3.page1 i {
    transform: rotateY(180deg)
}

.faq-item summary .icon svg {
    transition: transform 0.3s ease;
}

.faq-item[open] summary .icon svg {
    transform: rotate(180deg);
}

.form-step1-footer--head.noworking-time {
    color: var(--c-primary-350);
    font-size: 1rem;
    text-align: left;
    margin-left: 15rem;
    padding-bottom: .7rem
}

.form-step1-footer--head .subtitle {
    font-variation-settings: var(--fw-100)
}

.form-step1-footer--box {
    padding: 1.2rem;
    border-top-right-radius: 48px;
    border-top-left-radius: 48px;
    display: flex;
    align-items: center;
    position: relative;
    gap: 2rem;
    isolation: isolate
}

.form-step1-footer__notic {
    font-size: 1.2rem;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1.5;
    font-family: inherit;
    user-select: none;
    border-radius: 3rem;
    position: relative;
    padding: 1.1rem 1.4rem;
    background-color: var(--c-black);
    color: var(--c-white)
}

.form-step1-footer__notic.working-time {
    background-color: var(--c-primary-500);
    cursor: pointer
}

.form-step1-footer__img {
    position: absolute;
    left: 3rem;
    width: 10.4rem;
    z-index: -1;
    bottom: 0
}


.form-error-msg {
    display: block;
    color: var(--c-danger);
    text-align: right;
    padding: 0 1rem;
    font-size: var(--fs-12);
    line-height: 1.5;
    margin: 3rem 0 2rem
}

@media (min-width: 50em) {
    .section--hero.is-wave {
        padding-bottom: 0
    }

    .section--tabs {
        -moz-column-gap: 3rem;
        column-gap: 3rem;
        width: auto
    }

    .section--tabs-wrapper {
        flex-direction: row
    }

    .heading--center {
        width: 53%
    }

    :root {
        --padding-section-base: 2rem;
        --br-30: 3rem;
        --br-16: 1.6rem;
        --fs-10: 1rem;
        --fs-12: 1.2rem;
        --fs-13: 1.3rem;
        --fs-14: 1.4rem;
        --fs-15: 1.5rem;
        --fs-16: 1.6rem;
        --fs-18: 1.8rem;
        --fs-20: 2rem;
        --fs-22: 2.3rem;
        --fs-24: 2.4rem;
        --fs-26: 2.6rem;
        --fs-28: 2.8rem;
        --fs-30: 3rem;
        --fs-32: 3.2rem;
        --fs-34: 3.4rem;
        --fs-36: 3.6rem;
        --fs-38: 3.8rem;
        --fs-40: 4rem;
        --fs-42: 4.2rem
    }

    html {
        font-size: min(.57vw, 10px)
    }

    .heading--between {
        flex-direction: row;
        align-items: end;
        justify-content: space-between
    }

    .heading--between-right .typography, .heading--right .typography {
        margin-right: 0;
        margin-left: 0
    }

    .heading--right .subtitle {
        text-align: justify
    }

    .heading-base .entitle, .heading-base .title {
        text-align: unset
    }

    .lead-form-step1-wrapper, .lead-form-step3-wrapper {
        --p: 6.6rem
    }

    .lead-step2-wrapper {
        --p: 3.3rem
    }
}

.products-archive {
    margin-top: 30px
}

.product-item {
    margin-bottom: 30px;
    padding: 15px;
    border: 1px solid #eee;
    border-radius: 5px
}

.product-thumbnail {
    margin-bottom: 15px
}

.product-thumbnail img {
    width: 100%;
    height: auto
}

.single-products img {
    border-radius: 10px
}

.call-to-action:hover {
    background: #fff;
    color: #050033
}

.main-mm .menu > li {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.main-mm ul li > .sub-menu {
    position: fixed;
    top: 0;
    bottom: 0;
    width: 320px;
    background: var(--c-white);
    right: -350px;
    transition: 0.3s;
    z-index: 9;
    padding: 40px;
    border-top-left-radius: 32px;
    border-bottom-left-radius: 32px;
}

.childer {
    position: absolute;
    left: -25%;
    cursor: pointer;
    top: 10px;
    width: 25px;
    height: 25px;
    border-radius: 3px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.childer i {
    position: absolute;
    cursor: pointer;
    top: 9px;
    border: solid #424242;
    border-width: 0 2px 2px 0;
    display: inline-block;
    padding: 2.5px;
    transform: rotate(135deg);
    -webkit-transform: rotate(135deg);
    left: 10px;
}


/* Loading Spinner */
.loading-spinner {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 3rem;
}

.spinner {
    width: 50px;
    height: 50px;
    border: 3px solid #f3f3f3;
    border-top: 3px solid #3498db;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    0% {
        transform: rotate(0deg);
    }
    100% {
        transform: rotate(360deg);
    }
}

/* Smooth transitions */
.tab-item {
    transition: all 0.3s ease;
}

.tab-item.active {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    background: var(--c-brand2);
    color: var(--c-white) !important;
}


/* Product card hover effects */
.post {
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.post:hover {
    transform: translateY(-5px);
}

/* Responsive adjustments */
@media (max-width: 640px) {
    .tabs {
        padding-bottom: 8px;
    }

    .tab-item {
        padding: 8px 12px;
        font-size: 14px;
    }
}

.btn-inquiry {
    background: var(--c-brand2);
    padding: 2px 6px;
    color: #fff;
    border-radius: 18px;
}

.btn-inquiry-single {
    background: var(--c-brand2);
    padding: 2px 6px;
    color: #fff;
    border-radius: 12px;
}

.btn-whatsapp {
    background: var(--c-white);
    padding: 2px 6px;
    color: var(--c-brand2);
    border-radius: 18px;
    border: 2px solid #EEEEEE;
}

.btn-whatsapp-single {
    background: var(--c-white);
    padding: 2px 6px;
    color: var(--c-brand2);
    border-radius: 12px;
    border: 2px solid #EEEEEE;
}

/* برای حالت چپ به راست (اگر نیاز بود) */
/* .ltr {
    direction: ltr;
}

.ltr .read-more-link .text {
    margin-right: 0;
    margin-left: 8px;
}

.ltr .read-more-link::after {
    right: auto;
    left: 0;
    transform-origin: left center;
} */

.service-title:before {
    content: '';
    border-right: 6px solid var(--c-green);
    transform: rotate(90deg);
    display: inline-block;
    position: relative;
    left: 0;
    top: 4px;
    height: 20px;
    margin-left: 10px;
    border-radius: 33px;
}

.fill-green {
    fill: var(--c-green);
}

.arrow-service {
    position: absolute;
    left: 30px;
    top: 30px;
}

.arrow-kind {
    position: absolute;
    top: 0;
    display: flex;
    justify-content: end;
    align-items: center;
    z-index: -1;
    width: 98px;
    height: 40px;
    padding: 12px;
    border-radius: 100px;
}


/*--------------------------------------------------------------
>>>  Humburger-menu  :
----------------------------------------------------------------*/
@media screen and (max-width: 768px) {
    #menumobile {
        width: 95%;
    }
}

#menumobile {
    position: fixed;
    top: 0;
    bottom: 0;
    right: -100%;
    width: 320px;
    height: 100%;
    z-index: 99991;
    transition: all 0.5s;
    box-sizing: border-box;
    overflow: hidden;
    overflow-y: auto;
    border-top-left-radius: 32px;
    border-bottom-left-radius: 32px;
}

.js-topPushNav.isOpen, .pushNav_level.isOpen {
    right: 0;
}

.pushNav, .pushNav a {
    font-size: 15px;
    font-weight: 100;
    color: #fff;
    text-decoration: none;
}

.pushNav {
    margin: 0;
    list-style-type: none;
    padding: 40px;
    background: #14396C;
    height: 100%;
    position: fixed;
    top: 0;
    z-index: 100;
    overflow: hidden;
    transition: ease-in-out 0.5s;
}

.isOpen, .come-submenu {
    right: 0 !important;
}

/* Prevent text from being selected when dragging */
.product-gallery-swiper img {
    -webkit-user-drag: none;
    -khtml-user-drag: none;
    -moz-user-drag: none;
    -o-user-drag: none;
    user-drag: none;
}

/*calc foam*/
.on-line {
    position: absolute;
    top: -10px;
    right: 2vw;
    z-index: 2;
    background: var(--c-white);
}

/* Custom slider */
.vision-quantity-slider {
    position: absolute;
    bottom: -6px;
    right: 2vw;
    max-width: 89%;
    width: 100%;
}

/* Modern browsers */
.calc-foam input::placeholder {
    color: #313C58;
    font-size: 10px;
    line-height: 14px;
}

/* For old Firefox */
.calc-foam input::-moz-placeholder {
    color: #313C58;
    font-size: 10px;
    line-height: 14px;
}

/* For Internet Explorer */
.calc-foam input:-ms-input-placeholder {
    color: #313C58;
    font-size: 10px;
    line-height: 14px;
}

/* For old Safari and Chrome */
.calc-foam input::-webkit-input-placeholder {
    color: #313C58;
    font-size: 10px;
    line-height: 14px;
}


.vision-quantity-slider::-webkit-slider-thumb {
    -webkit-appearance: none !important;
    width: 20px !important;
    height: 20px !important;
    background: var(--c-white) !important;
    border-radius: 50% !important;
    cursor: pointer !important;
    border: 5px solid var(--c-green) !important;
}
