* {
  -webkit-box-sizing: border-box;
  box-sizing: border-box
}

body {
  color: var(--color-foreground);
  background: var(--color-background);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  margin: 0;
  min-height: 100svh
}

html {
  scrollbar-width: thin;
  scroll-behavior: smooth
}

img,
picture,
video {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  max-width: 100%;
  aspect-ratio: attr(width)/attr(height)
}

svg {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  max-width: 100%
}


input,
textarea, select {
  font: inherit;
  border-radius: var(--style-border-radius-inputs)
}

input,
textarea, select {
  color: var(--color-input-text);
  background-color: var(--color-input-background);
  border: var(--style-border-width-inputs) solid var(--color-input-border);
  outline: 0
}

input:focus,
input:hover,
textarea:focus,
textarea:hover {
  color: var(--color-input-hover-text);
  background-color: var(--color-input-hover-background);
  border-color: var(--color-input-hover-border)
}

h1,
h2,
h3,
h4,
h5,
h6, {
  overflow-wrap: break-word;
  margin: 0;
  padding: 0
}

p:empty {
  display: none
}


.svg-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center
}

.heading {
  color: var(--color-foreground-heading);
  font-weight: var(--font-heading--weight);
  font-family: var(--font-heading--family);
  font-style: var(--font-heading--style);
  letter-spacing: normal
}

.heading-color {
  color: var(--color-foreground-heading)
}

.subheading {
  color: var(--color-foreground-subheading);
  font-weight: 500;
  font-family: var(--font-heading--family);
  font-style: normal;
  letter-spacing: normal
}

.subheading-bg {
  background-color: var(--color-background-subheading);
  letter-spacing: normal;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 7px 20px;
  border-radius: 40px;
  border: 1px solid var(--color-border-subheading-bg);
  gap: 5px
}

.text {
  letter-spacing: normal;
  font-weight: var(--font-body--weight);
  color: var(--color-foreground);
  font-family: var(--font-body--family);
  font-style: var(--font-body--style)
}

.h1,
h1 {
  font-size: var(--font-h1--size);
  line-height: 1.16
}

.h2,
h2 {
  font-size: var(--font-h2--size);
  line-height: 1
}

.h3,
h3 {
  font-size: var(--font-h3--size);
  line-height: 1
}

.h4,
h4 {
  font-size: var(--font-h4--size);
  line-height: 1.2
}

.h5,
h5 {
  font-size: var(--font-h5--size);
  line-height: 1.3
}

.h6,
h6 {
  font-size: var(--font-h6--size);
  line-height: 1.4
}

.text-260 {
  font-size: 260px;
  line-height: 1;
  letter-spacing: 32px
}

.text-180 {
  font-size: 180px;
  line-height: 1
}

.text-90 {
  font-size: 90px;
  line-height: 1.15
}

.text-80 {
  font-size: 80px;
  line-height: 1.17
}

.text-64 {
  font-size: 64px;
  line-height: 1.2
}

.text-50 {
  font-size: 50px;
  line-height: 1.2
}

.text-36 {
  font-size: 36px;
  line-height: 1.2
}

.text-32 {
  font-size: 32px;
  line-height: 1.2
}

.text-30 {
  font-size: 30px;
  line-height: 1.2
}

.text-28 {
  font-size: 28px;
  line-height: 1.2
}

.text-24 {
  font-size: 24px;
  line-height: 1.25
}

.text-22 {
  font-size: 22px;
  line-height: 1.3
}

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

.text-18 {
  font-size: 18px;
  line-height: 1.55
}

.text-16 {
  font-size: 16px;
  line-height: 1.62
}

.text-14 {
  font-size: 14px;
  line-height: 1.62
}

.text-12 {
  font-size: 12px;
  line-height: 1
}

.fw-300 {
  font-weight: 300
}

.fw-400 {
  font-weight: 400
}

.fw-500 {
  font-weight: 500
}

.fw-600 {
  font-weight: 600
}

.fw-700 {
  font-weight: 700
}

@media (max-width:1440px) {
  .text-260 {
    font-size: 210px
  }

  .text-180 {
    font-size: 150px
  }
}

@media (max-width:1399px) {
  .text-180 {
    font-size: 120px
  }

  .text-90 {
    font-size: 70px
  }

  .text-80 {
    font-size: 60px
  }

  .text-64 {
    font-size: 54px
  }

  .text-50 {
    font-size: 38px
  }
}

@media (max-width:1199px) {
  .text-260 {
    font-size: 180px;
    letter-spacing: 24px
  }

  .text-180 {
    font-size: 100px
  }
}

@media (max-width:991px) {
  .text-260 {
    font-size: 130px;
    letter-spacing: 20px
  }

  .text-80,
  .text-90 {
    font-size: 60px
  }

  .text-64 {
    font-size: 50px
  }

  .text-50 {
    font-size: 36px
  }

  .text-180 {
    font-size: 80px
  }
}

@media (max-width:767px) {
  .text-260 {
    font-size: 60px;
    letter-spacing: 12px
  }

  .text-180 {
    font-size: 60px
  }

  .text-80,
  .text-90 {
    font-size: 45px
  }

  .text-64 {
    font-size: 42px
  }

  .text-50 {
    font-size: 30px
  }

  .text-36 {
    font-size: 32px
  }

  .text-32 {
    font-size: 30px
  }

  .text-30 {
    font-size: 28px
  }

  .text-28 {
    font-size: 24px
  }

  .text-24 {
    font-size: 22px
  }

  .text-22 {
    font-size: 20px
  }

  .text-20 {
    font-size: 18px
  }

  .text-18 {
    font-size: 16px
  }
}

.icon-80 {
  min-width: 80px;
  height: 80px
}

.icon-62 {
  min-width: 62px;
  height: 62px
}

.icon-50 {
  min-width: 50px;
  height: 50px
}

.icon-32 {
  min-width: 32px;
  height: 32px
}

.icon-28 {
  min-width: 28px;
  height: 28px
}

.icon-24 {
  min-width: 24px;
  height: 24px
}

.icon-20 {
  min-width: 20px;
  height: 20px
}

.icon-18 {
  min-width: 18px;
  height: 18px
}

.icon-14 {
  min-width: 14px;
  height: 14px
}

@media (max-width:767px) {
  .icon-80 {
    min-width: 60px;
    height: 60px
  }

  .icon-62 {
    min-width: 48px;
    height: 48px
  }
}

.button {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  min-height: var(--style-button-height);
  font-size: var(--font-button-size);
  font-weight: var(--font-button--weight);
  font-family: var(--font-button--family);
  font-style: normal;
  line-height: 1.4;
  letter-spacing: normal;
  padding: 10px 10px 10px 30px;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  text-decoration: none;
  border: none;
  outline: 0;
  -webkit-box-shadow: none;
  box-shadow: none;
  -webkit-transition: all .3s;
  -o-transition: all .3s;
  transition: all .3s
}

.button-without-icon {
  padding: 10px 30px
}

.button-without-icon.button--slim {
  padding: 10px 15px
}

.button--slim {
  height: var(--style-button-slim-height);
  min-height: var(--style-button-slim-height)
}

.button--primary {
  color: var(--color-primary-button-text);
  background-color: var(--color-primary-button-background);
  border: var(--style-border-width-buttons-primary) solid var(--color-primary-button-border);
  border-radius: var(--style-border-radius-buttons-primary)
}

.button--primary:focus,
.button--primary:hover {
  outline: 0;
  -webkit-box-shadow: none;
  box-shadow: none;
  color: var(--color-primary-button-hover-text);
  background-color: var(--color-primary-button-hover-background);
  border: var(--style-border-width-buttons-primary) solid var(--color-primary-button-hover-border)
}

.button--secondary {
  color: var(--color-secondary-button-text);
  background-color: var(--color-secondary-button-background);
  border: var(--style-border-width-buttons-secondary) solid var(--color-secondary-button-border);
  border-radius: var(--style-border-radius-buttons-secondary)
}

.button--secondary:focus,
.button--secondary:hover {
  color: var(--color-secondary-button-hover-text);
  background-color: var(--color-secondary-button-hover-background);
  border: var(--style-border-width-buttons-secondary) solid var(--color-secondary-button-hover-border)
}

.button .svg-wrapper {
  color: var(--color-primary-button-icon);
  background-color: var(--color-primary-button-icon-background);
  -webkit-transition: all .3s;
  -o-transition: all .3s;
  transition: all .3s;
  min-width: 36px;
  height: 36px;
  border-radius: 100%
}

.button:focus .svg-wrapper,
.button:hover .svg-wrapper {
  color: var(--color-primary-button-hover-icon);
  background-color: var(--color-primary-button-hover-icon-background)
}

.button--secondary .svg-wrapper {
  color: var(--color-secondary-button-icon);
  background-color: var(--color-secondary-button-icon-background)
}

.button--secondary:focus .svg-wrapper,
.button--secondary:hover .svg-wrapper {
  color: var(--color-secondary-button-hover-icon);
  background-color: var(--color-secondary-button-hover-icon-background)
}

.button--cta {
  font-size: 16px;
  font-weight: 500;
  font-family: var(--font-button--family);
  font-style: normal;
  line-height: 1;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  -webkit-transition: all .3s;
  -o-transition: all .3s;
  transition: all .3s;
  color: var(--color-primary);
  text-decoration: none;
  border-bottom: var(--style-cta-underline-thickness) solid var(--color-primary);
  -webkit-padding-after: var(--style-cta-underline-offset);
  padding-block-end: var(--style-cta-underline-offset)
}

.button--cta svg {
  --size: 12px;
  width: var(--size);
  height: var(--size)
}

.button--cta:hover {
  color: var(--color-primary-hover);
  border-color: var(--color-primary-hover)
}

@media (max-width:767px) {
  .button {
    min-height: var(--style-button-height-mobile);
    font-size: var(--font-button-size-mobile)
  }

  .button--slim {
    height: var(--style-button-slim-height-mobile);
    min-height: var(--style-button-slim-height-mobile)
  }
}

.content-absolute {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  z-index: 999
}

.overlay:after {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background: var(--color-overlay)
}

.list-unstyled {
  padding: 0;
  list-style: none;
  margin: 0
}

.border-bottom--theme {
  border-bottom: var(--style-border-width) solid var(--color-border)
}

.height-100 {
  height: 100%
}

.height-auto {
  min-height: auto;
  height: auto
}

.mt-100 {
  margin-top: 100px
}

.no-box-shadow {
  -webkit-box-shadow: none !important;
  box-shadow: none !important
}

.section-content {
  display: block;
  -webkit-margin-before: 45px;
  margin-block-start: 45px
}

.section-headings-horizontal {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  gap: 20px
}

.section-headings-vertical {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  gap: 20px
}

.section-headings-right {
  min-width: -webkit-fit-content;
  min-width: -moz-fit-content;
  min-width: fit-content
}

.section-headings-right>.text+.button {
  -webkit-margin-before: 40px;
  margin-block-start: 40px
}

.headings-width,
.section-headings-left {
  max-width: 645px
}

.headings-width {
  -webkit-margin-start: auto;
  margin-inline-start: auto;
  -webkit-margin-end: auto;
  margin-inline-end: auto
}

.section-headings .subheading+.heading {
  -webkit-margin-before: 30px;
  margin-block-start: 30px
}

.section-headings .heading+.text,
.section-headings .list-block,
.section-headings .text-lists {
  -webkit-margin-before: 30px;
  margin-block-start: 30px
}

.section-headings:not(.section-headings-horizontal) .buttons {
  -webkit-margin-before: 50px;
  margin-block-start: 50px
}

.section-headings-sticky {
  --position: calc(var(--header-height) + 40px);
  position: -webkit-sticky;
  position: sticky;
  top: var(--position, 0)
}

.section-padding {
  --padding-top: 100px;
  --padding-bottom: 100px;
  -webkit-padding-before: var(--padding-top);
  padding-block-start: var(--padding-top);
  -webkit-padding-after: var(--padding-bottom);
  padding-block-end: var(--padding-bottom)
}

@media (max-width:991px) {
  .mt-100 {
    margin-top: 80px
  }

  .section-padding {
    --padding-top: 80px;
    --padding-bottom: 80px
  }

  .section-content {
    -webkit-margin-before: 40px;
    margin-block-start: 40px
  }
}

@media (max-width:767px) {
  .mt-100 {
    margin-top: 60px
  }

  .section-headings .subheading+.heading {
    -webkit-margin-before: 20px;
    margin-block-start: 20px
  }

  .section-headings .heading+.text,
  .section-headings .list-block,
  .section-headings .text-lists {
    -webkit-margin-before: 30px;
    margin-block-start: 30px
  }

  .section-headings .buttons,
  .section-headings:not(.section-headings-horizontal) .buttons {
    -webkit-margin-before: 40px;
    margin-block-start: 40px
  }

  .section-headings-horizontal {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    gap: 24px
  }

  .section-headings-horizontal .buttons {
    width: 100%
  }

  .section-padding {
    --padding-top: 60px;
    --padding-bottom: 60px
  }

  .section-headings-right>.text+.button {
    -webkit-margin-before: 40px;
    margin-block-start: 40px
  }
}

.visually-hidden {
  position: absolute;
  overflow: hidden;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  clip: rect(0 0 0 0);
  word-wrap: normal
}

.radius18 {
  border-radius: 18px;
  overflow: hidden
}

.card-icon-text .svg-wrapper {
  --size: 70px;
  min-width: var(--size, 70px);
  width: var(--size, 70px);
  height: var(--size, 70px)
}

.card-icon-text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 16px
}

.card-icon-text .heading+.text {
  -webkit-margin-before: 10px;
  margin-block-start: 10px
}

.card-icon-text-horizontal {
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap
}

.service-slider .card-icon-text-horizontal {
  -webkit-margin-before: 20px;
  margin-block-start: 20px;
  gap: 30px
}

@media (max-width:1279px) {
  .card-icon-text .svg-wrapper {
    --size: 60px
  }
}

@media (max-width:767px) {
  .radius18 {
    border-radius: 10px
  }
}

@-webkit-keyframes inifinte-rotation {
  from {
    -webkit-transform: rotate(0)
  }

  to {
    -webkit-transform: rotate(360deg)
  }
}

@keyframes inifinte-rotation {
  from {
    -webkit-transform: rotate(0)
  }

  to {
    -webkit-transform: rotate(360deg)
  }
}

.overflow-hidden {
  overflow: hidden
}

.media-wrapper {
  position: relative;
  height: 100%
}

.media {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  overflow: hidden
}

.media-bg {
  z-index: -1
}

.media img {
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover
}

.swiper:not(.swiper-initialized) {
  opacity: 0
}

.swiper-nav-inner>* {
  --size: 44px;
  --color-border: rgba(28, 37, 57, 0);
  --style-border-width: 1px;
  position: static;
  width: var(--size);
  height: var(--size);
  border-radius: 100%;
  border: var(--style-border-width) solid var(--color-border);
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s;
  margin: 0
}

.swiper-nav-inner>:focus,
.swiper-nav-inner>:hover {
  --color-border: rgba(28, 37, 57, 1)
}

.swiper-nav-inner svg {
  width: var(--swiper-navigation-size);
  height: var(--swiper-navigation-size)
}

.swiper-nav-border {
  --margin-top: 60px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-margin-before: var(--margin-top);
  margin-block-start: var(--margin-top);
  position: relative
}

.swiper-nav-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: 24px;
  position: relative;
  z-index: 2;
  background: #fff;
  padding: 0 20px
}

.swiper-nav-border:after {
  --color-border: rgba(93, 102, 111, 1);
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  height: 1px;
  background: var(--color-border);
  width: 90%
}

@media (max-width:767px) {
  .swiper-nav-border {
    --margin-top: 40px
  }

  .swiper-nav-inner>* {
    --size: 36px
  }

  .swiper-nav-inner {
    gap: 16px
  }
}

.product-grid {
  row-gap: 30px
}

@media (min-width:1280px) {
  .container-fluid {
    max-width: 1680px;
    -webkit-padding-start: 3rem;
    padding-inline-start: 3rem;
    -webkit-padding-end: 3rem;
    padding-inline-end: 3rem
  }
}

@media (max-width:991px) {

  .container,
  .container-md,
  .container-sm {
    max-width: 100%
  }
}

@media (min-width:768px) and (max-width:991px) {

  .container,
  .container-fluid,
  .container-lg,
  .container-md,
  .container-sm,
  .container-xl {
    --bs-gutter-x: 3rem
  }
}

@media (max-width:767px) {
  .product-grid {
    row-gap: 24px
  }
}

.decorated-text {
  position: relative;
  display: inline-block;
  padding: 6px 12px;
  outline: 1.5px solid var(--color-foreground-heading);
  outline-offset: -9px
}

.decorated-text::after,
.decorated-text::before {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  background: var(--color-foreground-heading)
}

.decorated-text::before {
  top: 0;
  left: 0
}

.decorated-text::after {
  bottom: 0;
  right: 0
}

.decorated-text span::after,
.decorated-text span::before {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  background: var(--color-foreground-heading)
}

.decorated-text span::before {
  top: 0;
  right: 0
}

.decorated-text span::after {
  bottom: 0;
  left: 0
}

.accordion-block {
  --color-background: rgba(242, 242, 242, 1);
  border-radius: 10px;
  background-color: var(--color-background);
  overflow: hidden
}

.accordion-opener {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  gap: 32px;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  padding: 24px 20px;
  cursor: pointer
}

.accordion-block.active .accordion-opener {
  --color-background: rgba(28, 37, 57, 1);
  --color-foreground-heading: rgba(255, 255, 255, 1);
  background-color: var(--color-background);
  -webkit-transition: all .3s;
  -o-transition: all .3s;
  transition: all .3s
}

.accordion-content {
  max-height: 0;
  -webkit-transition: max-height .3s ease-in-out;
  -o-transition: max-height .3s ease-in-out;
  transition: max-height .3s ease-in-out
}

.accordion-content-inner {
  padding: 24px 20px
}

.accordion-opener .svg-wrapper {
  --color-background: rgba(32, 40, 45, 1);
  min-width: 30px;
  height: 30px;
  background-color: var(--color-background);
  border-radius: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-transition: all .3s;
  -o-transition: all .3s;
  transition: all .3s
}

.accordion-block.active .accordion-opener .svg-wrapper {
  --color-background: rgba(255, 255, 255, 1);
  -webkit-transform: rotate(-180deg);
  -ms-transform: rotate(-180deg);
  transform: rotate(-180deg);
  -webkit-transition: all .3s;
  -o-transition: all .3s;
  transition: all .3s
}

.accordion-opener .svg-wrapper svg {
  --color-foreground: rgba(255, 255, 255, 1);
  color: var(--color-foreground)
}

.accordion-block.active .accordion-opener .svg-wrapper svg {
  --color-foreground: rgba(32, 40, 45, 1);
  color: var(--color-foreground)
}

@media (max-width:767px) {
  .accordion-opener {
    gap: 24px;
    padding: 24px 15px
  }

  .accordion-content-inner {
    padding: 24px 15px
  }
}

.video {
  --color-foreground: rgba(255, 255, 255, 0.7);
  --color-foreground-heading: rgba(255, 255, 255, 1);
  --color-primary-button-text: rgba(32, 40, 45, 1);
  --color-primary-button-background: rgba(255, 255, 255, 1);
  --color-primary-button-border: rgba(255, 255, 255, 1);
  position: relative;
  min-height: 530px
}

.video .content {
  max-width: 546px;
  -webkit-margin-start: auto;
  margin-inline-start: auto;
  -webkit-margin-end: auto;
  margin-inline-end: auto
}

.video .video-wrap {
  -webkit-margin-before: 70px;
  margin-block-start: 70px;
  display: block
}

.hero-slider {
  --color-foreground: rgba(255, 255, 255, 1);
  --color-foreground-heading: rgba(255, 255, 255, 1);
  --color-foreground-subheading: rgba(255, 255, 255, 1);
  --slider-nav-height: 120px;
  min-height: 100vh
}

.hero-slider-wrapper {
  display: block
}

.slider-card {
  position: relative;
  -webkit-padding-before: var(--slider-nav-height);
  padding-block-start: var(--slider-nav-height);
  -webkit-padding-after: var(--slider-nav-height);
  padding-block-end: var(--slider-nav-height)
}

.slider-card .content-box {
  max-width: 772px
}

.slider-card-4 .content-box {
  max-width: 1000px
}

.slider-card-4 .heading-color {
  --color-foreground-heading: rgba(130, 180, 255, 1)
}

.slider-media {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 100%
}

.slider-media img {
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  height: 100%
}

.slider-nav {
  position: absolute;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  bottom: 0;
  left: 0;
  z-index: 99;
  width: 100%;
  height: var(--slider-nav-height)
}

hero-slider {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex
}

.slider-card {
  height: 100%
}

.slider-media {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%
}

.slider-content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  height: 100%;
  position: relative;
  z-index: 1
}

@media (max-width:1600px) {
  .hero-slider {
    --slider-nav-height: 80px
  }

}

@media (max-width:1280px) {
  .hero-slider {
    --slider-nav-height: 60px
  }

  .hero-slider-3 {
    min-height: 640px
  }
}

@media (max-width:991px) {
  .header-nav {
    --color-background: rgba(242, 242, 242, 1);
    --color-foreground: rgba(32, 40, 45, 1);
    --color-foreground-heading: rgba(28, 37, 57, 1);
    --color-primary: rgba(32, 40, 45, 1);
    --color-primary-background: rgba(240, 237, 239, 0);
    --color-primary-hover: rgba(32, 40, 45, 1);
    --color-primary-background-hover: rgba(233, 233, 233, 1);
    position: fixed;
    right: 0;
    top: 0;
    background: var(--color-background);
    z-index: 10;
    width: 100%;
    height: 100%;
    -webkit-transition: all .3s;
    -o-transition: all .3s;
    transition: all .3s;
    -webkit-transform: translateX(100%);
    -ms-transform: translateX(100%);
    transform: translateX(100%);
    overflow-y: auto
  }

  .header-nav-headings {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 20px;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    padding: 15px
  }

  .header-nav-headings .svg-wrapper {
    color: #000;
    width: 44px;
    height: 44px;
    margin-right: -10px
  }
}

.accordion-title {
  cursor: pointer
}

.accordion-title * {
  pointer-events: none
}

.accordion-li {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column
}

@media (min-width:992px) {
  .accordion-horizontal .accordion-li {
    min-width: var(--width);
    width: var(--width);
    overflow: hidden;
    -webkit-transition: width .4s ease, min-width .4s ease;
    -o-transition: width .4s ease, min-width .4s ease;
    transition: width .4s ease, min-width .4s ease
  }

  .accordion-horizontal .accordion-li.active {
    width: 100%;
    min-width: 420px
  }
}

@media (max-width:991px) {
  .accordion-title {
    width: 100%;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between
  }
}

form input,
form textarea, form select {
  width: 100%;
  padding: 0 15px;
  min-height: 54px
}

form textarea {
  padding: 20px 15px
}

.form {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 20px
}

.form>* {
  width: 100%
}

.contact-box-headings+form {
  -webkit-margin-before: 40px;
  margin-block-start: 40px
}

.contact-box {
  background: #fff;
  -webkit-box-shadow: 0 4px 4px 0 rgba(0, 0, 0, .25);
  box-shadow: 0 4px 4px 0 rgba(0, 0, 0, .25);
  overflow: hidden;
  position: relative;
  z-index: 1
}

.contact-form-wrap {
  padding: 40px
}

.contact-media {
  height: 400px
}

.contact-media img {
  -o-object-fit: cover;
  object-fit: cover;
  height: 100%
}

.contact-form .form-button {
  -webkit-margin-before: 20px;
  margin-block-start: 20px
}

@media (min-width:768px) {
  .form {
    gap: 24px
  }

  .form>.w-half {
    width: calc(50% - 24px / 2)
  }
}

@media (min-width:992px) {
  .contact-media {
    height: 100%
  }
}

@media (max-width:767px) {

  form input,
  form textarea {
    min-height: 48px
  }

  .contact-box-headings+form {
    -webkit-margin-before: 30px;
    margin-block-start: 30px
  }

  .contact-form-wrap {
    padding: 30px 15px
  }

  .contact-media {
    height: 300px
  }
}

.text-lists .text-item {
  --color-foreground: rgba(28, 37, 57, 1)
}

.text-lists .text-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 14px
}

.text-lists .text-item svg {
  min-width: 28px;
  height: 28px
}

.text-lists .text-item:not(:first-child) {
  -webkit-margin-before: 18px;
  margin-block-start: 18px
}

.image-text .media-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 100%;
  position: relative
}

.image-text .media-wrap img {
  -o-object-fit: contain;
  object-fit: contain;
  width: 100%;
}
.image-text .image img {
    width: 100%;
}
.image-text .video-wrap img {
  -o-object-fit: cover;
  object-fit: cover;
  height: 100%
}

.list-block .text-item {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: 0;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  max-width: 225px;
  margin: 0
}

.list-block .text-item svg {
  min-width: 60px;
  height: 60px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex
}

.list-block .title {
  -webkit-margin-before: 32px;
  margin-block-start: 32px
}

.list-block .text {
  -webkit-margin-before: 20px;
  margin-block-start: 20px
}

.list-block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 30px
}

.list-block .text-item {
  -webkit-margin-before: 0;
  margin-block-start: 0
}

.image-small {
  position: absolute;
  right: 0;
  bottom: 30px;
  z-index: 2;
  border-radius: 10px;
  background: rgba(255, 255, 255, .6);
  -webkit-backdrop-filter: blur(60px);
  backdrop-filter: blur(60px);
  -webkit-box-shadow: 0 30px 90px 0 #041f1f4d;
  box-shadow: 0 30px 90px 0 #041f1f4d
}

.image-small img {
  border-radius: inherit
}

.text-image-sticky .section-headings-right {
  min-width: auto
}

.text-image-sticky .image-text-card {
  position: -webkit-sticky;
  position: sticky;
  padding: 60px 40px;
  background-color: var(--color-background)
}

.text-image-sticky .image-text-card {
  --position: calc(var(--header-height) + var(--top, 40px));
  background-color: var(--color-background);
  top: var(--position)
}

.text-image-sticky .image-text-card:nth-child(1) {
  --color-background: rgba(239, 238, 251, 1);
  --top: 40px
}

.text-image-sticky .image-text-card:nth-child(2) {
  --color-background: rgba(235, 250, 165, 1);
  --top: 100px
}

.text-image-sticky .image-text-card:nth-child(3) {
  --color-background: rgba(212, 230, 233, 1);
  --top: 160px
}

.text-image-sticky-2 .image-text-card:nth-child(1),
.text-image-sticky-2 .image-text-card:nth-child(2),
.text-image-sticky-2 .image-text-card:nth-child(3) {
  --color-border: rgba(28, 37, 57, 0.7);
  --color-background: rgba(255, 255, 255, 1);
  padding: 0;
  border-top: 2px solid var(--color-border);
  padding-top: 40px;
  margin-top: 40px
}

.text-image-sticky-2 .image-text-card:nth-child(2) {
  --top: 40px
}

.image-text-video .headings-width {
  max-width: 950px;
  -webkit-margin-start: 0;
  margin-inline-start: 0
}

@media (min-width:992px) {
  .image-text .content {
    -webkit-padding-start: 32px;
    padding-inline-start: 32px
  }
}

@media (min-width:1400px) {
  .image-text .content {
    -webkit-padding-start: 55px;
    padding-inline-start: 55px
  }
}

@media (max-width:991px) {
  .image-text .content {
    -webkit-padding-before: 60px;
    padding-block-start: 60px
  }

  .list-block .text-item svg {
    min-width: 48px;
    height: 48px
  }

  .text-image-sticky .image-text-card {
    padding: 48px 24px
  }
}

@media (max-width:767px) {
  .image-text .content {
    -webkit-padding-before: 40px;
    padding-block-start: 40px
  }

  .text-image-sticky .image-text-card {
    padding: 32px 16px
  }

  .image-text-video .heading {
    font-size: 30px
  }
}

@media (max-width:575px) {
  .image-small img {
    max-width: 140px
  }
}

.hero-banner {
  --padding-block-start: 100px;
  --padding-block-bottom: 100px;
  min-height: 100vh;
  -webkit-padding-before: var(--padding-block-start);
  padding-block-start: var(--padding-block-start);
  -webkit-padding-after: var(--padding-block-bottom);
  padding-block-end: var(--padding-block-bottom);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  position: relative;
  overflow: hidden
}

.hero-banner-2 {
  --color-secondary-button-border: rgba(32, 40, 45, 1);
  overflow: hidden
}

.hero-banner-2 .section-headings-left {
  max-width: 560px
}

.hero-banner-2 .text-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
  gap: 6px
}

.hero-banner-2 .text-wrapper .heading {
  line-height: .9
}

.hero-banner-2 .buttons {
  margin-top: 40px
}

.hero-banner .content>.buttons {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 30px
}

.banner-slider {
  display: block;
  position: relative
}

.hero-banner .main-img {
  position: relative;
  border-radius: 10px
}

.hero-banner .main-img img {
  -o-object-fit: cover;
  object-fit: cover;
  height: 100%
}

.hero-banner .main-img img {
  -webkit-mask-image: url(../img/slider/subtract.png);
  mask-image: url(../img/slider/subtract.png);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-size: 100%;
  mask-size: 100%
}

.text-banner {
  --color-background: rgba(28, 37, 57, 1);
  --color-foreground: rgba(255, 255, 255, 1);
  --color-foreground-heading: rgba(255, 255, 255, 1);
  --color-foreground-subheading: rgba(255, 255, 255, 1);
  --color-secondary-button-hover-border: rgb(255, 255, 255, 0.3)
}

.text-banner-inner {
  --padding: 60px;
  background-color: var(--color-background);
  padding: var(--padding)
}

.text-banner .section-headings .text {
  max-width: 800px
}

.hero-banner-2 .banner-wrapper {
  position: relative;
  min-height: 720px
}

.hero-banner-2 .content-absolute {
  z-index: 1
}

.hero-banner-2.about-us-2 .content-box {
  --color-foreground: rgba(255, 255, 255, 1);
  --color-foreground-heading: rgba(255, 255, 255, 1);
  --color-border: rgba(255, 255, 255, 0.4);
  width: 100%;
  padding: 40px
}

.hero-banner-2.about-us-2 .content-box .section-headings {
  border-top: 1px solid var(--color-border);
  padding-top: 40px;
  margin-top: 40px
}

.hero-slider.height-auto {
  min-height: auto
}

@media (max-width:991px) {
  .banner-slider {
    -webkit-margin-before: 50px;
    margin-block-start: 50px
  }

  .hero-banner-2 .section-headings-horizontal {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    gap: 30px
  }

  .hero-banner-2 .section-headings-left {
    max-width: 100%
  }
}

@media (max-width:767px) {
  .hero-banner {
    --padding-block-start: 60px;
    --padding-block-bottom: 60px
  }

  .text-banner-inner {
    --padding: 40px 15px
  }

  .hero-banner .content>.buttons {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start
  }

  .hero-banner-2 .buttons {
    margin-top: 30px
  }

  .hero-banner-2.about-us-2 .content-box {
    padding: 24px 16px
  }

  .hero-banner-2.about-us-2 .content-box .section-headings {
    padding-top: 32px;
    margin-top: 32px
  }
}

.brand {
  position: relative
}

.brand-bg {
  background: #e7e7e7
}

.brand-logo {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center
}

.brand-logo img {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content
}

.brand .product-grid {
  row-gap: 24px
}

@-webkit-keyframes scroll {
  from {
    -webkit-transform: translateX(0);
    transform: translateX(0)
  }

  to {
    -webkit-transform: translateX(-100%);
    transform: translateX(-100%)
  }
}

@keyframes scroll {
  from {
    -webkit-transform: translateX(0);
    transform: translateX(0)
  }

  to {
    -webkit-transform: translateX(-100%);
    transform: translateX(-100%)
  }
}

.multicolumn {
  position: relative;
  overflow: hidden
}

.multicolumn.with-bg-color {
  --color-background: rgba(242, 242, 242, 1);
  background-color: var(--color-background)
}

.multicolumn.with-bg-color .multicolumn-inner {
  -webkit-margin-before: 60px;
  margin-block-start: 60px
}

.multicolumn-card {
  --color-background: rgba(255, 255, 255, 1)
}

.multicolumn-card .card-icon {
  --color-background: rgba(242, 242, 242, 1)
}

.multicolumn-header {
  text-align: center;
  max-width: 638px;
  -webkit-margin-start: auto;
  margin-inline-start: auto;
  -webkit-margin-end: auto;
  margin-inline-end: auto
}

.multi-col {
  -webkit-margin-before: 60px;
  margin-block-start: 60px
}

.multicolumn .multicolumn-card {
  padding: 36px;
  background-color: var(--color-background);
  border-radius: 10px;
  overflow: hidden;
  height: 100%;
  text-decoration: none;
  display: block;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s
}

.multicolumn .multicolumn-card:focus,
.multicolumn .multicolumn-card:hover {
  --color-background: rgba(32, 40, 45, 1);
  --color-foreground: rgba(255, 255, 255, 1);
  --color-foreground-heading: rgba(255, 255, 255, 1)
}

.multicolumn .card-icon {
  width: 70px;
  height: 70px;
  color: var(--color-foreground);
  background-color: var(--color-background);
  border-radius: 10px;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center
}

.multicolumn .multicolumn-card:focus .card-icon,
.multicolumn .multicolumn-card:hover .card-icon {
  --color-foreground: rgba(32, 40, 45, 1);
  --color-background: rgba(255, 255, 255, 1)
}

.multicolumn-card:focus .text-lists .text-item,
.multicolumn-card:hover .text-lists .text-item {
  --color-foreground: rgba(255, 255, 255, 1)
}

.multicolumn-card>.card-icon+.heading {
  -webkit-margin-before: 44px;
  margin-block-start: 44px
}

.multicolumn-card>.text {
  -webkit-margin-before: 24px;
  margin-block-start: 24px
}

.multicolumn-card>.text-lists {
  -webkit-margin-before: 32px;
  margin-block-start: 32px
}

.multicolumn-card>.text-lists>li+li {
  -webkit-margin-before: 18px;
  margin-block-start: 18px
}

.multicolumn-card .text-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 4px
}

.multicolumn-card .text-item svg {
  min-width: 24px;
  height: 24px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex
}

@media (max-width:1279px) {
  .multicolumn .multicolumn-card {
    padding: 36px 24px
  }
}

@media (max-width:991px) {
  .multi-col {
    -webkit-margin-before: 40px;
    margin-block-start: 40px
  }
}

@media (max-width:767px) {
  .multicolumn .multicolumn-card {
    padding: 24px 16px
  }

  .multicolumn-card>.card-icon+.heading {
    -webkit-margin-before: 32px;
    margin-block-start: 32px
  }

  .multicolumn.with-bg-color .multicolumn-inner {
    -webkit-margin-before: 40px;
    margin-block-start: 40px
  }
}

.project-media-button {
  --style-border-width-buttons-primary: 2px;
  --color-primary-button-border: rgba(255, 255, 255, 1);
  --color-background: rgba(32, 40, 45, 1)
}

.project-content {
  --color-background: rgba(32, 40, 45, 1);
  --color-foreground-heading: rgba(255, 255, 255, 1);
  --color-foreground: rgba(242, 242, 242, 1)
}

.project-button .button--secondary:focus,
.project-button .button--secondary:hover {
  --color-secondary-button-hover-border: rgba(255, 255, 255, 0.3)
}

.project-media {
  -webkit-margin-before: 60px;
  margin-block-start: 60px
}

.project-img {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  overflow: hidden;
  position: relative
}

.project-img img {
  -o-object-fit: cover;
  object-fit: cover;
  height: auto
}

.project-media-button {
  width: 60px;
  height: 60px;
  border-radius: 100%;
  text-decoration: none;
  position: absolute;
  bottom: -30px;
  z-index: 2;
  padding: 0
}

.project-button .button--secondary:focus,
.project-button .button--secondary:hover {
  color: var(--color-secondary-button-hover-text);
  background-color: var(--color-secondary-button-hover-background);
  border: var(--style-border-width-buttons-secondary) solid var(--color-secondary-button-hover-border)
}

.project-media-button svg {
  min-width: 28px;
  height: 28px
}

.project-content {
  max-width: 645px;
  -webkit-margin-start: auto;
  margin-inline-start: auto;
  background-color: var(--color-background);
  padding: 40px;
  -webkit-margin-before: -160px;
  margin-block-start: -160px;
  z-index: 3;
  position: relative
}

.project-grid .card-project img {
  -webkit-transition: all .3s;
  -o-transition: all .3s;
  transition: all .3s
}

.project-grid .card-project:hover>img {
  -webkit-transform: scale(1.05);
  -ms-transform: scale(1.05);
  transform: scale(1.05);
  -webkit-transition: all .3s;
  -o-transition: all .3s;
  transition: all .3s
}

@media (max-width:1199px) {
  .project-content {
    max-width: 510px;
    padding: 32px 24px
  }
}

@media (max-width:991px) {
  .project-media {
    -webkit-margin-before: 40px;
    margin-block-start: 40px
  }

  .project-img-small {
    -webkit-margin-before: 48px;
    margin-block-start: 48px
  }

  .project-content {
    max-width: 100%;
    -webkit-margin-before: 40px;
    margin-block-start: 40px
  }
}

@media (max-width:767px) {
  .project-media-button {
    width: 48px;
    height: 48px;
    bottom: -24px
  }

  .project-media-button svg {
    min-width: 20px;
    height: 20px
  }

  .project-content {
    padding: 24px 16px 30px
  }
}

.our-services {
  --color-background: rgba(32, 40, 45, 1);
  --color-foreground: rgba(255, 255, 255, 1);
  --color-foreground-heading: rgba(255, 255, 255, 1);
  --color-foreground-subheading: rgba(242, 242, 242, 1);
  --color-background-subheading: rgba(255, 255, 255, 0);
  --color-border-subheading-bg: rgba(255, 255, 255, 0.3);
  --color-secondary-button-hover-border: rgba(255, 255, 255, 0.3);
  background: var(--color-background);
  overflow: hidden
}

.our-services-2 {
  --color-background: rgba(228, 226, 239, 0);
  --color-foreground: rgba(28, 37, 57, 1);
  --color-foreground-heading: rgba(28, 37, 57, 1);
  --color-foreground-subheading: rgba(93, 102, 111, 1);
  --color-background-subheading: rgba(255, 255, 255, 0.1);
  --color-border-subheading-bg: rgba(32, 40, 45, 0.1)
}

.our-services-2 .multicolumn .multicolumn-card:not(:focus):not(:hover) {
  --color-background: rgba(242, 242, 242, 1)
}

.our-services .service-list {
  --color-background: rgba(62, 72, 78, 1);
  --color-primary-button-background: rgb(255, 255, 255, 0);
  --color-primary-button-border: rgba(255, 255, 255, 1);
  background: var(--color-background);
  padding: 40px 36px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  overflow: hidden;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap
}

.our-services .service-content-inner .button {
  padding: 10px;
  min-height: 44px;
  font-size: 16px;
  -webkit-margin-before: 80px;
  margin-block-start: 80px
}

.our-services .service-content-inner .heading {
  -webkit-margin-before: 50px;
  margin-block-start: 50px
}

.our-services .service-content-inner .heading+.text {
  -webkit-margin-before: 24px;
  margin-block-start: 24px
}

.service-list .accordion-li {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  overflow: hidden
}

.service-list .accordion-li svg {
  --size: 70px;
  width: var(--size);
  min-width: var(--size);
  height: var(--size)
}

.service-list .accordion-li .icon {
  --size: 44px;
  color: var(--color-foreground);
  width: var(--size);
  min-width: var(--size);
  height: var(--size)
}

.service-list .accordion-li .accordion-title,
.service-list .accordion-li .accordion-title-icon {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 15px
}

.service-list .accordion-content {
  --padding: 36px;
  padding: 0 var(--padding)
}

.service-list .accordion-li .icon+.icon {
  display: none
}

.service-slider .swiper {
  overflow: visible
}

.service-slider .card-service {
  display: block;
  text-decoration: none
}

.service-slider .card-service img {
  height: 440px;
  -o-object-fit: cover;
  object-fit: cover
}

.service-slider .swiper-pagination-bullet.swiper-pagination-bullet-active {
  --swiper-pagination-color: rgb(39, 61, 109)
}

.card-service-content {
  --color-background: rgba(255, 255, 255, 0.8);
  --color-foreground: rgba(28, 37, 57, 1);
  --color-foreground-heading: rgba(28, 37, 57, 1);
  background: var(--color-background);
  padding: 32px 24px;
  border-radius: 18px;
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  -webkit-transition: all .3s;
  -o-transition: all .3s;
  transition: all .3s
}

.card-service-content .card-working-process .has-border {
  --color-border: rgba(255, 255, 255, 0.2)
}

.card-service-content .svg-wrapper svg {
  --color-icon: rgba(28, 37, 57, 1);
  color: var(--color-icon)
}

.card-service-content-absolute {
  position: absolute;
  bottom: 0;
  left: auto;
  padding: 40px;
  width: 100%
}

.service-slider .card-service:hover .card-service-content {
  --color-background: rgba(28, 37, 57, 1);
  --color-foreground: rgba(255, 255, 255, 1);
  --color-foreground-heading: rgba(255, 255, 255, 1);
  --color-icon: rgba(255, 255, 255, 1)
}

.service-slider .card-service:hover .card-service-content .svg-wrapper svg {
  --color-icon: rgba(255, 255, 255, 1)
}

.service-content-left .card-icon {
  --color-foreground: rgba(28, 37, 57, 1);
  --color-background: rgba(255, 255, 255, 1);
  width: 50px;
  height: 50px;
  color: var(--color-foreground);
  background-color: var(--color-background);
  border-radius: 10px;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center
}

.service-content-left {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 60px 16px;
  height: 100%
}

.service-content-left .headings-width {
  max-width: 790px
}

.service-content-image img {
  height: inherit;
  -o-object-fit: cover;
  object-fit: cover
}

.our-services .service-content-left .service-list {
  background: 0 0;
  overflow: hidden;
  padding: 60px 0 48px
}

.service-content-left .multicolumn-card>.card-icon+.heading {
  -webkit-margin-before: 20px;
  margin-block-start: 20px
}

.service-content-left .section-headings .heading+.text {
  -webkit-margin-before: 16px;
  margin-block-start: 16px
}

.service-content-left .service-list .product-grid {
  row-gap: 50px
}

@media (min-width:992px) {
  .service-list .service-content-inner {
    max-width: 360px;
    min-width: 360px;
    height: 100%;
    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-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between
  }

  .service-list .accordion-content {
    height: 100%;
    max-height: unset
  }

  .our-services .accordion-li {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row
  }

  .our-services .service-list {
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
    overflow-x: auto
  }

  .service-list .accordion-li .accordion-title,
  .service-list .accordion-li .accordion-title-icon {
    gap: 20px;
    padding: 0 50px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    height: 100%
  }

  .service-list .accordion-li .accordion-title-icon {
    padding: 0;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between
  }

  .service-list .accordion-li:first-child .accordion-title {
    -webkit-padding-start: 0;
    padding-inline-start: 0
  }

  .service-list .accordion-li:last-child .accordion-title {
    -webkit-padding-end: 0;
    padding-inline-end: 0
  }

  .service-list .accordion-li.active .accordion-title {
    display: none
  }

  .service-list .accordion-li:not(:first-child) {
    border-left: var(--style-border-width) solid var(--color-border)
  }

  .service-list .accordion-li:first-child .accordion-content {
    -webkit-padding-start: 0;
    padding-inline-start: 0
  }

  .service-list .accordion-li:last-child .accordion-content {
    -webkit-padding-end: 0;
    padding-inline-end: 0
  }
}

@media (max-width:991px) {
  .service-list .accordion-li {
    width: 100%
  }

  .service-list .accordion-content {
    --padding: 0;
    max-height: 0;
    overflow: hidden;
    -webkit-transition: max-height .3s ease-in-out;
    -o-transition: max-height .3s ease-in-out;
    transition: max-height .3s ease-in-out
  }

  .service-list .accordion-li.active .icon {
    display: none
  }

  .service-list .accordion-li.active .icon+.icon {
    display: block
  }

  .service-list .accordion-li svg {
    --size: 60px
  }

  .service-list .accordion-li .icon {
    --size: 36px
  }

  .our-services .service-content-inner .button {
    -webkit-margin-before: 35px;
    margin-block-start: 35px
  }

  .our-services .service-content-inner .heading,
  .our-services .service-content-inner svg {
    display: none
  }

  .service-list .accordion-li {
    --padding: 24px
  }

  .service-list .accordion-li .accordion-title {
    --padding: 24px;
    padding: var(--padding) 0;
    border-top: var(--style-border-width) solid var(--color-border)
  }

  .service-list .accordion-li:first-child .accordion-title {
    -webkit-padding-before: 0;
    padding-block-start: 0;
    border-top: none
  }

  .service-content-inner {
    --padding: 24px;
    -webkit-padding-after: var(--padding);
    padding-block-end: var(--padding)
  }

  .our-services .service-content-inner .heading+.text {
    -webkit-margin-before: 0;
    margin-block-start: 0
  }

  .our-services .service-list {
    -webkit-padding-after: 12px;
    padding-block-end: 12px
  }

  .card-service-content-absolute {
    padding: 24px
  }

  .card-service-content {
    padding: 24px 16px
  }

  .service-content-left .headings-width {
    max-width: 100%
  }

  .service-content-left .service-list .product-grid {
    row-gap: 30px
  }
}

@media (max-width:767px) {
  .our-services .service-list {
    padding: 30px 15px
  }

  .service-list .accordion-li svg {
    --size: 50px
  }

  .service-list .accordion-li .icon {
    --size: 30px
  }

  .our-services .accordion-title-icon .heading {
    font-size: 20px
  }

  .our-services .service-list {
    -webkit-padding-after: 6px;
    padding-block-end: 6px
  }

  .card-service-content-absolute {
    padding: 16px
  }

  .our-services .section-headings-horizontal .buttons {
    -webkit-margin-before: 10px;
    margin-block-start: 10px
  }
}

.service-contact {
  position: relative
}

.service-details-content>.heading,
.service-details-content>.service-choose-us,
.service-details-content>p.text {
  -webkit-margin-before: 40px;
  margin-block-start: 40px
}

.service-details-content .choose-us-img {
  height: 100%
}

.service-details-content .choose-us-img img {
  -o-object-fit: cover;
  object-fit: cover;
  height: 100%
}

.service-details-content .service-row {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center
}

.service-details-content .service-row>* {
  -ms-flex-item-align: stretch;
  -ms-grid-row-align: stretch;
  align-self: stretch
}

.service-faq {
  -webkit-margin-before: 40px;
  margin-block-start: 40px;
  display: block
}

.service-faq>div+div {
  -webkit-margin-before: 30px;
  margin-block-start: 30px
}

.service-faq .accordion-block .accordion-opener svg {
  -webkit-transition: all .3s;
  -o-transition: all .3s;
  transition: all .3s
}

.service-faq .accordion-block.active .accordion-opener svg {
  -webkit-transform: rotate(-180deg);
  -ms-transform: rotate(-180deg);
  transform: rotate(-180deg);
  -webkit-transition: all .3s;
  -o-transition: all .3s;
  transition: all .3s
}

.service-faq .accordion-block.active .accordion-opener {
  --color-background: rgba(242, 242, 242, 1);
  --color-foreground-heading: rgba(28, 37, 57, 1)
}

.service-contact-content a {
  text-decoration: none
}

project-slider {
  display: block;
  overflow: hidden
}

project-slider .swiper-slide {
  height: auto
}

.card-project {
  --color-foreground: rgba(255, 255, 255, 1);
  --color-foreground-heading: rgba(255, 255, 255, 1);
  text-decoration: none;
  position: relative;
  display: block;
  overflow: hidden;
  height: 100%
}

.card-project:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: -webkit-gradient(linear, left top, left bottom, from(rgba(28, 37, 57, 0)), to(#1c2539));
  background: -webkit-linear-gradient(top, rgba(28, 37, 57, 0) 0, #1c2539 100%);
  background: -o-linear-gradient(top, rgba(28, 37, 57, 0) 0, #1c2539 100%);
  background: linear-gradient(180deg, rgba(28, 37, 57, 0) 0, #1c2539 100%);
  -webkit-transition: .5s;
  -o-transition: .5s;
  transition: .5s;
  opacity: 0
}

.card-project:hover:after {
  opacity: 1
}

.card-project img {
  border-radius: inherit;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover
}

.card-project-content-absolute {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
  z-index: 1;
  padding: 35px
}

.card-project-content .heading+.text {
  -webkit-margin-before: 10px;
  margin-block-start: 10px
}

.card-project-content {
  opacity: 0;
  -webkit-transform: translateY(80px);
  -ms-transform: translateY(80px);
  transform: translateY(80px);
  -webkit-transition: all .5s;
  -o-transition: all .5s;
  transition: all .5s
}

.card-project:hover .card-project-content {
  opacity: 1;
  -webkit-transform: translateY(0);
  -ms-transform: translateY(0);
  transform: translateY(0)
}

.icon-project-link {
  position: absolute;
  top: 30px;
  right: 30px;
  z-index: 1;
  opacity: 0;
  -webkit-transform: scale(.5);
  -ms-transform: scale(.5);
  transform: scale(.5);
  -webkit-transition: .5s;
  -o-transition: .5s;
  transition: .5s
}

.card-project:hover .icon-project-link {
  opacity: 1;
  -webkit-transform: scale(1);
  -ms-transform: scale(1);
  transform: scale(1)
}

.icon-project-link svg {
  --size: 52px;
  width: var(--size);
  height: var(--size)
}

@media (max-width:767px) {
  .card-project-content-absolute {
    padding: 24px
  }

  .slider-container .swiper {
    overflow: visible
  }
}

.project-details-content {
  -webkit-margin-before: 60px;
  margin-block-start: 60px
}

.content-details-inner>.project-image-block,
.content-details-inner>.text {
  -webkit-margin-before: 40px;
  margin-block-start: 40px
}

.project-info-list {
  -webkit-margin-before: 30px;
  margin-block-start: 30px
}

.project-info-item {
  --color-border: rgba(28, 37, 57, 0.3);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  gap: 20px;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  border-bottom: dotted var(--style-border-width) var(--color-border);
  -webkit-margin-after: 40px;
  margin-block-end: 40px;
  -webkit-padding-after: 20px;
  padding-block-end: 20px
}

.project-info-item:last-child {
  -webkit-margin-after: 0;
  margin-block-end: 0
}

.project-info-item .info-data {
  text-align: end
}

@media (max-width:767px) {
  .project-details-content {
    -webkit-margin-before: 40px;
    margin-block-start: 40px
  }
}

.pagination-left {
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start
}

.pagination-link {
  --size: 44px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  text-decoration: none;
  font-size: 18px;
  color: var(--pagination-item-foreground);
  background-color: var(--pagination-item-background);
  border: var(--style-pagination-border-width) solid var(--pagination-item-border);
  width: var(--size);
  height: var(--size);
  border-radius: 100%;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s
}

.pagination-link svg {
  --size: 14px;
  width: var(--size);
  height: var(--size)
}

.pagination-link.active,
.pagination-link:not([aria-disabled]):focus,
.pagination-link:not([aria-disabled]):hover {
  color: var(--pagination-item-active-foreground);
  background-color: var(--pagination-item-active-background);
  border-color: var(--pagination-item-active-border)
}

@media (max-width:767px) {
  .pagination-link {
    --size: 36px
  }

  .pagination-link svg {
    --size: 12px
  }
}

.why-choose-us {
  --color-background: rgba(242, 242, 242, 1);
  --color-foreground: rgba(93, 102, 111, 1);
  --color-foreground-heading: rgba(28, 37, 57, 1);
  --color-foreground-subheading: rgba(93, 102, 111, 1);
  --color-background-subheading: rgba(255, 255, 255, 0);
  --color-border-subheading-bg: rgba(93, 102, 111, 0.3);
  overflow: hidden;
  background-color: var(--color-background);
  position: relative
}

.choose-media {
  height: 100%
}

.choose-media img {
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover
}

.choose-logo {
  -webkit-margin-before: 50px;
  margin-block-start: 50px
}

.choose-bottom {
  --margin-block-start: 60px;
  -webkit-margin-before: var(--margin-block-start);
  margin-block-start: var(--margin-block-start);
  position: relative
}

@media (min-width:768px) {
  .choose-bottom {
    --offset: 300px
  }

  .choose-media-absolute {
    position: absolute;
    bottom: 0;
    right: 0;
    width: var(--offset)
  }
}

@media (min-width:1280px) {
  .choose-us-content {
    -webkit-padding-start: 40px;
    padding-inline-start: 40px
  }
}

@media (max-width:991px) {
  .choose-top>* {
    row-gap: 40px
  }

  .choose-logo {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center
  }
}

@media (max-width:767px) {
  .choose-bottom {
    --margin-block-start: 40px
  }

  .choose-media-absolute {
    -webkit-margin-before: 40px;
    margin-block-start: 40px
  }
}

.team-slider {
  display: block;
  position: relative;
  overflow: hidden
}

.team-slider .swiper-slide {
  height: auto
}

.card-team {
  --color-foreground: rgba(255, 255, 255, 1);
  --color-foreground-heading: rgba(255, 255, 255, 1);
  text-decoration: none;
  position: relative;
  display: block;
  overflow: hidden;
  height: 100%
}

.card-team:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: -webkit-gradient(linear, left top, left bottom, from(rgba(28, 37, 57, 0)), to(#1c2539));
  background: -webkit-linear-gradient(top, rgba(28, 37, 57, 0) 0, #1c2539 100%);
  background: -o-linear-gradient(top, rgba(28, 37, 57, 0) 0, #1c2539 100%);
  background: linear-gradient(180deg, rgba(28, 37, 57, 0) 0, #1c2539 100%);
  -webkit-transition: .5s;
  -o-transition: .5s;
  transition: .5s;
  opacity: 0
}

.card-team:hover:after {
  opacity: 1
}

.card-team img {
  border-radius: inherit;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover
}

.card-team-content-absolute {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
  z-index: 1;
  padding: 35px
}

.card-team-content .heading {
  text-decoration: none
}

.card-team-content .heading+.text {
  -webkit-margin-before: 7px;
  margin-block-start: 7px
}

.card-team-content {
  opacity: 0;
  -webkit-transform: translateY(80px);
  -ms-transform: translateY(80px);
  transform: translateY(80px);
  -webkit-transition: all .5s;
  -o-transition: all .5s;
  transition: all .5s
}

.card-team:hover .card-team-content {
  opacity: 1;
  -webkit-transform: translateY(0);
  -ms-transform: translateY(0);
  transform: translateY(0)
}

.card-team:hover .svg-wrapper {
  opacity: 1;
  -webkit-transform: translateX(21px);
  -ms-transform: translateX(21px);
  transform: translateX(21px)
}

.service-slider .swiper-pagination-bullet,
.team-slider .swiper-pagination-bullet {
  width: 20px;
  height: 14px;
  display: inline-block;
  border-radius: 10px;
  background: var(--swiper-pagination-bullet-inactive-color);
  opacity: var(--swiper-pagination-bullet-inactive-opacity);
  -webkit-transition: all .3s;
  -o-transition: all .3s;
  transition: all .3s;
  margin: 0 !important
}

.service-slider .swiper-pagination-bullet.swiper-pagination-bullet-active,
.team-slider .swiper-pagination-bullet.swiper-pagination-bullet-active {
  background: var(--swiper-pagination-color);
  width: 40px
}

@media (max-width:767px) {
  .card-team-content-absolute {
    padding: 24px
  }

  .team-slider .section-headings-horizontal .buttons {
    -webkit-margin-before: 10px;
    margin-block-start: 10px
  }
}

@media (max-width:575px) {
  .team-slider .swiper {
    overflow: visible
  }
}

.testimonial {
  --color-background: rgba(242, 242, 242, 1);
  background-color: var(--color-background)
}

.card-testimonial {
  --color-background: rgba(255, 255, 255, 1);
  background-color: var(--color-background);
  padding: 40px
}

.testimonial-card-inner>div+div {
  -webkit-margin-before: 30px;
  margin-block-start: 30px
}

.card-testimonial .rating-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 2px
}

.card-testimonial .rating-list .rating-icon svg[fill] {
  --color-background: rgba(236, 176, 20, 1);
  color: var(--color-background)
}

.card-testimonial .rating-list+.text {
  -webkit-margin-before: 16px;
  margin-block-start: 16px
}

.card-testimonial .user-info-wrap {
  -webkit-margin-before: 32px;
  margin-block-start: 32px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  gap: 16px;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between
}

.card-testimonial .user-info {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 20px
}

.card-testimonial .user-img {
  --size: 80px;
  min-width: var(--size);
  width: var(--size);
  height: var(--size);
  border-radius: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  overflow: hidden
}

.card-testimonial .user-img img {
  -o-object-fit: cover;
  object-fit: cover;
  height: 100%
}

.card-testimonial .user-info .user-desig {
  -webkit-margin-before: 7px;
  margin-block-start: 7px
}

.card-testimonial .icon-quote {
  --color-background: rgba(28, 37, 57, 1);
  color: var(--color-background)
}

.testimonial-3 .section-headings {
  --color-background: rgba(50, 113, 124, 1);
  --color-foreground: rgba(255, 255, 255, 1);
  --color-foreground-subheading: rgba(255, 255, 255, 1);
  --color-foreground-heading: rgba(255, 255, 255, 1);
  background: var(--color-background);
  padding: 40px;
  border-radius: 18px;
  height: 100%
}

.testicolumn-slider {
  --color-background: rgba(28, 37, 57, 1);
  background: var(--color-background);
  padding: 40px;
  border-radius: 18px;
  display: block
}

.testicolumn-slider .card-testimonial {
  --color-background: rgba(28, 37, 57, 1);
  --color-foreground: rgba(255, 255, 255, 1);
  --color-foreground-heading: rgba(255, 255, 255, 1);
  padding: 0
}

.testicolumn-slider .swiper-pagination-bullet.swiper-pagination-bullet-active {
  --swiper-pagination-color: rgba(50, 113, 124, 1)
}

@media (max-width:991px) {
  .card-testimonial {
    padding: 24px 15px
  }

  .testimonial-card-inner {
    -webkit-margin-before: 40px;
    margin-block-start: 40px
  }

  .testicolumn-slider,
  .testimonial-3 .section-headings {
    padding: 32px 24px
  }
}

@media (max-width:767px) {
  .card-testimonial .user-info {
    gap: 16px
  }

  .card-testimonial .user-img {
    --size: 60px
  }

  .card-testimonial .icon-quote svg {
    width: 36px;
    height: 36px;
    min-width: 36px
  }

  .testicolumn-slider,
  .testimonial-3 .section-headings {
    padding: 24px 16px
  }
}

.testimonial-2 {
  position: relative
}

.testimonial-slider {
  display: block
}

.testimonial-2 .main-img {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  z-index: 1;
  height: 100%
}

.testimonial-2 .main-img img {
  -o-object-fit: cover;
  object-fit: cover
}

.testimonial-2 .swiper-pagination-bullet-active {
  --style-pagination-border-width: 2px;
  --pagination-item-active-border: rgba(32, 40, 45, 1);
  background: 0 0;
  outline: var(--style-pagination-border-width) solid var(--pagination-item-active-border);
  outline-offset: 10px;
  -webkit-transition: all .1s;
  -o-transition: all .1s;
  transition: all .1s
}

.testimonial-2 .testicolumn-slider .swiper-pagination-bullet-active {
  --pagination-item-active-border: rgba(255, 255, 255, 0.6);
  outline-offset: 7px
}

.testimonial-2 .testicolumn-slider {
  --color-background: transparent;
  padding: 0
}

@media (max-width:991px) {
  .testimonial-slider {
    -webkit-margin-before: 40px;
    margin-block-start: 40px
  }
}

@media (max-width:767px) {
  .testimonial-2 .swiper-pagination-bullet-active {
    outline-offset: 7px
  }

  .testimonial-2 .testicolumn-slider .swiper-pagination-bullet-active {
    outline-offset: 5px
  }
}

.testimonial.how-we-work {
  --color-background: transparent
}

.how-we-work .card-working-process {
  --color-background: rgba(28, 37, 57, 0.7);
  --color-foreground: rgba(255, 255, 255, 1);
  --color-foreground-heading: rgba(255, 255, 255, 1);
  --position: calc(var(--header-height) + var(--top));
  --top: 40px;
  background: var(--color-background);
  padding: 40px;
  border-radius: 18px;
  position: -webkit-sticky;
  position: sticky;
  top: var(--position);
  -webkit-backdrop-filter: blur(50px);
  backdrop-filter: blur(50px)
}

.how-we-work .card-working-process .card-icon-text .svg-wrapper {
  color: var(--color-foreground)
}

.how-we-work .card-working-process .has-border {
  border: none
}

.how-we-work .card-working-process .card-icon-text {
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start
}

.how-we-work .card-working-process-inner {
  counter-reset: increment-number
}

.how-we-work .card-working-process:after {
  counter-increment: increment-number;
  content: counter(increment-number);
  position: absolute;
  top: 10px;
  right: 30px;
  font-size: 130px;
  color: var(--color-foreground-heading);
  opacity: .1;
  line-height: 1;
  -webkit-transform: rotate(10deg);
  -ms-transform: rotate(10deg);
  transform: rotate(10deg);
  font-weight: 700;
  font-style: normal;
  font-family: var(--font-heading-family)
}

@media (min-width:992px) {
  .how-we-work .heading {
    -webkit-padding-end: 30px;
    padding-inline-end: 30px
  }
}

@media (max-width:767px) {
  .how-we-work .card-working-process {
    padding: 24px 16px
  }
}

:is(.blog-description) :is(p, div, a, li, span) {
  font-size: 18px
}

@media (max-width:767px) {
  :is(.blog-description) :is(p, div, a, li, span) {
    font-size: 16px
  }
}

.faq .section-headings {
  -webkit-padding-end: 100px;
  padding-inline-end: 100px;
  position: relative;
  height: 100%
}

.faq .accordion-list>div+div {
  -webkit-margin-before: 24px;
  margin-block-start: 24px
}

.faq .image-absolute {
  position: absolute;
  bottom: -185px;
  right: 25%
}

.faq-row>* {
  -ms-flex-item-align: start;
  align-self: flex-start
}

.faq-2 .section-headings-horizontal {
  padding: 0
}

.faq-2 .section-headings-right {
  min-width: auto;
  max-width: 530px
}

.faq-2 .accordion-block {
  --color-background: transparent;
  border-radius: 0
}

.faq-2 .accordion-opener .svg-wrapper {
  --color-background: transparent
}

.faq-2 .accordion-opener .svg-wrapper svg {
  --color-foreground: rgba(32, 40, 45, 1)
}

.faq-2 .accordion-block.active .accordion-opener {
  --color-background: transparent;
  --color-foreground-heading: rgba(32, 40, 45, 1)
}

.faq-2 .accordion-block.active,
.faq-2 .accordion-opener {
  --color-border: rgba(32, 40, 45, 0.2);
  border-bottom: 1px solid var(--color-border)
}

.faq-2 .accordion-list>div+div {
  -webkit-margin-before: 0;
  margin-block-start: 0
}

.faq-2 .accordion-opener {
  padding: 32px 20px
}

.faq-2 .video-wrap.section-headings-sticky {
  z-index: 1
}

.faq-form-wrap {
  -webkit-margin-before: 50px;
  margin-block-start: 50px
}

.faq-form {
  --color-background: rgba(242, 242, 242, 1);
  background-color: var(--color-background);
  padding: 40px 30px;
  display: block
}

.faq-form>.field {
  -webkit-margin-before: 24px;
  margin-block-start: 24px
}

.faq-form>.button {
  -webkit-margin-before: 36px;
  margin-block-start: 36px;
  width: 100%
}

@media (max-width:1199px) {
  .faq .section-headings {
    -webkit-padding-end: 0;
    padding-inline-end: 0
  }

  .faq .image-absolute {
    right: 10%
  }

  .faq-form {
    padding: 24px 20px
  }
}

@media (max-width:991px) {
  .faq .accordion-list {
    -webkit-margin-before: 40px;
    margin-block-start: 40px
  }

  .faq-2 .accordion-list {
    -webkit-margin-before: 20px;
    margin-block-start: 20px
  }

  .faq .image-absolute {
    bottom: -40px;
    -webkit-padding-end: 0;
    padding-inline-end: 0
  }

  .faq-2 .section-headings {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
  }

  .faq-2 .section-headings-right {
    min-width: 100%;
    max-width: 100%
  }
}

@media (max-width:767px) {
  .image-absolute img {
    max-width: 90px;
    height: auto
  }

  .faq .image-absolute {
    right: 0
  }

  .faq-form {
    padding: 24px 15px
  }
}

.section-contact-form {
  overflow: hidden
}

.section-contact-form .card-icon-text-horizontal {
  -webkit-margin-before: 40px;
  margin-block-start: 40px
}

.contact-form-headings .heading+.text {
  -webkit-margin-before: 15px;
  margin-block-start: 15px
}

.section-contact-form .contact-form {
  -webkit-margin-before: 32px;
  margin-block-start: 32px
}

.section-contact-form .contact-form-wrap {
  --color-background: rgba(32, 40, 45, 1);
  --color-foreground: rgba(242, 242, 242, 1);
  --color-foreground-heading: rgba(255, 255, 255, 1);
  --color-input-text: rgba(93, 102, 111, 1);
  --color-input-background: rgba(255, 255, 255, 1);
  --color-input-border: rgba(255, 255, 255, 1);
  --color-input-hover-text: rgba(93, 102, 111, 1);
  --color-input-hover-background: rgba(255, 255, 255, 1);
  --color-input-hover-border: rgba(255, 255, 255, 1);
  --color-secondary-button-hover-border: rgba(255, 255, 255, 0.3);
  background-color: var(--color-background)
}

.section-contact-form .contact-box {
  --padding: 60px;
  -webkit-box-shadow: 5px 8px 30px 4px rgba(23, 36, 38, .08);
  box-shadow: 5px 8px 30px 4px rgba(23, 36, 38, .08);
  padding: var(--padding)
}

.section-contact-form.without-box-shadow .contact-box {
  -webkit-box-shadow: none;
  box-shadow: none;
  padding: 0
}

@media (min-width:992px) {
  .section-contact-form .section-headings {
    max-width: 593px
  }

  .section-contact-form .card-icon-text-horizontal {
    -webkit-margin-before: 40px;
    margin-block-start: 40px;
    max-width: 442px
  }
}

@media (min-width:1400px) {
  .section-contact-form .col-contact-form {
    width: 520px
  }

  .section-contact-form .col-contact-content {
    width: calc(100% - 520px - 30px)
  }
}

@media (max-width:991px) {
  .section-contact-form .contact-form-wrap {
    -webkit-margin-before: 30px;
    margin-block-start: 30px
  }

  .contact-us .contact-form-wrap {
    padding: 32px 0
  }
}

@media (max-width:767px) {
  .section-contact-form .contact-box {
    --padding: 40px 15px
  }

  .section-contact-form .contact-form-wrap {
    -webkit-margin-before: 20px;
    margin-block-start: 20px
  }
}

.contact-2 .contact-box {
  -webkit-margin-before: 60px;
  margin-block-start: 60px
}

.contact-2 .section-headings {
  max-width: 840px;
  -webkit-margin-start: auto;
  margin-inline-start: auto;
  -webkit-margin-end: auto;
  margin-inline-end: auto
}

.contact-2 .card-icon-text svg {
  min-width: 28px;
  width: 28px;
  height: 28px;
  color: #fff
}

.contact-2 .contact-info-list .svg-wrapper {
  --color-background: rgba(32, 40, 45, 1);
  min-width: 60px;
  width: 60px;
  height: 60px;
  background: var(--color-background);
  border-radius: 6px
}

.contact-info-list .content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: 5px
}

.contact-2 .card-icon-text .content>.heading {
  opacity: .7
}

.contact-2.section-padding {
  --padding-bottom: 32px
}

.contact-2 .card-icon-text .heading+.text {
  -webkit-margin-before: 3px;
  margin-block-start: 3px
}

.contact-2 .card-icon-text a {
  text-decoration: none;
  -webkit-transition: .3s;
  -o-transition: .3s;
  transition: .3s
}

.contact-2 .card-icon-text a:focus,
.contact-2 .card-icon-text a:hover {
  opacity: .75
}

.contact-us .contact-box {
  background: 0 0;
  -webkit-box-shadow: none;
  box-shadow: none
}

.team-details .content-info {
  -webkit-padding-start: 80px;
  padding-inline-start: 80px
}

.team-details .content-info .info-desig {
  -webkit-margin-before: 18px;
  margin-block-start: 18px
}

.team-details .content-info .email {
  -webkit-margin-before: 18px;
  margin-block-start: 18px
}

.team-details .content-info .email {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 10px
}

.text-absolute {
  --color-foreground-heading: rgba(255, 255, 255, 1);
  --color-background: rgba(28, 37, 57, 1);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  background: var(--color-background);
  color: var(--color-foreground-heading);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  border-radius: 100px;
  position: absolute;
  z-index: 2;
  top: 50%;
  right: -40px;
  -webkit-writing-mode: vertical-lr;
  -ms-writing-mode: tb-lr;
  writing-mode: vertical-lr;
  text-orientation: mixed;
  padding: 32px;
  height: 100%;
  max-height: 410px;
  text-align: center
}

.team-about>.heading+.text {
  -webkit-margin-before: 36px;
  margin-block-start: 36px
}

@media (max-width:1199px) {
  .team-details .content-info {
    -webkit-padding-start: 60px;
    padding-inline-start: 60px
  }

  .text-absolute {
    padding: 25px
  }
}

@media (max-width:991px) {
  .team-details .content-info {
    -webkit-padding-start: 40px;
    padding-inline-start: 40px
  }

  .text-absolute {
    padding: 20px;
    right: -35px
  }
}

@media (max-width:767px) {
  .team-details .content-info {
    -webkit-padding-start: 0;
    padding-inline-start: 0;
    -webkit-margin-before: 50px;
    margin-block-start: 50px
  }

  .text-absolute {
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
    top: auto;
    right: auto;
    left: 50%;
    bottom: -30px;
    width: calc(100% - 20%);
    max-height: 60px;
    -webkit-writing-mode: horizontal-tb;
    -ms-writing-mode: lr-tb;
    writing-mode: horizontal-tb;
    padding: 16px
  }
}

.service-contact {
  position: relative
}

.service-details-content>.heading,
.service-details-content>.service-choose-us,
.service-details-content>p.text {
  -webkit-margin-before: 40px;
  margin-block-start: 40px
}

.service-details-content .choose-us-img {
  height: 100%
}

.service-details-content .choose-us-img img {
  -o-object-fit: cover;
  object-fit: cover;
  height: 100%
}

.service-details-content .service-row {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center
}

.service-details-content .service-row>* {
  -ms-flex-item-align: stretch;
  -ms-grid-row-align: stretch;
  align-self: stretch
}

.service-faq {
  -webkit-margin-before: 40px;
  margin-block-start: 40px;
  display: block
}

.service-faq>div+div {
  -webkit-margin-before: 30px;
  margin-block-start: 30px
}

.service-faq .accordion-block .accordion-opener svg {
  -webkit-transition: all .3s;
  -o-transition: all .3s;
  transition: all .3s
}

.service-faq .accordion-block.active .accordion-opener svg {
  -webkit-transform: rotate(-180deg);
  -ms-transform: rotate(-180deg);
  transform: rotate(-180deg);
  -webkit-transition: all .3s;
  -o-transition: all .3s;
  transition: all .3s
}

.service-faq .accordion-block.active .accordion-opener {
  --color-background: rgba(242, 242, 242, 1);
  --color-foreground-heading: rgba(28, 37, 57, 1)
}

.service-contact-content a {
  text-decoration: none
}

.card-working-process .has-border {
  --color-border: rgba(93, 102, 111, 0.3);
  border-top: var(--style-border-width) solid var(--color-border);
  border-bottom: var(--style-border-width) solid var(--color-border);
  padding: 15px 0;
  -webkit-margin-before: 10px;
  margin-block-start: 10px
}

.card-working-process .card-icon-text {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center
}

.card-working-process .card-icon-text .svg-wrapper {
  --size: 54px
}

.service-slider .card-working-process .card-icon-text .svg-wrapper {
  --size: 44px
}

@media (min-width:768px) {
  .working-process .product-grid {
    --bs-gutter-x: 50px;
    row-gap: 40px
  }
}

@media (min-width:992px) {
  .working-process .product-grid {
    --bs-gutter-x: 100px;
    row-gap: 50px
  }
}

.brand-bg .brand-logo {
  width: 100%;
  border: 1px solid #e0e0e0;
  border-top-right-radius: 20px;
  border-bottom-left-radius: 20px;
  padding: 22px 49px 23px;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  background: #fff
}

.industry_expertise_sec .support_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 30px
}

.industry_expertise_sec .support_list .support_box {
  border-radius: 10px;
  transition: all .5s ease;
  padding: 35px 10px 35px;
  box-shadow: 0 0 4px rgba(0, 0, 0, .25);
  width: 23.24%;
  text-align: center;
  background: #fff
}

.industry_expertise_sec {
  background: #f0f1f5
}

.industry_expertise_sec .sec_head {
  margin-bottom: 40px;
  text-align: center
}

.industry_expertise_sec .support_list .support_box h4 {
  margin: 0;
  font-size: 18px;
  font-weight: 600;
  color: #000
}

.industry_expertise_sec .support_list .support_box span.icon {
  display: flex;
  justify-content: center;
  margin-bottom: 15px
}

.industry_expertise_sec .support_list .support_box span.icon svg {
  height: 70px;
  width: 70px
}

.industry_expertise_sec .support_list .support_box:hover {
  transform: translateY(-10px);
  background: #1c2539
}

.industry_expertise_sec .support_list .support_box:hover h4 {
  color: #fff
}

.industry_expertise_sec .support_list .support_box:hover span.icon svg path {
  fill: #fff
}

.how-we-work .card-working-process .card-icon-text .svg-wrapper svg path {
  fill: #fff
}

.typical_list {
  margin-top: 30px
}

.case_studies_main {
  background: #f0f1f5
}
.case_studies_main .project-media {
    margin-top: 30px;
}
.case_studies_main .media-wrap {
  overflow: hidden;
  border-radius: 15px;
  box-shadow: 1px 1px 5px #ccc
}
.testimonial-3 .swiper-pagination {
    position: unset;
    display: flex;
    align-items: center;
    justify-content: center;
    column-gap: 10px;
    padding-top: 40px;
}

.how-we-work .card-working-process {
    background: rgba(28, 37, 57, 0.7);
    padding: 40px;
    border-radius: 18px;

    position: sticky;
    top: 40px;
    backdrop-filter: blur(50px);
    -webkit-backdrop-filter: blur(50px);
}
.contact-form-wrap form select {
    color: #8d919b;
}
.slider-content .col-span-12 .text {
    margin-top: 20px;
}
.button:after, .button:before{display: none;}
.text-banner.mt-100 {
    padding-bottom: 100px;
}
.slider-content {
    padding-top: 75px;
}
@media (max-width:1440px) {
.industry_expertise_sec .support_list {
    gap: 25px;
}
}
@media (max-width:1279px) {
.industry_expertise_sec .support_list {
    gap: 20px;
}
}
@media (max-width:991px) {
  .industry_expertise_sec .support_list .support_box {
    width: 46.75%
  }

  .industry_expertise_sec .support_list {
    gap: 20px
  }
  .slider-content {
    padding-top: 0px;
}
}

@media (max-width:767px) {
  .cad-services.drafting .support_list {
    gap: 15px
  }

  .cad-services.drafting .support_list .support_box {
    width: 45%;
    padding: 30px 10px
  }
  .brand-bg .brand-logo {
    padding: 15px 30px 15px;
}
}




