@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@300;400;500;600;700&family=IBM+Plex+Sans+Condensed:wght@300;400;500;600;700&family=IBM+Plex+Mono:wght@300;400;500;600;700&family=Barlow:wght@300;400;500;600;700&display=swap');

/* THIN (100) */
@font-face {
    font-family: "Bw Gradual DEMO";
    src: url("../../fonts/Bw-Gradual-DEMO/BwGradualDEMO-Thin.otf") format("opentype");
    font-weight: 100;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Bw Gradual DEMO";
    src: url("../../fonts/Bw-Gradual-DEMO/BwGradualDEMO-ThinItalic.otf") format("opentype");
    font-weight: 100;
    font-style: italic;
    font-display: swap;
}

/* End of font declarations */
/* EXTRA LIGHT (200) */
@font-face {
    font-family: "Bw Gradual DEMO";
    src: url("../../fonts/Bw-Gradual-DEMO/BwGradualDEMO-ExtraLight.otf") format("opentype");
    font-weight: 200;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Bw Gradual DEMO";
    src: url("../../fonts/Bw-Gradual-DEMO/BwGradualDEMO-ExtraLightItalic.otf") format("opentype");
    font-weight: 200;
    font-style: italic;
    font-display: swap;
}

/* LIGHT (300) */
@font-face {
    font-family: "Bw Gradual DEMO";
    src: url("../../fonts/Bw-Gradual-DEMO/BwGradualDEMO-Light.otf") format("opentype");
    font-weight: 300;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Bw Gradual DEMO";
    src: url("../../fonts/Bw-Gradual-DEMO/BwGradualDEMO-LightItalic.otf") format("opentype");
    font-weight: 300;
    font-style: italic;
    font-display: swap;
}

/* REGULAR (400) */
@font-face {
    font-family: "Bw Gradual DEMO";
    src: url("../../fonts/Bw-Gradual-DEMO/BwGradualDEMO-Regular.otf") format("opentype");
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Bw Gradual DEMO";
    src: url("../../fonts/Bw-Gradual-DEMO/BwGradualDEMO-RegularItalic.otf") format("opentype");
    font-weight: 400;
    font-style: italic;
    font-display: swap;
}

/* MEDIUM (500) */
@font-face {
    font-family: "Bw Gradual DEMO";
    src: url("../../fonts/Bw-Gradual-DEMO/BwGradualDEMO-Medium.otf") format("opentype");
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Bw Gradual DEMO";
    src: url("../../fonts/Bw-Gradual-DEMO/BwGradualDEMO-MediumItalic.otf") format("opentype");
    font-weight: 500;
    font-style: italic;
    font-display: swap;
}

/* SEMIBOLD (600) */
@font-face {
    font-family: "Bw Gradual DEMO";
    src: url("../../fonts/Bw-Gradual-DEMO/BwGradualDEMO-SemiBold.otf") format("opentype");
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Bw Gradual DEMO";
    src: url("../../fonts/Bw-Gradual-DEMO/BwGradualDEMO-SemiBoldItalic.otf") format("opentype");
    font-weight: 600;
    font-style: italic;
    font-display: swap;
}

/* BOLD (700) */
@font-face {
    font-family: "Bw Gradual DEMO";
    src: url("../../fonts/Bw-Gradual-DEMO/BwGradualDEMO-Bold.otf") format("opentype");
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Bw Gradual DEMO";
    src: url("../../fonts/Bw-Gradual-DEMO/BwGradualDEMO-BoldItalic.otf") format("opentype");
    font-weight: 700;
    font-style: italic;
    font-display: swap;
}

/* EXTRA BOLD (800) */
@font-face {
    font-family: "Bw Gradual DEMO";
    src: url("../../fonts/Bw-Gradual-DEMO/BwGradualDEMO-ExtraBold.otf") format("opentype");
    font-weight: 800;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Bw Gradual DEMO";
    src: url("../../fonts/Bw-Gradual-DEMO/BwGradualDEMO-ExtraBoldItalic.otf") format("opentype");
    font-weight: 800;
    font-style: italic;
    font-display: swap;
}

/* BLACK (900) */
@font-face {
    font-family: "Bw Gradual DEMO";
    src: url("../../fonts/Bw-Gradual-DEMO/BwGradualDEMO-Black.otf") format("opentype");
    font-weight: 900;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Bw Gradual DEMO";
    src: url("../../fonts/Bw-Gradual-DEMO/BwGradualDEMO-BlackItalic.otf") format("opentype");
    font-weight: 900;
    font-style: italic;
    font-display: swap;
}

/* ======================================================================================================================================================================================================== */
:root {
    --body-bg: #141424;
    --white: #ffffff;
    --white-70: rgba(255, 255, 255, .7);
    --main-color: #20DAC1;
    --main-color-action-btn: linear-gradient(180deg, #00e5b9%, #2dd5c4 100%);
    --card-bg: #2a2a4a;
    --section1-bg: rgba(28, 28, 50, 0.4);
    --header-bg: #1b1b30;

    --background: #141424;
    --boxes: #1c1c32;
    --active: #2a2a4a;
    --inactive: #161626;
    --text: #fff;
    --subtext: rgba(255, 255, 255, 0.7);
    --accent: #20dac1;
    --danger: #ff6060;


    --font-family: "IBM Plex Sans Condensed", sans-serif;
    --second-family: "IBM Plex Mono", monospace;
    --third-family: "Bw Gradual DEMO", sans-serif;
    --font3: "IBM Plex Sans", sans-serif;
    --font4: "Barlow", sans-serif;

    --stroke1-bg: linear-gradient(90deg, #ff68fb 5%, #7e52ff 40%, #f9cdb4 95%);
    --stroke2-bg: linear-gradient(180deg, #2A2A4A 0%, #161626 100%);
    --gap: 24px;
    /* horizontal gap between slides */
    --sideW: calc((100% - var(--gap) * 2) / 4);
    /* 25% each side */
    --centerW: calc((100% - var(--gap) * 2) / 2);
    /* 50% center */
    --card-bg: #2A2A4A;
    --card-bg-center: #3A3A5E;
    --ring: rgba(255, 255, 255, .12);
}

.color-main {
    color: var(--accent) !important;
}

.flex-center {
    display: flex;
    align-items: center;
    justify-content: center;
}

/* =====================================================================================================================================================================================================[basics] */
/* sm: phones */
@media (width >=360px) {}

/* md: large phones / phablets */
@media (width >=576px) and (width < 768px) {}

/* md */
@media (width >=768px) and (width < 992px) {}

/* lg */
@media (width >=992px) and (width < 1200px) {}

/* xl-narrow */
@media (width >=1200px) and (width < 1400px) {}

/* xxl */
@media (width >=1400px) and (width < 1800px) {}

/* 3xl */
@media (width >=1800px) {}

/* ================================================================================================= */
.ok-container {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
}

@media (width <=576px) {
    .ok-container {
        max-width: calc(100% - 15px);
    }
}

@media (width >=576px) and (width < 768px) {
    .ok-container {
        max-width: calc(100% - 20px);
    }
}

@media (width >=768px) and (width < 992px) {
    .ok-container {
        max-width: calc(100% - 30px);
    }
}

@media (width >=992px) and (width < 1200px) {
    .ok-container {
        max-width: calc(100% - 40px);
    }
}

@media (width >=1200px) and (width < 1400px) {
    .ok-container {
        max-width: calc(100% - 50px);
    }
}

@media (width >=1400px) and (width < 1800px) {
    .ok-container {
        max-width: 1252px;
    }
}

@media (width >=1800px) {
    .ok-container {
        max-width: 1732px;
    }

    .col-3xl-8 {
        max-width: 1252px;
    }

}

/* ============================================================================================= */
* {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    background: var(--body-bg);
    min-height: 100vh;
    overflow-x: hidden;
}

.wrapper {
    /* min-height: inherit; */
    overflow-x: hidden;
}

/* 
.row {
    margin-left: 0;
    margin-right: 0;
} */

.generic-stroke {
    position: relative;
    /* Draw a 1px gradient stroke using a pseudo-element so we don't overwrite
       the host element's background. The pseudo-element uses masking to
       create a hollow center (so only the border is visible) and inherits the
       host border-radius so the stroke follows the same rounding. */
}

.generic-stroke::before {
    content: '';
    position: absolute;
    inset: 0;
    /* cover the host box */
    border-radius: inherit;
    /* follow the host element's radius */
    padding: 1px;
    /* thickness of the gradient stroke */
    background: var(--stroke2-bg);
    /* gradient for the border */
    background: linear-gradient(180deg, #2A2A4A 0%, #161626 100%);

    /* mask out the inner area so the background of the host remains visible */
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    pointer-events: none;
    z-index: 1;
}

@media (min-width:1800px) {
    .remove-stroke-less-3xl::before {
        display: none !important;
    }
}

@media (max-width:1800px) {
    .remove-3xl-stroke::before {
        display: none !important;
    }
}

.w-150per {
    width: 150%;
}

.section-title {
    font-family: var(--second-family);
    font-weight: 500;
    font-size: 12px;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    text-align: center;
    color: var(--subtext);
    display: inline-flex;
    border: 0.50px solid var(--subtext);
    border-radius: 200px;
    padding: 8px 24px;
    min-height: 32px;
}


.section-heading {
    font-family: var(--third-family);
    font-weight: 400;
    font-size: 42px;
    line-height: 110%;
    letter-spacing: -0.05em;
    text-align: center;
    color: var(--text);
}

.section-description {
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 21px;
    line-height: 124%;
    text-align: center;
    color: var(--subtext);
}

@media (width < 768px) {
    .section-heading {
        font-size: 32px;
    }

    .section-description {
        font-size: 16px;
    }
}

@media (width >=768px) and (width < 992px) {
    .section-heading {
        font-size: 36px;
    }

    .section-description {
        font-size: 18px;
    }
}

@media (width >=992px) and (width < 1200px) {
    .section-heading {
        font-size: 40px;
    }

    .section-description {
        font-size: 19px;
    }
}

.pl-27px {
    padding-left: 27px;
}

.px-10px {
    padding: 0 10px;
}

.py-50px {
    padding: 50px 0;
}

.my-80px {
    margin: 80px 0;
}

.my-100px {
    margin: 100px 0;
}

.mt-10px {
    margin-top: 10px;
}

.mt-16px {
    margin-top: 16px;
}

.mt-20px {
    margin-top: 20px;
}

.mt-28px {
    margin-top: 28px;
}

.mt-30px {
    margin-top: 30px;
}

.mt-36px {
    margin-top: 36px;
}

.mt-43px {
    margin-top: 43px;
}

.mt-58px {
    margin-top: 58px;
}

.mt-80px {
    margin-top: 80px;
}

.mt-100px {
    margin-top: 100px;
}

.mt-120px {
    margin-top: 120px;
}


.border-radius-20px {
    border-radius: 20px;
}

/* ================================================================================================== */
.ok-nav {
    background: var(--body-bg);
    min-height: 60px;
    margin-top: 20px;
    position: sticky;
    top: 0;
    left: 0;
    z-index: 5;

    box-shadow: inset 0 -30px 34px -9px rgba(42, 42, 74, 0.6);
    background: var(--header-bg);
    border-radius: 30px;

    padding: 8px 30px;
    position: relative;
}

.ok-nav-link {
    font-family: var(--second-family);
    font-weight: 500;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text) !important;
    margin: auto 24px;
}

.nav-item:last-of-type>.ok-nav-link {
    margin-right: 0px !important;
}

.ok-nav-link.active,
.ok-nav-link:hover {
    color: var(--main-color) !important;
}

@media (max-width:992px) {
    .ok-nav-link {
        margin-left: 10px;
    }
}

@media (min-width:992px) and (max-width:1200px) {
    .ok-nav-link {
        margin: auto 10px;
    }
}

@media (min-width:1200px) {
    .ok-nav-link {
        margin: auto 24px;
    }
}


.nav-item {
    display: flex;
    transition: all 0.6s cubic-bezier(0.34, 1.56, 0.64, 1);
    will-change: transform;
}

.nav-item:hover {
    transform: translateY(-3px);
}



.burger {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin-left: 15px;
    border: 0px;
    outline: none !important;
}

.navbar-toggler:focus,
.navbar-toggler:active {
    outline: none !important;
    box-shadow: none !important;
}

.burger .line {
    width: 25px;
    height: 3px;
    background: var(--text);
    margin-top: 5px;
}

.burger .line1 {
    margin-top: 0px;
}

.burger.close {
    -webkit-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
    -webkit-transition-delay: 0.6s;
    transition-delay: 0.6s;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    opacity: 1;

    position: absolute;
    top: 12px;
    right: 12px;
}

.burger.close .line {
    -webkit-transition-delay: 0.3s;
    transition-delay: 0.3s;
}

.burger.close .line1 {
    -webkit-transform: translateY(3px);
    transform: translateY(3px);
}

.burger.close .line2 {
    width: 0;
}

.burger.close .line3 {
    -webkit-transform: translateY(-13px) rotate(90deg);
    transform: translateY(-13px) rotate(90deg);
}

/* ==============================================================================================================[welcome banners]/ */
.main-banner {
    width: 100%;
    min-height: 350px;
    border-radius: 20px;
    display: flex;
    flex-direction: column;
    background-size: cover;
}

.main-banner-title {
    font-family: var(--third-family);
    font-weight: 400;
    font-size: 54px;
    line-height: 126%;
    letter-spacing: -0.05em;
    text-align: center;
    color: var(--text);
}

.main-banner-description {
    font-family: var(--font-family);
    font-weight: 300;
    font-size: 21px;
    line-height: 124%;
    text-align: center;
    color: var(--subtext);
}

.call2action {
    border: 1px solid #00e5b9;
    border-radius: 200px;
    padding: 16px 34px;
    height: 50px;

    box-shadow: inset 0 4px 4px 0 #3fe6d1;
    background: linear-gradient(180deg, #00e5b9 0%, #2dd5c4 100%);

    font-family: var(--second-family);
    font-weight: 600 !important;
    line-height: 1;
    font-size: 14px;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    text-align: center;
    color: var(--background) !important;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.6s cubic-bezier(0.34, 1.56, 0.64, 1) !important;
    will-change: transform;
}

.call2action.outlined {
    background: transparent;
    border-color: var(--main-color);
    color: var(--main-color) !important;
    box-shadow: none;
}

/* NewMarwan */
.know-more {
    transition: all 0.6s cubic-bezier(0.34, 1.56, 0.64, 1);
    will-change: transform;
}


/* NewMarwan */
.know-more:hover,
.know-more:focus {
    transform: translateY(-7px);
    /* box-shadow: inset 0 4px 4px 0 #3fe6d1, 0 8px 15px rgba(32, 218, 193, 0.4); */
}

.call2action:hover,
.call2action:focus {
    transform: translateY(-4px) !important;
}


@media (width < 576px) {
    .call2action {
        padding: 10px 20px;
        font-size: 12px;
        letter-spacing: 0.03em;
    }
}

@media (width >=1200px) {
    .main-banner {
        min-height: 596px;
    }
}

@media (width >=992px) and (width < 1200px) {
    .main-banner {
        min-height: 500px;
    }

    .main-banner-title {
        font-size: 48px;
    }

    .main-banner-description {
        font-size: 19px;
    }
}

@media (width >=768px) and (width < 992px) {
    .main-banner {
        min-height: 500px;
    }

    .main-banner-title {
        font-size: 42px;
    }

    .main-banner-description {
        font-size: 18px;
    }
}

@media (width < 768px) {
    .main-banner {
        min-height: 500px;
    }

    .main-banner-title {
        font-size: 36px;
    }

    .main-banner-description {
        font-size: 16px;
    }
}

/* ================================================================ */
.homepage-banner {
    background: url('../../images/new-templates-v1/imgs/webp-imgs/home-main.webp');
    background-size: cover;
    background-position: center;
}

.services-banner {
    background: url('../../images/new-templates-v1/imgs/webp-imgs/services-main.webp');
    background-size: cover;
    background-position: center;
}

.who-we-serve-banner {
    background: url('../../images/new-templates-v1/imgs/webp-imgs/who-main.webp');
    background-size: cover;
    background-position: center;
}

.about-us-banner {
    background: url('../../images/new-templates-v1/imgs/webp-imgs/about-main.webp');
    background-size: cover;
    background-position: center;
}



.contact-us-banner {
    background: url('../../images/new-templates-v1/imgs/webp-imgs/contact-main.webp');
    background-size: cover;
    background-position: center;
}


/* ============================================================================= */
/* ###############################################[Home page] */
.info-box-value {
    font-family: var(--font-family);
    font-weight: 500;
    font-size: 36px;
    line-height: 128%;
    letter-spacing: -0.05em;
    text-align: center;
    color: var(--accent);
}

.info-box-text {
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 16px;
    line-height: 137%;
    text-align: center;
    color: var(--text) !important;
}

@media (max-width:768px) {
    .info-box {
        max-width: 80%;
    }
}

/* ================================================================================================== */
.main-card {
    padding: 26px 20px;
    background: var(--active);
    border-radius: 20px;
}

.testimonial-card {
    max-height: 288px;
}

.icon-container {
    width: 58px;
    height: 58px;
    display: flex;
    align-items: start;
    justify-content: start;
}

@media (min-width:1400px) {
    .main-card.vertical-card {
        padding-right: 65px;
        padding-left: 40px;
    }
}

.main-card.vertical-card .icon-container2 {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.main-card.vertical-card .icon-container2 img {
    height: 71px;
    margin: auto;
}

.main-card.team-member .team-pp-container {
    width: 124px;
    height: 124px;
    border-radius: 50%;
    overflow: hidden;
}

.main-card.team-member .team-pp-container img {
    width: 100%;
    object-fit: cover;
}


.team-member-title {
    font-family: var(--font3);
    font-weight: 600;
    font-size: 16px;
    line-height: 150%;
    text-align: center;
    color: var(--accent);
}

.team-member-subject {
    font-weight: 400;
    color: var(--text);
}

.team-member-description {
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 12px;
    line-height: 150%;
    text-align: center;
    color: var(--subtext);
}

.icon-container img {
    max-width: 100%;
    max-height: 100%;
}

.main-card .card-title {
    font-family: var(--font-family);
    font-weight: 600;
    font-size: 16px;
    line-height: 287%;
    color: var(--text);
}

.main-card .card-title2 {
    font-family: var(--font3);
    font-weight: 500;
    font-size: 21px;
    line-height: 171%;
    color: var(--text);
}



.main-card .icon-and-title-sameline .card-title {
    font-size: 21px;
    line-height: 124%;
    color: var(--text);
}

.main-card .icon-and-title-sameline div.icon-container {
    height: 56px;
    width: auto;
    margin-right: 15px;
}



.main-card .card-title.main-color-title {
    line-height: 112%;
    color: var(--accent);
}

.main-card .card-description {
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 14px;
    line-height: 129%;
    color: var(--subtext);
}

.main-card .card-description2 {
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 16px;
    line-height: 137%;
    color: var(--subtext);
}

.main-card .card-description.type2 {
    font-size: 16px;
    line-height: 137%;
}

.main-card .know-more {
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 14px;
    font-weight: 500;
    text-decoration: underline;
    text-decoration-skip-ink: none;
    color: var(--accent);
}

.main-card .list {
    list-style-type: none;
}

.main-card .list.list-type2 {
    padding-left: 5px;
}

.main-card .list li {
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 21px;
    line-height: 152%;
    color: var(--text);
    position: relative;
    padding-left: 20px;
}

.main-card .list.list-type2 li {
    font-size: 16px;
    line-height: 187%;
}

.main-card .list li::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 0;
    width: 4px;
    height: 4px;
    background: var(--text);
    border-radius: 50%;
    transform: translateY(-50%);
}

.main-card .list.list.list-type2 li::before {
    top: 15px !important;
}

.badge-card {
    aspect-ratio: 1;
}

.badge-img {
    max-width: 80%;
    max-height: 80%;
}

@media (max-width:576px) {
    .main-card {
        padding: 20px 15px;
    }

    .main-card .card-title {
        font-size: 14px;
    }

    .main-card .card-title2 {
        font-size: 18px;
    }

    .main-card .card-description {
        font-size: 12px;
    }

    .main-card .card-description2 {
        font-size: 14px;
    }

    .main-card .card-description.type2 {
        font-size: 14px;
    }

    .main-card .know-more {
        font-size: 12px;
    }

    .main-card .list li {
        font-size: 16px;
    }


    .main-card .list.list-type2 li {
        font-size: 13px;
    }
}

@media (min-width:576px) and (max-width:768px) {
    .main-card .list li {
        font-size: 18px;
    }
}

@media (min-width:768px) and (max-width:992px) {
    .main-card .list li {
        font-size: 19px;
    }

    .main-card .card-title2 {
        font-size: 20px;
    }

    .main-card .list.list-type2 li {
        font-size: 14px;
    }

}

@media (min-width:992px) and (max-width:1200px) {
    .main-card .list li {
        font-size: 20px;
    }

    .main-card .card-title2 {
        font-size: 21px;
    }

    .main-card .list.list-type2 li {
        font-size: 14px;
    }
}

/* ========================================== */
@media (min-width:1800px) {
    .waivy-mauve-section-bg {
        background: url('../../images/new-templates-v1/imgs/homepage/waivy-mauve-3xl.svg');
        background-size: cover;
        background-repeat: no-repeat;
        border-radius: 20px;
        position: relative;
    }

    .waivy-mauve-section-bg::after {
        content: '';
        position: absolute;
        top: -1px;
        left: -1px;
        right: -1px;
        bottom: -1px;
        background: linear-gradient(180deg, #2A2A4A 0%, #161626 100%);
        z-index: -1;
        padding: 1px;
        border-radius: inherit;
        -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
        -webkit-mask-composite: xor;
        mask-composite: exclude;
    }

}

@media (max-width:1200px) {
    .waivy-mauve-section-bg {
        background: url('../../images/new-templates-v1/imgs/homepage/waivy-mauve.svg');
        background-size: cover;
        background-repeat: no-repeat;
        border-radius: 20px;
        position: relative;
    }

    .waivy-mauve-section-bg::after {
        content: '';
        position: absolute;
        top: -1px;
        left: -1px;
        right: -1px;
        bottom: -1px;
        background: linear-gradient(180deg, #2A2A4A 0%, #161626 100%);
        z-index: -1;
        padding: 1px;
        border-radius: inherit;
        -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
        -webkit-mask-composite: xor;
        mask-composite: exclude;
    }
}

.waivy-bg-at-1440screen {
    display: none;
}

@media (min-width:1200px) and (max-width:1800px) {
    .waivy-bg-at-1440screen {
        display: block;
        position: absolute;
        top: -50px;
        left: 50%;
        width: calc(100% - 134px);
        height: calc(100% + 100px);
        max-width: 1440px;
        transform: translateX(-50%);
        background: url('../../images/new-templates-v1/imgs/homepage/waivy-mauve.svg');
        background-size: cover;
        background-repeat: no-repeat;
        border-radius: 20px;
        z-index: -1;
    }

}

.waivy-main-color-section-bg {
    background: url('../../images/new-templates-v1/imgs/homepage/waivy-maincolor.svg');
    background-size: cover;
    background-repeat: no-repeat;
    border-radius: 20px;
    position: relative;
}

@media (min-width:1800px) {
    .waivy-main-color-section-bg {
        background: url('../../images/new-templates-v1/imgs/homepage/waivy-maincolor-3xl.svg');
    }
}

.section-with-bg-dark {
    background: rgba(28, 28, 50, 0.4);
}

@media (min-width:1800px) {
    .section-with-bg-dark-3xlscreen {
        background: rgba(28, 28, 50, 0.4);
    }

}

@media (max-width:1800px) {
    .section-with-bg-dark-1440-1800screen {
        background: rgba(28, 28, 50, 0.4);
    }

}

.logos-swiper {
    /* padding: 8px 40px; */
    overflow: hidden;
    width: 100%;
}

.logos-swiper .swiper-slide {
    background: var(--active);
    border-radius: 20px;
    opacity: 0.4;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    min-height: 140px;
}

.logos-swiper .swiper-slide img {
    /* mix-blend-mode: multiply; */
    /* or try overlay, screen, soft-light, etc. */
    max-width: 100px;
    max-height: 60px;
    margin: auto;
}


.swiper-button-lock {
    display: inline-flex;
}

/* highlight central slide(s) */
.logos-swiper .swiper-slide.extra-active {
    transition: transform .25s ease, outline-color .25s ease, opacity .25s ease;
    opacity: 1;
}

.swiper-button-prev,
.swiper-button-next {
    width: 23px;
    height: 23px;
    border: 1px solid var(--subtext);
    border-radius: 50%;
    display: flex;
    top: calc(50% + 8px);
}

.swiper-button-prev i,
.swiper-button-next i {
    color: var(--subtext);
    font-size: 12px;
    margin: auto;
}


/* remove default btns for swipper */
.swiper-button-next:after,
.swiper-button-prev:after {
    display: none;
}

.swiper-button-prev {
    left: -48px;
}

.swiper-button-next {
    right: -48px;
}

@media (max-width:992px) {

    .swiper-button-prev,
    .swiper-button-next {
        display: none;
    }
}

/* XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX */
/* Updated testimonial slider with working width overrides */
.testi-swiper {
    overflow: hidden;
    /* padding: 20px 0; */
}

.testi-swiper .swiper-wrapper {
    display: flex;
    align-items: center;
}

/* Override Swiper's inline styles with more specific selectors */
.testi-swiper .swiper-slide {
    width: 20% !important;
    transition: all 0.3s ease;
    opacity: 0.6;
    flex-shrink: 0;
}

.testi-swiper .swiper-slide-active,
.testi-swiper .swiper-slide-active[style] {
    width: 60% !important;
    opacity: 1;
}

.testi-card {
    background: #2A2A4A;
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 16px;
    padding: 32px 24px;
    height: 200px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 16px;
    color: var(--text);
    transition: all 0.3s ease;
    margin: 0 12px;
}

.testi-swiper .swiper-slide-active .testi-card {
    background: #3A3A5E;
    border-color: rgba(32, 218, 193, 0.3);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
}

/* Navigation buttons */
.testi-prev,
.testi-next {
    width: 40px;
    height: 40px;
    background: var(--active);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 50%;
    color: var(--text);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    transition: all 0.3s ease;
}

.testi-prev:hover,
.testi-next:hover {
    background: var(--main-color);
    color: var(--background);
}

/* .testi-prev {
    left: -60px;
}

.testi-next {
    right: -60px;
} */

.testi-prev::after,
.testi-next::after {
    content: '';
    width: 12px;
    height: 12px;
    border: solid currentColor;
    border-width: 0 2px 2px 0;
    display: inline-block;
}

.testi-prev::after {
    transform: rotate(135deg);
    margin-left: 2px;
}

.testi-next::after {
    transform: rotate(-45deg);
    margin-right: 2px;
}

/* Mobile adjustments */
@media (max-width: 767.98px) {
    .testi-swiper .swiper-slide {
        width: 25% !important;
    }

    .testi-swiper .swiper-slide-active,
    .testi-swiper .swiper-slide-active[style] {
        width: 75% !important;
    }

    .testi-card {
        height: 180px;
        padding: 24px 16px;
        font-size: 14px;
        margin: 0 8px;
    }
}

@media (max-width: 576px) {
    .testi-swiper .swiper-slide {
        width: 30% !important;
    }

    .testi-swiper .swiper-slide-active,
    .testi-swiper .swiper-slide-active[style] {
        width: 80% !important;
    }

    .testi-card {
        height: 160px;
        padding: 20px 12px;
        font-size: 13px;
        margin: 0 6px;
    }

    .testi-prev,
    .testi-next {
        display: none;
    }
}

/* ===============================================[footer banner] */
.footer-banner {
    width: 100%;
    min-height: 342px;
    border-radius: 20px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    background-size: cover;
    background-repeat: no-repeat;
}

.footer-banner-title {
    font-family: var(--third-family);
    font-weight: 500;
    font-size: 36px;
    line-height: 128%;
    letter-spacing: -0.05em;
    color: var(--text);
}

.footer-banner-description {
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 21px;
    line-height: 124%;
    color: var(--subtext);
}


@media (width >=992px) and (width < 1200px) {
    .footer-banner-title {
        font-size: 32px;
    }

    .footer-banner-description {
        font-size: 19px;
    }
}

@media (width >=768px) and (width < 992px) {
    .footer-banner-title {
        font-size: 28px;
    }

    .footer-banner-description {
        font-size: 18px;
    }
}

@media (width < 768px) {
    .footer-banner-title {
        font-size: 24px;
    }

    .footer-banner-description {
        font-size: 16px;
    }
}

.homepage-footer-banner {
    background: url('../../images/new-templates-v1/imgs/webp-imgs/home-cta.webp');
    background-size: cover;
    background-position: center;
}

.services-footer-banner {
    background: url('../../images/new-templates-v1/imgs/webp-imgs/services-cta.webp');
    background-size: cover;
    background-position: center;
}

.who-we-service-footer-banner {
    background: url('../../images/new-templates-v1/imgs/webp-imgs/who-cta.webp');
    background-size: cover;
    background-position: center;
}

.about-us-footer-banner {
    background: url('../../images/new-templates-v1/imgs/webp-imgs/about-cta.webp');
    background-size: cover;
    background-position: center;
}

@media (width >=1400px) and (width < 1800px) {
    .pl-3xl-147px {
        padding-left: 107px !important;
    }
}

@media (width >=1800px) {


    .services-footer-banner {
        background: url('../../images/new-templates-v1/imgs/services/footer-banner-3xl.svg');
    }

    .who-we-service-footer-banner {
        background: url('../../images/new-templates-v1/imgs/who-we-serve/footer-banner-3xl.svg');
    }

    .pl-3xl-147px {
        padding-left: 147px !important;
    }
}

/* ===========================================================================[footer] */
.ok-footer {
    border-radius: 30px 30px 0px 0px;
    box-shadow: inset 0 20px 44px -9px rgba(42, 42, 74, 0.6);
    background: var(--header-bg);
}

@media (width>=1800px) {
    .footer-content-3xl {
        width: 100%;
        padding: 0px 87px;
    }
}

.footer-logo {
    max-width: 120px;
}

.footer-description {
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 12px;
    line-height: 150%;
    color: var(--subtext);
    max-width: 308px;
}

.footer-links-group {
    gap: 16px;
}

.footer-link {
    font-family: var(--second-family);
    font-weight: 500;
    font-size: 12px;
    letter-spacing: 0.05em;
    color: var(--text);
    text-transform: uppercase;
    text-decoration: none;
}

.copyrights {
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 8px;
    line-height: 225%;
    color: var(--subtext);
}

.footer-y-padding {
    padding-top: 17px;
    padding-bottom: 34px;
}


/* #####################################################################################[Services page] */
.services-overview-img-container img {
    max-width: 100%;
}

.services-overview-title {
    font-family: var(--third-family);
    font-weight: 400;
    font-size: 36px;
    line-height: 128%;
    letter-spacing: -0.05em;
    color: var(--text);
}

.services-overview-description {
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 21px;
    line-height: 124%;
    color: var(--subtext);
}

@media (width >=992px) and (width < 1200px) {
    .services-overview-title {
        font-size: 32px;
    }

    .services-overview-description {
        font-size: 19px;
    }
}

@media (width >=768px) and (width < 992px) {
    .services-overview-title {
        font-size: 28px;
    }

    .services-overview-description {
        font-size: 18px;
    }
}

@media (width < 768px) {
    .services-overview-title {
        font-size: 24px;
    }

    .services-overview-description {
        font-size: 16px;
    }
}


.filters__tabs {
    display: flex;
    flex-wrap: nowrap;
    gap: 8px;
    overflow-x: auto;
    overflow-y: hidden;
    white-space: nowrap;
    border-bottom: 1px solid var(--subtext);
    scrollbar-width: none;
    -ms-overflow-style: none;
    max-width: fit-content;
}

.filters__tabs::-webkit-scrollbar {
    display: none;
}

.filters__tabs .nav-link.active {
    background-color: transparent;
}


.filters__tabs .filter-item {
    flex: 0 0 auto;
    white-space: nowrap;
    font-family: var(--second-family);
    font-weight: 400;
    font-size: 12px;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    text-align: center;
    color: var(--subtext);
    position: relative;
    cursor: pointer;
    text-decoration: none !important;
    text-transform: uppercase;
    display: inline-flex;
    padding: 8px 24px 9px 24px;
    position: relative;
    border: none;
}

.filters__tabs .filter-item:hover,
.filters__tabs .filter-item.active {
    color: var(--accent);
    font-weight: 600;
}

.filters__tabs .filter-item.active::after {
    content: "";
    width: 100%;
    height: 6px;
    background: var(--accent) !important;
    position: absolute;
    bottom: -2px;
    left: 0;
}

/* optional: slim scrollbar */
.filters__tabs::-webkit-scrollbar {
    height: 6px;
}

.filters__tabs::-webkit-scrollbar-thumb {
    background: var(--border-main-color4);
    border-radius: 6px;
}

.tab-free-text {
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 21px;
    line-height: 124%;
    text-align: center;
    color: var(--text);
}

@media (width >=992px) and (width < 1200px) {
    .tab-free-text {
        font-size: 19px;
    }
}

@media (width >=768px) and (width < 992px) {
    .tab-free-text {
        font-size: 18px;
    }
}

@media (width < 768px) {
    .tab-free-text {
        font-size: 16px;
    }
}

.custom-tab-content {
    margin-top: 48px;
    margin-bottom: 127px;
}

.section-with-after-highlight {
    background-repeat: no-repeat;
}

.section-with-after-highlight.left-main {
    background-image: url('../../images/new-templates-v1/imgs/left-green-after.svg');
    background-position: bottom left;
}

.section-with-after-highlight.righ-mauve {
    background-image: url('../../images/new-templates-v1/imgs/right-mauve-after.svg');
    background-position: bottom right;
}

@media (min-width:1200px) {
    .stepper-vertical {
        justify-content: space-between;
    }
}


.stepper-step-item {
    width: 192px;
    max-width: 100%;
}

@media (min-width:992px) and (max-width:1200px) {
    .stepper-step-item-container {
        width: 33%;
        display: inline-flex;
        justify-content: center;
        margin-top: 20px;
    }
}

@media (min-width:500px) and (max-width:992px) {
    .stepper-step-item-container {
        width: 50%;
        display: inline-flex;
        justify-content: center;
        margin-top: 20px;
    }
}

@media (max-width:500px) {
    .stepper-step-item-container {
        width: 100%;
        display: inline-flex;
        justify-content: center;
        margin-top: 20px;
    }
}



.stepper-step-item .img-container {
    height: 54px;
}

.stepper-step-item .title {
    font-family: var(--font-family);
    font-weight: 600;
    font-size: 21px;
    line-height: 219%;
    text-align: center;
    color: var(--text);
}

.stepper-step-item .description {
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 12px;
    line-height: 150%;
    text-align: center;
    color: var(--text);
}

.stepper-step-item .bullet {
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: var(--card-bg);
    box-shadow: inset 0 4px 10px -6px var(--accent);
    margin: 21px auto;
}

@media (max-width:1200px) {
    .stepper-step-item .bullet {
        display: none !important;
    }

    .stepper-step-item-container {
        margin-top: 50px !important;
    }
}

.stepper-vertical::after {
    content: '';
    position: absolute;
    width: 0;
    height: 1px;
    background: var(--card-bg);
    left: 104px;
    top: 131px;
    z-index: -1;
    opacity: 0;
}

@keyframes drawLineLeft {
    0% {
        width: 0;
        opacity: 1;
    }

    30% {
        width: 20%;
        opacity: 1;
    }

    70% {
        width: 80%;
        opacity: 1;
    }

    100% {
        width: calc(100% - 200px);
        opacity: 1;
    }
}

.stepper-vertical.animate-stepper::after {
    animation: drawLineLeft 1.1s ease-in-out forwards;
}

@media (max-width:1200px) {
    .stepper-vertical::after {
        display: none;
    }
}

@media (min-width:1400px) {
    .custom-targret-market-stepper-wrapper {
        padding-right: 60px;
    }

}

.target-market-step {
    min-height: 48px;
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 14px;
    line-height: 143%;
    color: var(--text);

    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    box-shadow: 0 4px 20px 0 rgba(28, 28, 50, 0.4);
    border-radius: 35px;
    background: linear-gradient(180deg, #141424 0%, #1c1c32 20.67%, #2a2a4a 100%);
}

.target-market-stepper-wrapper {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 25px;
    padding-left: 40px;
}

.target-market-stepper-wrapper::before {
    content: '';
    position: absolute;
    left: 14px;
    top: 20px;
    bottom: 0;
    width: 1px;
    height: calc(100% - 40px);
    background: var(--active);
}

.target-market-step::after {
    content: '';
    position: absolute;
    left: -35px;
    top: 14px;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: linear-gradient(180deg, #0afacb 0%, #0ccba9 7%, #0ea08a 14%, #107b6f 22%, #125b58 31%, #134245 40%, #142e37 50%, #15202d 61%, #151827 75%, #2a2a4a 100%);
}

.company-story-stepper {
    padding-left: 65px;
    position: relative;
    gap: 36px;
}

.company-story-stepper::after {
    content: '';
    width: 1px;
    /* dynamic height — JS will set --company-stepper-line-height on the container */
    height: var(--company-stepper-line-height, calc(100% - 56px));
    background: var(--accent);
    position: absolute;
    top: 0;
    left: 0px;
    z-index: 1;
}

.fw-300 {
    font-weight: 300 !important;
}

.fw-500 {
    font-weight: 500 !important;
}


.fw-600 {
    font-weight: 600 !important;
}


.company-story-step {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.7s cubic-bezier(0.34, 1.56, 0.64, 1), transform 0.7s cubic-bezier(0.34, 1.56, 0.64, 1);
    position: relative;
}

.company-story-step.visible {
    opacity: 1;
    transform: translateY(0);
}


.company-story-step::before {
    content: '';
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: var(--accent);
    position: absolute;
    left: -75px;
    top: 4px;
    z-index: 2;
}

.company-story-step b {
    font-weight: 600;
}

@media (max-width:768px) {
    .company-story-stepper {
        padding-left: 40px;
    }

    .company-story-stepper::after {
        left: 10px;
    }

    .company-story-step::before {
        width: 14px;
        height: 14px;
        left: -36px;
    }

    .company-story-step:last-child:after {
        left: -36px;
        top: 18px;
    }
}

.our-mission-vision-whole-card {
    border-radius: 20px;
    background: linear-gradient(180deg, #1c1c32 0%, #141424 100%);
}

.custom-vision-margin {
    margin-top: 36px;
}

@media (min-width:768px) {
    .custom-vision-margin {
        margin-top: -15px;
    }
}

/* =================================================== */

.ok-testimonial-slider {
    width: 100%;
    margin: 0 auto;
    position: relative;
}

.ok-testimonial-viewport {
    overflow: hidden;
    position: relative;
}

.ok-testimonial-track {
    display: flex;
    gap: var(--ok-testimonial-gap);
    align-items: stretch;
}

.ok-testimonial-slide {
    display: none;
    /* only the ones we mark are visible */
    flex: 0 0 auto;
    /* border-radius: var(--ok-testimonial-radius);
    box-shadow: var(--ok-testimonial-shadow); */
    user-select: none;
    transform-origin: center center;
    transition: flex-basis .35s ease, transform .35s ease, opacity .25s ease;
    overflow: hidden;
}


/* Visible states (JS toggles these) */
.ok-testimonial-slide.ok-testimonial-is-active {
    display: block;
    opacity: 1;
}

.ok-testimonial-slide.ok-testimonial-is-prev,
.ok-testimonial-slide.ok-testimonial-is-next {
    opacity: .4 !important;
}

.ok-testimonial-slide.ok-testimonial-is-prev .testimonial-custom,
.ok-testimonial-slide.ok-testimonial-is-next .testimonial-custom {
    display: -webkit-box;
    -webkit-line-clamp: 8;
    /* number of lines */
    -webkit-box-orient: vertical;
    overflow: hidden;
}


/* WIDE mode: >1400px → 3-up, 25/50/25  */
@media (min-width: 1401px) {

    .ok-testimonial-slide.ok-testimonial-is-prev,
    .ok-testimonial-slide.ok-testimonial-is-next {
        flex-basis: 25%;
        transform: scaleX(.96);
        opacity: .9;
    }

    .ok-testimonial-slide.ok-testimonial-is-active {
        flex-basis: 50%;
        transform: scale(1);
    }

    /* Single-card wide case: center it at 50% */
    .ok-testimonial-slider.ok-testimonial--only-one .ok-testimonial-track {
        justify-content: center;
    }

    .ok-testimonial-slider.ok-testimonial--only-one .ok-testimonial-slide.ok-testimonial-is-active {
        display: block;
        flex-basis: 50%;
    }
}

/* NARROW mode: ≤1400px → 1-up, active = 100% */
@media (max-width: 1400px) {
    .ok-testimonial-slide.ok-testimonial-is-active {
        display: block;
        flex-basis: 100%;
        transform: none;
        opacity: 1;
    }

    .ok-testimonial-slide.ok-testimonial-is-prev,
    .ok-testimonial-slide.ok-testimonial-is-next {
        display: none !important;
    }
}

/* Controls */
.ok-testimonial-controls {
    display: flex;
    gap: 12px;
    justify-content: center;
    align-items: center;
    margin-top: 14px;
}

.ok-testimonial-btn {
    appearance: none;
    border: 1px solid #d0d4e4;
    background: white;
    padding: 10px 14px;
    border-radius: 10px;
    font-weight: 600;
    cursor: pointer;
    transition: transform .08s ease, background .2s;
}

.ok-testimonial-btn:active {
    transform: translateY(1px);
}

.ok-testimonial-status {
    font-size: 14px;
    color: #5b6275;
}

/* Autoplay indicator */
.ok-testimonial-autoplay {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 12px;
    justify-content: center;
}

.ok-testimonial-autoplay-btn {
    background: none;
    border: none;
    cursor: pointer;
    font-size: 18px;
    color: #5b6275;
    transition: color 0.2s;
}

.ok-testimonial-autoplay-btn:hover {
    color: #111;
}

/* Style ok-testimonial-controls to match testi-prev/testi-next design */
.ok-testimonial-controls {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 24px;
    margin-top: 24px;
}

/* Parent must be positioned so absolute buttons sit relative to the slider */
.ok-testimonial-slider {
    position: relative;
}

.ok-testimonial-btn {
    width: 40px;
    height: 40px;
    background: var(--active);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 50%;
    color: var(--text);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.3s ease;
    font-size: 0;
    padding: 0;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 30;
}


.ok-testimonial-btn:hover {
    background: var(--main-color);
    color: var(--background);
}

.ok-testimonial-btn::after {
    content: '';
    width: 12px;
    height: 12px;
    border: solid currentColor;
    border-width: 0 2px 2px 0;
    display: inline-block;
}

#okTestimonialPrev::after {
    transform: rotate(135deg);
    margin-left: 2px;
}

#okTestimonialNext::after {
    transform: rotate(-45deg);
    margin-right: 2px;
}

.ok-testimonial-status {
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 14px;
    color: var(--subtext);
    min-width: 120px;
    text-align: center;
}

/* =================================================== */

/* =============================================================================Blog Page */
.main-banner-heading {
    font-weight: var(--semi-bold);
    color: var(--main-color);
    font-family: var(--ibm);
    text-align: center;
}


.blog-card.link:hover {
    text-decoration: none !important;
}

.blog-img-container {
    position: relative;
    width: 100%;
    overflow: hidden;
    border: 1px solid var(--border-blur-white);
}

.blog-card .blog-img-container {
    aspect-ratio: 340 / 226;
    border-radius: 8px;
}

.blog-img-container-full-blog {
    border-radius: 20px;
}

@media (max-width:1400px) {
    .blog-img-container-full-blog {
        aspect-ratio: 1100 / 548;
        border-radius: 10px;
        background: none;
    }

    .blog-img-container-full-blog .img {
        object-fit: cover;
        width: 100%;

    }
}

@media (min-width:1400px) {
    .blog-img-container-full-blog {
        background-size: cover;
        background-repeat: no-repeat;
        height: 584px;
    }

    .blog-img-container-full-blog .img {
        object-fit: fill;
    }

    .blog-img-container-full-blog .img {
        display: none;
    }
}


.blog-card .blog-img-container img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
    transition-duration: 0.5s;
}

.blog-card .blog-img-container:hover img {
    transform: scale(1.2);
}

.blog-card .auther-date,
.blog-card .blog-description,
.full-blog .auther-date {
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 12px;
    line-height: 133%;
    color: var(--subtext);
}


.full-blog .blog-description * {
    margin-bottom: 0;
}


.full-blog .blog-description p {
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 21px;
    line-height: 152%;
    color: var(--text);
}

/* Blog description headings */
.full-blog .blog-description h1,
.full-blog .blog-description h2,
.full-blog .blog-description h3,
.full-blog .blog-description h4,
.full-blog .blog-description h5,
.full-blog .blog-description h6 {
    font-family: var(--font-family);
    color: var(--text);
    line-height: 1.4;
    font-weight: 600;
}

.full-blog .blog-description h1 {
    font-size: 36px;
}

.full-blog .blog-description h2 {
    font-size: 32px;
}

.full-blog .blog-description h3 {
    font-size: 28px;
}

.full-blog .blog-description h4 {
    font-size: 24px;
}

.full-blog .blog-description h5 {
    font-size: 21px;
}

.full-blog .blog-description h6 {
    font-size: 18px;
}

.full-blog .blog-description ul li {
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 18px;
    line-height: 1.6;
    color: var(--text);
}

/* Blog description links */
.full-blog .blog-description a {
    color: var(--accent);
    text-decoration: none;
    font-weight: 500;
    transition: opacity 0.3s ease;
}

.full-blog .blog-description a:hover {
    opacity: 0.8;
    text-decoration: underline;
}

/* Blog description images */
.full-blog .blog-description img {
    max-width: 100%;
    height: auto;
    display: block;
    margin: 28px auto;
    border-radius: 8px;
}

.full-blog .blog-description b {
    font-weight: 600;
}

/* Responsive: Tablet (768px - 991px) */
@media (max-width: 991px) {
    .full-blog .blog-description p {
        font-size: 18px;
        line-height: 1.5;
    }

    .full-blog .blog-description h1 {
        font-size: 28px;
        margin-top: 24px;
        margin-bottom: 14px;
    }

    .full-blog .blog-description h2 {
        font-size: 26px;
    }

    .full-blog .blog-description h3 {
        font-size: 24px;
    }

    .full-blog .blog-description h4 {
        font-size: 22px;
    }

    .full-blog .blog-description h5 {
        font-size: 19px;
    }

    .full-blog .blog-description h6 {
        font-size: 16px;
    }

    .full-blog .blog-description ul {
        padding-left: 20px;
        margin-bottom: 16px;
    }

    .full-blog .blog-description ul li {
        font-size: 16px;
        line-height: 1.5;
        margin-bottom: 10px;
    }

    .full-blog .blog-description img {
        margin: 20px auto;
        border-radius: 6px;
    }
}

/* Responsive: Mobile (< 768px) */
@media (max-width: 767px) {
    .full-blog .blog-description p {
        font-size: 16px;
        line-height: 1.5;
    }

    .full-blog .blog-description h1 {
        font-size: 24px;
        margin-top: 20px;
        margin-bottom: 12px;
    }

    .full-blog .blog-description h2 {
        font-size: 22px;
    }

    .full-blog .blog-description h3 {
        font-size: 20px;
    }

    .full-blog .blog-description h4 {
        font-size: 18px;
    }

    .full-blog .blog-description h5 {
        font-size: 17px;
    }

    .full-blog .blog-description h6 {
        font-size: 15px;
    }

    .full-blog .blog-description ul {
        padding-left: 16px;
        margin-bottom: 14px;
    }

    .full-blog .blog-description ul li {
        font-size: 15px;
        line-height: 1.5;
        margin-bottom: 8px;
    }

    .full-blog .blog-description img {
        margin: 16px auto;
        border-radius: 4px;
    }
}

@media (min-width:992px) and (max-width:1200px) {
    .full-blog .blog-description p {
        font-size: 16px;
    }
}

@media (min-width:425px) and (max-width:992px) {
    .full-blog .blog-description p {
        font-size: 15px;
    }
}

@media (max-width:425px) {
    .blog-card .blog-title {
        font-size: 14px;
    }
}


.full-blog .auther-date {
    font-size: 16px;
    line-height: 225%;
}


.full-blog .blog-title {
    font-family: var(--third-family);
    font-weight: 500;
    font-size: 54px;
    line-height: 126%;
    letter-spacing: -0.05em;
    color: var(--accent);
}

@media (min-width:1200px) and (max-width:1400px) {
    .full-blog .blog-title {
        font-size: 40px;
    }
}

@media (min-width:992px) and (max-width:1200px) {
    .full-blog .blog-title {
        font-size: 30px;
    }
}

@media (min-width:768px) and (max-width:992px) {
    .full-blog .blog-title {
        font-size: 25px;
    }
}

@media (min-width:425px) and (max-width:768px) {
    .full-blog .blog-title {
        font-size: 20px;
    }
}

.blog-card .blog-title {
    font-family: var(--font3);
    font-weight: 600;
    font-size: 21px;
    line-height: 171%;
    color: var(--accent);
}

@media (max-width:425px) {
    .blog-card .blog-title {
        font-size: 16px;
    }
}

@media (min-width:992px) and (max-width:1200px) {
    .blog-card .blog-title {
        font-size: 20px;
    }
}

@media (min-width:768px) and (max-width:992px) {
    .blog-card .blog-title {
        font-size: 18px;
    }
}

@media (min-width:768px) and (max-width:992px) {
    .blog-card .blog-title {
        font-size: 16px;
    }
}

.blog-categories .category-tag {
    font-family: var(--second-family);
    font-weight: 500;
    font-size: 8px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    text-align: center;
    color: var(--subtext);

    display: inline-flex;
    padding: 3px 8px;
    border: 0.50px solid var(--subtext);
    border-radius: 15px;
}

.full-blog .blog-categories .category-tag {
    font-size: 10px;
}

.pagination {
    gap: 8px;
}

.page-item {
    width: 30px !important;
    height: 30px !important;
    border-radius: 50%;
    border: .5px solid var(--subtext);
    display: flex;
    align-items: center;
    justify-content: center;
}

.page-item .page-link {
    padding: 0 !important;
    background: none !important;
    border: none;

    font-family: var(--font4);
    font-weight: 700;
    font-size: 10px;
    text-align: center;
    color: var(--subtext);

    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: auto;
}

.page-item .page-link:not(.arrow) {
    margin-right: -2px;
}

.page-item:not(:first-child) .page-link {
    margin: auto;

}

.page-item.active {
    background: var(--main-color) !important;
    border-color: var(--main-color) !important;
}

.page-item.active .page-link {
    color: var(--semi-black);
}

.blogsSwipper-wrapper {
    position: relative;
}

.blogsSwipper-wrapper .swiper-button-next,
.blogsSwipper-wrapper .swiper-button-prev {
    position: absolute;
    top: 37%;
    transform: translateY(-50%);
    color: var(--main-color);
}


.blogsSwipper-wrapper .swiper-button-next::after,
.blogsSwipper-wrapper .swiper-button-prev::after {
    font-size: 18px;
}

.blogsSwipper-wrapper .swiper-button-next,
.blogsSwipper-wrapper .swiper-button-prev {
    display: none;
}

@media (min-width:1200px) {
    .main-banner-heading {
        font-size: 39px;
    }

    .blogsSwipper-wrapper .swiper-button-next,
    .blogsSwipper-wrapper .swiper-button-prev {
        display: block;
    }

    .blogsSwipper-wrapper .swiper-button-next {
        right: -40px;
    }

    .blogsSwipper-wrapper .swiper-button-prev {
        left: -40px;
    }

}

@media (min-width:992px) and (max-width:1200px) {
    .main-banner-heading {
        font-size: 35px;
    }

    .blog-card .blog-title {
        font-size: 18px;
    }

    .full-blog .blog-title {
        font-size: 32px;
    }

    .full-blog .blog-description p {
        font-size: 16px;
    }
}

@media (min-width:768px) and (max-width:992px) {
    .main-banner-heading {
        font-size: 28px;
    }

    .filters__tabs .filter-item {
        font-size: 12px;
        padding: 18px 20px;
    }

    .blog-card .blog-title {
        font-size: 16px;
    }

    .full-blog .blog-title {
        font-size: 25px;
    }

    .full-blog .blog-description {
        font-size: 14px;
    }
}

@media (min-width:425px) and (max-width:768px) {
    .main-banner-heading {
        font-size: 22px;
    }

    .filters__tabs .filter-item {
        font-size: 10px;
        padding: 15px;
    }

    .blog-card .auther-date,
    .blog-card .blog-description {
        font-size: 10px;
    }

    .blog-card .blog-title {
        font-size: 14px;
    }

    .full-blog .blog-title {
        font-size: 20px;
    }

    .full-blog .blog-description p {
        font-size: 12px;
    }
}

@media (max-width:425px) {
    .main-banner-heading {
        font-size: 18px;
    }

    .blog-card .auther-date,
    .blog-card .blog-description,
    .full-blog .blog-description p {
        font-size: 10px;
    }

    .blog-card .blog-title {
        font-size: 14px;
    }

    .full-blog .blog-title {
        font-size: 18px;
    }
}

/* =====================================================================================[contact us] */
.contact-form-card {
    border-radius: 10px;
}

@media (min-width: 992px) {
    .contact-form-card {
        padding: 81px 53px;
    }
}

.contact-field-group .form-label {
    font-family: var(--font-family);
    font-weight: 500;
    font-size: 16px;
    line-height: 137%;
    color: var(--text);
    display: inline-flex;
    position: relative;
    margin-bottom: 0;
}

.contact-field-group .form-label.required::after {
    content: '*';
    color: var(--danger);
    position: absolute;
    top: -1px;
    right: -10px;
}

.contact-field-group .form-control,
.contact-field-group .form-select {
    border: none;
    box-shadow: none;
    outline: none;
    background: transparent;
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 16px;
    line-height: 137%;
    color: var(--text);
    border-bottom: 1px solid var(--subtext);
    border-radius: 0;
    padding-left: 0;
    margin-bottom: 0;
}

.contact-field-group .form-select {
    position: relative;
    padding-right: 20px;
}

.select-arrow {
    position: relative;
}

.select-arrow::after {
    content: "\f078";
    /* Font Awesome down arrow */
    font-family: "Font Awesome 7 Free";
    font-weight: 600;
    position: absolute;
    bottom: 2px;
    right: 13px;
    transform: translateY(-50%);
    pointer-events: none;
    color: rgba(255, 255, 255, 0.4);
    font-size: 10px;
}

.select-arrow:has(.form-select option:checked:not([value=""]))::after {
    color: var(--text);
}


.contact-field-group .form-control::placeholder,
.contact-field-group .form-select {
    color: rgba(255, 255, 255, 0.4);
}

.contact-field-group .form-select:has(option:checked:not([value=""])) {
    color: var(--text);
}

/* Dark dropdown panel (Chrome/Edge/Safari) */
.contact-field-group .form-select option {
    background-color: var(--body-bg) !important;
    /* dark theme options */
    color: #fff;
    cursor: pointer;
    padding: 5px 10px;
    display: inline-block;
    /* text in list */
}

/* Improve for Firefox */
.contact-field-group .form-select {
    background-color: transparent;
    cursor: pointer;
}

.contact-field-group .text-area {
    min-height: 150px;
    width: 100%;
}

.contact-field-group .form-select:focus option {
    background-color: var(--card-bg);
    cursor: pointer !important;
}

.contact-field-group .textarea-wrapper {
    position: relative;
}

.contact-field-group .textarea-wrapper .placeholder {
    position: absolute;
    bottom: 10px;
    left: 10px;
    color: rgba(255, 255, 255, 0.4);
    background: transparent;
    pointer-events: none;
    transition: 0.2s ease;
    font-size: 16px;
}

/* Hide placeholder when user types or focuses */
.contact-field-group .textarea-wrapper textarea:focus+.placeholder,
.contact-field-group .textarea-wrapper textarea:not(:placeholder-shown)+.placeholder {
    opacity: 0;
    /* instead of background:red */
    /* or transform, etc. if you want animation */
}

.contact-fields-hint {
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 14px;
    line-height: 157%;
    color: var(--subtext);
}

.contact-info-items {
    gap: 32px;
    margin-top: 45px;
}

.contact-info-item {
    gap: 16px;
}

.contact-info-item-img {
    width: 27px;
    margin-bottom: auto;
    margin-top: 10px;
}

.contact-us-info-col {
    gap: 30px;
}

@media screen and (min-width:1200px) {
    .contact-us-info-col {
        padding-top: 81px;
        gap: 60px;
    }
}



.like-hr {
    width: 100%;
    height: 1px;
    background: var(--active);
}

/* Accordion: transparent background and right-centered circular toggle */
.accordion {
    background: transparent;
    border: none;
}

.accordion .accordion-item {
    background: transparent;
    border: none;
    position: relative;
    /* anchor pseudo toggle */
    overflow: visible;
    /* leave room for the circular toggle */
    padding: 7px 55px 7px 36px;

}

.accordion .accordion-button {
    background: transparent;
    border: none;
    box-shadow: none;
    padding-right: 0;
    /* handled by item padding */
    text-align: left;
}

/* hide the default bootstrap chevron so we can draw our small circular control */
.accordion .accordion-button::after {
    display: none;
}

/* circle background (23x23) positioned at the right, vertically centered relative to the whole item */
/* .accordion .accordion-item::after {
    content: '';
    position: absolute;
    top: 50%;
    right: 12px;
    transform: translateY(-50%);
    width: 23px;
    height: 23px;
    border-radius: 50%;
    background: var(--active);
    border: 1px solid rgba(255,255,255,0.06);
    z-index: 2;
    pointer-events: none; /* let clicks pass to underlying button */
/* } */


/* make collapse body transparent as well */
.accordion .accordion-collapse,
.accordion .accordion-body {
    background: transparent;
    border: none;
}

/* when the item is open, rotate the chevron to indicate state */
/* Clear previous empty/no-op rules and provide final accordion styling and
   the small circular control drawn on the header button itself so we can
   react to the `.collapsed` state (down arrow) and open state (up arrow). */

.accordion {
    background: transparent;
    border: none;
}

.accordion .accordion-item {
    background: transparent;
    border: none;
    border-bottom: 1px solid var(--active);
    position: relative;
    overflow: visible;
}

.accordion .accordion-button {
    background: transparent;
    border: none;
    box-shadow: none;
    padding-right: 56px;
    /* room for the circular control */
    text-align: left;
    position: relative;
    /* anchor pseudo-elements */
    font-family: var(--font-family);
    font-weight: 600;
    font-size: 16px;
    line-height: 287%;
    color: var(--text);
}

/* Remove default bootstrap chevron */
/* remove old pseudo-controls on .accordion-button */
.accordion .accordion-button::after,
.accordion .accordion-button::before {
    display: none !important;
}

/* New toggle button (centered horizontally above the whole .accordion-item)
   Use the same visual style as `.swiper-button-prev/.swiper-button-next`. */
.accordion-item {
    position: relative;
}

/* .accordion .accordion-header-inner {
    padding: 12px 16px;
} */

.accordion .accordion-title {
    font-family: var(--font-family);
    font-weight: 600;
    font-size: 16px;
    line-height: 287%;
    color: var(--text);
}

@media (max-width:1200px) {
    .accordion .accordion-title {
        line-height: 175%;
    }
}

.accordion .accordion-toggle {
    position: absolute;
    right: 0%;
    top: 50%;
    /* place above the accordion-item */
    transform: translateY(-50%);
    width: 23px;
    height: 23px;
    border-radius: 50%;
    background: transparent;
    border: 1px solid var(--subtext);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--subtext);
    z-index: 5;
}

/* chevron inside toggle */
.accordion .accordion-toggle::after {
    content: '';
    width: 6px;
    height: 6px;
    border: solid currentColor;
    border-width: 0 2px 2px 0;
    display: inline-block;
    transform: rotate(45deg);
    margin: auto;
    margin-top: 5px;
    /* collapsed = down arrow */
}

.accordion .accordion-toggle[aria-expanded="true"]::after {
    transform: rotate(-135deg);
    margin-top: 7px;
    /* open = up arrow */
}

/* Collapse body typography */
.accordion .accordion-body {
    background: transparent;
    border: none;
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 16px;
    line-height: 131%;
    color: var(--subtext);
    padding: 0;
}

.accordion-body .core {
    max-width: 772px;
}