/*Main Css */
:root {
    --primary: #81F729;
    --font-heading: "Neulis Alt", sans-serif;
    --font-body: "Neulis Alt", sans-serif;
    --icon: "Font Awesome 6 Pro", sans-serif;
}
:root::-webkit-scrollbar{
    display: none !important;
  }
::selection {
    background: var(--primary);
    color: #fff;
    text-shadow: none;
}

::-webkit-scrollbar {
    width: 0.667vw;
    background-color: #f5f5f5;
}

::-webkit-scrollbar-button:start:decrement,
::-webkit-scrollbar-button:end:increment {
    display: none;
}

::-webkit-scrollbar-track-piece {
    -webkit-box-shadow: inset 0 0 0.8vw rgba(0, 0, 0, 0.3);
    background-color: #fff;
}

::-webkit-scrollbar-thumb:vertical {
    border-radius: 1.333vw;
    background-color: var(--primary);
}

/* Tabbing CSS */

[class^="box-"] {
    display: none;
}

[class^="box-"].showfirst {
    display: block;
}

html {
    overflow: hidden;
}

body {

    font-family: var(--font-body);
    overflow: hidden;
    font-size: 16px;
    line-height: 1;
    color: #000000;
    margin: 0;
    padding: 0;
    position: relative;
    z-index: 0;
    background: radial-gradient(195.07% 71.65% at 54.96% 54.03%, #100000 0%, #021B79 100%);
}

main.home {
    opacity: 0;
}

main.home.active {
    opacity: 1;
}

header.header {
    z-index: 16;
    display: flex;
    position: fixed;
    width: 100%;
    justify-content: space-between;
    padding: .5vw 1.2vw;
    align-items: center;
    /* background: #00000017; */
    /* backdrop-filter: blur(0.667vw); */
    /* position: relative; */
}

header.header .wrap {
    position: absolute;
    top: -20.6vw;
    z-index: 2;
    transition: all .6s cubic-bezier(.34, 1.5, .64, 1);
}

a.logo img {
    max-width: 10vw;
    /* filter: invert(1); */
    /* mix-blend-mode: difference; */
}

body.inner-header {
    padding-top: 13.333vw;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    display: block;
    font-weight: normal;
    font-family: var(--font-heading);
}

*:hover,
*:focus,
* {
    outline: none !important;
}

img {
    max-width: 100%;
    height: auto;
    width: auto;
}

a,
input[type="submit"] {
    -webkit-transition: all 0.4s ease-In-out;
    -moz-transition: all 0.4s ease-In-out;
    -o-transition: all 0.4s ease-In-out;
    transition: all 0.4s ease-In-out;
    display: inline-block;
    cursor: pointer;
    text-decoration: none;
}

span {
    display: inline-block;
}

textarea,
select,
input[type],
textarea,
select,
button {


    font-family: var(--font-body);
    font-weight: 400;
}

::-webkit-input-placeholder {
    color: #a3a3a3;
    font-weight: 400;
}

::-moz-placeholder {
    color: #a3a3a3;
    font-weight: 400;
}

:-ms-input-placeholder {
    color: #a3a3a3;
    font-weight: 400;
}

:-moz-placeholder {
    color: #a3a3a3;
    font-weight: 400;
}

::-moz-placeholder {
    opacity: 1;
}

.main {
    max-height: 100dvh;
    overflow-y: scroll;
    scroll-snap-type: y mandatory;
    transition: .5s ease;
    scroll-behavior: smooth;
    padding: 0 !important;
    
}

.normal-scroll {
    overflow-y: auto;
    max-height: 100dvh;
}

main:has(.panel:focus-visible) {
    scroll-behavior: smooth;
    scroll-snap-type: y mandatory;
}

.panel:focus-visible {
    scroll-snap-align: start;
}

.panel {
    min-height: 100dvh;
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    scroll-snap-align: start;
    text-align: center;
    gap: 2rem;
    position: relative;
    z-index: 0;
    flex-direction: column;
}

.main::before {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    background: transparent;
    background-image: radial-gradient(#ffffff73 0.133vw, transparent 0);
    background-size: 10.667vw 10.667vw;
    background-position: -2.533vw -2.533vw;
    left: 0;
    top: 0;
    z-index: -1;
    animation: opacity 5s infinite alternate;
}

@keyframes opacity {
    0% {
        opacity: .2;
    }

    100% {
        opacity: .8;
    }
}

.content {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-bottom: 1rem;
    width: 100%;
}

.panel .banner-text {
    font-size: 1.2vw;
    color: #fff;
}

.panel h1,
.panel h2 {
    color: #FFF;
    text-align: center;
    text-shadow: 0vw 0.533vw 1.867vw rgba(82, 82, 82, 0.25);
    font-family: var(--font-heading);
    font-size: 4.8vw;
    font-weight: 700;
    line-height: 1.3;
    letter-spacing: -0.123vw;
    transition: .5s ease;
}

.panel h4 {
    color: #FFF;
    text-shadow: 0vw 0.533vw 1.867vw rgba(82, 82, 82, 0.25);
    font-family: var(--font-heading);
    font-size: 3.158vw;
    font-weight: 700;
    line-height: 1;
    letter-spacing: -0.123vw;
    transition: .5s ease;
}

.service-content h4 {
    color: #FFF;
    text-shadow: 0vw 0.533vw 1.867vw rgba(82, 82, 82, 0.25);
    font-family: var(--font-heading);
    font-size: 3.158vw;
    font-weight: 700;
    line-height: 1;
    letter-spacing: -0.123vw;
    transition: .5s ease;
}

.eyebrow-heading-line {
    overflow: hidden;
}

.eyebrow-heading-word {
    vertical-align: middle;
}

.panel h1 span,
.panel h2 span {
    color: var(--primary);
    text-transform: capitalize;
    display: inline;
}

.panel h3 {
    color: #FFF;
    text-align: center;
    font-size: max(24px, min(5vw, 32px));
    font-weight: 400;
    line-height: max(34px, min(5vw, 52px));
    font-family: var(--font-body);
}

.panel p {
    color: #FFF;
    text-align: center;
    font-size: .9vw;
    line-height: 1.5;
    /* 183.333% */
}

.circle {
    position: absolute;
    width: 106.667vw;
    aspect-ratio: 1/1;
    border: 0.067vw solid #dddddd4f;
    top: 48%;
    transform: translateY(-50%);
    margin: 0 auto;
    left: 0;
    right: 0;
    max-width: 90%;
    border-radius: 100%;
}

.circle.c1 {
    animation: scale 3s infinite alternate;
}

.circle.c2 {
    animation: scale 2s infinite alternate;
}

.menu-bar {
    right: 0;
    display: flex;
    justify-content: center;
    gap: 2.667vw;
    z-index: 99;
    position: absolute;
    width: 19vw;
    left: 0;
    right: 0;
    margin: 0 auto;
}

a.menu-btn {
    background: url(../images/menu.svg) no-repeat;
    background-size: contain;
    width: 100%;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: end;
    gap: 0vw;
    flex-direction: column;
    z-index: -1;
    height: 8.5vw;
    padding-bottom: 3.5vw;
    top: -3.3vw;
}

a.menu-btn::before,
a.menu-btn::after {
    content: "";
    width: 1.5vw;
    height: .05vw;
    background: #333;
    transition: .5s ease;
}

a.menu-btn::after {
    margin-top: 0.5vw;
}

.menu-bar.open .menu-btn:before {
    transform: rotate(45deg);
}

.menu-bar.open .menu-btn:after {
    transform: rotate(-45deg);
    margin-top: 0;
}

.menu-bar.open .menu-btn {
    gap: 0;
}

.dropdown {
    width: 100%;
    background: var(--primary);
    padding: .7vw;
    border-radius: 2.5vw;
    max-width: 100%;
    height: 18vw;
}

header.header .wrap.open {
    top: -1vw;
}

.dropdown>div {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.dropdown li {
    transition: .5s ease;
    border-bottom: 0.133vw solid #00000038;
}

.dropdown li a,
.dropdown li p {
    font-size: .8vw;
    line-height: 1.3;
    color: #000;
    width: 100%;
    padding: .7vw 0;
    text-transform: uppercase;
}

.dropdown ul {
    display: flex;
    flex-direction: column;
    /* background: #00000040; */
    padding: 1vw 1vw 0;
    border-radius: 1.333vw;
}

.dropdown .social-links {
    display: flex;
    flex-direction: row;
    justify-content: center;
    gap: 1vw;
    padding: 1vw 0 0;
}

.dropdown .social-links li {
    border: 0;
}

.dropdown .social-links li a {
    padding: 0;
    opacity: .5;
}

.dropdown .social-links li a:hover {
    opacity: 1;
}

.dropdown .social-links li a:hover img {
    transform: translateY(-0.667vw);
}

.dropdown .social-links li a img {
    transition: .2s ease;
    width: 1vw;
}

ul.side-menu {
    position: absolute;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    left: .7vw;
    bottom: .7vw;
    z-index: 1;
}

ul.side-menu a {
    color: white;
    font-size: 1vw;
    display: flex;
    gap: .3vw;
    align-items: center;
}

ul.side-menu a span {
    position: relative;
    display: flex;
    align-items: center;
    gap: 1vw;
    width: 1.2vw;
}

ul.side-menu a b {
    transition: .5s ease;
    display: flex;
    width: 0vw;
    height: 0.133vw;
    background: #fff;
}

a.footer-email {
    color: #FFF;
    font-size: 1.1vw;
    font-style: normal;
    font-weight: 500;
    line-height: normal;
    position: absolute;
    right: .7vw;
    bottom: .7vw;
    z-index: 1;
}

@keyframes scale {
    0% {
        width: 20%;
    }

    100% {
        width: 40%;
    }
}

@keyframes slide {
    0% {
        transform: translateY(2.667vw)
    }

    100% {
        transform: translateY(0vw)
    }
}

.arrow {
    animation: slide .5s infinite alternate;
}

.arrow img {
    width: 2vw;
}

ul.side-menu li {
    padding: 1vw;
    transition: .5s ease;
    border: 0.133vw solid transparent;
    border-radius: 100vw;
    width: fit-content;
}

ul.side-menu li.active {
    border: 0.133vw solid #fff;
}

.panel h2 span.text {
    font-size: .9vw !important;
    display: inline-flex;
    width: 22vw;
    font-family: var(--font-body);
    font-weight: 400;
    color: white;
    text-align: left;
    position: relative;
    line-height: 1.2;
    letter-spacing: 0;
    -webkit-line-clamp: 2;
    display: -webkit-inline-box;
    overflow: hidden;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
}

.theme-btn {
    color: #FFF;
    text-align: center;
    font-size: 1.4vw;
    line-height: normal;
}

.case-card {
    background: #FFF;
    position: relative;
    z-index: 0;
    transition: .5s ease;
    display: flex;
    flex-direction: column;
}

.case-card .data .client {
    display: flex;
    align-items: center;
    gap: 0.667vw;
}

.case-card .data .client .det {
    display: flex;
    flex-direction: column;
    align-items: start;
    gap: 0.667vw;
}

.case-card .data .client .det .name {
    font-size: 1.867vw;
    font-weight: 600;
    color: #444;
}

.case-card .data .client .det .des {
    font-size: 1.6vw;
    font-weight: 400;
    color: #444;
}

.case-card .data p {
    color: #444;
    font-size: 1.6vw;
    font-style: normal;
    font-weight: 400;
    line-height: 2.933vw;
    /* 183.333% */
    text-align: left;
}

.case-card .data {
    padding: 1rem;
    display: flex;
    flex-direction: column;
    align-items: start;
    gap: 1.333vw;
    background: white;
}

.case-card .data .bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    width: 100%;
}

.case-card .data .bottom .tags {
    display: flex;
    gap: 1.333vw;
}

.case-card .data .bottom .tags tag {
    color: #0B0B0B;
    font-size: 1.333vw;
    font-weight: 500;
    line-height: 2.933vw;
    /* 220% */
    letter-spacing: 0.013vw;
    text-transform: uppercase;
    background: #8FFF00;
    box-shadow: 0.533vw 0.533vw 0vw 0vw #1411A7;
}

.case-card .data .bottom .tags .tag {
    position: relative;
    background: #8FFF00;
    box-shadow: 0.533vw 0.533vw 0vw 0vw #1411A7;
    color: #0B0B0B;
    font-size: 1.333vw;
    font-weight: 500;
    line-height: 2.933vw;
    /* 220% */
    letter-spacing: 0.013vw;
    text-transform: uppercase;
    padding: 0.667vw 1.333vw;
}

.case-card:before {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    right: 0;
    top: 0;
    background: #f11d94;
    z-index: -1;
    transition: .5s ease;
}

.case-card:hover {
    transform: translate(-1.333vw, -1.333vw);
    z-index: 2;
    box-shadow: 0vw 0.533vw 0.8vw -0.133vw rgb(0 0 0 / 10%), 0vw 0.267vw 0.533vw -0.133vw rgb(0 0 0 / 6%);
}

.case-card:hover:before {
    transform: translate(1.333vw, 1.333vw);
}

.case-card>img {
    height: 20vw;
    object-fit: cover;
    width: 100%;
}

.case h3 {
    font-size: max(3.2vw, min(5vw, 4.267vw));
    font-weight: 400;
    line-height: max(5.067vw, min(5vw, 6.133vw));
    letter-spacing: -0.01em;
    color: white;
}

.case-slide p span {
    display: -webkit-box;
    overflow: hidden;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
}

.contact-form input,
.contact-form select,
.contact-form textarea {
    border-radius: .2vw;
    background: #efefef;
    width: 100%;
    padding: 1vw;
    border: 0;
    font-size: .9vw;
}

.contact-form .submit {
    border-radius: 6px;
    background: #8FFF00;
    padding: 1.2vw;
    color: #0B0B0B;
    font-size: 1.2vw;
    border: 0;
}

/* .case-slide {
    border: 0.267vw solid #fff;
    text-align: left;
    display: flex !important;
    flex-direction: column;
     gap: 1rem;}
*/
.case-slide {
    padding-top: 9.333vw;
}

.case-slide h3 {
    text-align: left;
    font-size: 1.3vw;
    line-height: normal;
}

.case-slide p {
    line-height: 1.5;
    font-size: .9vw;
    text-align: left;
}

.case-slide a {
    font-size: 1vw;
    font-weight: 600;
    color: #86f83b;
}

.case-slider .slick-slide {
    margin: 0 .5vw;
    padding-top: .5vw;
}

.slider-arrows {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1vw;
}

.slider-arrows a.arrow-btn {
    width: 2vw;
    background: white;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 100%;
    color: #333;
    opacity: .6;
    aspect-ratio: 1/1;
    font-size: .8vw;
}

.slider-arrows a.arrow-btn:hover {
    opacity: 1;
}

.case-slide .slide-content {
    padding: 2.667vw;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.case-slide .slide-content .client {
    display: flex;
    align-items: center;
    align-items: center;
    gap: 1.333vw;
}

.case-slide .slide-content .client .name {
    color: white;
}

.case-slide .slide-content .client .des {
    color: #adadad;
    font-size: 1.867vw;
}

.case-slide .slide-content .client .det {
    flex-direction: column;
    display: flex;
    gap: 0.667vw;
}

.service-card {
    border-radius: .2vw;
    background: white;
    padding: 1vw;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 1vw;
    height: 100%;
}

.service-card img {
    height: 4vw;
}

.service-card a {
    color: var(--primary);
    font-weight: 600;
    font-size: .9vw;
}

.service-card h3 {
    font-size: 1.2vw;
    font-weight: 700;
    line-height: 4.4vw;
    letter-spacing: 0em;
    text-align: center;
    color: #333;
}

.service-card p {
    font-size: .9vw;
    font-weight: 400;
    line-height: 1.2;
    letter-spacing: 0em;
    text-align: center;
    color: #333;
}

.service-card.d2 p {
    font-size: .8vw;
    color: #4D4D4D;
    flex: 1;
    line-height: 1.4;
}

.service-card.d2 {
    align-items: start;
    background: #FBF8FF;
}

.service-card.d2 img {
    width: 100%;
    height: auto;
}

.service-card.d2 * {
    text-align: left !important;
}

.service-card.d2 h3 {
    font-size: 1.1vw;
    color: #1D1D1F;
    line-height: 1.2;
}

.services-list {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
}

.services-list li {
    padding: 1.333vw 1.333vw;
}

.services-list li span {
    font-size: 1.25vw;
    font-weight: 400;
    color: white;
    display: inline-block;
    letter-spacing: 0.267vw;
    font-family: var(--font-heading);
    padding: 0.78125vw 1.5625vw;
    border: 0.133vw solid white;
    border-radius: 13.333vw;
    transition: all 0.4s;
}

.services-list li span:hover {
    background-color: white;
    color: #0B0B0B;
}

.service-content p {
    text-align: left;
    color: #FFF;
    font-size: .9vw;
    line-height: 1.5;
}

.service-content>span {
    font-size: 1.042vw;
    color: white;
}

.service-content span span {
    color: #86F83B;
}

.service-content p span {
    font-size: 1.042vw;
}

.service-sec .row {
    padding: 2vw 0;
}

.mySwiper .swiper-slide .content.service-btn {
    justify-content: space-between;
}

.mySwiper .swiper-slide .content .upper a {
    display: flex;
    width: 100%;
    justify-content: start;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
}

.mySwiper .swiper-slide .content .upper a .tag {
    /* padding: 1.333vw; */
    border: 1px solid #fff;
    border-radius: 13.333vw;
    font-size: 1vw;
    /* display: flex; */
    /* flex-direction: column; */
    /* align-items: center; */
    height: 2.5vw;
    display: block;
    padding: 0 1rem;
    box-sizing: content-box;
    color: #fff;
}

h1.h-small {
    font-size: 2.5vw;
    font-weight: 400;
    line-height: 1.2;
    letter-spacing: -0.01em;
    text-align: center;
    color: white;
}

h2.h-small {
    font-size: 2vw;
    font-weight: 600;
    line-height: 1.2;
    letter-spacing: -0.01em;
    text-align: left;
    margin-bottom: 1vw;
    color: white;
}
h1.h-medium {
    font-size: 4vw;
}
ul.accordion {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

ul.accordion li h3 {
    font-size: 1.1vw;
    font-weight: 400;
    line-height: 1.2;
    letter-spacing: -0.01em;
    text-align: left;
    color: #333;
    display: flex;
}

ul.accordion li p {
    font-size: .9vw;
    text-align: left;
    line-height: 1.2;
    color: #555;
}

ul.accordion li {
    display: flex;
    flex-direction: column;
    gap: 1vw;
    background: white;
    padding: 1vw;
    border-left: 1.333vw solid #8fff00;
    cursor: pointer;
}

ul.accordion li h3::before {
    content: "\f054";
    font-family: var(--icon);
    width: 2vw;
    display: flex;
}

ul.accordion li.active h3::before {
    content: "\f077";
}

.normal-scroll section {
    padding: 70px 0;
    position: relative;
    z-index: 1;
}

.case-header {
    position: relative;
    border-radius: 1vw;
    overflow: hidden;
    /* background-color: black; */
}

.case-header .content {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: start;
    justify-content: center;
    flex-direction: column;
    gap: 1vw;
    padding: 2vw;
}

.case-header img {
    display: none;
}

.case-header .content span.hdng {
    font-size: 2.5vw;
    font-weight: 400;
    line-height: 1.2;
    letter-spacing: -0.01em;
    text-align: center;
    color: var(--primary);
}

.case-header .content .h-small {
    font-size: 4vw;
    font-weight: 400;
    line-height: 1.2;
    letter-spacing: -0.01em;
    text-align: left;
}

.case h2 {
    font-size: 2vw;
    font-weight: 400;
    line-height: 1.2;
    letter-spacing: -0.01em;
    color: white;
}

.case p {
    font-size: 1vw;
    font-weight: 400;
    line-height: 1.5;
    letter-spacing: -0.01em;
    color: white;
    margin-top: .8vw;
}

.case ul {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    color: white;
    margin: 1vw 0;
    list-style: disc;
    margin-left: 1vw;
    font-size: 1vw;
}

.case-slide .inner {
    height: 15vw;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 1vw;
    position: relative;
    transform-origin: 100% 100%;
    /* transition: all .4s cubic-bezier(.215,.61,.355,1); */
}

.case-slide .inner .img {
    position: absolute;
    width: 100%;
    height: 100%;
    object-fit: cover;
    left: 0;
    top: 100%;
    /* z-index: -2; */
    border-radius: 1.333vw;
    transition: all .5s ease;
    overflow: hidden;
    /* transform: scale(0); */
}

.case-slide .inner .img::before {
    content: "";
    background: var(--bg);
    position: absolute;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    transition: background-position 7s ease;
    background-size: cover;
}

.case-slide .inner:hover .img::before {
    background-position: bottom;
    /* transform: translateY(-8.667vw); */
}

.case-slide .inner:hover .img {
    /* animation: case-slide  8s ease-in-out; */
    /* transform: translateY(-8.8vw); */
    z-index: 1;
    top: -8vw;
}

@keyframes case-slide {
    0% {
        z-index: -2;
        transform: scale(0);
    }

    10% {
        z-index: 1;
        transform: scale(1);
    }

    90% {
        z-index: 1;
        transform: scale(1);
    }

    91% {
        z-index: -2;
        transform: scale(0);
    }

    100% {
        z-index: -2;
        transform: scale(0);
    }
}

.case-slide .inner::before {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    background: #2D324F;
    left: 0;
    top: 0;
    z-index: -1;
    border: 0.267vw dashed #FFFFFF;
    border-radius: 1.333vw;
}

.testimonial-slide .content {
    flex-basis: 100%;
    height: 100%;
    background: white;
    padding: 1.2vw 14vw 1.2vw 1.2vw;
    border-radius: 1vw;
}

.testimonial-slide {
    display: flex;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    position: relative;
}

.testimonial-slide .img {
    background: var(--bg);
    flex-basis: 100%;
    height: 100%;
    background-size: cover;
    display: flex;
    transform: translateX(-12vw) translateY(-5vw);
    /* transition: 8s ease; */
}

p.normal-text {
    font-size: 1vw;
    line-height: 1.2;
    color: white;
}

ul.progress-wrap {
    display: flex;
    flex-direction: column;
    gap: 1.4vw;
    margin-top: 1.2vw;
}

ul.progress-wrap li {
    display: flex;
    flex-direction: column;
    gap: 1vw;
}

ul.progress-wrap li .upper .hdng {
    font-size: 1vw;
    color: white;
    line-height: 1.4;
}

ul.progress-wrap li .upper .percent {
    color: var(--primary);
    font-size: 1vw;
    line-height: 1.2;
}

ul.progress-wrap li .upper {
    display: flex;
    width: 100%;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
}

ul.progress-wrap li .progress {
    height: 1.2vw;
    border-radius: 100vw;
    background: #D9D9D9;
    position: relative;
}

ul.progress-wrap li .progress::before {
    content: "";
    height: 100%;
    width: var(--width);
    background: var(--primary);
    border-radius: 13.333vw;
}

.pageload {
    position: fixed;
    height: 0;
    bottom: 0;
    background: white;
    transition: 1s ease;
    width: 100%;
    z-index: 100;
}

.pageload.full {
    height: 100dvh;
}

.pageload.top {
    bottom: auto;
    top: 0;
}

.pageload.out {
    height: 0;
}

.g-4 {
    --bs-gutter-x: 1vw;
    --bs-gutter-y: 1vw;
}

.profile-link {
    /* position: fixed; */
    color: white;
    right: 1vw;
    top: 40vh;
    z-index: 2;
}

.profile-link a {
    /* writing-mode: vertical-rl; */
    /* transform: rotate(180deg); */
    font-size: 1vw;
    color: #0B0B0B;
    padding: 1vw;
    background: var(--primary);
    border-radius: 6px;
    display: flex;
    align-items: center;
    gap: 1rem;
}
.profile-link a img {
    display: none;
}
.profile-link a:hover {
    transform: scale(1.05);
}

.testimonial-slide .content h3 {
    color: #333;
}

.testimonial-slide .content p {
    color: #333;
}

a.visit {
    font-size: 1vw;
    color: #FFFFFF;
    margin-left: auto;
    background: var(--primary);
    color: #222;
    font-weight: 600;
    padding: 0.8vw 1vw;
    border-radius: 0.5vw;
}

a.visit i {
    /* color: var(--primary); */
}

a.visit:hover i {
    transform: scale(1.2);
}

a.visit i {
    transition: .5s ease;
}

.bg-sec {
    background-size: cover;
    background-position: center;
    padding: 5.365vw 0;
}

.content>span {
    font-size: 1.146vw;
    color: white;
}

.content h6 {
    font-size: 2.083vw;
    color: white;
    font-weight: 600;
    line-height: 1.2;
}

.about-content p span {
    color: #86F83B;
    font-weight: 700;
}

.about-content h5 {
    font-size: 1.667vw;
    color: white;
    text-align: left;
    font-family: var(--font-body);
    line-height: 1.4;
}

.about-content h2 {
    color: #86F83B;
    text-align: center;
    text-shadow: 0vw 0.533vw 1.867vw rgba(82, 82, 82, 0.25);
    font-family: var(--font-body);
    font-size: 4.8vw;
    font-weight: 700;
    line-height: 1;
    letter-spacing: -0.123vw;
    transition: .5s ease;
}

.progress-box span {
    color: #86F83B;
    text-align: center;
    text-shadow: 0vw 0.533vw 1.867vw rgba(82, 82, 82, 0.25);
    font-family: var(--font-body);
    font-size: 4.8vw;
    font-weight: 700;
    line-height: 1;
    letter-spacing: -0.123vw;
    transition: .5s ease;
}

.progress-box p {
    font-size: 1.667vw;
    color: white;
    text-align: left;
    line-height: 1.4;
}

.project-img {
    position: relative;
}

.project-img-content {
    position: absolute;
    bottom: 0vw;
    left: 0;
    padding: 2rem;
    color: white;
    text-align: left;
}

.project-img-content h3 {
    /* font-size: 2.083vw; */
    font-family: var(--font-heading);
    font-weight: 700;
    margin-bottom: 1.333vw;
    text-align: left;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.project-img-content p {
    font-size: 0.833vw;
    text-align: left;
}

.project-imgs .col-md-6:nth-child(odd) {
    margin-top: -30px;
}

.hdng-col {
    display: flex;
    justify-content: space-between;
    width: 100%;
    align-items: center;
}

.hdng-col * {
    text-align: left !important;
}

.swiper-container {
    height: 100%;
    max-height: 100vw;

    min-height: 0;
    min-width: 0;
    max-width: 100vw;
    width: 100%;
    overflow: hidden;
}

.swiper-slide {
    width: auto;
    flex-shrink: 0;
    display: block;
    height: 100%;
    max-height: 100%;
    min-width: 0;
    background: white;
    height: 91dvh;
    display: flex;
    align-items: center;
    justify-content: space-between;
    overflow: hidden;
}

.swiper-wrapper {
    max-height: 100%;
    height: 100%;
    display: flex;
    min-width: 0;
    width: 100%;
    gap: 0;
}

.swiper-slide .img img {
    transform: scale(1.1);
    transition: 1s ease;
    width: 100%;
}

.swiper-slide:hover .img img {
    transform: scale(1.01);
}

.mySwiper .swiper-slide .content {
    position: absolute;
    display: flex;
    flex-direction: column;
    gap: 2vw;
    height: 100%;
    justify-content: end;
    margin: 0;
    padding: 1.3vw;
    z-index: 2;
    color: white;
}

.mySwiper .swiper-slide {
    position: relative;
    z-index: 0;
}

.mySwiper .swiper-slide .content .upper div {
    display: flex;
    width: 100%;
    justify-content: start;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
    margin-bottom: 0.3rem;
}

.mySwiper .swiper-slide .content .upper div .tag {
    /* padding: 1.333vw; */
    border: 1px solid;
    border-radius: 13.333vw;
    font-size: 1vw;
    /* display: flex; */
    /* flex-direction: column; */
    /* align-items: center; */
    height: 2.5vw;
    display: block;
    padding: 0 1rem;
    box-sizing: content-box;
}

.mySwiper .swiper-slide .content .upper .text {
    font-size: 20px;
}

.mySwiper .swiper-slide .content .upper .date {
    text-align: left;
    display: flex;
    font-weight: 600;
    font-size: .8vw;
}

.mySwiper .swiper-slide .content .bottom {
    display: flex;
    align-items: center;
    gap: 1rem;
    justify-content: space-between;
    text-align: left;
}

.mySwiper .swiper-slide .content .bottom h3 {
    text-align: left;
    line-height: 1.1;
    font-size: 2vw;
    font-weight: 600;
}
.upper span.text {
    padding-bottom: 1rem;
}
.content .upper {
    text-align: left;
}
/**
 * ANIMATION - FLIP
 */
.m-flip {
    overflow: hidden;
    cursor: pointer;
}

.m-flip_item {
    display: block;
    position: relative;
    top: 0;
    transition: top 0.2s ease-out 0s;
    line-height: 2.5vw;
    font-size: 14px;
}

.mySwiper .swiper-slide .content .bottom a i {
    color: white;
    font-weight: 200;
    font-size: 1.3vw;
    flex-shrink: 0;
    line-height: 2.5vw;
    transition: .5s ease;
}

.mySwiper .swiper-slide .content .bottom a {
    width: 3vw;
    height: 3vw;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 100%;
}

.mySwiper .swiper-slide .content .bottom a:hover {
    background: #222;
    width: 40px;
    height: 40px;
}

.mySwiper .swiper-slide .content .bottom a:hover i {
    font-size: 20px;
}

.loader {
    position: fixed;
    z-index: 9999;
    width: 100%;
    height: 100dvh;
}

.loader video {
    width: 100%;
    background-color: transparent;
}

.inner {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}

.wrap {
    width: 100%;
    display: block;
}

.cursor {
    position: absolute;
    padding: 1vw;
    background: white;
    border-radius: 100vw;
    font-size: .8vw;
    color: #222;
}

#testimonials .content {
    margin-bottom: 0;
    justify-content: space-between;
}

section#testimonials {
    justify-content: end;
}

.swiper-slide::before {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    z-index: 1;
    background: linear-gradient(to bottom, rgb(255 255 255 / 27%), rgb(0 0 0 / 60%));
    left: 0;
    top: 0;
}

.mySwiper .swiper-slide .img {
    height: 100%;
    width: 100%;
    object-fit: cover;
    object-position: center;
}

.mySwiper .swiper-slide .img img {
    height: 100%;
    object-fit: cover;
}

/* changes */
.project-img-content a i {
    width: 39.998px;
    height: 39.998px;
    line-height: 39.998px;
    background: white;
    text-align: center;
    border-radius: 100%;
    color: black;
    font-size: 24.997px;
    font-weight: 500;
    transition: all 0.4s;
}

.project-img:hover .project-img-content a i {
    background-color: #86F83B;
}

.normal-scroll .panel {
    min-height: unset;
}
.service-img.service-content a{
    color:var(--primary)
}
@media (max-width: 1440px) {
    .dropdown{
        height: 21vw; 
    }
    header.header .wrap{
        top: -23.5vw;
    }
    a.menu-btn {
        padding-bottom: 2.5vw;
        top: -68px;
    }
}

@media (max-width: 1200px) {
    a.menu-btn {
        height: 11vw;
    }
    .dropdown{
        height: 24vw;
    }
    header.header .wrap{
        top: -27.8vw;
    }

    .service-card.d2 h3 {
        font-size: 1.2rem;
    }

    .service-card.d2 p {
        font-size: .8rem;
    }

    .profile-link a {
        font-size: 1rem;
        padding: 1rem;
    }

    .profile-link {
        right: 1rem;
        top: 40%;
    }

    ul.side-menu {
        display: none;
    }

    .panel h2 span.text {
        /* top: -3.467vw; */
        font-size: 1.867vw !important;
        line-height: 2.933vw;
        display: block;
        inset: 0;
        width: 77.333vw;
        text-align: center;
        margin: 0 auto;
        max-width: 100%;
    }

    a.footer-email {
        font-size: 1rem;
        right: 1rem;
        bottom: 1rem;
        display: none;
    }

    a.logo img {
        max-width: 120px;
    }

    .panel p {
        font-size: 1rem;
    }

    .panel .banner-text {
        font-size: 1.2rem;
    }

    .panel h1,
    .panel h2 {
        font-size: 8vw;
        line-height: 1.4;
    }

    .theme-btn {
        font-size: 1.2rem;
    }

    .arrow img {
        width: 5.333vw;
    }

    .case-slide .inner {
        height: 29.333vw;
        padding: 1rem;
    }

    .case-slide h3 {
        font-size: 2.933vw;
    }

    .case-slide p {
        font-size: 1.867vw;
    }

    .case-slide a {
        font-size: 1rem;
    }

    .slider-arrows a.arrow-btn {
        width: 4vw;
        font-size: 1rem;
    }

    .contact-form input,
    .contact-form select,
    .contact-form textarea {
        padding: 1rem;
        font-size: 1rem;
    }

    .contact-form .submit {
        padding: 1rem;
        font-size: 1rem;
    }

    .normal-scroll header {
        position: relative;
    }

    .case h2 {
        font-size: 2rem;
        line-height: 1.4;
    }

    .case p {
        margin-top: 1.333vw;
        font-size: 1rem;
    }

    .case ul {
        font-size: 1rem;
        margin: 1rem 0;
        margin-left: 1rem;
    }

    ul.accordion li {
        padding: 1rem;
        gap: 1rem;
    }

    ul.accordion li h3 {
        font-size: 1rem;
    }

    ul.accordion li h3::before {
        width: 4vw;
    }

    ul.accordion li p {
        font-size: 1rem;
    }

    .dropdown li a,
    .dropdown li p {
        font-size: 1rem;
    }

    .service-card {
        border-radius: 1rem;
        padding: 1rem;
    }

    .service-card h3 {
        font-size: 1.2rem;
    }

    .service-card p {
        font-size: .8rem;
    }

    .service-card a {
        font-size: .8rem;
    }

    h1.h-small {
        font-size: 2.5rem;
    }

    h2.h-small {
        font-size: 1.5rem;
    }

    .g-4 {
        --bs-gutter-x: 1rem;
        --bs-gutter-y: 1rem;
    }
}

@media (max-width : 1023px) {
    .dropdown {
        height: 260px;
    }
    
    header.header .wrap {
        top: -307px;
    }
    .main::before {
        background-size: 8vw 8vw;
    }

    .panel h2 span.text {
        position: relative;
        inset: 0;
        display: flex;
        width: 100%;
        text-align: center;
    }

    .panel p {
        font-size: 1.867vw;
    }

    .panel h2 {
        font-size: 6.667vw;
        line-height: 1.4;
    }

    a.theme-btn {
        font-size: 20px;
    }

    .case-slide .inner {
        height: 40vw;
        padding: 2.667vw;
    }

    .case-slide h3 {
        font-size: 2.667vw;
    }

    .slider-arrows a.arrow-btn {
        width: 5.333vw;
        font-size: 1rem;
    }

    .slider-arrows {
        gap: 1rem;
    }

    a.footer-email {
        font-size: 1rem;
        right: 1rem;
        bottom: 1rem;
    }

    .panel .banner-text {
        font-size: 1.1rem;
    }

    header.header {
        padding: 1rem;
    }

    a.menu-btn {
        width: 100%;
        height: 115px;
        top: -68px;
    }

    a.menu-btn::before,
    a.menu-btn::after {
        width: 30px;
    }

    a.menu-btn::after {
        margin-top: 1.067vw;
    }

    .mySwiper .swiper-slide .content .upper div .tag {
        font-size: 2vw;
        height: 32px;
    }

    .mySwiper .swiper-slide .content .upper div .text {
        font-size: 2vw;
    }
}

/* iPads (portrait and landscape) ----------- */
@media only screen and (min-width : 768px) and (max-width : 1024px) {
    /* Styles */
}

/* iPads (landscape) ----------- */
@media only screen and (min-width : 768px) and (max-width : 1024px) and (orientation : landscape) {
    /* Styles */
}

/* iPads (portrait) ----------- */
@media only screen and (min-width : 768px) and (max-width : 1024px) and (orientation : portrait) {
    /* Styles */
}

/* iPhone 6-8 Plus */
@media only screen and (min-width : 414px) and (max-width : 736px) and (orientation : portrait) {
    /* Styles */
}

@media only screen and (min-width : 414px) and (max-width : 736px) and (orientation : landscape) {
    /* Styles */
}

/* iPhone 6-8  */
@media only screen and (min-width : 375px) and (max-width : 667px) and (orientation : portrait) {
    /* Styles */
}

@media only screen and (min-width : 375px) and (max-width : 667px) and (orientation : landscape) {
    /* Styles */
}

/* Android (Pixel 2) */
@media only screen and (min-width : 412px) and (max-width : 684px) and (orientation : portrait) {
    /* Styles */
}

@media only screen and (min-width : 412px) and (max-width : 684px) and (orientation : landscape) {
    /* Styles */
}

/* Iphone X */
@media only screen and (min-width : 375px) and (max-width : 734px) and (orientation : portrait) {}

@media (max-width : 767px) {

    
    .profile-link {
        /* display: none; */
    }

    .case-header .content {
        position: relative;
        padding: 0;
        margin-top: 1rem;
    }

    a.footer-email {
        display: none;
    }

    ul#menu {
        display: none;
    }

    .panel .banner-text {
        font-size: 16px;
        line-height: 26px;
    }

    .panel h3 {
        font-size: 20px;
        line-height: 1.3;
    }

    .panel p {
        line-height: 1.4;
        font-size: 16px;
    }

    a.arrow img {
        width: 4vw;
    }

    .content {
        margin-bottom: 0;
    }

    .panel h2 span.text {
        inset: 0;
        width: 100%;
        text-align: center;
        margin: 1rem 0;
    }

    .case-card {
        margin: 1rem 0;
    }

    section#testimonials {
        scroll-snap-align: end;
        padding: 0;
    }

    .dropdown ul {
        padding: 1.333vw;
    }

    .dropdown {
        padding: 1.333vw;
        border-radius: 30px;
        padding: 20px;
        height: 320px;
    }

    .panel {
        /* min-height: auto; */
        padding: 1rem 0;
    }

    a.arrow {
        display: none;
    }

    .panel h1 br,
    .panel h2 br {
        display: none;
    }

    .menu-bar {
        flex-direction: column;
        align-items: end;
    }

    .service-card {
        padding: 2.667vw;
        gap: 1rem;
        border-radius: 2.667vw;
    }

    .service-card img {
        height: 6.667vw;
    }

    .service-card h3 {
        font-size: 2.667vw;
    }

    .service-card p {
        font-size: 1rem;
    }

    .service-card a {
        font-size: 1rem;
    }

    h2.h-small {
        font-size: 4vw;
        margin-bottom: 1rem;
    }

    .contact-form input,
    .contact-form select,
    .contact-form textarea {
        font-size: 1rem;
        padding: 10px;
        border-radius: 1.333vw;
    }

    .contact-form .submit {
        font-size: 1rem;
        padding: 1rem;
    }

    ul.accordion li h3 {
        font-size: 2.667vw;
        gap: 1.333vw;
    }

    header.header {
        padding: 1rem;
        /* position: relative; */
    }

    a.menu-btn::before,
    a.menu-btn::after {
        width: 60%;
        height: 0.133vw;
    }

    a.menu-btn::after {
        margin-top: 0.933vw;
    }

    h1.h-small {
        font-size: 4vw;
    }

    .dropdown li a,
    .dropdown li p {
        font-size: 1rem;
        padding: 1rem;
    }

    .panel h1,
    .panel h2 {
        font-size: 3.467vw;
        line-height: 1.2;
    }

    .case-slide .inner {
        height: 33.333vw;
        padding: 2.667vw;
    }

    .case-slider .slick-slide {

        margin: 0 1.333vw;
    }

    .main::before {
        background-size: 5.333vw 5.333vw;
    }

    .service-content h4 {
        font-size: 20px;
    }

    .service-content p {
        font-size: 16px;
    }

    .service-content>span {
        font-size: 20px;
    }

    .service-content p span {
        font-size: 16px;
    }

    .service-sec .row:nth-child(even) {
        flex-direction: column-reverse;
    }

    .service-sec .row {
        padding: 2.667vw 0;
    }

    .service-img {
        margin-top: 3.333vw;
    }

    .content h6 {
        font-size: 24px;
    }

    .content>span {
        font-size: 16px;
    }

    .bg-sec {
        padding: 6.667vw 0 !important;
    }

    .services-list li span {
        font-size: 1.867vw;
        padding: 1.333vw 2.667vw;
    }

    .services-list li {
        padding: 0.667vw;
    }

    .swiper-slide {
        width: 100%;
    }

    .mySwiper .swiper-slide .content {
        text-align: left;
        color: white;
        padding: 20px;
    }

    .mySwiper .swiper-slide .content .bottom h3 {
        font-size: 26px;
    }

    .mySwiper .swiper-slide .content .upper div .tag {
        font-size: 20px;
    }

    .mySwiper .swiper-slide .content .upper div .text {
        font-size: 4vw;
    }

    header.header {
        z-index: 16;
        display: flex;
        width: 100%;
        justify-content: space-between;
        padding: 1.5rem 10px 0;
        align-items: center;
        background: #00000017;
        backdrop-filter: blur(0.667vw);
    }

    .panel h1,
    .panel h2 {
        color: #FFF;
        text-align: center;
        text-shadow: 0vw 0.533vw 1.867vw rgba(82, 82, 82, 0.25);
        font-family: var(--font-heading);
        font-size: 32px;
        font-weight: 700;
        line-height: 1.2;
        letter-spacing: -0.123vw;
        transition: .5s ease;
    }

    .menu-bar {
        position: absolute;
        right: 0;
        top: 2.667vw;
        display: flex;
        justify-content: end;
        /* flex-direction: column; */
        align-items: start;
        gap: 2.667vw;
        z-index: 99;
        flex-direction: row-reverse;
        left: 0;
        margin: 0 auto;
    }

    a.menu-btn {
        width: 100%;
        /* background: white; */
        /* border-radius: 100%; */
        aspect-ratio: 1/1;
        /* position: relative; */
        /* display: flex; */
        /* align-items: center; */
        /* justify-content: center; */
        gap: 0vw;
        flex-direction: column;
        z-index: -1;
        top: -55px;
        padding-bottom: 26px;
        height: 120px;
    }

    a.menu-btn::before,
    a.menu-btn::after {
        content: "";
        width: 30px;
        height: .1vw;
        background: #333;
        transition: .5s ease;
    }

    a.menu-btn::after {
        margin-top: 10px;
    }

    .dropdown li {
        /* border-radius: 1.333vw; */
        transition: .5s ease;
    }

    .dropdown li a,
    .dropdown li p {
        font-size: 14px;
        line-height: 1.3;
        color: #222;
        width: 100%;
        padding: 12px 0;
    }

    .dropdown ul {
        display: flex;
        gap: 0.667vw;
        flex-direction: column;
        /* background: #00000040; */
        /* padding: 2.667vw; */
        /* border-radius: 1.333vw; */
    }

   

    .service-sec2 .row {
        padding: 2vw 0;
    }

    .profile-link {
        /* position: fixed; */
        /* color: white; */
        /* right: 1vw; */
        /* top: 40vh; */
        /* z-index: 2; */
    }

    .profile-link a {
        /* writing-mode: vertical-rl; */
        /* transform: rotate(180deg); */
        font-size: 1rem;
        color: #212121;
        padding: 10px;
        background: var(--primary);
        border-radius: 100vw;
    }

    .service-sec2 .row {
        padding: 2.667vw 0;
    }

    .project-imgs .col-md-6:nth-child(odd) {
        margin-top: 2vw;
    }
    .menu-bar {
        max-width: 90%;
    }
    header.header .wrap {
        top: -352px;
    }
    a.logo img {
        max-width: 180px;
    }
    .profile-link a span {
        display: none;
    }
    
    .profile-link a {
        width: 40px;
        height: 40px;
        flex-shrink: 0;
    }
    .mySwiper .swiper-slide .content .bottom a {
        width: 40px;
        height: 40px;
    }
    
    .mySwiper .swiper-slide .content .bottom a i {
        font-size: 20px;
    }
    .m-flip_item{
        line-height: 32px;
    }

    
    .about-content h5 {
        font-size: 16px;
    }
    
    .sevice-img.mb-5 {
        margin-bottom: 1rem !important;
    }
    
    .panel h4 {
        font-size: 24px;
    }
    
    .progress-box span {
        font-size: 32px;
        line-height: 42px;
    }
    .service-img.service-content a {
        margin: 1rem 0 1rem !important;
        display: flex;
    }
    
    .normal-scroll section {
        padding: 1rem 0;
    }
    .profile-link a img {
        display: block;
    }
    section#services {
        padding: 0;
    }
}