/*==========Common CSS ==========*/
:root {
    /* === Brand Colors === */
    --color-primary: #f7b617;
    --color-primary-hover: #e0a512;
    --color-secondary: #1d4ed8;
    --color-secondary-hover: #2e4eb7;

    /* === Accent & Status === */
    --color-accent: #13c2c2;
    --color-tertiary: #9333ea;
    --color-success: #10b981;
    --color-warning: #f97316;
    --color-error: #ef4444;
    --color-green: #319609;

    /* === Neutrals === */
    --color-bg: #ffffff;
    --color-silver: #f9fafb;
    --color-white: #ffffff;
    --color-border: #e5e7eb;
    --color-text: #111827;
    --color-muted: #484b54;
    --input-color: rgba(72, 75, 84, 0.5);

    /* === Dark Section === */
    --color-dark: #0f172a;
    --color-black: #1c1b1b;
    --color-on-dark: #f9fafb;
    --color-on-dark-text: rgb(249, 250, 251, 0.8);
    --color-border-dark: #45474a;

    /* === Fonts === */
    --body-font: "Inter Tight", sans-serif;
    --title-font: "Inter Tight", sans-serif;

    /* Font Weights */
    --font-light: 300;
    --font-regular: 400;
    --font-medium: 500;
    --font-semibold: 600;
    --font-bold: 700;
    --font-extrabold: 800;

    /* Font Sizes - Desktop */
    --font-size-xs: 0.75rem;
    /* 12px */
    --font-size-sm: 0.875rem;
    /* 14px */
    --font-size-base: 1rem;
    /* 16px */
    --font-size-lg: 1.125rem;
    /* 18px */
    --font-size-xl: 1.25rem;
    /* 20px */
    --font-size-2xl: 1.5rem;
    /* 24px */
    --font-size-3xl: 1.875rem;
    /* 30px */
    --font-size-4xl: 2.25rem;
    /* 36px */
    --font-size-5xl: 3rem;
    /* 48px */
    --font-size-6xl: 3.85rem;
    /* 60px */
    --font-size-7xl: 4.625rem;
    /* 75px */

    --section-padding: 120px;
}

@media (max-width: 1199px) {
    :root {
        --section-padding: 100px;
        --font-size-2xl: 1.3rem;
        --font-size-4xl: 2rem;
    }
}

@media (max-width: 991px) {
    :root {
        --section-padding: 80px;
        --font-size-2xl: 1.3rem;
        --font-size-4xl: 2rem;
    }
}

@media (max-width: 575px) {
    :root {
        --font-size-lg: 1rem;
    }
}

body {
    font-family: var(--body-font);
    font-size: var(--font-size-base);
    font-weight: var(--font-regular);
    line-height: 1.5;
    color: var(--color-text);
    background-color: var(--color-bg);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

::-webkit-scrollbar {
    width: 5px;
}

::-webkit-scrollbar-track {
    background-color: var(--color-muted);
}

::-webkit-scrollbar-thumb {
    background: var(--color-primary);
    border-radius: 10px;
}

::-webkit-scrollbar-thumb:hover {
    background: var(--color-primary-hover);
}

.body-fixed {
    position: fixed;
    width: 100%;
    height: 100vh;
    top: auto;
    left: auto;
}

body,
html {
    /* overflow-x: hidden; */
}

* {
    -webkit-tap-highlight-color: transparent;
}

img {
    max-width: 100%;
    height: auto;
    object-fit: cover;
    object-position: center;
}

p a {
    color: var(--color-primary);
    transition: 0.3s;
}

p a:hover {
    color: var(--color-primary-hover);
}

a:hover {
    color: initial;
}

.sec-wp {
    position: relative;
    z-index: 4;
}

.section {
    padding-block: var(--section-padding);
    position: relative;
}

section {
    overflow: hidden;
}

::selection {
    background-color: var(--color-primary);
    color: var(--color-dark);
}

::-moz-selection {
    background-color: var(--color-primary);
    color: var(--color-dark);
}

.back-img {
    background-position: center;
    background-size: cover;
}

.repeat-img {
    background-size: contain;
    background-repeat: repeat;
}

/* Inner Banner Styles */
.inner-banner {
    position: relative;
    background: var(--color-dark);
    padding: 250px 30px 150px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    min-height: 300px;
}

.inner-banner-content {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.inner-banner-title {
    font-size: var(--font-size-6xl);
    font-weight: var(--font-bold);
    line-height: 1.05;
    color: var(--color-white);
}

.breadcrumb {
    margin: 0;
    justify-content: center;
    gap: 12px;
    color: var(--color-on-dark-text);
}

.breadcrumb a {
    color: var(--color-white);
    text-decoration: none;
    opacity: 0.8;
}

.breadcrumb span {
    color: var(--color-primary);
}

.inner-banner-icons img {
    position: absolute;
    width: 65px;
    height: auto;
}

.inner-banner-icons img:nth-child(1) {
    top: 34%;
    left: 7%;
    transform: rotate(-15deg);
}

.inner-banner-icons img:nth-child(2) {
    top: 35%;
    right: 6%;
    transform: rotate(-15deg);
}

.inner-banner-icons img:nth-child(3) {
    bottom: 16%;
    right: 16%;
    transform: rotate(-15deg);
}

.inner-banner-icons img:nth-child(4) {
    bottom: 18%;
    left: 16%;
    transform: rotate(-15deg);
}

.inner-banner-shape {
    position: absolute;
    bottom: 0;
    width: 100%;
}

.inner-banner-shape img {
    width: 100%;
}

.list li {
    position: relative;
    padding-left: 2em;
    margin-bottom: 0.75em;
}

.list li:last-child {
    margin-bottom: 0;
}

.list li:before {
    content: "\2714";
    position: absolute;
    left: 0;
    color: #009688;
    font-size: 1.2em;
    line-height: 1;
    top: 0.1em;
}

.wow {
    visibility: hidden;
}

.for-mob {
    display: none;
}

.for-des {
    display: block;
}

.wpcf7 form.invalid .wpcf7-response-output, 
.wpcf7 form.unaccepted .wpcf7-response-output, 
.wpcf7 form.payment-required .wpcf7-response-output {
    border-color: var(--color-error) !important;
    color: var(--color-error) !important;
}

.wpcf7 form.sent .wpcf7-response-output {
    border-color: var(--color-green) !important;
    color: var(--color-green) !important;
}

.inner-page-text {
    padding: var(--section-padding) 0;
}

.inner-page-box h1,
.inner-page-box h2,
.inner-page-box h3, 
.inner-page-box h4,
.inner-page-box h5,
.inner-page-box h6 {
    margin-top: 40px;
    margin-bottom: 10px;
}

.inner-page-box h1:first-child,
.inner-page-box h2:first-child,
.inner-page-box h3:first-child, 
.inner-page-box h4:first-child,
.inner-page-box h5:first-child,
.inner-page-box h6:first-child {
    margin-top: 0;
}

.error-404 {
    text-align: center;
}

.error-404 img {
    width: 700px;
    height: auto;
    object-fit: contain;
}

@media (max-width: 1199px) {
    .inner-banner-title {
        font-size: 3.5rem;
    }

    .inner-banner {
        padding: 220px 15px 130px;
    }

    .inner-banner-icons img:nth-child(1) {
        top: 38%;
    }

    .inner-banner-icons img:nth-child(2) {
        top: 40%;
    }
}

@media (max-width: 991px) {

    .for-mob {
        display: block;
    }
    
    .for-des {
        display: none;
    }


    .inner-banner-title {
        font-size: 3rem;
    }

    .inner-banner-icons img {
        width: 50px;
    }

    .inner-banner-icons img:nth-child(1),
    .inner-banner-icons img:nth-child(2) {
        display: none;
    }

    .inner-banner-icons img:nth-child(3) {
        bottom: 10%;
        right: 10%;
    }

    .inner-banner-icons img:nth-child(4) {
        bottom: 12%;
        left: 12%;
    }

    .inner-banner {
        padding: 160px 15px 90px;
    }
}

@media (max-width: 575px) {
    .inner-banner-title {
        font-size: var(--font-size-6xl);
    }
}

@media (max-width: 480px) {
    .inner-banner-icons img {
        width: 40px;
    }

    .inner-banner-icons img:nth-child(3) {
        bottom: 2%;
    }

    .inner-banner-icons img:nth-child(4) {
        bottom: 2%;
    }

    .inner-banner {
        padding: 120px 15px 50px;
        min-height: 280px;
    }
}

/*==========Common CSS End==========*/

/*==========Typography CSS==========*/

button,
input,
select,
optgroup,
textarea {
    color: var(--color-dark);
    font-size: var(--font-size-base);
    line-height: 1.625;
}

p,
.text-base {
    font-size: var(--font-size-base);
    font-weight: var(--font-regular);
    line-height: 1.625;
    color: var(--color-muted);
    font-weight: 450;
}

p:last-of-type {
    margin: 0
}

.text-lg {
    font-size: var(--font-size-lg);
    font-weight: var(--font-regular);
    line-height: 1.625;

    p {
        font-size: inherit;
        line-height: inherit;
        font-weight: inherit;
    }
}

.text-sm {
    font-size: var(--font-size-sm);
    font-weight: var(--font-regular);
    line-height: 1.5;

    p {
        font-size: inherit;
        line-height: inherit;
        font-weight: inherit;
    }
}

.text-xs {
    font-size: var(--font-size-xs);
    font-weight: var(--font-regular);
    line-height: 1.5;
    color: var(--color-muted);

    p {
        font-size: inherit;
        line-height: inherit;
        font-weight: inherit;
    }
}

a {
    background-color: transparent;
    text-decoration: none !important;
    outline: none !important;
}

ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

ol {
    list-style: decimal;
}

.h1,
.h2,
.h3,
.h4,
.h5,
.h6,
h1,
h2,
h3,
h4,
h5,
h6 {
    margin-bottom: 0;
}

h1,
.h1 {
    font-size: var(--font-size-5xl);
    font-weight: var(--font-bold);
    line-height: 1.12;
}

h2,
.h2 {
    font-size: var(--font-size-4xl);
    font-weight: var(--font-semibold);
    line-height: 1.12;
}

h3,
.h3 {
    font-size: var(--font-size-2xl);
    font-weight: var(--font-semibold);
    line-height: 1.25;
}

h4,
.h4 {
    font-size: var(--font-size-xl);
    font-weight: var(--font-medium);
    line-height: 1.5;
}

h5,
.h5 {
    font-size: var(--font-size-lg);
    font-weight: var(--font-medium);
    line-height: 1.5;
}

h6,
.h6 {
    font-size: var(--font-size-base);
    font-weight: var(--font-medium);
    line-height: 1.5;
}

.lead-text {
    font-size: var(--font-size-lg);
    font-weight: var(--font-regular);
    line-height: 1.625;
    color: var(--color-text);
}

.section-title {
    font-size: var(--font-size-5xl);
    font-weight: var(--font-bold);
    line-height: 1.12;
    color: var(--color-text);
}

.dark-section-title {
    color: var(--color-on-dark);
}

.dark-section-description {
    color: var(--color-on-dark-text);
}

.eyebrow-text {
    font-size: var(--font-size-sm);
    font-weight: var(--font-semibold);
    line-height: 1.5;
    text-transform: uppercase;
    color: var(--color-primary);

}

.pill-text {
    font-size: var(--font-size-xs);
    font-weight: var(--font-semibold);
    line-height: 1.5;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    background-color: var(--color-white);
    border: 1px solid rgba(107, 114, 128, 0.2);
    padding: 8px 15px;
    border-radius: 100vmax;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    text-align: left;
    gap: 8px;
    margin-bottom: 8px;
}

.pill-text:before {
    content: "";
    width: 6px;
    height: 6px;
    display: inline-block;
    background: var(--color-accent);
    border-radius: 50%;
    box-shadow: 0 0 0 rgba(0, 0, 0, 0.2);
    animation: breathe 2s infinite ease-in-out;
}

@keyframes breathe {
    0% {
        box-shadow: 0 0 0 0 rgba(0, 0, 0, 0.2);
    }

    50% {
        box-shadow: 0 0 10px 4px rgb(19, 194, 194, 0.4);
    }

    100% {
        box-shadow: 0 0 0 0 rgba(0, 0, 0, 0.2);
    }
}

.dark-pill-text {
    background-color: rgba(225, 225, 225, 0.2);
    border-color: rgba(107, 114, 128, 0.5);
    color: var(--color-on-dark);
}


.section-title-wrapper {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    margin-bottom: 40px;
    gap: 16px;
}

.section-title-wrapper p {
    max-width: 540px;
}

.section-title-center {
    justify-content: center;
    align-items: center;
    text-align: center;
    max-width: 740px;
    margin-inline: auto;
}

.brand-name {
    font-weight: var(--font-bold);
}

.brand-name span {
    font-weight: var(--font-light);
    color: var(--color-muted);
}

.text-effect {
    font-weight: bold;
    font-size: 24px;
    line-height: 1.5;
    letter-spacing: 0.02em;
    color: var(--color-dark);
}

.text-effect span {
    display: inline-block;
    opacity: 0;
    filter: blur(10px);
    transition: all 0.3s ease;
}

/* For image animation, start scaled down and rotated */
.text-effect span img {
    transform: scale(0.8) rotate(-15deg);
    transition: all 0.3s ease;
    vertical-align: middle;
}


@media (max-width: 991px) {
    .pill-text {
        margin: 0;
    }
}

/*==========Typography CSS End==========*/

/*==========Form CSS==========*/

select {
    -moz-appearance: none;
    -webkit-appearance: none;
}

.form-element {
    position: relative;
}

.form-element i {
    position: absolute;
    top: 15px;
    right: 20px;
    pointer-events: none;
    color: var(--color-primary);
}

.form-input::-webkit-input-placeholder {
    color: var(--input-color);
}

.form-input::-moz-placeholder {
    color: var(--input-color);
}

.form-input:-ms-input-placeholder {
    color: var(--input-color);
}

.form-input::-ms-input-placeholder {
    color: var(--input-color);
}

.form-input::placeholder {
    color: var(--input-color);
}

select option {
    color: var(--color-dark) !important;
}

select {
    color: var(--input-color) !important;
}

select::-ms-expand {
    display: none;
}

.form-input,
select {
    width: 100%;
    height: 50px;
    outline: none !important;
    padding: 10px 15px;
    color: var(--color-dark);
    -webkit-appearance: none;
    border-radius: 10px;
    border: none;
    background: var(--color-silver);
    border: 1px solid var(--color-border);
}

textarea.form-input {
    height: 160px;
    resize: none;
    display: block;
}

.form-input-wp label {
    font-size: 16px;
    text-transform: capitalize;
    font-weight: 300;
    margin-bottom: 10px;
}

.form-input-wp label span,
.contact-title p span {
    color: var(--red-color);
}

.form-input-wp {
    margin-bottom: 24px;
}

.modal-footer-custom {
    text-align: right;
}

.modal-title {
    font-weight: var(--font-bold);
    font-size: var(--font-size-xl);
}

@media (max-width: 1199px) {
    .form-input-wp {
        margin-bottom: 12px;
    }
}

/*==========Form CSS End==========*/


/*==========Button CSS==========*/

.sec-btn {
    position: relative;
    font-size: var(--font-size-base);
    font-weight: var(--font-semibold);
    background: var(--color-primary);
    border: 1px solid transparent;
    color: var(--color-white);
    line-height: 1.5;
    text-decoration: none;
    display: inline-flex;
    gap: 6px;
    padding: 12px 24px;
    border-radius: 100vmax;
    transition: all 0.2s ease-in-out;
    cursor: pointer;
    justify-content: center;
    align-items: center;
}

.sec-btn:hover {
    color: var(--color-white);
    background-color: var(--color-primary-hover);
}

.secondary-btn {
    background-color: var(--color-secondary);
    color: var(--color-white);
}

.secondary-btn:hover {
    background-color: var(--color-secondary-hover);
    color: var(--color-white);
}

.dark-btn {
    background-color: var(--color-dark);
    color: var(--color-white);
}

.dark-btn:after {
    content: "";
    position: absolute;
    z-index: -1;
    inset: 0;
    opacity: 0;
    border-radius: inherit;
    box-shadow: 0 0 0em 0em var(--color-primary);
    transition: 0.5s;
}

.dark-btn:hover {
    background-color: var(--color-primary-hover);
    color: var(--color-white);
}

.dark-btn:hover::after {
    opacity: 0.5;
    box-shadow: 0 0 1em 0.4em var(--color-primary);
}

.white-btn {
    background-color: var(--color-white);
    color: var(--color-dark);
}

.outline-btn {
    background-color: transparent;
    color: var(--color-secondary);
    border-color: var(--color-secondary);
}

.outline-btn:hover {
    background-color: var(--color-secondary);
    color: var(--color-white);
}

.transparent-btn {
    border: 1px solid var(--color-border-dark);
    background: transparent;
}

.transparent-btn:hover {
    background-color: var(--color-secondary);
    border-color: var(--color-secondary);
}

.learn-more-btn {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    color: var(--color-dark);
    letter-spacing: 0.05em;
    transition: 0.3s;
}

.learn-more-btn:hover,
.services-card-content .learn-more-btn:hover {
    color: var(--color-primary);
}

.icon-btn {
    width: 50px;
    height: 50px;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 26px;
    border-radius: 50%;
}

.whatsapp-btn {
    height: auto;
    margin-block: auto;
    font-size: 40px;
    display: inline-flex;
    color: var(--color-green);
    transition: 0.3s;
}

.whatsapp-btn:hover {
    --hover_color: color-mix(in srgb, var(--color-green), black 30%);
    color: var(--hover_color);
}

.whatsapp-btn.white {
    color: var(--color-white);
}

.whatsapp-btn.white:hover {
    --hover_color: color-mix(in srgb, var(--color-green), white 30%);
    color: var(--hover_color);
}

.call-icon-btn {
    height: auto;
    margin-block: auto;
    font-size: 40px;
    display: inline-flex;
    color: var(--color-dark);
    transition: 0.3s;
}

.call-icon-btn:hover {
    color: var(--color-primary);
}

/*==========Button CSS End==========*/


/* ===== UTILITY CLASSES ===== */
.font-light {
    font-weight: var(--font-light);
}

.font-regular {
    font-weight: var(--font-regular);
}

.font-medium {
    font-weight: var(--font-medium);
}

.font-semibold {
    font-weight: var(--font-semibold);
}

.font-bold {
    font-weight: var(--font-bold);
}

.font-extrabold {
    font-weight: var(--font-extrabold);
}

.text-primary {
    color: var(--color-primary);
}

.text-secondary {
    color: var(--color-secondary);
}

.text-accent {
    color: var(--color-accent);
}

.text-tertiary {
    color: var(--color-tertiary);
}

.text-success {
    color: var(--color-success);
}

.text-warning {
    color: var(--color-warning);
}

.text-error {
    color: var(--color-error);
}

.text-dark {
    color: var(--color-text);
}

.text-muted {
    color: var(--color-muted);
}

.text-on-dark {
    color: var(--color-on-dark);
}

/* === Background Colors === */
.bg-primary {
    background-color: var(--color-primary);
}

.bg-secondary {
    background-color: var(--color-secondary);
}

.bg-accent {
    background-color: var(--color-accent);
}

.bg-tertiary {
    background-color: var(--color-tertiary);
}

.bg-success {
    background-color: var(--color-success);
}

.bg-warning {
    background-color: var(--color-warning);
}

.bg-error {
    background-color: var(--color-error);
}

.bg-surface {
    background-color: var(--color-white);
}

.bg-dark {
    background-color: var(--color-dark);
}


/*==========Slider Css==========*/

.swiper-button-next:after,
.swiper-button-prev:after {
    display: none;
}

.swiper-button-wp {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.swiper-button-next,
.swiper-button-prev {
    position: unset;
    width: 52px;
    height: 52px;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    font-size: 24px;
    border-radius: 50%;
    overflow: hidden;
    margin: 0;
    color: var(--color-dark);
    background: var(--color-white);
    transition: 0.3s;
    border: 1px solid var(--color-border);
}

.swiper-button-next:hover,
.swiper-button-prev:hover {
    background: var(--color-primary);
}

.swiper-button-next:hover iconify-icon,
.swiper-button-prev:hover iconify-icon {
    color: var(--color-white);
}

.swiper-pagination {
    position: unset;
    margin-top: 1.5rem;
}

@media (max-width: 991px) {
    .swiper-pagination {
        margin-top: 1.8rem;
    }
}

.swiper-pagination .swiper-pagination-bullet {
    position: relative;
    width: 14px;
    border-radius: 100vmax;
    opacity: 1;
    background: rgb(0 0 0 / 10%);
    height: 4px;
    overflow: hidden;
    margin: 0 2px !important;
}

.swiper-pagination .swiper-pagination-bullet b {
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 2;
    width: 0%;
    height: 100%;
    border-radius: 100vmax;
    background-color: var(--color-primary);
}

.swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active b {
    -webkit-animation-name: countingBar;
    animation-name: countingBar;
    -webkit-animation-duration: 3s;
    animation-duration: 3s;
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
    -webkit-animation-iteration-count: 1;
    animation-iteration-count: 1;
    -webkit-animation-direction: alternate;
    animation-direction: alternate;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards;
}

@-webkit-keyframes countingBar {
    0% {
        width: 0;
    }

    100% {
        width: 100%;
    }
}

@keyframes countingBar {
    0% {
        width: 0;
    }

    100% {
        width: 100%;
    }
}


/*==========Slider Css End==========*/


/*==========Overflow CSS Start ==========*/


[data-simplebar] {
    position: relative;
    z-index: 0;
    overflow: hidden;
    -webkit-overflow-scrolling: touch
}

[data-simplebar=init] {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding-right: 10px;
    scrollbar-width: none
}

.simplebar-scroll-content {
    overflow-x: hidden;
    overflow-y: scroll;
    min-width: 100%;
    -webkit-box-sizing: content-box;
    box-sizing: content-box;
    padding-right: 0 !important;
    margin-bottom: 0 !important
}

.simplebar-content {
    overflow-x: scroll;
    overflow-y: hidden;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    min-height: 100%;
    margin-right: 0 !important;
    padding-bottom: 0 !important;
}

.simplebar-track {
    z-index: 1;
    position: absolute;
    right: 0;
    bottom: 0;
    width: 3px;
    background: rgb(24 26 37 / 25%);
}

.simplebar-scrollbar {
    position: absolute;
    right: 0;
    border-radius: 7px;
    min-height: 10px;
    width: 100%;
    opacity: 1 !important;
    -webkit-transition: opacity .2s linear;
    transition: opacity .2s linear;
    background: var(--color-primary);
    background-clip: padding-box;
    z-index: 66
}

.simplebar-track:hover .simplebar-scrollbar {
    opacity: .5;
    -webkit-transition: opacity 0s linear;
    transition: opacity 0s linear;
}

.simplebar-track.horizontal {
    left: 0;
    width: auto;
    height: 4px;
    border-radius: 3px;
}

.simplebar-track.vertical {
    top: 0
}

.horizontal.simplebar-track .simplebar-scrollbar {
    right: auto;
    top: 0;
    height: 100%;
    min-height: 0;
    min-width: 10px;
    width: auto;
    margin-left: -2px;
}

body.compensate-for-scrollbar {
    overflow: hidden
}

.overflow-text {
    height: 300px;
    scrollbar-width: none;
    width: 100%;
}

.overflow-text::-webkit-scrollbar,
.simplebar-scroll-content::-webkit-scrollbar,
[data-simplebar=init]::-webkit-scrollbar,
.simplebar-content::-webkit-scrollbar {
    width: 0;
    opacity: 0 !important;
    display: none;
    clip-path: inset(0 0 30px 0)
}

.overflow-text::-webkit-scrollbar-thumb {
    opacity: 0 !important
}

.overflow-text::-webkit-scrollbar-track {
    opacity: 0 !important
}

/*==========Overflow CSS End==========*/

/*==========Header CSS==========*/

.site-header {
    position: fixed;
    width: 100%;
    top: 0;
    left: 0;
    z-index: 99;
    transition: 0.3s;
}

.header-wrapper:after {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    width: 100%;
    height: 100%;
    background: rgb(255 255 255 / 92%);
    border-radius: 14px;
    box-shadow: 0px 4px 60px -1px rgba(0, 0, 0, .1);
    z-index: -1;
    transform: translate(-50%, 0);
    transition: 0.4s;
    backdrop-filter: blur(8px);
}

.header-social-info {
    display: flex;
    gap: 10px;
}

.header-social-info a {
    width: 30px;
    height: 30px;
    font-size: 26px;
    display: inline-flex;
    justify-content: center;
    align-items: center;
}

.site-logo-wp {
    width: 250px;
}

.site-logo {
    display: inline-flex;
    gap: 4px;
    align-items: center;
}

.site-logo img {
    width: 220px;
}

.header-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-block: 14px;
}

.header-top .header-contact-info {
    display: flex;
    align-items: center;
    justify-content: flex-start;
}

.header-top .header-contact-info li {
    display: flex;
}

.header-top .header-contact-info li:not(:last-child) {
    padding-right: 15px;
    margin-right: 15px;
    border-right: 1px solid var(--color-border);
}

.header-top .header-contact-info li a {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--color-dark);
    transition: 0.3s ease;
}

.header-top .header-contact-info li a iconify-icon {
    color: var(--color-dark);
    width: 30px;
    height: 30px;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 50%;
    background: var(--color-primary);
    padding: 7px;
    transition: 0.3s;
}

.header-top .header-contact-info li a:hover iconify-icon {
    color: var(--color-white);
    background: var(--color-secondary);
}

.header-wrapper {
    padding: 20px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    gap: 24px;
    position: relative;
    transition: 0.3s;
}

.main-navigation {
    margin-inline: auto;
}

.main-navigation ul {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 40px;
}

.main-navigation ul li a {
    font-size: var(--font-size-base);
    font-weight: var(--font-medium);
    color: var(--color-muted);
    transition: 0.3s ease;
    opacity: 0.8;
}

.main-navigation ul li a:hover:after,
.main-navigation ul>li.current_page_item>a:after {
    opacity: 1;
    transform: scale(1)
}

.main-navigation ul.menu>li {
    display: inline-flex;
    align-items: center;
    position: relative;
}

.main-navigation ul li ul.sub-menu {
    position: absolute;
    top: 100%;
    left: 100%;
    min-width: 145px;
    transform: translate(-50%, 0);
    white-space: nowrap;
    background: var(--color-white);
    box-shadow: 0 0 10px rgba(60, 140, 244, 0.15);
    padding-left: 0;
    display: none;
    opacity: 0;
    border-radius: 12px;
    overflow: hidden;
}

.main-navigation ul li.menu-parent:after {
    content: "";
    position: absolute;
    right: 0;
    top: 14px;
    transform: translate(0, -50%);
    width: 20px;
    height: 20px;
    --svg: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 48 48'%3E%3Cpath fill='none' stroke='%23000' stroke-linecap='round' stroke-linejoin='round' stroke-width='4' d='M36 18L24 30L12 18'/%3E%3C/svg%3E");
    background-color: var(--color-primary-hover);
    -webkit-mask-image: var(--svg);
    mask-image: var(--svg);
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-size: 100% 100%;
    mask-size: 100% 100%;
    transition: 0.3s;
    pointer-events: none;
    margin-top: 2px;
}

.main-navigation ul li ul.sub-menu li:not(:last-child) {
    border-bottom: 1px solid rgba(24 26 37/ .1375);
}

.main-navigation ul li ul.sub-menu li a {
    display: block;
    padding: 7px 38px 7px 18px;
    text-align: left;
    color: var(--color-dark);
}

.main-navigation ul li ul.sub-menu li a:hover,
.main-navigation ul.menu>li.active-menu .active-sub-menu a {
    color: var(--color-white);
    background-color: var(--color-primary);
}

.header-button {
    width: 250px;
    text-align: right;
    justify-content: flex-end;
}

.main-navigation ul.menu>li.menu-parent {
    padding-right: 22px;
}

body:has(main>.inner-banner, main>.branding-banner) .header-top .header-contact-info li a {
    color: var(--color-white);
}

body:has(main>.inner-banner, main>.branding-banner) .header-top .header-contact-info li a {
    color: var(--color-white);
}

.main-navigation ul.menu>li.active-menu>a,
.main-navigation ul.menu>li.current_page_item>a {
    color: var(--color-primary-hover);
}

@media(min-width: 992px) {
    .menu-toggle {
        display: none;
    }

    .site-header.sticky-header {
        top: -62px;
    }

    .site-header.sticky-header .header-wrapper:after {
        width: 100vw;
        border-radius: 0;
    }

    .main-navigation ul.menu>li.menu-parent:hover ul.sub-menu {
        display: block;
        top: 100%;
        opacity: 1;
        animation: swip_up var(--transition) linear 1;
    }




    .main-navigation ul li a:after {
        content: "";
        position: absolute;
        right: -15px;
        bottom: -8px;
        width: 40px;
        height: 22px;
        --svg: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADEAAAAWBAMAAACbG2mhAAAAAXNSR0IB2cksfwAAAAlwSFlzAAALEwAACxMBAJqcGAAAAA9QTFRFAAAA9d1l+u6z/fbZ+OWN2sm8HgAAAAV0Uk5TAP////8c0CZSAAAAaklEQVR4nGNgwAZMXBwNsEowOAoKKmCXUVEyxi4xTAGzAi4RRRF0GUUhCC0IpRlMYJoZBR1AFBMsVJkFhWGmCQqC4kBREM6HG6sI1gQ3jAGiEqxIEWQOIooQMlB5OMsRVzwyGOKUYUA1DAC7Jwcb8TO35AAAAABJRU5ErkJggg==);
        background-color: var(--color-primary-hover);
        -webkit-mask-image: var(--svg);
        mask-image: var(--svg);
        -webkit-mask-repeat: no-repeat;
        mask-repeat: no-repeat;
        -webkit-mask-size: 100% 100%;
        mask-size: 100% 100%;
        transition: 0.3s;
        pointer-events: none;
        transform: scale(1.15);
        transition: 0.3s;
        opacity: 0;
    }

    .main-navigation ul li.menu-parent a:after {
        display: none;
    }

    @keyframes swip_up {
        from {
            top: calc(100% + 20px);
            opacity: 0;
        }

        to {
            top: 100%;
            opacity: 1;
        }
    }

    .main-navigation ul.menu>li.menu-parent:hover:after {
        transform: translate(0, -50%) rotate(-180deg);
    }

    .main-navigation ul.menu li a:hover,
    .main-navigation ul.menu>li.menu-parent:hover>a,
    .main-navigation ul.menu>li.active-menu>a,
    .main-navigation ul.menu>li.active-menu:after {
        color: var(--color-primary-hover);
    }
}

@media (min-width: 2100px) {
    .site-header .container .row {
        margin: 0;
        height: 100%;
    }
}

@media (max-width: 1399px) {
    .site-logo-wp {
        width: 200px;
    }

    .button-wrapper.header-button {
        width: 220px;
        gap: 10px;
    }

    .whatsapp-btn,
    .call-icon-btn {
        font-size: 34px;
    }

    .main-navigation ul {
        gap: 25px;
    }

    .site-logo img {
        width: auto;
    }
}

@media(max-width: 1199px) {
    .main-navigation ul {
        gap: 24px;
    }

    .main-navigation ul li a {
        font-size: 16px;
    }

    .site-logo-wp {
        width: 180px;
    }

    .header-wrapper {
        gap: 16px;
    }

    .button-wrapper.header-button .sec-btn {
        padding: 8px 18px;
        font-size: 15px;
    }

    .button-wrapper.header-button {
        width: 202px;
    }
}

@media (max-width: 991px) {
    .site-header.sticky-header .header-wrapper {
        padding: 14px 20px;
    }

    .site-header .container {
        max-width: 100%;
        padding: 0;
        height: 100%;
    }

    .site-header .container .row {
        margin: 0;
        height: 100%;
    }

    .header-top {
        display: none;
    }

    .site-header .container .row .col-lg-12 {
        padding: 0;
    }

    .header-wrapper:after {
        border-radius: 0;
    }

    .menu-toggle {
        position: absolute;
        top: 50%;
        right: 30px;
        border: none;
        outline: none !important;
        background: var(--color-primary);
        width: 35px;
        height: 35px;
        transform: translate(0, -50%);
        z-index: 100;
        border-radius: 5px;
        padding: 0 8px;
    }

    .menu-toggle span {
        display: block;
        width: 100%;
        height: 3px;
        background: var(--color-white);
        margin-bottom: 5px;
        transition: 0.3s;
        border-radius: 5px;
        position: relative;
    }

    .menu-toggle span:last-child {
        margin: 0;
    }

    .toggled .menu-toggle span:nth-child(1) {
        transform: rotate(45deg);
        top: 4px;
    }

    .toggled .menu-toggle span:nth-child(2) {
        transform: rotate(-45deg);
        top: -4px;
    }

    .toggled .menu-toggle span:nth-child(3) {
        opacity: 0;
        height: 0;
    }

    .toggled .main-navigation {
        transform: translatey(0);
    }

    .main-navigation {
        height: 100vh;
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        padding-top: max(9vh, 30px);
        padding-left: max(6vh, 30px);
        padding-right: max(6vh, 30px);
        padding-bottom: 30px;
        z-index: 99;
        transition: 1s cubic-bezier(0.165, 0.84, 0.44, 1);
        overflow-y: auto;
        transform: translatey(-100%);
        background: linear-gradient(rgba(255, 255, 255, 0.95), rgba(225, 225, 225, 0.6)), url(../images/note-bg.jpg);
        background-size: cover;
        background-position: center;
    }

    .main-navigation .menu {
        flex-direction: column;
        align-items: flex-start;
        gap: 0;
    }

    .main-navigation ul.menu>li {
        display: block;
        float: none;
        margin: 0;
        margin-bottom: max(30px, 5vh);
        width: 100%;
    }

    .header-wrapper .menu li a {
        display: inline-block;
        font-size: max(18px, 2.5vh);
    }

    .button-wrapper.header-button:not(.main-navigation .button-wrapper.header-button) {
        width: auto;
        padding-right: 68px;
        gap: 16px;
    }

    .button-wrapper.header-button .sec-btn:not(.main-navigation .button-wrapper.header-button .sec-btn) {
        display: none;
    }

    .main-navigation .button-wrapper.header-button {
        margin-top: 30px;
    }

    .header-wrapper .menu .dropdown-items .for-mob {
        position: absolute;
        top: 0;
        right: 30px;
        transition: 0.3s;
        width: 30px;
        height: 30px;
        display: flex !important;
        justify-content: center;
        align-items: center;
        cursor: pointer;
        z-index: 2;
    }

    .header-wrapper .menu .sub-menu li {
        margin-bottom: 5px;
        border: none !important;
    }

    .header-wrapper .menu li:last-child {
        margin: 0;
    }

    .main-navigation ul li ul.sub-menu {
        position: relative;
        background: transparent;
        box-shadow: unset;
        min-width: unset;
        left: 0;
        transform: translate(00);
        white-space: unset;
        opacity: 1;
        max-width: 220px;
        opacity: 1;
        visibility: visible;
        display: none;
        padding-left: 8px;
        margin-top: 10px;
    }

    .main-navigation ul li ul.sub-menu li a {
        text-align: left;
        background-color: transparent !important;
    }

    .main-navigation ul li ul.sub-menu li a:hover {
        color: var(--color-primary);
    }


    .header-wrapper .menu .dropdown-items.dropdown-open .sub-menu {
        position: unset;
        display: block;
        width: auto;
        margin-top: 6px;
        padding: 0;
        background: transparent;
        box-shadow: none;
        margin-left: 15px;
        max-width: none;
    }


    .main-navigation ul.opened-menu li.menu-parent:after {
        transform: translate(0, -50%) rotate(-180deg);
    }


    .header-wrapper .menu .sub-menu li a {
        padding: 0;
    }

    .main-navigation ul.header-social-info {
        justify-content: flex-start;
        margin-top: 30px;
        gap: 10px;
    }

    .main-navigation ul.header-social-info li a {
        font-size: 25px;
    }
}

@media(max-width: 480px) {

    .header-wrapper {
        padding: 20px 12px;
    }

    .site-header.sticky-header .header-wrapper {
        padding: 8px 12px;
    }

    .menu-toggle {
        right: 15px;
    }

    .button-wrapper.header-button:not(.main-navigation .button-wrapper.header-button) {
        padding-right: 54px;
        gap: 10px;
    }

    .whatsapp-btn,
    .call-icon-btn {
        font-size: 26px;
    }

    .site-logo-wp {
        width: 140px;
    }
}

/*==========Header CSS End==========*/

/*==========Hero Banner CSS==========*/

.hero-banner {
    position: relative;
    padding-block: 240px 140px;
    min-height: 95vh;
    background-size: cover;
    background-position: center;
}

.hero-banner:after {
    content: "";
    position: absolute;
    inset: 0;
    background: var(--color-white);
    opacity: 0.5;
    pointer-events: none;
}

.banner-icons {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 2;
}

.banner-icon {
    position: absolute;
    pointer-events: auto;
    transition: transform 0.6s cubic-bezier(0.4, 0.2, 0.2, 1);
    opacity: 0.85;
    width: 70px;
}

.banner-icon.icon-1 {
    top: 24%;
    left: 43%;
    transform: rotate(-12deg);
}

.banner-icon.icon-4 {
    bottom: 22%;
    right: 8%;
    transform: rotate(8deg);
}

.hero-content {
    display: flex;
    align-items: flex-start;
    flex-direction: column;
    gap: 24px;
}

.hero-title {
    font-size: var(--font-size-5xl);
    font-weight: var(--font-bold);
    line-height: 1.05;
    max-width: 620px;
}

.hero-title span,
.section-title span:not(.brand-name, .brand-name span) {
    -webkit-text-fill-color: transparent;
    background-clip: text;
    background-image: linear-gradient(to right, rgba(250, 132, 88, 1) 0%, rgba(243, 195, 77, 1) 100%);
}

/* .hero-description {
    max-width: 540px;
} */

.mask-img.hero-bottom-shape {
    position: absolute;
    bottom: 0;
    width: 1920px;
    height: 90px;
    left: 50%;
    transform: translate(-50%, 0);
    background-color: var(--color-white);
    pointer-events: none;
}

.hero-icons img {
    width: 100px;
    height: 100px;
    position: absolute;
}

.hero-icons img:nth-child(1) {
    top: 2%;
    transform: rotate(-14deg);
    left: -20%;
}

.hero-icons img:nth-child(2) {
    top: 34%;
    transform: rotate(-38deg);
    left: -22%;
    animation: float-social-icon-2 3.1s ease-in-out infinite alternate-reverse;
}

.hero-icons img:nth-child(3) {
    top: 34%;
}

.hero-icons img:nth-child(4) {
    top: 41%;
    left: 80%;
    animation: float-social-icon-4 3.4s ease-in-out infinite alternate-reverse;
}

.hero-icons img:nth-child(5) {
    top: 28%;
    left: 50%;
    animation: float-social-icon-5 3.5s ease-in-out infinite alternate;
}

.hero-icons img:nth-child(6) {
    top: 62%;
    left: 20%;
    animation: float-social-icon-6 3.6s ease-in-out infinite alternate-reverse;
}

.hero-icons img:nth-child(7) {
    top: 48%;
    left: 30%;
    animation: float-social-icon-7 3.7s ease-in-out infinite alternate;
}

.button-wrapper {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 1rem;
}

.button-wrapper .social {
    font-size: 35px;
    line-height: 1;
    display: inline-flex;
    align-items: center;
}

.banner-slider {
    width: 360px;
    aspect-ratio: 9/12;
    margin: 0 auto;
}

.hero-banner-img {
    justify-content: center;
    display: flex;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    align-items: flex-end;
    padding-bottom: 28px;
}

.hero-banner-img:before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 60%;
    background: #000000;
    background: linear-gradient(0deg, rgba(0, 0, 0, 0.85) 20%, rgba(255, 255, 255, 0) 60%);
}

.hero-banner-img h3 {
    position: relative;
    z-index: 1;
    font-size: var(--font-size-2xl);
    color: var(--color-white);
}

.banner-slider .swiper-slide {
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 18px;
}

#cursor {
    display: inline-block;
    width: 4px;
    height: 1em;
    margin-left: 2px;
    background: rgba(243, 195, 77, 1);
    animation: blink 0.7s steps(1) infinite;
    border-radius: 2px;
    position: relative;
    top: 0.5rem;
}

.banner-fade-slider .swiper-slide {
    opacity: 0 !important;
    transition: 0.5s !important;
}

.banner-fade-slider .swiper-slide.swiper-slide-active {
    opacity: 1 !important;
}

.banner-fade-img {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}

@keyframes blink {

    0%,
    100% {
        opacity: 1;
    }

    50% {
        opacity: 0;
    }
}

@media(max-width: 1199px) {
    .banner-slider {
        width: 335px;
    }

    .banner-icon {
        width: 55px;
    }

    .hero-banner {
        padding-block: 220px 100px;
    }
    .hero-title {
        font-size: var(--font-size-4xl);
        max-width: 410px;
    }
}


@media (max-width: 991px) {
    .hero-banner {
        padding-block: 160px 60px;
    }

    .hero-description {
        max-width: 100%;
    }

    .hero-content {
        margin-bottom: 60px;
    }

    .banner-icon {
        width: 48px !important;
        height: 48px !important;
    }

    .banner-icon.icon-1 {
        top: 15%;
        left: 77%;
    }

    .banner-icon.icon-2 {
        top: 34%;
        left: 2%;
    }

    .banner-icon.icon-3 {
        top: 18%;
        left: 60%;
    }

    .banner-icon.icon-4 {
        bottom: 40%;
        left: 10%;
    }

}

@media (max-width: 767px) {
    .hero-content {
        margin-bottom: 40px;
    }

    .hero-banner {
        padding-block: 160px 30px;
    }

    .hero-title {
        font-size: var(--font-size-5xl);
    }
}

@media(max-width: 575px) {
    .banner-icon.icon-4 {
        bottom: 36%;
        left: 3%;
    }


    .hero-description p {
        font-size: var(--font-size-base);
    }

    .banner-icon.icon-1 {
        top: 10%;
        left: 85%;
    }

}

@media(max-width: 480px) {
    .banner-slider {
        width: 280px;
    }

    .hero-banner {
        padding-block: 130px 30px;
    }

    .hero-title {
        max-width: 360px;
    }

    .button-wrapper .social {
        font-size: 25px;
    }

}

@media(max-width: 380px) {
    .banner-icons {
        display: none;
    }

    .banner-slider {
        width: 240px;
    }

    .hero-title {
        font-size: var(--font-size-4xl);
        max-width: 310px;
    }
}


/*==========Hero Banner CSS End==========*/

/*==========Why Choose Us CSS==========*/

.why-choose-us {
    position: relative;
    padding-block: 40px var(--section-padding);
    background: var(--color-white);
    background-image: radial-gradient(at 192% 34%, hsla(28, 100%, 74%, 0.8) 0px, transparent 50%),
        radial-gradient(at -10% 65%, hsla(189, 100%, 56%, 0.1) 0px, transparent 50%);
}

.feature-card {
    padding: 18px 24px;
    transition: 0.3s all;
    height: 100%;
    display: flex;
    flex-direction: column;
    gap: 24px;
    border: 1px solid var(--color-border);
    background: var(--color-on-dark);
    border-radius: 14px;
}

.feature-card .feature-card-icon {
    width: 80px;
    aspect-ratio: 1;
    -webkit-mask: url('../images/icon-bg.svg') center/contain no-repeat;
    background: var(--color-primary);
    padding: 18px;
}

.feature-card .feature-card-icon img {
    object-fit: contain;
    width: 100%;
}

.feature-card .content {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.feature-card .content h3 {
    font-weight: bold;
}

.feature-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 30px 60px -40px var(--color-primary);
}

@media (max-width: 1199px) {
    .feature-card {
        padding: 18px;
        gap: 18px;
    }

    .feature-card .feature-card-icon {
        width: 70px;
    }

    .why-choose-us {
        padding-block: 40px var(--section-padding);
    }
}

@media(max-width: 991px) {
    .feature-card-row .col-lg-4:not(:last-child) .feature-card {
        margin-bottom: 30px;
        height: auto;
    }
}

/*==========Why Choose Us End==========*/


/*==========About Us CSS Start==========*/

.about-sec {
    padding-bottom: var(--section-padding);
}

.about-image-box-wp {
    position: relative;
    max-width: 520px;
    margin-left: auto;
}

.about-image-box-bg {
    width: 487px;
    height: auto;
    aspect-ratio: 1 / 1;
    position: absolute;
    left: 0;
    bottom: 1px;
    border-radius: 30px;
    overflow: hidden;
    z-index: -1;
    background: var(--color-primary-hover);
}

.about-image-bg-shape {
    position: relative;
    width: 100%;
    height: 100%;
    mix-blend-mode: overlay;
}

.about-image-bg-shape::before,
.about-image-bg-shape::after {
    content: "";
    position: absolute;
    top: 105px;
    left: 0;
    width: 100%;
    height: 90px;
    transform: skewY(-15deg);
    background-color: rgb(25 37 75 / 60%);
}

.about-image-bg-shape::after {
    top: 245px;
}

.about-image {
    text-align: right;
}

.about-image img {
    max-width: 444px;
    max-height: 557px;
    margin-bottom: 1px;
    margin-right: 12px;
}

.about-image-icon {
    --size: 66px;
    height: var(--size);
    width: var(--size);
    position: absolute;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: var(--color-white);
    border-radius: 10px;
    box-shadow: 0px 4px 40px -1px rgb(0 0 0 / 20%);
    transition: 0.3s;
    z-index: 2;
}

.about-image-icon.top-icon {
    bottom: -5px;
    left: -10px;
    transform: rotate(21deg);
}

.about-image-icon img {
    width: 46px;
    object-fit: cover;
}

.about-image-icon.bottom-icon {
    right: 59px;
    top: 108px;
    transform: rotate(-14deg);
}

.about-content {
    margin-left: 23px;
}

.about-sec-row .row:not(:last-child) {
    margin-bottom: 60px;
}

.about-sec-row .row:nth-child(even) .about-content {
    margin-right: 23px;
    margin-left: 0;
}

.about-text .sec-btn {
    margin-top: 18px;
}

.about-content .section-title-wrapper {
    margin-bottom: 20px;
}

.about-feature-text h4 {
    font-weight: var(--font-bold);
}

.about-content .sec-title .h2-title {
    margin-bottom: 22px;
}

.about-text {
    margin-bottom: 26px;
}

.about-feature-info-wp {
    display: flex;
    justify-content: flex-end;
}

.about-feature-info {
    display: inline-flex;
    gap: 35px;
    margin-top: 40px;
    padding-top: 30px;
    border-top: 1px solid rgba(0, 0, 0, 0.15);
    justify-content: flex-end;
    margin-right: 30px;
}

.about-feature-box {
    display: flex;
    align-items: center;
    gap: 14px;
}

.about-feature-icon {
    --size: 56px;
    width: var(--size);
    height: var(--size);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--color-white);
    box-shadow: 0px 4px 40px -1px rgb(0 0 0 / 20%);
    flex: 0 0 auto;
}

.about-feature-box:hover .about-feature-icon img {
    animation: hvr-buzz-out 0.75s linear 1;
}

.about-content .button-wrapper {
    margin-top: 27px;
}

.about-counter-row {
    --width: 20%;
    --gap: 24px;
    margin-top: 100px;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 33px var(--gap);
}

.about-counter-row .about-counter-box-wp {
    flex: 0 0 calc(var(--width) - calc(var(--gap)));
    display: block;
}

.about-counter-box {
    display: flex;
    flex-direction: column;
    gap: 10px;
    text-align: center;
    justify-content: center;
    align-items: center;
}

.about-counter-text p {
    font-size: var(--font-size-lg);
    color: var(--color-primary);
}

.about-counter-box .h1 {
    font-weight: var(--font-extrabold);
    font-size: var(--font-size-6xl);
    margin-bottom: 0;
    line-height: 1;
}


@media (min-width: 1921px) {
    .about-feature-info {
        padding-right: 10px;
    }
}

@media (max-width: 1199px) {
    .about-image-box-bg {
        width: 460px;
    }

    .about-content {
        margin-left: 10px;
    }

    .about-sec-row .row:nth-child(even) .about-content {
        margin-right: 10px;
    }

    .about-feature-info {
        gap: 8px;
        margin-right: 0;
    }

    .about-feature-box {
        gap: 8px;
    }

    .about-feature-icon {
        --size: 50px;
    }

    .about-counter-row {
        --gap: 12px;
        margin-top: 80px;
    }

    .about-counter-box .h1 {
        font-size: var(--font-size-5xl);
    }

    .about-image-box-wp {
        margin: 0 auto;
    }

    .about-image-box-bg {
        width: 460px;
    }
}

@media(max-width: 991px) {

    .about-image {
        text-align: center;
    }

    .about-image img {
        max-width: 100%;
        max-height: 100%;
    }

    .about-content {
        margin-left: 0;
        margin-top: 50px;
        max-width: 100%;
    }

    .about-feature-info-wp {
        justify-content: center;
        padding-right: 50px;
    }

    .about-feature-info {
        flex-direction: row;
        justify-content: start;
        gap: 24px;
        flex-wrap: wrap;
        margin-top: 35px;
        padding-top: 0;
        border-top: 0;
    }

    .about-counter-row {
        margin-top: 70px;
        --width: 50%;
    }

    .about-counter-row .about-counter-box-wp {
        text-align: center;
    }

    .about-counter-row .about-counter-box {
        /* display: inline-block; */
        text-align: left;
        align-items: flex-start;
    }

    .about-text {
        margin: 0;
    }

    .about-sec-row .row:not(:last-child) {
        margin-bottom: 30px;
    }
}

@media (max-width: 767px) {
    .about-content .button-wrapper {
        gap: 1rem 0.6rem;
    }

    .about-image-box-bg {
        width: 100%;
        border-radius: 20px;
    }
}

@media (max-width: 575px) {
    .about-image-icon {
        --size: 56px;
        padding: 10px;
    }

    .about-image-icon.bottom-icon {
        right: -7px;
        top: 15%;
    }

    .about-feature-info-wp {
        justify-content: flex-start;
        padding-right: 0;
    }

}

@media (max-width: 480px) {
    .about-image-icon {
        --size: 46px;
    }

    .about-image-icon.bottom-icon {
        right: -7px;
        top: 18%;
    }

    .about-feature-info {
        gap: 16px;
    }

    .about-counter-row {
        margin-top: 50px;
    }

    .about-counter-text p {
        font-size: var(--font-size-sm);
    }

    .about-content-body {
        flex-direction: column;
    }

}

@media (max-width: 360px) {
    .about-content .button-wrapper {
        gap: 1rem 0.4rem;
    }
}

/*==========About Us CSS End==========*/

/*==========Our Services CSS==========*/

.our-services {
    padding-block: var(--section-padding);
    background: var(--color-dark);
    background-image: radial-gradient(at 50% -10%, hsla(60, 100%, 70%, 0.3) 0px, transparent 50%), radial-gradient(at -20% 135%, hsla(215, 100%, 56%, 0.3) 0px, transparent 50%);
}

.our-services-title {
    margin-bottom: 60px;
}

.service-card {
    background: rgb(255 255 255 / 5%);
    border-radius: 12px;
    padding: 12px 12px 22px 12px;
    position: relative;
    overflow: hidden;
    border: 1px solid rgb(229 231 235 / 20%);
    display: flex;
    flex-direction: column;
    gap: 22px;
    height: 100%;
    backdrop-filter: blur(50px);
    transition: 0.3s;
}

.service-card .thumb {
    aspect-ratio: 1/1;
    border-radius: 8px;
    display: flex;
    justify-content: center;
    align-items: center;
    overflow: hidden;
    background-image: radial-gradient(at 50% 50%, hsl(0deg 0% 100% / 30%) 0px, transparent 60%);
}

.service-card .thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    border-radius: 8px;
}

.our-services .pointer-highlight-wrapper {
    position: relative;
    color: var(--color-on-dark);
}

.pointer-highlight {
    position: relative;
    display: inline-block;
    line-height: 1.2;
    z-index: 1;
}

.pointer-highlight-rectangle {
    position: absolute;
    border: 1px solid;
    border-radius: 3px;
    top: 0;
    left: 0;
    z-index: -1;
    pointer-events: none;
    background-color: transparent;
    transition: all 0.3s ease;
    line-height: 1;
    opacity: 1;
}

.pointer {
    position: absolute;
    width: 18px;
    height: 18px;
    z-index: 1;
    transform: rotate(-90deg);
    display: flex;
    justify-content: center;
    align-items: center;
    top: 18px;
}

.pointer svg {
    width: 100%;
    height: 100%;
    fill: currentColor;
}

.services-card-content {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    padding-inline: 16px;
    flex: 1;
}

.our-services-row .row {
    --bs-gutter-y: 1.5rem;
}

.services-card-content p {
    color: var(--color-on-dark-text);
}

.services-card-content .learn-more-btn {
    color: var(--color-white);
    margin-top: auto;
}

.services-card-content .learn-more-btn iconify-icon {
    margin-top: 2px;
}

.our-services-row .view-all-services {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-top: 40px;
}

@media (max-width: 1199px) {
    .services-card-content {
        padding-inline: 0;
    }
}

@media (max-width: 991px) {
    .our-services-title .section-title {
        margin-bottom: 15px;
    }

    .our-services-title {
        margin-bottom: 40px;
    }
}

/*==========Our Services CSS End==========*/

/*==========Our Process Section CSS==========*/

.our-process {
    padding-block: var(--section-padding);
    position: relative;
    background-image: radial-gradient(at -80% 40%, hsla(50, 100%, 50%, 0.35) 0px, transparent 50%), radial-gradient(at 100% 85%, hsl(308deg 100% 56% / 10%) 0px, transparent 20%);
    overflow: visible;
}

.our-process .section-title-wrapper {
    margin-bottom: 80px;
}

.our-process .process-wp {
    display: flex;
    flex-direction: column;
    gap: 24px;
    max-width: 824px;
    margin-left: auto;
    position: relative;
}

.our-process .process-wp .process-card-wp {
    padding-left: calc(var(--poiter-width) + 30px);
    position: relative;
    --poiter-width: 24px;
}

.our-process .process-wp .process-card-wp:before {
    position: absolute;
    content: '';
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: var(--poiter-width);
    aspect-ratio: 1/1;
    border-radius: 50%;
    background-color: var(--color-dark);
    border: 7px solid var(--color-primary);
}

.our-process .process-wp .process-card-wp:nth-of-type(2):after,
.our-process .process-wp .process-card-wp:last-of-type:after {
    position: absolute;
    content: '';
    left: 0;
    top: 0;
    width: var(--poiter-width);
    height: 50%;
    background: var(--color-bg);
    z-index: -1;
}

.our-process .process-wp .process-card-wp:last-of-type:after {
    top: auto;
    bottom: 0;
}

.our-process .progress-bar {
    background: rgb(251 172 24 / 40%);
    width: 4px;
    height: 100%;
    position: absolute;
    z-index: -1;
    left: 10px;
}

.our-process .progress-bar span {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 0;
    background: var(--color-primary);
    z-index: 2;
    opacity: 1;
}

.our-process .process-card-wp .process-card {
    display: flex;
    gap: 32px;
}

.our-process .process-card-wp .process-card .icon {
    margin-bottom: 0;
}

.process-card-wp .feature-card .feature-card-icon {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 60px;
    aspect-ratio: 1;
    padding: 14px;
    flex: 0 0 auto;
}

.process-card-wp .feature-card {
    flex-direction: row;
    align-items: flex-start;
}

.process-card-wp .feature-card .content h3 {
    font-size: 1.65rem;
}


@media (max-width: 1399px) {
    .our-process .process-wp .process-card-wp {
        --poiter-width: 22px;
    }

    .our-process .progress-bar {
        left: 9px;
    }

    .our-process .process-card-wp .process-card {
        gap: 20px;
        padding: 30px;
    }
}

@media (max-width: 1199px) {
    .our-process .section-title-wrapper {
        margin-bottom: 60px;
    }
}

@media (max-width: 991px) {
    .our-process .process-wp .process-card-wp {
        --poiter-width: 20px;
        padding-left: calc(var(--poiter-width) + 20px);
    }

    .our-process .process-wp .process-card-wp:before {
        border: 6px solid var(--color-primary);
    }

    .our-process .progress-bar {
        left: 8px;
        width: 4px;
    }

    .our-process .process-wp .process-card img {
        max-width: 28px;
    }

    .our-process .h2-title {
        text-align: center;
    }

    .our-process .process-wp {
        gap: 15px;
    }

}

@media (max-width: 767px) {
    .our-process .process-wp .process-card-wp {
        --poiter-width: 18px;
    }

    .our-process .progress-bar {
        left: 7px;
    }

    .our-process .process-card-wp .process-card {
        padding: 20px;
        flex-direction: column;
        gap: 30px;
    }
}

@media (max-width: 575px) {
    .our-process .process-wp .process-card-wp {
        --poiter-width: 16px;
        padding-left: calc(var(--poiter-width) + 10px);
    }

    .our-process .process-wp .process-card-wp:before {
        border: 5px solid var(--color-primary);
    }

    .our-process .progress-bar {
        left: 6px;
        width: 2px;
    }

    .our-process .process-wp {
        gap: 10px;
    }
}

@media (max-width: 400px) {
    .our-process .process-wp .process-card-wp {
        padding-left: calc(var(--poiter-width) + 7px);
    }

    .our-process .process-wp {
        gap: 8px;
    }
}

/*==========Our Process Section CSS End==========*/

/*==========Sticky Scroll Reveal Section CSS==========*/
.sticky-scroll-container {
    display: flex;
    flex-direction: row;
    max-width: 1200px;
    margin: 0 auto;
    gap: 48px;
    min-height: 70vh;
}

.sticky-scroll-left {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
}

.sticky-scroll-item {
    margin-block: 30px;
    opacity: 0.3;
    transition: opacity 0.5s;
    padding-right: 60px;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
    position: relative;
}

.sticky-scroll-item.active {
    opacity: 1;
}

.sticky-scroll-item h2 {
    font-size: var(--font-size-5xl);
    font-weight: bold;
    margin-bottom: 30px;
}

.sticky-scroll-item p {
    font-size: 1.1rem;
    color: var(--color-dark);
}

.sticky-scroll-right {
    height: 100vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    position: sticky;
    top: 10px;
    width: 100%;
    border-radius: 14px;
    overflow: hidden;
    background: var(--color-dark);
}

.sticky-scroll-content {
    display: none;
    align-items: center;
    justify-content: center;
    border-radius: 16px;
    overflow: hidden;
    position: absolute;
    inset: 0;
    opacity: 0.5;
}

.sticky-scroll-content.active {
    display: flex;
    animation: fadeInSticky 3s;
    z-index: 2;
    opacity: 1;
}

@keyframes fadeInSticky {
    from {
        opacity: 0;
        transform: translateY(20px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.sticky-scroll-content img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 16px;
    display: block;
}

.sticky-scroll-right:after {
    content: "";
    position: absolute;
    inset: 0;
    background: var(--color-dark);
    background: linear-gradient(180deg, var(--color-dark) 0%, rgba(255, 255, 255, 0) 50%, var(--color-dark) 100%);
    z-index: 2;
    opacity: 0.75;
}

.sticky-scroll-icon {
    position: sticky;
    top: 50%;
    left: 45%;
    width: 50%;
    opacity: 0.1;
    z-index: -1;
    transform: translate(-50%, -65%);
}

.sticky-scroll-img {
    display: none;
}

@media(max-width: 1199px) {
    .sticky-scroll-item h2 {
        font-size: 2.5rem;
        margin-bottom: 20px;
    }

    .sticky-scroll-item {
        padding-right: 30px;
    }
}

@media (max-width: 991px) {
    .sticky-scroll-container {
        flex-direction: column;
        gap: 32px;
    }

    .sticky-scroll-right {
        width: 100%;
        min-width: 0;
        position: static;
        height: 220px;
        margin-top: 20px;
    }

    .sticky-scroll-item {
        padding: 0;
        opacity: 1;
        min-height: auto;
        margin-bottom: 10px;
    }

    .sticky-scroll-item:last-child {
        margin-bottom: 0;
    }

    .sticky-scroll-img {
        width: 100%;
        aspect-ratio: 1/1.2;
        border-radius: 24px;
        margin-bottom: 30px;
        display: block;
    }

    .sticky-scroll-item h2 {
        font-size: var(--font-size-4xl);
        margin-bottom: 12px;
    }

    .sticky-scroll-icon {
        position: absolute;
        top: auto;
        bottom: 12%;
        width: 120px;
        right: 4%;
        left: auto;
        transform: unset;
    }

    .our-process .section-title-wrapper {
        margin-bottom: 10px;
    }
}

@media (max-width: 767px) {
    .sticky-scroll-icon {
        bottom: 20%;
    }
}

@media (max-width: 575px) {

    .sticky-scroll-item h2 {
        font-size: 1.3rem;
    }

    .sticky-scroll-bg {
        font-size: 1rem;
    }

    .sticky-scroll-right {
        height: 120px;
    }

    .sticky-scroll-item p {
        font-size: 1rem;
    }

    .sticky-scroll-img {
        margin-bottom: 20px;
    }
}

/*==========Our Portfolio Section CSS==========*/

.our-portfolio {
    padding-block: var(--section-padding);
    position: relative;
}

.portfolio-tab {
    position: relative;
    overflow: hidden;
    display: flex;
    /* border-radius: 100vmax; */
    /* background: var(--color-on-dark);
    border: 1px solid var(--color-border); */
    margin-bottom: 24px;
}

/* .portfolio-tab::after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 140px;
    height: 100%;
    background: linear-gradient(to left, rgb(29 78 216 / 45%), transparent);
    pointer-events: none;
    z-index: 3;
    opacity: var(--shadow-opacity, 1);
    transition: opacity 0.3s ease;
} */

.portfolio-tab ul {
    --spacing: 5px;
    width: 100%;
    display: inline-flex;
    position: relative;
    z-index: 2;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 5px;
    /* padding: var(--spacing); */
    /* white-space: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: none;
    user-select: none; */
}

.portfolio-tab ul::-webkit-scrollbar {
    display: none;
}

.portfolio-tab ul li {
    display: inline-flex;
    text-transform: capitalize;
    line-height: normal;
    cursor: pointer;
    padding: 12px 26px;
    border-radius: 100vmax;
    transition: 0.3s;
    justify-content: center;
    align-items: center;
    font-weight: 500;
    transition: 0.3s;
}

.portfolio-tab ul li:hover {
    color: var(--color-secondary);
}

.portfolio-tab ul li.mixitup-control-active {
    background: var(--color-secondary);
    color: var(--color-white);
}

.portfolio-filter-active {
    position: absolute;
    left: 0;
    height: calc(100% - var(--spacing) * 2);
    z-index: -1;
}

.portfolio-tab ul li img {
    margin-right: 10px;
    position: relative;
    top: 1px;
}

.portfolio-tab ul .portfolio-filter-active {
    color: var(--color-white);
    background: var(--color-secondary);
}

.portfolio-list-row .row {
    --bs-gutter-y: 1.5rem;
}

.portfolio-box {
    border-radius: 10px;
    overflow: hidden;
    background: var(--color-on-dark);
    border: 1px solid var(--color-border);
}

.portfolio-box-img {
    width: 100%;
    aspect-ratio: 1 / 0.65;
    border-radius: 10px 10px 0 0;
    overflow: hidden;
    border-bottom: 1px solid var(--color-border);
}

.portfolio-box-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.portfolio-box-content {
    --top: 20px;
    padding: calc(var(--top) + 20px) 20px 20px 20px;
    margin-top: calc(var(--top) * -1);
    display: flex;
    flex-direction: column;
    gap: 2px;
    text-align: center;
}

.portfolio-box-content h3,
.portfolio-box-content p {
    text-transform: capitalize;
}

@media(max-width: 767px) {
    .portfolio-box-content h3 {
        font-size: var(--font-size-lg);
    }

    .portfolio-box-content p {
        font-size: var(--font-size-sm);
    }

    .portfolio-box-content {
        gap: 0;
    }
}

@media(max-width: 575px) {
    .portfolio-tab::after {
        width: 80px;
    }
}

@media (max-width: 480px) {
    .portfolio-tab ul li {
        font-size: 14px;
        padding: 10px 15px;
    }
}

/*==========Our Portfolio Section CSS End==========*/

/*==========Pricing Section==========*/

.pricing-card {
    position: relative;
    overflow: visible;
}

.pricing-card-glow {
    position: absolute;
    inset: -8px;
    z-index: 0;
    border-radius: 24px;
    pointer-events: none;
    background: radial-gradient(circle at 50% 50%, #163067 0%, #2563eb00 80%);
    filter: blur(12px);
    opacity: 0.5;
    transition: opacity 0.3s;
    z-index: -1;
}

.pricing-card:hover .pricing-card-glow,
.pricing-card:hover .pricing-card-glow-starter {
    opacity: 1;
}

.pricing-card-glow-starter {
    position: absolute;
    inset: -8px;
    z-index: 0;
    border-radius: 24px;
    pointer-events: none;
    background: radial-gradient(circle at 50% 50%, rgba(225, 225, 225, 0.2) 0%, #2563eb00 80%);
    filter: blur(12px);
    opacity: 0.5;
    transition: opacity 0.3s;
}

.pricing-section {
    padding-block: var(--section-padding);
    background: var(--color-dark);
}

.pricing-header {
    margin-bottom: 48px;
}

.pricing-subtitle {
    color: var(--color-muted);
    max-width: 600px;
    margin: 0 auto;
    font-size: var(--font-size-lg);
}

.pricing-cards {
    margin-top: 28px;
}

.pricing-card {
    background: var(--color-dark);
    border: 2px solid var(--color-border-dark);
    border-radius: 20px;
    padding: 40px 32px 32px 32px;
    display: flex;
    flex-direction: column;
    height: 100%;
    box-shadow: none;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.pricing-card:hover {
    border-color: var(--color-border);
    box-shadow: 0 8px 32px 0 rgba(0, 0, 0, 0.12);
}

.pricing-card-popular {
    border: 2px solid var(--color-secondary);
    box-shadow: 0 8px 32px 0 rgba(37, 99, 235, 0.12);
    position: relative;
    z-index: 1;
    transform: scale(1.04);
}

.most-popular-badge {
    background: var(--color-secondary);
    color: var(--color-on-dark);
    font-size: var(--font-size-xs);
    font-weight: var(--font-semibold);
    padding: 5px 20px;
    border-radius: 999px;
    position: absolute;
    top: -18px;
    left: 50%;
    transform: translateX(-50%);
    text-transform: uppercase;
    letter-spacing: 1.28px;
    box-shadow: 0 2px 8px 0 rgba(37, 99, 235, 0.12);
    white-space: nowrap;
}

.pricing-card-header {
    margin-bottom: 24px;
}

.plan-title {
    font-size: var(--font-size-xl);
    font-weight: var(--font-semibold);
    margin-bottom: 15px;
    color: var(--color-on-dark);
}

.plan-desc {
    color: var(--color-on-dark-text);
    font-weight: 400;
    margin: 0;
}

.pricing-card-price {
    margin-bottom: 24px;
}

.plan-price {
    font-size: var(--font-size-4xl);
    font-weight: var(--font-bold);
    color: var(--color-on-dark);
}

.plan-duration {
    color: var(--color-on-dark-text);
    font-size: var(--font-size-lg);
    margin-left: 2px;
    font-weight: 300;
}

.plan-features {
    list-style: none;
    padding: 0;
    margin-bottom: 32px;
    flex-grow: 1;
}

.plan-features li {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 12px;
    color: var(--color-on-dark);
}

.feature-icon {
    display: inline-block;
    width: 20px;
    height: 20px;
    flex-shrink: 0;
    margin-top: 2px;
}

.feature-icon {
    width: 20px;
    height: 20px;
    display: inline-block;
    vertical-align: middle;
    fill: var(--color-success);
}

.feature-disabled .feature-icon,
.feature-x .feature-icon {
    fill: var(--color-muted);
}

.feature-disabled {
    color: var(--color-muted);
}

@media (max-width: 1199px) {
    .pricing-card {
        padding: 30px 22px 32px 22px;
    }

    .pricing-card-price {
        margin-bottom: 16px;
    }

    .pricing-card-header {
        margin-bottom: 15px;
    }

    .plan-features {
        margin-bottom: 20px;
    }
}

@media (max-width: 991px) {
    .pricing-card {
        padding: 32px 20px 24px 20px;
    }

    .pricing-title {
        font-size: var(--font-size-3xl);
    }

    .pricing-cards {
        --bs-gutter-y: 2.5rem;
        margin-top: 0;
    }

    .pricing-card-popular {
        transform: scale(1);
    }

    .pricing-cards .col-lg-4:first-child {
        margin-top: 0;
    }
}

@media (max-width: 767px) {
    .pricing-title {
        font-size: var(--font-size-2xl);
    }

    .pricing-cards {
        --bs-gutter-y: 30px;
    }
}

@media (max-width: 575px) {
    .pricing-header {
        margin-bottom: 32px;
    }

    .pricing-title {
        font-size: var(--font-size-lg);
    }

    .pricing-card {
        border-radius: 12px;
        padding: 24px 20px;
        height: auto;
    }

    .plan-features {
        flex-grow: none;
    }
}

.plan-features .feature-check {
    vertical-align: middle;
}

.plan-features .feature-x {
    vertical-align: middle;
}

.plan-features .feature-check {
    background: none;
}

.plan-features .feature-x {
    background: none;
}

/*==========Pricing Section End CSS==========*/

/*==========Marquee Section CSS==========*/

.marquee-wrapper {
    overflow: hidden;
}

.marquee {
    padding: 0.5vw;
    white-space: nowrap;
}

.marquee:first-child {
    background-color: var(--color-secondary-hover);
}

.marquee:first-child .marquee-inner {
    transform: scale(-1, 1);
}

.marquee:last-child {
    background-color: var(--color-dark);
    margin-top: 8px;
}

.marquee-inner {
    display: flex;
    gap: 45px;
}

.marquee-content-inner {
    color: var(--color-white);
    font-size: clamp(30px, 3vw, 40px);
    font-weight: var(--font-semibold);
    display: flex;
    gap: 32px;
}

.marquee-content-inner span {
    display: flex;
    gap: 12px;
}

.marquee:first-child .marquee-inner .marquee-content-inner {
    transform: scale(-1, 1);
}

.marquee-content img {
    flex: 0 0 auto;
    width: 40px;
    object-fit: contain;
}

@media (max-width: 575px) {
    .marquee-content img {
        width: 30px;
    }

    .marquee-content-inner {
        font-size: clamp(26px, 3vw, 40px);
        gap: 20px;
    }
}

/*==========Marquee Section CSS End==========*/

/*==========Testimonials Section==========*/

.testimonials-section {
    background-image: url(../images/testimonial-bg.png);
    background-repeat: no-repeat;
    background-size: auto;
    background-position: center center;
    overflow: hidden;
}

.testimonials-section .section-title-wrapper .section-description {
    max-width: fit-content;
}

.testimonials-section .section-title-wrapper {
    height: 100%;
}

.testimonials-section .section-title-wrapper .button-wrapper {
    margin-top: 12px;
}

.testimonial-card {
    position: relative;
    background: var(--color-silver);
    border: 1px solid var(--color-border);
    border-radius: 24px;
    padding: 40px 32px 32px 32px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    width: 100%;
    min-height: 380px;
}

.testimonial-card:hover {
    border-color: var(--color-secondary);
}

.testimonial-quote-icon {
    margin-bottom: 20px;
    color: var(--color-secondary);
    opacity: 0.85;
    z-index: 1;
}

.testimonial-quote-icon img {
    width: auto;
    height: 30px;
    object-fit: contain;
}

.testimonial-card .overflow-text {
    height: 170px;
    padding-bottom: 15px;
}

.testimonial-text p {
    font-size: var(--font-size-xl);
    color: var(--color-text);
    font-weight: var(--font-light);
    line-height: 1.6;
}

.testimonial-divider {
    width: 100%;
    height: 1px;
    background: var(--color-secondary);
    opacity: 0.16;
    margin-block: auto 24px;
    z-index: 1;
}

.review-by {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
}

.review-badge-wp {
    display: inline-flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 5px;
}

.review-badge {
    --badge-color: var(--color-primary);
    display: inline-block;
    padding: 5px 10px;
    background: color-mix(in srgb, var(--badge-color), white 90%);
    border: 1px solid var(--badge-color);
    border-radius: 5px;
    font-size: 12px;
    line-height: 1.2;
    font-weight: 500;
    color: var(--badge-color);
}

.review-badge.logo {
    --badge-color: var(--color-primary);
}

.review-badge.package {
    --badge-color: var(--color-secondary);
}

.review-badge.tm {
    --badge-color: var(--color-green);
}

.review-badge.brand {
    --badge-color: var(--color-warning);
}

.review-badge.website {
    --badge-color: var(--color-tertiary);
}

.review-badge.hosting {
    --badge-color: var(--color-error);
}

.review-badge.menu {
    --badge-color: var(--color-success);
}

.review-badge.social {
    --badge-color: var(--color-accent);
}

.review-badge.flyer {
    --badge-color: var(--color-dark);
}

.review-badge.brochure {
    --badge-color: var(--color-secondary-hover);
}

.review-badge.video {
    --badge-color: var(--color-border-dark);
}

.review-badge.merchandise {
    --badge-color: var(--color-black);
}

.review-badge.google {
    --badge-color: var(--color-primary-hover);
}

.review-badge.uiux {
    --badge-color: var(--color-muted);
}

.testimonial-author {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    z-index: 1;
    /* padding-right: 130px; */
}

.testimonial-avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    margin-right: 16px;
    border: 2px solid var(--color-border-dark);
    object-fit: cover;
}

.testimonial-author-name {
    font-size: var(--font-size-lg);
}

.testimonial-author-role {
    font-size: var(--font-size-sm);
    font-weight: var(--font-light);
}

.testimonials-swiper {
    width: 100%;
    height: 380px;
    overflow: visible;
}

.testimonials-swiper:after {
    content: "";
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    height: 120px;
    z-index: 2;
    background: #ffffff;
    background: linear-gradient(0deg, rgba(255, 255, 255, 0.75) 0%, rgba(255, 255, 255, 0) 100%);
}

.testimonials-swiper:before {
    content: "";
    position: absolute;
    bottom: 100%;
    left: 0;
    width: 100%;
    height: 120px;
    z-index: 2;
    background: #ffffff;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.75) 0%, rgba(255, 255, 255, 0) 100%);
}

.testimonials-swiper .swiper-button-wp {
    position: absolute;
    bottom: 31px;
    right: 30px;
    z-index: 22;
    justify-content: flex-end;
    background: var(--color-silver);
    border-radius: 100vmax;
}

.testimonials-swiper .swiper-slide {
    height: auto;
    display: flex;
    justify-content: center;
}

.testimonials-swiper .swiper-pagination {
    position: absolute;
    left: 100%;
    display: flex;
    gap: 6px;
    width: auto;
    font-size: var(--font-size-3xl);
    line-height: 1;
    font-weight: var(--font-semibold);
    flex-direction: column;
    margin: 0;
    top: 50%;
    bottom: auto;
    transform: translate(18px, -50%);
}

.testimonials-swiper .swiper-pagination .divider {
    transform: rotate(90deg);
    position: relative;
    line-height: 0;
    color: var(--color-primary);
}

.testimonials-swiper .swiper-pagination .swiper-pagination-total {
    position: relative;
}

.testimonials-swiper .swiper-pagination span {
    transform: rotate(90deg);
}

.banner-ratings-content {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 15px;
}

.banner-ratings-img img {
    width: 130px;
}

.banner-ratings-content-inr {
    flex: 1;
}

.ratings-stars-wp {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 2px;
    line-height: 1;
    font-size: 22px;
    color: var(--theme_color9);
}

.ratings-stars-wp .star {
    display: inline-flex;
    line-height: 1;
    font-size: inherit;
}

.ratings-stars-wp iconify-icon {
    width: 1em;
    height: 1em;
    color: var(--color-primary);
}

@media(max-width: 1199px) {
    .testimonials-swiper .swiper-pagination {
        font-size: 1.2rem;
        transform: translate(9px, -50%);
    }
    .testimonial-text p {
        font-size: var(--font-size-lg);
    }
    .review-by {
        justify-content: flex-start;
        flex-direction: column;
        align-items: flex-start;
    }
}

@media (max-width: 991px) {
    .testimonial-card {
        padding: 32px 16px 24px 16px;
        min-height: auto;
    }

    .testimonial-text p {
        font-size: var(--font-size-lg);
    }

    .testimonials-swiper:before {
        display: none;
    }

    .testimonials-swiper {
        margin-top: 40px;
        height: auto;
    }

    .testimonials-swiper .swiper-pagination {
        transform: none;
        position: unset;
        flex-direction: row;
        justify-content: left;
        margin-top: 40px;
    }

    .testimonials-swiper .swiper-pagination span {
        transform: none;
    }

    .testimonials-swiper .swiper-pagination .divider {
        transform: unset;
        top: 8px;
    }

    .testimonials-swiper .swiper-button-wp {
        bottom: -18px;
        right: 0;
        background: transparent;
    }
}

@media (max-width: 767px) {
    .banner-ratings-img img {
        width: 100px;
    }
}

@media (max-width: 575px) {
    .testimonial-text p {
        font-size: var(--font-size-lg);
    }

    .testimonial-text.overflow-text {
        height: 165px;
    }
}

@media(max-width: 480px) {
    .testimonials-swiper .swiper-button-wp {
        bottom: -12px;
        right: 0;
        background: transparent;
    }

    .testimonials-swiper .swiper-pagination {
        display: inline-flex;
        padding-top: 10px;
    }

    .testimonial-author {
        padding: 0;
    }

    .testimonials-section .section-title-wrapper .section-description {
        font-size: var(--font-size-base);
    }
}

@media(max-width: 400px) {
    .section-title-wrapper p {
        font-size: 14px;
    }
}

@media(max-width: 350px) {
    .banner-ratings-img img {
        width: 70px;
    }
}

/*==========Testimonials Section End==========*/

/*========== CTA Section Start ==========*/

.our-clients {
    overflow: visible;
}

.cta-clients-wrapper {
    padding-block: var(--section-padding);
    background: var(--color-silver);
    display: flex;
    flex-direction: column;
    gap: var(--section-padding);
}

.cta-section .row {
    width: 100%;
}

.cta-section-inner {
    padding-inline: 80px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    border-radius: 24px;
    box-shadow: 0 4px 64px 0 rgba(27, 96, 255, 0.08);
    position: relative;
    z-index: 2;
    background: var(--color-dark);
}

.cta-content {
    padding-block: 80px;
}

.cta-bg {
    position: absolute;
    inset: 0;
    background-image: linear-gradient(90deg, rgba(255, 255, 255, 0.071) 1px, rgba(255, 255, 255, 0) 0), linear-gradient(rgba(255, 255, 255, 0.071) 1px, rgba(255, 255, 255, 0) 0);
    background-size: 50px 50px;
    z-index: -1;
    border-radius: 24px;
    pointer-events: none;
}

.cta-img {
    position: relative;
    height: 100%;
}

.cta-img .cta-main-img {
    position: absolute;
    bottom: 0;
    right: 40px;
    max-width: 400px;
    width: 100%;
}

.cta-section .section-title-wrapper {
    max-width: 840px;
    margin-bottom: 0;
}

.cta-section-inner .section-title {
    color: var(--color-on-dark);
}

.cta-section-inner p {
    color: var(--color-on-dark-text);
    max-width: 610px;
}

.cta-section-inner .button-wrapper {
    margin-top: 16px;
}

.social-icons img {
    position: absolute;
    will-change: transform, top, left;
    animation: float-social-icon var(--float-duration, 3s) ease-in-out infinite;
    animation-direction: var(--float-direction, alternate);
    width: 80px;
    height: 80px;
}

.social-icons img:nth-child(1) {
    top: 10%;
    left: 20%;
    animation: float-social-icon-1 3.2s ease-in-out infinite alternate;
}

.social-icons img:nth-child(2) {
    top: 40%;
    left: 44%;
    animation: float-social-icon-2 2.8s ease-in-out infinite alternate-reverse;
}

.social-icons img:nth-child(3) {
    top: 38%;
    left: 15%;
    animation: float-social-icon-3 3.7s ease-in-out infinite alternate;
}

.social-icons img:nth-child(4) {
    top: 37%;
    left: 79%;
    animation: float-social-icon-4 3.4s ease-in-out infinite alternate-reverse;
}

.social-icons img:nth-child(5) {
    top: 68%;
    left: 32%;
    animation: float-social-icon-5 3.1s ease-in-out infinite alternate;
}

.social-icons img:nth-child(6) {
    top: 11%;
    left: 47%;
    animation: float-social-icon-6 2.9s ease-in-out infinite alternate-reverse;
}

.social-icons img:nth-child(7) {
    top: 58%;
    left: 76%;
    animation: float-social-icon-7 3.5s ease-in-out infinite alternate;
}

.social-icons img:nth-child(8) {
    top: 58%;
    left: 13%;
    animation: float-social-icon-8 3.1s ease-in-out infinite alternate;
}

.social-icons img:nth-child(9) {
    top: 13%;
    left: 70%;
    animation: float-social-icon-9 2.9s ease-in-out infinite alternate-reverse;
}

.social-icons img:nth-child(10) {
    top: 70%;
    left: 55%;
    animation: float-social-icon-10 3.5s ease-in-out infinite alternate;
}

@keyframes float-cta-img {
    0% {
        transform: translateY(0) scale(1) rotate(-6deg);
    }

    50% {
        transform: translateY(-18px) scale(1.04) rotate(4deg);
    }

    100% {
        transform: translateY(0) scale(1) rotate(-6deg);
    }
}

@keyframes float-social-icon-1 {
    0% {
        transform: translateY(0) rotate(-8deg);
    }

    30% {
        transform: translateY(-10px) rotate(6deg);
    }

    60% {
        transform: translateY(12px) rotate(-3deg);
    }

    100% {
        transform: translateY(0) rotate(-8deg);
    }
}

@keyframes float-social-icon-2 {
    0% {
        transform: translateY(0) rotate(2deg);
    }

    40% {
        transform: translateY(15px) rotate(-7deg);
    }

    80% {
        transform: translateY(-8px) rotate(4deg);
    }

    100% {
        transform: translateY(0) rotate(2deg);
    }
}

@keyframes float-social-icon-3 {
    0% {
        transform: translateY(0) rotate(0deg);
    }

    50% {
        transform: translateY(-20px) rotate(-10deg);
    }

    100% {
        transform: translateY(0) rotate(0deg);
    }
}

@keyframes float-social-icon-4 {
    0% {
        transform: translateY(0) rotate(-4deg);
    }

    25% {
        transform: translateY(8px) rotate(8deg);
    }

    75% {
        transform: translateY(-10px) rotate(-8deg);
    }

    100% {
        transform: translateY(0) rotate(-4deg);
    }
}

@keyframes float-social-icon-5 {
    0% {
        transform: translateY(0) rotate(3deg);
    }

    60% {
        transform: translateY(18px) rotate(-6deg);
    }

    100% {
        transform: translateY(0) rotate(3deg);
    }
}

@keyframes float-social-icon-6 {
    0% {
        transform: translateY(0) rotate(-2deg);
    }

    40% {
        transform: translateY(-17px) rotate(7deg);
    }

    100% {
        transform: translateY(0) rotate(-2deg);
    }
}

@keyframes float-social-icon-7 {
    0% {
        transform: translateY(0) rotate(2deg);
    }

    30% {
        transform: translateY(10px) rotate(-8deg);
    }

    100% {
        transform: translateY(0) rotate(5deg);
    }
}

@keyframes float-social-icon-8 {
    0% {
        transform: translateY(0) rotate(-5deg);
    }

    30% {
        transform: translateY(16px) rotate(-2deg);
    }

    100% {
        transform: translateY(0) rotate(8deg);
    }
}

@keyframes float-social-icon-9 {
    0% {
        transform: translateY(0) rotate(-8deg);
    }

    30% {
        transform: translateY(6px) rotate(-4deg);
    }

    100% {
        transform: translateY(0) rotate(-5deg);
    }
}

@keyframes float-social-icon-10 {
    0% {
        transform: translateY(0) rotate(-11deg);
    }

    30% {
        transform: translateY(12px) rotate(-5deg);
    }

    100% {
        transform: translateY(0) rotate(-8deg);
    }
}


@media (max-width: 1399px) {
    .cta-section-inner {
        padding-inline: 60px;
    }
}

@media(max-width: 1199px) {
    .social-icons img {
        width: 70px;
        height: 70px;
    }

    .social-icons img:nth-child(1) {
        top: 15%;
        left: 15%;
    }

    .social-icons img:nth-child(2) {
        top: 40%;
        left: 45%;
    }

    .social-icons img:nth-child(3) {
        top: 40%;
        left: 9%;
    }

    .social-icons img:nth-child(8) {
        top: 55%;
        left: 8%;
    }

    .social-icons img:nth-child(5) {
        top: 70%;
        left: 25%;
    }

    .social-icons img:nth-child(7) {
        top: 57%;
        left: 80%;
    }

    .social-icons img:nth-child(9) {
        top: 19%;
        left: 72%;
    }
}

@media(max-width: 991px) {
    .social-icons {
        height: 390px;
    }

    .cta-img {
        margin: 0 auto;
        max-width: 380px;
        left: -22px;
    }

    .cta-content {
        padding-block: 60px 20px;
    }
}

@media (max-width: 767px) {
    .cta-section-inner {
        border-radius: 16px;
        padding-inline: 30px;
    }

    .cta-content {
        padding-block: 40px 0px;
    }
}

@media (max-width: 575px) {
    .cta-section-inner {
        padding-inline: 30px;
    }

    .cta-content {
        padding-block: 40px 20px;
    }
}

@media (max-width: 480px) {

    .cta-section-inner {
        padding-inline: 12px;
    }

    .cta-content {
        padding-block: 30px 0;
    }

    .cta-section .section-title-wrapper {
        gap: 8px;
    }

    .social-icons img {
        width: 50px;
        height: 50px;
    }

    .cta-img {
        left: -14px;
    }

    .social-icons {
        height: 300px;
    }
}

/*========== CTA Section End ==========*/


/*==========Our Clients Logos Grid==========*/


.clients-logos-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 24px;
    justify-items: start;
    align-items: center;
}

.client-logo {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 10px;
    border-radius: 8px;
    width: 100%;
    height: 90px;
    border: 1px solid var(--color-border);
    transition: 0.3s;
}

.client-logo:hover {
    scale: 1.05 !important;
}

.client-logo img {
    display: block;
    height: auto;
    max-height: 80%;
    max-width: 80%;
    width: 100%;
    object-fit: contain;
    object-position: center;
}

.client-logo .client-logo-extra {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
}

.client-logo .client-logo-extra .img {
	width: 45px;
	height: 45px;
	border: 1px solid rgba(0,0,0,0.2);
	border-radius: 50%;
	object-fit: contain;
	object-position: center;
	padding: 10px;
	position: relative;
	z-index: 1;
	margin-left: -20px;
	background-color: var(--color-white);
	font-size: 15px;
    font-weight: 600;
}

.client-logo .client-logo-extra .img:first-child {
	margin-left: 0;
}

@media (max-width: 991px) {
    .clients-logos-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 24px 24px;
    }
}

@media (max-width: 767px) {
    .clients-logos-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 16px 16px;
        padding: 12px 4px;
    }
}

@media (max-width: 480px) {
    .clients-logos-grid {
        padding-inline: 12px;
        padding-block: 0;
    }
}

/*==========Our Clients Logos Grid End==========*/

/*========== Money Back Guarantee Section ==========*/

.money-back-guarantee {
    background: var(--color-white);
    padding-block: var(--section-padding);
}

.money-back-guarantee-box {
    padding: 60px 80px;
    border-radius: 30px;
    background: var(--color-dark);
    position: relative;
}

.money-back-guarantee-inner .section-title {
    color: var(--color-white);
}

.money-back-content {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.money-back-content ul {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.money-back-content p,
.money-back-content ul li {
    font-size: var(--font-size-lg);
    line-height: 1.8;
    color: var(--color-on-dark);
    margin: 0;
}

.money-back-guarantee-inner {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 24px;
}

.money-back-signature img {
    filter: brightness(0) invert(1);
}

.circle-text-container {
    margin: 0 auto;
    border-radius: 50%;
    width: 220px;
    height: 220px;
    position: relative;
    text-align: center;
    cursor: pointer;
    transform-origin: 50% 50%;
    -webkit-transform-origin: 50% 50%;
    mask-image: url("../images/verify.svg");
    mask-size: cover;
    mask-position: center;
    mask-repeat: no-repeat;
    mask-mode: match-source;
    background-color: var(--color-primary);
}

.circle-text-container span {
    position: absolute;
    display: inline-block;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    font-size: 24px;
    font-weight: 900;
    color: #fff;
    transition: all 0.5s cubic-bezier(0, 0, 0, 1);
}

.circle-text-container-wrapper {
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;
    top: -80px;
    left: -80px;
}

@media (max-width: 1199px) {
    .circle-text-container-wrapper {
        transform: scale(0.7);
        top: -100px;
        left: -70px;
    }

    .money-back-guarantee-box {
        padding: 60px 40px;
    }
}

@media (max-width: 991px) {
    .money-back-guarantee-box {
        padding: 100px 40px 60px;
    }
}

@media (max-width: 575px) {
    .circle-text-container-wrapper {
        transform: scale(0.6);
        top: -90px;
        left: -90px;
    }

    .money-back-guarantee-box {
        padding: 85px 40px 50px;
    }
}

@media (max-width: 480px) {
    .circle-text-container-wrapper {
        transform: scale(0.6);
        top: -90px;
        left: -87px;
    }

    .money-back-guarantee-box {
        padding: 90px 30px 60px;
    }

    .money-back-guarantee-inner {
        gap: 8px;
    }

    .money-back-signature {
        margin-block: 12px;
    }
}

/*========== Money Back Guarantee Section End ==========*/


/*==========Note Section CSS==========*/

.note-section {
    padding-block: 80px;
    position: relative;
    background-size: cover;
    background-position: center;
}

.note-section:after {
    content: "";
    position: absolute;
    inset: 0;
    background: var(--color-silver);
    z-index: 0;
    opacity: 0.7;
    pointer-events: none;
}

.note-content {
    text-align: center;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 20px;
    position: relative;
    z-index: 2;
}

.note-content .pill-text {
    margin-bottom: 0;
}

.note-content h2 {
    max-width: 1020px;
    margin: 0 auto;
    line-height: 1.25;
}

.note-content h2 .hashtag {
    color: var(--color-secondary);
}

.note-content-bottom {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 14px;
    margin-top: 10px;
}

@media(max-width: 575px) {
    .note-section {
        padding-block: 40px;
    }

    .note-content-bottom {
        gap: 8px;
    }

    .note-content-bottom img {
        width: 200px;
    }
}

/*==========Note Section End==========*/


/*========== Team Signatures Section Start ==========*/

.team-signatures-section {
    padding-top: var(--section-padding);
}

.team-signatures-box {
    background: var(--color-silver);
    padding: 60px;
    border-radius: 14px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    row-gap: 30px;
    position: relative;
    z-index: 2;
    overflow: hidden;
}

.team-signatures {
    width: 20%;
    text-align: center;
}

.team-signatures img {
    width: 100%;
    height: 55px;
    object-fit: contain;
    /* border-bottom: 1px solid var(--color-border); */
}

.team-signatures p {
    margin-top: 10px;
    font-weight: 500;
}

.team-signatures-background {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image: url("../images/paper-img.jpg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    opacity: 0.4;
    z-index: -1;
}

@media(max-width: 1199px) {
    .team-signatures-box {
        padding: 40px;
    }
}

@media(max-width: 991px) {
    .team-signatures {
        padding-inline: 10px;
        width: 25%;
    }
}

@media(max-width: 991px) {
    .team-signatures {
        width: 33.3333%;
    }
}

@media (max-width: 575px) {
    .team-signatures-box {
        padding: 30px 20px;
    }
    .team-signatures {
        width: 50%;
    }
}

@media (max-width: 400px) {
    .team-signatures-box {
        padding: 30px 10px;
    }
}
/*========== Team Signatures Section End ==========*/

/*========== FAQ Section Start ==========*/
.faq-section {
    padding-block: var(--section-padding);
    background: var(--color-white);
    background-image: radial-gradient(at 130% 50%, hsl(269.18deg 100% 70% / 10%) 0px, transparent 50%), radial-gradient(at 0% 65%, hsl(308deg 100% 56% / 10%) 0px, transparent 20%);
}

.faq-accordion {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.faq-item {
    border: 1px solid var(--color-border);
    background: linear-gradient(to bottom right, var(--color-white), rgba(128, 128, 128, 0.1), var(--color-white));
    border-radius: 16px;
    box-shadow: 0 2px 16px 0 rgba(27, 96, 255, 0.04);
    transition: box-shadow 0.2s, background 0.3s;
    overflow: hidden;
}

.faq-item:hover {
    background: var(--color-bg);
}

.faq-item.open,
.faq-item:focus-within {
    box-shadow: 0 6px 32px 0 rgba(247, 182, 23, 0.08);
}

.faq-question {
    width: 100%;
    background: none;
    border: none;
    outline: none;
    padding: 24px 32px 24px 24px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: var(--font-size-xl);
    font-weight: var(--font-semibold);
    color: var(--color-text);
    cursor: pointer;
    transition: background 0.2s;
    text-align: left;
}

.faq-icon {
    margin-left: 18px;
    display: flex;
    align-items: center;
    transition: transform 0.4s cubic-bezier(0.86, 0, 0.07, 1);
    color: var(--color-dark);
}

.faq-item.open .faq-icon {
    transform: rotate(180deg);
}

.faq-answer {
    display: block;
}

.faq-answer-inner {
    padding: 24px 32px 24px 24px;
    border-top: 1px solid var(--color-border);
}

.faq-answer p {
    font-size: var(--font-size-lg);
    line-height: 1.6;
}

.faq-contact-box {
    background: var(--color-bg);
    border-radius: 14px;
    padding: 36px 24px 32px 24px;
    margin-top: 32px;
    box-shadow: 0 2px 16px 0 rgba(27, 96, 255, 0.03);
    overflow: hidden;
}

.faq-contact-box h3 {
    font-weight: var(--font-bold);
    color: var(--color-white);
}

.faq-contact-box p {
    color: var(--color-on-dark-text);
}

.faq-contact-box>*:not(.silk-bg-wrap) {
    position: relative;
    z-index: 1;
}

.faq-contact-box .button-wrapper {
    justify-content: center;
}

.silk-bg-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    background: linear-gradient(180deg, #000 0%, rgb(255 255 255 / 20%) 100%);
}

@media (max-width: 991px) {
    .faq-section {
        padding: 80px 0 80px 0;
    }

    .faq-question {
        font-size: var(--font-size-lg);
        padding: 20px 20px 20px 16px;
    }

    .faq-answer-inner {
        padding: 20px 20px 20px 16px;
    }

    .faq-answer p {
        font-size: var(--font-size-base);
    }

    .faq-contact-box {
        padding: 28px 12px 24px 12px;
    }
}

@media (max-width: 575px) {
    .faq-section {
        padding: 48px 0 48px 0;
    }

    .faq-question {
        font-size: var(--font-size-base);
        padding: 16px 10px 16px 10px;
    }

    .faq-answer-inner {
        padding: 12px 10px 12px 10px;
    }
}


/*========== FAQ Section End ==========*/

/*========== About Us Page Section Start ==========*/
/*========== About Us Section Start ==========*/

.about-us-main {
    padding-block: 80px var(--section-padding);
}

.about-us-content-btn {
    margin-top: 30px;
}

.about-us-main-img {
    display: flex;
    flex-wrap: wrap;
    gap: 30px;
    margin-right: 20px;
}

.about-experience-box {
    width: calc(60% - 15px);
    height: 100%;
    border: 1px solid var(--color-border);
    border-radius: 30px;
    padding: 30px;
    display: flex;
    flex-direction: column;
    gap: 40px;
}

.about-us-box-img-1 {
    position: relative;
    width: calc(40% - 15px);
}

.about-us-box-img {
    height: 100%;
}

.about-us-main-img img {
    width: 100%;
    height: 100%;
    border-radius: 30px;
    overflow: hidden;
    object-fit: cover;
    object-position: center;
}

.about-us-box-img-1 img {
    aspect-ratio: 1 / 1.036;
}

.about-experience-box iconify-icon {
    color: var(--color-primary);
    font-size: 50px;
}

.about-experience-content {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.about-us-box-img-2 {
    width: 100%;
}

.about-us-box-img-2 img {
    aspect-ratio: 1 / 0.61;
}

.about-us-content .section-title-wrapper {
    margin-bottom: 12px;
    gap: 8px;
}

.about-content-body {
    display: flex;
    flex-wrap: wrap;
    gap: 30px 60px;
    margin-block: 60px 0;
}

.about-service-item {
    position: relative;
    width: calc(50% - 30px);
    display: flex;
    gap: 22px;
}

.about-service-item:not(:last-child):before {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    right: -30px;
    background: var(--color-border);
    width: 1px;
    height: 100%;
}

.about-service-content {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.about-service-item iconify-icon {
    color: var(--color-primary);
    font-size: 50px;
}

.about-service-content h4,
.about-experience-content h4 {
    font-weight: var(--font-semibold);
}

@media (max-width: 1499px) {
    .about-content-body {
        gap: 30px;
    }

    .about-service-item:not(:last-child):before {
        right: -15px;
    }

    .about-service-content .text-lg {
        font-size: var(--font-size-base);
    }

    .about-service-content h3 {
        font-size: var(--font-size-xl);
    }

    .about-service-item {
        width: calc(50% - 15px);
    }

    .about-experience-box {
        padding: 22px;
    }

    .about-service-item iconify-icon {
        font-size: 40px;
    }

    .about-us-main .about-us-content .text-lg {
        font-size: var(--font-size-base);
    }

    .about-us-main-img {
        margin: 0;
        gap: 15px;
    }

    .about-us-box-img-1 {
        width: 40%;
    }

    .about-us-box-img-2 img {
        border-radius: 20px;
    }
}

@media (max-width: 991px) {
    .about-us-box-img-1 img {
        aspect-ratio: 1 / 0.036;
    }

    .about-experience-box {
        gap: 25px;
    }

    .about-us-box-img-2 img {
        aspect-ratio: 1 / 0.55;
    }

    .about-counter-row {
        margin-top: 60px;
    }

    .about-counter-box .h1 {
        font-size: 2.65rem;
    }
}

@media (max-width: 767px) {
    .about-content-body {
        flex-direction: column;
    }
    .about-service-item {
        width: 100%;
    }
    .about-service-item:not(:last-child):before {
        display: none;
    }
}

@media (max-width: 480px) {
    .about-us-main {
        padding-block: 50px var(--section-padding);
    }

    .about-experience-box {
        width: 100%;
        border-radius: 12px;
        padding: 16px;
        gap: 16px;
    }

    .about-us-box-img-1 {
        width: 50%;
    }

    .about-us-box-img-1 img {
        aspect-ratio: 1 / 0.6;
    }

    .about-us-box-img-2 {
        width: calc(50% - 12px);
    }

    .about-us-main-img {
        gap: 12px;
    }

    .about-us-main-img img {
        border-radius: 12px;
    }

    .about-experience-box iconify-icon {
        font-size: 35px;
    }

    .about-service-item {
        width: 100%;
    }

    .about-service-item:not(:last-child):before {
        right: 0;
        width: 100%;
        height: 1px;
    }
}

@media (max-width: 400px) {
    .about-service-item {
        gap: 15px;
    }
}
/*========== About Us Section End ==========*/

/*========== Our Approach Section Start ==========*/

.our-approach {
    padding-block: var(--section-padding);
    background: var(--color-dark);
}

.our-approach-box {
    padding: 60px 40px;
    border: 1px solid var(--color-border-dark);
    border-radius: 20px;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    position: relative;
    overflow: hidden;
    z-index: 2;
}

.our-approach-box:after {
    content: '';
    position: absolute;
    inset: 0;
    background-image: radial-gradient(circle at 50% 90%, rgb(147 51 234 / 75%) 0%, rgba(15, 23, 42, 0.2) 80%);
    z-index: -1;
    transition: 0.3s;
}

.our-approach-box:hover:after {
    transform: scale(1.5);
}

.our-approach-box-number {
    margin-bottom: 80px;
}

.our-approach-box-number h3 {
    color: var(--color-tertiary);
}

.our-approach-box-content h2 {
    color: var(--color-white);
    margin-bottom: 20px;
}

.our-approach-box-content p {
    font-size: var(--font-size-xl);
    color: var(--color-on-dark-text);
    opacity: 0.9;
}

.our-approach-box-2:after {
    background-image: radial-gradient(circle at 50% 90%, rgb(19 194 194 / 75%) 0%, rgba(15, 23, 42, 0.2) 80%);
}

.our-approach-box-2 .our-approach-box-number h3 {
    color: var(--color-accent);
}

.our-approach-box-3:after {
    background-image: radial-gradient(circle at 50% 90%, rgb(51 234 185 / 75%) 0%, rgba(15, 23, 42, 0.2) 80%);
}

.our-approach-box-3 .our-approach-box-number h3 {
    color: #33eab9;
}

@media(max-width: 1399px) {
    .our-approach-box {
        padding: 30px;
    }

    .our-approach-box-content h2 {
        margin-bottom: 10px;
        font-size: var(--font-size-3xl);
    }

    .our-approach-box-content p {
        font-size: var(--font-size-lg);
    }
}

@media (max-width: 1199px) {
    .our-approach-box {
        padding: 22px;
    }

    .our-approach-box-number {
        margin-bottom: 30px;
    }

    .our-approach-box {
        margin-bottom: 30px;
        height: auto;
    }

    .our-approach-box.our-approach-box-3 {
        margin-bottom: 0;
    }
}

/*========== Our Approach Section End ==========*/


/*========== Leader Section Start ==========*/

.leader-section {
    padding-block: var(--section-padding);
}

.leader-image {
    position: relative;
    padding: 0 0 225px 100px;
}

.leader-image-1 img,
.leader-image-2 img {
    border-radius: 40px;
    display: block;
}

.leader-image-2 {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    max-width: 542px;
}

.leader-image-2 img {
    border: 9px solid var(--color-bg);
}

.leader-image-2 .circle-text-container-wrapper {
    top: auto;
    right: 0;
    bottom: 50px;
    left: auto;
    transform: translate(50%, 0);
}

.leader-content p {
    font-size: var(--font-size-xl);
}

.leader-section .section-title-wrapper {
    margin-bottom: 60px;
}

.leader-content-wp {
    padding-right: 30px;
    display: flex;
    flex-direction: column;
    gap: 60px;
}

.leader-content-bottom ul li {
    display: flex;
    gap: 20px;
}

.leader-content-bottom ul li:not(:last-child) {
    margin-bottom: 18px;
    padding-bottom: 18px;
    border-bottom: 1px solid var(--color-border);
}

.leader-content-bottom-icon {
    flex: 0 0 auto;
    width: 80px;
    height: 80px;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 20px;
    background: rgb(147 51 234 / 10%);
    padding: 10px;
}

.leader-content-bottom-text {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

@media (max-width: 1399px) {
    .leader-content p {
        font-size: var(--font-size-lg);
    }

    .leader-content-wp {
        gap: 30px;
    }

    .leader-image {
        padding: 0 0 230px 60px;
    }

    .leader-image-2 {
        max-width: 500px;
    }

    .leader-image-2 .circle-text-container-wrapper {
        transform: scale(0.8);
        right: -100px;
        bottom: 20px;
    }
}

@media (max-width: 991px) {
    .leader-section .section-title-wrapper {
        margin-bottom: 30px;
    }

    .leader-image {
        margin-top: 60px;
    }


    .leader-content-wp {
        padding: 0;
        gap: 40px;
    }

    .leader-content {
        text-align: center;
    }
}

@media (max-width: 480px) {
    .leader-content-bottom-icon {
        width: 50px;
        height: 50px;
        border-radius: 10px;
    }

}

@media (max-width: 480px) {
    .leader-image {
        margin-top: 30px;
        padding: 0 0 140px 60px;
    }

    .leader-image-1 img,
    .leader-image-2 img {
        border-radius: 20px;
    }

    .leader-image-2 .circle-text-container-wrapper {
        transform: scale(0.5);
        right: -120px;
        bottom: 50px;
    }
}

/*========== Leader Section End ==========*/

/*========== Expertise Section Start ==========*/

.expertise-section {
    min-height: 85vh;
    padding-block: 160px;
    text-align: center;
    background: var(--color-dark);
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: hsla(222, 47%, 11%, 1);
    background-image:
        radial-gradient(at 100% 100%, hsla(224, 76%, 48%, 0.5) 0px, transparent 50%),
        radial-gradient(at 0% 77%, hsla(41, 93%, 52%, 0.24) 0px, transparent 50%);
}

.expertise-content {
    display: flex;
    flex-direction: column;
    gap: 40px
}

.expertise-content h2 {
    font-size: 100px;
    font-weight: 200;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 40px;
    flex-wrap: wrap;
    line-height: 1.2;
}

.expertise-content p {
    font-size: var(--font-size-3xl);
    color: var(--color-on-dark-text);
    font-weight: 300;
    max-width: 860px;
    margin-inline: auto;
}

.expertise-title span {
    color: var(--color-white);
    transition: 0.3s ease-in;
}

.expertise-title .gradient-design.active {
    color: transparent;
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-image: linear-gradient(90deg, #00c6fb, #005bea, #00c6fb);
}

.gradient-build.active {
    color: transparent;
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-image: linear-gradient(90deg, #a650ce, #a4508b, #a4508b);
}

.gradient-market.active {
    color: transparent;
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-image: linear-gradient(90deg, #ffb347, #ff5858, #ffb347);
}

@media (max-width: 1399px) {
    .expertise-content h2 {
        font-size: 80px;
        gap: 30px;
    }
}

@media (max-width: 1199px) {
    .expertise-content {
        gap: 30px;
    }

    .expertise-section {
        padding-block: 100px;
    }

    .expertise-content p {
        font-size: var(--font-size-2xl);
    }
}

@media (max-width: 991px) {
    .expertise-content h2 {
        font-size: 70px;
        gap: 20px;
    }

    .expertise-section {
        min-height: auto;
    }
}

@media(max-width: 575px) {
    .expertise-content h2 {
        font-size: 50px;
        gap: 12px;
    }

    .expertise-content p {
        font-size: var(--font-size-lg);
    }
}

@media (max-width: 480px) {
    .expertise-section {
        padding-block: 60px;
    }

    .expertise-content h2 {
        font-size: 40px;
    }

    .expertise-content {
        gap: 20px;
    }
}

/*========== Expertise Section End ==========*/

.about-us-team {
    padding-bottom: var(--section-padding);
}

/*========== About Us Page Section End ==========*/

/*========== Services Page Start ==========*/

/*========== What We Do Section Start ==========*/

.what-we-do {
    padding-block: 40px var(--section-padding);
    background-image: radial-gradient(at 100% 40%, hsla(224, 76%, 48%, 0.1) 0px, transparent 50%), radial-gradient(at 0% 100%, hsla(41, 93%, 52%, 0.12) 0px, transparent 50%);
}

.what-we-do-row {
    display: flex;
    flex-direction: column;
    gap: 30px;
}

.what-we-do-row .thumb {
    width: 100%;
    aspect-ratio: 1;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 4px 60px -1px rgba(0, 0, 0, 0.1);
}

.what-we-do-row .thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.what-we-do-card-content {
    display: flex;
    flex-direction: column;
    gap: 20px;
    padding-inline: 30px;
    align-items: flex-start;
}

.what-we-do-card-content p,
.what-we-do-card-content ul li {
    font-size: var(--font-size-lg);
}

.what-we-do-card-content .h2 {
    font-weight: var(--font-bold);
}

.what-we-do-card {
    padding: 30px;
    background: rgb(249 250 251 / 50%);
    border-radius: 20px;
    border: 1px solid var(--color-border);
    backdrop-filter: blur(8px);
    display: block;
}

.what-we-do .service-card {
    background: var(--color-dark);
}

.what-we-do .services-card-content .pointer-highlight-wrapper {
    color: var(--color-white);
}


@media (max-width: 1199px) {
    .what-we-do-card-content {
        padding: 0;
        gap: 12px;
    }

    .what-we-do-card .row.align-items-center {
        align-items: flex-start !important;
    }

    .what-we-do-card-content p,
    .what-we-do-card-content ul li {
        font-size: var(--font-size-base);
    }

    .list li {
        margin-bottom: 0.5em;
    }

    .what-we-do-card {
        padding: 24px;
    }
}

@media (max-width: 991px) {
    .what-we-do-row .thumb {
        max-width: 460px;
        margin-inline: auto;
        margin-bottom: 40px;
    }
}

@media (max-width: 575px) {
    .list li {
        padding-left: 1.2em;
    }

    .list li:before {
        top: 0.3em;
    }
}

@media (max-width: 480px) {
    .what-we-do-card {
        padding: 16px;
    }

    .what-we-do-row .thumb {
        margin-bottom: 22px;
    }

}

/*========== What We Do Section End ==========*/

/*========== Services Page End ==========*/

/*========== Services Details Page Start ==========*/
.about-sec.services-about {
    padding-block: 60px 0;
}

.services-about-img-wp {
    width: 100%;
    position: relative;
    height: 100%;
    min-height: 480px;
    max-height: 560px;
}

.services-about-img {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    border-radius: 20px;
}

.we-offer {
    padding-block: var(--section-padding);
}

.we-offer-row .row {
    --bs-gutter-y: 1.5rem;
}

.we-offer-box {
    display: flex;
    flex-direction: column;
    gap: 24px;
    align-items: flex-start;
    padding: 26px;
    background-color: #f7f7f7;
    border-radius: 14px;
    transition: 0.3s;
}

.we-offer-box:hover {
    background-image: radial-gradient(at 14% 26%, hsla(224, 76%, 48%, 0.0) 0px, transparent 30%), radial-gradient(at 100% 130%, hsla(193, 100%, 76%, 0.25) 0px, transparent 60%);
}

.we-offer-box-icon {
    width: 60px;
    aspect-ratio: 1;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 50%;
    padding: 14px;
    background: var(--color-secondary);
    box-shadow: 0 0 20px 10px rgba(29, 78, 216, 0.2);
}

.we-offer-box-content {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.service-why-us {
    background: var(--color-dark);
    background-image: radial-gradient(at 50% -10%, hsla(60, 100%, 70%, 0.3) 0px, transparent 50%), radial-gradient(at -20% 135%, hsla(215, 100%, 56%, 0.3) 0px, transparent 50%);
}

.service-why-us-content {
    padding-block: var(--section-padding);
    padding-left: 40px;
}

.service-why-us-content ul li {
    display: flex;
    gap: 10px;
    flex: 1 0 calc(50% - 12px);
    padding: 12px;
    border-radius: 8px;
    background: rgb(255 255 255 / 10%);
    border: 1px solid rgb(229 231 235 / 20%);
}

.service-why-us-content ul li .service-why-box-icon {
    font-size: 22px;
    color: var(--color-success);
    padding-top: 2px;
    flex: 0 0 auto;
}

.service-why-box-content p {
    color: var(--color-on-dark-text);
}

.service-why-us-content .pill-text {
    margin-bottom: 20px;
}

.service-why-us-content ul {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-block: 30px;
}

.service-why-box-content {
    display: flex;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.service-why-box-title {
    display: flex;
    gap: 8px;
}

.service-why-box-content h4 {
    font-weight: var(--font-semibold);
    color: var(--color-white);
}

.service-why-us-content .section-title {
    margin-bottom: 20px;
}

.service-why-us-content p:not(.service-why-box-content p) {
    font-size: var(--font-size-lg);
}

.service-why-us-image-wp {
    position: relative;
    height: 100%;
    width: 100%;
}

.service-why-us-image {
    position: absolute;
    top: 0;
    right: 0;
    background-size: cover;
    background-position: center;
    width: calc(100% + 15vw);
    height: 100%;
}

.services-process {
    padding-block: var(--section-padding);
}


.services-process-row .row {
    --bs-gutter-y: 1.5rem;
}

/* Process Step */
.process-step {
    position: relative;
    height: 100%;
}

/* Step Card */
.step-card {
    background: var(--color-white);
    border-radius: 1rem;
    padding: 2rem;
    box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
    border: 1px solid #f3f4f6;
    transition: all 0.3s ease;
    position: relative;
    height: 100%;
}

.step-card:hover {
    transform: translateY(-0.5rem);
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
}

/* Step Header */
.step-header {
    position: relative;
    margin-bottom: 1.5rem;
}

.step-icon {
    width: 4rem;
    height: 4rem;
    border-radius: 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-white);
    font-size: 2rem;
    margin-bottom: 1rem;
    transition: transform 0.3s ease;
}

.step-card:hover .step-icon {
    transform: scale(1.1);
}

.step-icon-1 {
    background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);
}

.step-icon-2 {
    background: linear-gradient(135deg, #8b5cf6 0%, #7c3aed 100%);
}

.step-icon-3 {
    background: linear-gradient(135deg, #10b981 0%, #059669 100%);
}

.step-icon-4 {
    background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
}

.step-number {
    position: absolute;
    top: -0.5rem;
    right: -0.5rem;
    width: 2rem;
    height: 2rem;
    background: #111827;
    color: var(--color-white);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.875rem;
    font-weight: 700;
}

/* Step Content */
.step-title {
    font-size: 1.25rem;
    font-weight: 700;
    margin-bottom: 0.75rem;
    transition: color 0.3s ease;
}

.step-card:hover .step-title {
    color: var(--color-secondary);
}

.step-description {
    color: #6b7280;
    line-height: 1.7;
    margin-bottom: 1.5rem;
}

/* Progress Bar */
.progress-bar {
    width: 100%;
    background: #f3f4f6;
    border-radius: 9999px;
    height: 0.375rem;
    margin-bottom: 0.5rem;
    overflow: hidden;
}

.progress-fill {
    height: 100%;
    border-radius: 9999px;
    transition: width 0.7s ease;
}

.step-card:hover .progress-fill {
    width: 100% !important;
}

.progress-fill-1 {
    background: linear-gradient(90deg, #3b82f6 0%, #2563eb 100%);
}

.progress-fill-2 {
    background: linear-gradient(90deg, #8b5cf6 0%, #7c3aed 100%);
}

.progress-fill-3 {
    background: linear-gradient(90deg, #10b981 0%, #059669 100%);
}

.progress-fill-4 {
    background: linear-gradient(90deg, #f59e0b 0%, #d97706 100%);
}

.progress-text {
    font-size: 0.875rem;
    color: #9ca3af;
}

/* Arrow Right */
.arrow-right {
    display: none;
    position: absolute;
    top: 50%;
    right: -1.8rem;
    transform: translateY(-50%);
    color: var(--color-secondary);
    font-size: 2rem;
    transition: 0.3s ease;
    opacity: 0.6;
}


.process-step:hover .arrow-right {
    opacity: 1;
}

.services-process-row .row .col-xl-3:last-child .process-step .arrow-right {
    display: none;
}

@media (max-width: 1399px) {
    .step-card {
        padding: 1.5rem;
    }
}

@media (max-width: 1199px) {
    .service-why-box-title {
        gap: 6px;
    }

    .service-why-box-content h4 {
        font-size: var(--font-size-lg);
    }

    .service-why-us-content {
        padding-left: 20px;
    }

    .service-why-us-content p:not(.service-why-box-content p) {
        font-size: var(--font-size-base);
    }
}

@media(max-width: 991px) {
    .service-why-us-content {
        padding-block: 60px;
        padding-left: 0;
    }

    .service-why-us-image-wp {
        height: auto;
        aspect-ratio: 1 / 0.85;
    }

    .service-why-us-image {
        width: calc(100% + 30vw);
        left: 50%;
        transform: translate(-50%, 0);
    }

    .about-sec.services-about {
        padding-block: 40px 0;
    }
}

@media (min-width: 1199px) {
    .arrow-right {
        display: block;
    }
}

@media (max-width: 575px) {
    .services-about-img-wp {
        min-height: auto;
        max-height: initial;
        aspect-ratio: 1/0.8;
    }

    .about-content {
        margin-top: 30px;
    }

    .we-offer-box-icon {
        width: 50px;
    }

    .we-offer-box {
        gap: 16px;
        padding: 20px;
    }

    .services-about-img {
        border-radius: 12px;
    }
}

@media (max-width: 480px) {
    .service-why-us {
        background: var(--color-dark);
        background-image: radial-gradient(at 50% -10%, hsla(60, 100%, 70%, 0.15) 0px, transparent 140%), radial-gradient(at -20% 175%, hsla(215, 100%, 56%, 0.2) 0px, transparent 80%);
    }

    .service-why-us-content ul {
        margin-block: 20px;
        flex-direction: column;
    }

    .services-about-img-wp {
        aspect-ratio: 1/1;
    }
}

/*========== Services Details Page End ==========*/

/*========== Our Portfolio Page Start ==========*/

.our-portfolio-main {
    padding-block: 40px var(--section-padding);
}

/* Portfolio Grid */
.portfolio-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 24px;
    padding-inline: 24px;
    margin-top: 12px;
}


/* Portfolio Box */
.project-box {
    position: relative;
    aspect-ratio: 4/5;
    border-radius: 24px;
    overflow: hidden;
    cursor: pointer;
    transition: all 0.7s cubic-bezier(0.4, 0, 0.2, 1);
}

.project-box:hover {
    transform: translateY(-8px);
}

/* Project Image */
.project-image,
.project-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.7s cubic-bezier(0.4, 0, 0.2, 1);
    object-position: center;
}

.project-box:hover .project-image {
    transform: scale(1.1);
}

/* Gradient Overlay */
.gradient-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 0%, rgba(0, 0, 0, 0.1) 40%, rgba(0, 0, 0, 0.7) 100%);
    opacity: 0.4;
    transition: opacity 0.5s ease;
    z-index: 1;
    pointer-events: none;
}

.project-box:hover .gradient-overlay {
    opacity: 0.7;
}

/* Content Overlay */
.project-content-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 24px;
    z-index: 10;
    display: flex;
    justify-content: space-between;
    color: var(--color-white);
    align-items: center;
}

.project-content-overlay a {
    width: 40px;
    height: 40px;
    background: var(--color-white);
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    color: var(--color-black);
    font-size: 20px;
    transform: translateY(20px);
    opacity: 0;
    transition: 0.7s cubic-bezier(0.4, 0, 0.2, 1);
}

.project-box:hover .project-content-overlay a {
    opacity: 1;
    transform: translateY(0);
}


/* === Portfolio Swiper Custom Styles === */
.portfolio-swiper {
    position: relative;
    width: 100%;
    height: 100%;
}

.portfolio-swiper .swiper-pagination {
    position: absolute;
    bottom: 10px;
    left: 0;
    width: 100%;
    text-align: center;
    z-index: 10;
    margin: 0;
}

.portfolio-swiper .swiper-pagination-bullet {
    opacity: 1;
    background: rgb(0 0 0 / 30%);
}

.portfolio-swiper .swiper-pagination-bullet-active {
    background: var(--color-primary);
}

.portfolio-swiper .swiper-button-prev,
.portfolio-swiper .swiper-button-next {
    color: var(--color-primary);
    top: 50%;
    width: 32px;
    height: 32px;
    background: rgba(255, 255, 255, 0.8);
    border-radius: 50%;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.07);
    position: absolute;
    transform: translate(0, -50%);
    cursor: pointer;
    pointer-events: auto;
}

.portfolio-swiper .swiper-button-prev::after,
.portfolio-swiper .swiper-button-next::after {
    all: revert;
    display: inline-block;
    width: 24px;
    height: 24px;
    content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='%23000' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m14 7l-5 5l5 5'/%3E%3C/svg%3E");
    position: relative;
    top: -2px;
}

.portfolio-swiper .swiper-buttons:has(.swiper-button-lock) {
    display: none;
}

.portfolio-swiper .swiper-button-next::after {
    transform: scale(-1, 1);
}

.portfolio-swiper .swiper-button-prev {
    left: 15px;
}

.portfolio-swiper .swiper-button-next {
    right: 15px;
}


@media (min-width: 768px) and (max-width: 1024px) {
    .portfolio-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 992px) {

    .portfolio-swiper .swiper-button-prev,
    .portfolio-swiper .swiper-button-next {
        opacity: 0;
    }

    .portfolio-swiper .swiper-button-prev {
        left: 0;
    }

    .portfolio-swiper .swiper-button-next {
        right: 0;
    }

    .portfolio-box-img:hover .portfolio-swiper .swiper-button-next {
        right: 15px;
        opacity: 1;
    }

    .portfolio-box-img:hover .portfolio-swiper .swiper-button-prev {
        left: 15px;
        opacity: 1;
    }

    .portfolio-box-img:hover .portfolio-swiper .swiper-button-next.swiper-button-disabled,
    .portfolio-box-img:hover .portfolio-swiper .swiper-button-prev.swiper-button-disabled {
        opacity: 0.35;
    }

}

@media (min-width: 1024px) {
    .portfolio-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (min-width: 1280px) {
    .portfolio-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

@media (max-width: 767px) {

    .portfolio-swiper .swiper-button-prev,
    .portfolio-swiper .swiper-button-next {
        width: 26px;
        height: 26px;
    }

}

/*========== Our Portfolio Page End ==========*/

/*========== Contact Us Page Start ==========*/

.contact-us {
    padding-block: 80px var(--section-padding);
    background-image: radial-gradient(at 100% 50%, hsla(60, 100%, 70%, 0.2) 0px, transparent 50%), radial-gradient(at -20% 135%, hsla(215, 100%, 56%, 0.3) 0px, transparent 50%);
}

.contact-us-form-wp .section-title-wrapper {
    margin-bottom: 20px;
}

.contact-us-form-wp {
    padding: 30px;
    background: var(--color-silver);
    border-radius: 24px;
    border: 1px solid var(--color-border);
}

.contact-us-form-wp .form-input {
    background: var(--color-white);
}

.contact-map {
    width: 100%;
    height: 100%;
    border-radius: 24px;
    overflow: hidden;
}

.contact-map iframe {
    width: 100%;
    height: 100%;
}

.contact-info {
    height: 100%;
    padding: 30px;
    border-radius: 18px;
    background: rgb(255 255 255 / 60%);
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    flex-direction: column;
    gap: 16px;
    border: 1px solid var(--color-border);
    backdrop-filter: blur(20px);
}

.contact-info .contact-info-icon {
    width: 60px;
    aspect-ratio: 1;
    border-radius: 50%;
    background: var(--color-primary);
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 24px;
}

.contact-info-content {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.contact-info-content a {
    color: var(--color-dark);
    font-size: var(--font-size-lg);
    transition: 0.3s;
}

.contact-info-wp {
    margin-top: 24px;
}

.contact-info-content a:hover {
    color: var(--color-primary);
}

@media (max-width: 1199px) {
    .contact-us-form-wp {
        padding: 20px;
    }

    .contact-us-form-wp form .row {
        --bs-gutter-x: 12px;
    }

    .contact-info {
        padding: 18px;
    }

    .contact-info-content a {
        font-size: var(--font-size-base);
    }
}

@media (max-width: 991px) {
    .contact-map {
        height: auto;
        aspect-ratio: 1/0.6;
        margin-top: 30px;
        min-height: 300px;
    }
}

/*========== Contact Us Page End ==========*/

/*========== Career Page Start ==========*/

.career-section {
    padding-block: 60px var(--section-padding);
}

.career-content .section-title-wrapper {
    margin-bottom: 20px;
    gap: 8px;
}

.career-content .button-wrapper {
    margin-top: 20px;
}

.career-boxes {
    --gap: 24px;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--gap);
    width: 610px;
    max-width: 100%
}

.career-boxes .career-box {
    position: relative;
    background: var(--color-white);
    border-radius: 24px;
    box-shadow: 0px 4px 60px -1px rgba(0, 0, 0, .1);
    padding: 24px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
    text-align: left;
}

.career-boxes .career-box:nth-child(even) {
    margin-block: var(--gap) calc(var(--gap) * -1);
}

.career-box-icon img {
    width: 50px;
}

.career-box .career-box-title {
    font-size: var(--font-size-xl);
    margin-top: 12px;
    font-weight: var(--font-semibold);
}

.career-boxes .career-box p {
    color: #6b7280;
}

.job-section {
    background: #f9fafd;
    padding-block: var(--section-padding);
}

/* Job Card Styles */
.job-card {
    background: var(--color-white);
    border-radius: 24px;
    padding: 24px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.05);
    position: relative;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.2);
    transition: all 0.7s cubic-bezier(0.4, 0, 0.2, 1);
    height: 100%;
    display: flex;
    flex-direction: column;
}

/* Decorative Element */
.job-card:after {
    content: '';
    position: absolute;
    top: -50px;
    right: -50px;
    width: 100px;
    height: 100px;
    background: linear-gradient(135deg, rgba(59, 130, 246, 0.1), rgba(29, 78, 216, 0.1));
    border-radius: 50%;
    pointer-events: none;
    transition: transform 0.7s cubic-bezier(0.4, 0, 0.2, 1);
}

.job-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 30px 80px rgba(0, 0, 0, 0.15);
}

.job-card:hover:after {
    transform: scale(1.3);
}

/* Card Header */
.job-card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 24px;
}

.company-logo {
    width: 70px;
    height: 70px;
    background: linear-gradient(135deg, #3b82f6, #1d4ed8);
    border-radius: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 35px;
    color: white;
    box-shadow: 0 8px 25px rgba(59, 130, 246, 0.3);
    transition: transform 0.3s ease;
}

.job-card:hover .company-logo {
    transform: rotate(5deg) scale(1.1);
}

.urgent-badge {
    background: linear-gradient(135deg, #ef4444, #dc2626);
    color: var(--color-white);
    padding: 8px 16px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 1px;
    box-shadow: 0 4px 15px rgba(239, 68, 68, 0.4);
    animation: pulse 2s infinite;
    z-index: 2;
}

@keyframes pulse {

    0%,
    100% {
        transform: scale(1);
    }

    50% {
        transform: scale(1.05);
    }
}

/* Job Title Section */
.job-title {
    margin-bottom: 22px;
}

.job-title h2 {
    font-size: 28px;
    font-weight: 800;
    color: #1f2937;
    margin-bottom: 8px;
    background: linear-gradient(135deg, #1f2937, #4b5563);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.company-name {
    color: #6b7280;
    font-size: 16px;
    font-weight: 500;
}

/* Job Details Grid */
.job-details {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin-bottom: 24px;
    padding: 16px;
    background: linear-gradient(135deg, #f8fafc, #f1f5f9);
    border-radius: 16px;
    border: 1px solid #e2e8f0;
}

.detail-item {
    display: flex;
    align-items: center;
    gap: 12px;
}

.detail-icon {
    width: 40px;
    height: 40px;
    background: linear-gradient(135deg, #3b82f6, #1d4ed8);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 16px;
    flex-shrink: 0;
    box-shadow: 0 4px 12px rgba(59, 130, 246, 0.2);
}

.detail-content {
    display: flex;
    flex-direction: column;
}

.detail-label {
    font-size: 12px;
    color: #6b7280;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.detail-value {
    font-size: 14px;
    color: #1f2937;
    font-weight: 600;
    margin-top: 2px;
}

/* Responsibilities Section */
.responsibilities {
    margin-bottom: 24px;
}

.responsibilities h4 {
    margin-bottom: 14px;
    font-weight: var(--font-semibold);
}

.responsibilities ul {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.responsibilities li {
    display: flex;
    align-items: flex-start;
    gap: 8px;
}

.responsibilities li iconify-icon {
    color: var(--color-success);
    font-size: 18px;
    padding-top: 2px;
}

.responsibilities li span {
    color: #374151;
    font-size: 15px;
    line-height: 1.6;
    font-weight: 500;
}

/* Apply Button */
.apply-section {
    text-align: center;
    margin-top: auto;
}


/* Responsive Design */

@media(max-width: 1199px) {
    .career-boxes .career-box {
        padding: 18px;
    }

    .job-details {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .job-title h2 {
        font-size: 24px;
    }

    .job-card {
        padding: 15px;
    }

    .company-logo {
        width: 60px;
        height: 60px;
        font-size: 28px;
    }
}

@media (max-width: 991px) {
    .career-boxes {
        width: 100%;
        margin-inline: auto;
        margin-top: 40px;
    }

    .career-boxes .career-box {
        padding: 24px;
    }

    .job-card {
        padding: 24px;
    }

    .job-details {
        grid-template-columns: 1fr 1fr;
    }

    .job-card-row {
        --bs-gutter-y: 1.5rem;
    }

}

@media (max-width: 768px) {
    .job-card {
        padding: 24px;
    }

    .job-details {
        grid-template-columns: 1fr;
        gap: 16px;
    }

    .job-title h2 {
        font-size: 22px;
    }

    .company-logo {
        width: 60px;
        height: 60px;
        font-size: 28px;
    }
}

@media (max-width: 575px) {
    .career-boxes {
        display: block;
    }

    .career-boxes .career-box:nth-child(even) {
        margin-block: 20px;
    }
}

@media (max-width: 480px) {
    .job-card {
        padding: 20px;
        border-radius: 16px;
    }

    .job-title h2 {
        font-size: 22px;
    }

    .apply-btn {
        padding: 14px 32px;
        font-size: 14px;
    }
}

/*========== Career Page End ==========*/

/*========== Customer Page Start ==========*/

.our-clients-page {
    padding-block: 40px var(--section-padding);
}

/*========== Customer Page End ==========*/

/*========== Branding Page Start ==========*/
.branding-banner {
    padding: 180px 0 100px;
    background: #060606;
    min-height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    z-index: 2;
    background-size: cover;
    background-position: center;
}

.branding-banner:after {
    content: "";
    position: absolute;
    inset: 0;
    background: #060606;
    opacity: 0.65;
    z-index: -1;
}

.branding-banner-content {
    text-align: center;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.branding-banner-title {
    font-size: 10rem;
    font-weight: var(--font-medium);
    color: var(--color-white);
}

.branding-banner-content p {
    color: var(--color-white);
    font-size: var(--font-size-lg);
}

.branding-portfolio .our-portfolio {
    padding-top: 0;
}

.intro {
    position: relative;
    padding: 5vw;
    background: #C0D7D8;
    overflow: hidden;
}

.intro__content {
    position: absolute;
    right: 8%;
    bottom: 15%;
    z-index: 3;
}

.intro__title {
    font-size: 25vw;
    overflow: hidden;
    letter-spacing: -2.3vw;
    padding-right: 2.3vw;
}

.intro__img {
    position: absolute;
    width: 35%;
    max-width: 390px;
    height: auto;
}

.intro__img--1 {
    z-index: 2;
    left: 10%;
    bottom: 35%;
}

.intro__img--2 {
    z-index: 1;
    left: 25%;
    bottom: 40%;
}

.intro__txt {
    max-width: 35vw;
    margin-left: 25vw;
}

.branding-slider .slide {
    display: flex;
    align-items: stretch;
    min-height: 100vh;
    overflow: hidden;
}

.branding-slider .slide:nth-of-type(even) {
    background: #C4CDC4;
}

.branding-slider .col {
    flex-basis: 50%;
}

.col--1 {
    position: relative;
    z-index: 1;
}

.col--2 {
    position: relative;
    overflow: hidden;
}

.col__content {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    overflow: hidden;
    height: 100%;
    padding: 6vw;
}

.col__content--1 {
    background: #D8C0C0;
}

.col__content--2 {
    background: #CDD5E0;
}

.col__content--3 {
    background: #F3D3B0;
}

.col__content--4 {
    background: #F8E9E6;
}

.col__content--5 {
    background: #D1E2EC;
}

.col__content--6 {
    background: #D7CEC5;
}

.col__content-title {
    margin: 0 0 2vw;
    font-size: 6vw;
    letter-spacing: -0.2vw;
    line-height: 1.16;
}

.col__content-wrap {
    display: flex;
    justify-content: flex-end;
}

.col__content-txt {
    max-width: 22vw;
    order: 2;
    margin-left: 32px;
}

.line {
    overflow: hidden;
}

.line:nth-of-type(even) {
    margin-top: -1vw;
}

.line__inner {
    display: block;
}

.slide--0 .slide__scroll-line {
    background: #C0D7D8;
}

.slide--1 .slide__scroll-line {
    background: #D8C0C0;
}

.slide--2 .slide__scroll-line {
    background: #CDD5E0;
}

.slide--3 .slide__scroll-line {
    background: #F3D3B0;
}

.slide--4 .slide__scroll-line {
    background: #F8E9E6;
}

.slide--5 .slide__scroll-line {
    background: #D1E2EC;
}

.slide--6 .slide__scroll-line {
    background: #D7CEC5;
}

.col__image-wrap {
    position: absolute;
    inset: 0;
    width: 100%;
}

.col__image-wrap .img {
    object-fit: cover;
    width: 100%;
    height: 100%;
}

@media (max-width: 1499px) {
    .branding-banner-title {
        font-size: 7rem;
    }

    .col__content-txt {
        max-width: 28vw;
    }
}

@media (max-width: 1199px) {
    .col__content-txt {
        max-width: 33vw;
    }
}

@media (max-width: 991px) {
    .branding-slider .slide {
        min-height: auto;
        flex-direction: column;
    }

    .branding-slider .slide:nth-child(odd) {
        flex-direction: column-reverse;
    }

    .branding-slider .col.col--2 {
        aspect-ratio: 1 / 0.6;
    }

    .col__content-txt {
        max-width: 100%;
    }

    .branding-banner-title {
        font-size: clamp(4.375rem, 11.765vw + 2.022rem, 6.25rem);
    }
}

@media (max-width: 575px) {
    .col__content-title {
        font-size: clamp(1.55rem, 4.314vw + 0.637rem, 2.188rem);
    }
}

/*========== Branding Page End ==========*/

/*========== Product Page Start ==========*/

.about-sec.product-about {
    padding-block: 40px var(--section-padding);
}

.product-about .services-about-img-wp {
    aspect-ratio: 1;
}

/*========== Product Page End ==========*/

/*========== Footer Section Start ==========*/

@keyframes move-gradient {
    0% {
        background-position: 0% 0%, 100% 100%;
    }

    100% {
        background-position: 100% 100%, 0% 0%;
    }
}

.get-started {
    padding-top: 80px;
}

.get-started-wrapper {
    padding-bottom: 60px;
    border-bottom: 1px solid rgb(255 255 255 / 15%);
}

.get-started-content h2 {
    color: var(--color-white);
    font-size: var(--font-size-7xl);
    font-weight: var(--font-medium);
    letter-spacing: 0.015em;
}

.get-started-content p {
    font-size: var(--font-size-3xl);
    color: var(--color-on-dark-text);
    font-weight: 300;
}

.site-footer {
    position: relative;
    background: var(--color-dark);
    background-image: radial-gradient(at 40% 130%, hsla(60, 100%, 70%, 0.2) 100px, transparent 55%), radial-gradient(at 80% 100%, hsla(215, 100%, 56%, 0.3) 0px, transparent 60%);
    background-size: 200% 200%;
    animation: move-gradient 6s ease-in-out infinite alternate;
    margin: 0px;
    border-radius: 0;
    transition: 0.3s;
    overflow: hidden;
}

.footer-top {
    padding-block: 80px 60px;
}

.site-footer .footer-top-shape {
    position: absolute;
    top: calc(var(--height) * -1);
    width: 1920px;
    height: var(--height);
    left: 50%;
    transform: translate(-50%, 0);
    background-color: var(--color-dark);
    pointer-events: none;
}

.footer-logo {
    display: flex;
    flex-direction: column;
    max-width: 240px;
    position: relative
}

.footer-content {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.footer-quote p {
    color: var(--color-white);
    font-size: var(--font-size-2xl);
    font-weight: var(--font-semibold);
    line-height: 1.55;
}

.footer-quote-icon {
    margin-right: 5px;
    vertical-align: text-bottom;
}

.footer-menu-wp {
    display: flex;
    justify-content: space-around;
}

.footer-menu {
    display: flex;
    flex-direction: column;
    gap: 20px;
    max-width: 200px;
}

.footer-title {
    color: var(--color-white);
}

.footer-menu ul {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.footer-menu ul li a {
    color: var(--color-white);
    transition: 0.3s;
}

.footer-menu ul li a:hover {
    color: var(--color-primary);
}

.footer-contact {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.footer-contact ul {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.footer-contact ul li a {
    color: var(--color-on-dark);
    transition: 0.3s;
    display: inline-flex;
    gap: 8px;
}

.footer-contact ul li a:hover {
    color: var(--color-primary);
}

.footer-contact ul li a iconify-icon {
    color: var(--color-primary);
}

.footer-contact ul li a span.address-text {
    display: inline-block;
    max-width: 310px;
}

.footer-social-icon {
    display: flex;
    flex-direction: column;
    gap: 20px;
    margin-top: 20px;
}

.footer-social-icon ul {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 15px;
}

.footer-social-icon ul li a {
    font-size: 25px;
}

.footer-bottom-content {
    padding-block: 30px;
    border-top: 1px solid var(--color-border-dark);
}

.footer-bottom-content p {
    color: var(--color-on-dark-text);
}

.footer-bottom-menu ul {
    display: flex;
    justify-content: flex-end;
    gap: 12px;
}

.footer-bottom-menu ul li a {
    color: var(--color-on-dark);
    opacity: 0.8;
    line-height: 1;
}

.footer-bottom-menu ul li a:hover {
    opacity: 1;
}

.footer-bottom-menu ul li:not(:last-child):after {
    content: '';
    width: 6px;
    height: 6px;
    background: var(--color-white);
    display: inline-block;
    border-radius: 50%;
    margin-left: 12px;
}

.footer-bottom-menu ul li {
    display: flex;
    align-items: center;
}

.footer-bottom-menu {
    display: flex;
    align-items: center;
    justify-content: end;
}

.footer-quote-gradient {
    background: linear-gradient(270deg, var(--color-white), var(--color-primary), var(--color-white));
    background-size: 200% 200%;
    background-clip: text;
    -webkit-background-clip: text;
    color: transparent;
    -webkit-text-fill-color: transparent;
    animation: gradient-move 10s ease-in-out infinite;
    display: inline;
}

@keyframes gradient-move {
    0% {
        background-position: 0% 50%;
    }

    50% {
        background-position: 100% 50%;
    }

    100% {
        background-position: 0% 50%;
    }
}

.get-started .button-group {
    display: flex;
    align-items: center;
    gap: 20px;
    flex-wrap: wrap;
}

.get-started .button-group .call-icon-btn:not(:hover) {
    color: var(--color-primary);
}

.logo-tagline {
    color: var(--color-white);
    font-weight: 500;
    display: block;
    padding-left: 22%;
    font-size: 14px;
    margin-top: -3%;
    letter-spacing: 2.1px;
}


@media (min-width: 992px) {
    .get-started .button-group {
        justify-content: flex-end;
    }

    .get-started .button-group .sec-btn {
        font-size: var(--font-size-xl);
        padding: 18px 34px;
    }
}

@media (max-width: 1399px) {
    .get-started-content h2 {
        font-size: var(--font-size-6xl);
    }

    .get-started-content p {
        font-size: var(--font-size-2xl);
    }

    .footer-quote p {
        font-size: 22px;
    }

    .footer-quote-icon svg {
        width: 26px;
    }
}

@media (max-width: 1199px) {
    .site-footer {
        margin: 0 !important;
        border-radius: 0 !important;
    }

    .get-started {
        padding-top: 60px;
    }

    .get-started-wrapper {
        padding-bottom: 40px;
    }

    .footer-top {
        padding-block: 60px;
    }

    .get-started-content h2 {
        font-size: 3.4rem;
    }
}

@media (max-width: 991px) {
    .get-started .button-group {
        margin-top: 12px;
    }

    .footer-quote-icon svg {
        width: 22px;
    }

    .footer-contact {
        margin-top: 30px;
    }

    .footer-menu-wp {
        gap: 40px;
        margin-top: 30px;
        justify-content: flex-start;
    }

    .footer-bottom-content {
        text-align: center;
    }

    .footer-bottom-menu {
        justify-content: center;
        margin-bottom: 10px;
    }

    .footer-top {
        padding-block: 30px;
    }

    .get-started-wrapper {
        padding-bottom: 30px;
    }

    .get-started-content h2 {
        font-size: 3rem;
        margin-bottom: 5px;
    }

    .get-started-content p {
        font-size: var(--font-size-xl);
    }
}

@media (max-width: 575px) {
    .get-started .button-group {
        gap: 15px;
    }
}

@media(max-width: 360px) {
    .get-started-content h2 {
        font-size: 2.2rem;
    }

    .get-started-content p {
        font-size: var(--font-size-lg);
    }

    .footer-menu-wp {
        margin-top: 14px;
        gap: 20px;
    }

    .footer-contact ul {
        gap: 12px;
    }

    .footer-menu {
        gap: 10px;
    }
}

/*========== Footer Section End ==========*/

/*==========Responsive Start CSS==========*/

@media (min-width: 1500px) {
    .container {
        max-width: 1368px;
    }
}

@media (min-width: 2100px) {
    .container {
        max-width: 1400px;
    }

    p,
    body {
        font-size: var(--font-size-lg);
    }
}


@media (max-width: 1199px) {
    .section-title {
        font-size: 2.5rem;
    }
}

@media (max-width: 767px) {
    :root {
        --font-size-5xl: 2rem;
        /* 32px */
        --font-size-4xl: 1.75rem;
        /* 28px */
        --font-size-3xl: 1.5rem;
        /* 24px */
        --font-size-6xl: 2.5rem;
        /* 40px */
        --section-padding: 60px;
    }

    .section-title {
        font-size: 2.1rem;
    }

    h1,
    .h1 {
        font-size: var(--font-size-4xl);
    }

    h2,
    .h2 {
        font-size: var(--font-size-3xl);
    }
}

@media (max-width: 575px) {

    .container,
    .container-fluid {
        padding: 0 30px;
    }

    .section-title {
        font-size: 2rem;
    }
}

@media (max-width: 480px) {
    :root {
        --font-size-5xl: 1.75rem;
        /* 28px */
        --font-size-4xl: 1.5rem;
        /* 24px */
        --font-size-6xl: 2rem;
        /* 32px */
    }

    .sec-btn {
        font-size: var(--font-size-sm);
        padding: 10px 20px;
    }
}

@media (max-width: 400px) {

    .container,
    .container-fluid {
        padding: 0 15px;
    }
}

@media (max-width: 380px) {
    :root {
        --font-size-xs: 0.7rem;
    }
}

/*==========Responsive Start CSS End==========*/