/* <--------------------------------------------------------- FONTS ---------------------------------------------------------> */

@font-face {
  font-family: "Rubik-Black";
  src: url(fonts/Rubik-Black.ttf);
  font-display: swap;
}

@font-face {
  font-family: "Rubik-ExtraBold";
  src: url(fonts/Rubik-ExtraBold.ttf);
  font-display: swap;
}

@font-face {
  font-family: "Rubik-Bold";
  src: url(fonts/Rubik-Bold.ttf);
  font-display: swap;
}

@font-face {
  font-family: "Rubik-SemiBold";
  src: url(fonts/Rubik-SemiBold.ttf);
  font-display: swap;
}

@font-face {
  font-family: "Rubik-Medium";
  src: url(fonts/Rubik-Medium.ttf);
  font-display: swap;
}

@font-face {
  font-family: "Rubik-Regular";
  src: url(fonts/Rubik-Regular.ttf);
  font-display: swap;
}

@font-face {
  font-family: "Rubik-Light";
  src: url(fonts/Rubik-Light.ttf);
  font-display: swap;
}

/* <--------------------------------------------------------- ROOT ---------------------------------------------------------> */

:root {
  /* --font-black: "Rubik-Black";
  --font-extrabold: "Rubik-ExtraBold";
  --font-bold: "Rubik-Bold";
  --font-semibold: "Rubik-SemiBold";
  --font-medium: "Rubik-Medium";
  --font-regular: "Rubik-Regular";
  --font-light: "Rubik-Light"; */


  /*** GENERALS ***/
  --primary-color: #41aac5;
  --secondary-color: #81cdb9;
  --complementary-color: #2f353a;
  --light-gray: #f5f5f5;

  --btn-radius: 0;

  --radius: 10px;
  --img-radius: 10px;

  --transition-fast: all 0.25s linear;
  --transition-medium: all 0.35s linear;
  --transition-slow: all 0.5s linear;

  --container-padding: var(--col-gap);
  --row-padding: clamp(2em, 4vw, 4em);
  --col-padding: clamp(2em, 4vw, 4em);
  --row-gap: max(1.75em, 1.75vw);
  --col-gap: 3.75vw;

  --title-size: clamp(1.7rem, calc(2vh + 1.5vw), 3rem);
  --fs-xs: 0.775rem;
}

/* <--------------------------------------------------------- TYPOGRAPHY ---------------------------------------------------------> */

body,
.content-wrapper {
  overflow-x: clip;
}

.container-fluid {
    margin: 0 auto;
    padding-left: 0;
    padding-right: 0;
}
.container-fluid .row {
  padding-left: var(--container-padding);
  padding-right: var(--container-padding);
}
.container {
  margin: 0 auto;
  padding-left: var(--container-padding);
  padding-right: var(--container-padding);
  max-width: 100%;
}
.row {
  max-width: 100%;
  margin: 0 auto;
}

.mw-10 {
    max-width: 1000px;
}
main {
    min-height: calc(100vh - 200px);
}


body {
  color: #000;
}


h1 {
  font-size: var(--title-size);
  font-weight: 600;
  margin-bottom: 0;
}
h2 {
  font-size: calc(var(--title-size) * 0.618);
  font-weight: 600;
}
h3 {
  font-size: calc(var(--title-size) * 0.618);
}

.fh {
  height: 100%;
}
.fh img {
  height: 100%;
  object-fit: cover;
}

.text-white strong {
  color: var(--primary-color);
}

p {
  font-family: var(--regular);
  font-size: min(max(16px, calc(1rem + ((1vw - 2.8px) * 0.122))), 18px);
  font-weight: 300;
  text-align: justify;
}
.module-text.md > * {
  font-size: clamp(18px, 2vw, 23px);
}

a {
  text-decoration: none !important;
}

li {
  font-size: min(max(14px, calc(0.875rem + ((1vw - 2.8px) * 0.2439))), 18px);
  color: var(--black);
}

/* <--------------------------------------------------------- GENERALS ---------------------------------------------------------> */
/*** FORMS ***/

.form-control {
  background: transparent;
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 10px;
  height: 50px;
  padding-right: 5rem;
}

.form-group {
  position: relative;
  height: fit-content;
}

.form-group:not(.agreement-radio) label {
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  height: fit-content;
  left: 1.5rem;
  z-index: -1;
  color: rgba(0, 0, 0, 0.5);
  opacity: 0.7;
  margin-top: auto;
  margin-bottom: auto;
}
.form-group:not(.agreement-radio) label span {
  color: rgba(0, 0, 0, 0.5);
  opacity: 0.7;
  transition: var(--transition-medium);
}

.form-control:focus {
  color: var(--primary-color);
  background-color: inherit;
  border-color: inherit;
  box-shadow: none;
}

.focus label,
.focus span {
  color: transparent;
}

.form-group:not(.item-acceptance) label {
  position: absolute;
  transition: var(--transition-medium);
  left: 1rem;
  white-space: nowrap;
  pointer-events: none;
  z-index: 999;
}

.form-group {
  margin-bottom: 0px;
}

.contact-form-col {
  display: flex;
  flex-direction: column;
  /* gap: 20px; */
}
.contact-form-col .form-group {
  margin-bottom: 20px;
}
.contact-form-col .form-group:last-child {
  margin-bottom: 0;
}

.contact-form-col .form-group textarea {
  height: 120px;
}

.contact-form-col .form-group input {
  height: 60px;
}

.contact-form-col .textarea label {
  bottom: inherit;
  top: 20px;
}

.form-group:not(.item-acceptance).focus label,
.form-group:not(.item-acceptance).focus label {
  color: transparent;
}

.form-group:not(.item-acceptance).focus span,
.form-group:not(.item-acceptance).focus span {
  color: transparent;
  transition: var(--transition-medium);
}

.form-group:not(.item-acceptance).focuss label,
.form-group:not(.item-acceptance).focuss label {
  color: transparent;
}

input[type="checkbox"] {
  display: none;
}

input[type="checkbox"] + .checkbox-text:before {
  content: "";
  display: block;
  width: 20px;
  height: 20px;
  border: 2px solid var(--primary-color);
  position: absolute;
  left: 0;
  top: 2px;
  transition: all 0.12s, border-color 0.08s;
  border-radius: 5px;
}

input[type="checkbox"]:checked + .checkbox-text:before {
  width: 10px;
  top: -5px;
  left: 5px;
  border-radius: 0;
  opacity: 1;
  border-top-color: transparent;
  border-left-color: transparent;
  transform: rotate(45deg);
}

input[type="checkbox"] + .checkbox-text {
  cursor: pointer;
  padding-left: 30px;
}

.form-group.load label {
  position: relative;
  color: #000;
}
.form-group.load.focus label {
  color: #000;
}
input[type="file"] {
  height: auto !important;
  border: 1px solid #cccccc;
  padding: 5px;
  border-radius: 10px;
}

input[type=file]::file-selector-button {
  margin-right: 20px;
  border: none;
  background: #084cdf;
  padding: 10px 20px;
  border-radius: 10px;
  color: #fff;
  cursor: pointer;
  transition: background .2s ease-in-out;
}

input[type=file]::file-selector-button:hover {
  background: #0d45a5;
}

.c-error {
  position: absolute;
  bottom: -1rem;
  left: 0;
  font-size: 12px;
}


/*** IMAGES ***/

.img-radius img {
  border-radius: var(--img-radius);
}


.display-none {
  display: none;
}

.primary-bg {
  background: var(--primary-color);
}

.supratitle .text-section p:first-of-type {
  margin: 0px;
}

/*** BUTTONS ***/
.btn {
  text-transform: uppercase;
}
.btn-primary {
  background-color: var(--primary-color);
  padding: 15px 20px;
  color: #fff;
  border: none;
  border-radius: var(--btn-radius);
  display: flex;
  flex-direction: row;
  align-items: center;
  max-width: fit-content;
  gap: 25px;
  transition: var(--transition-medium);
}

.btn-primary:not(:disabled):not(.disabled):active,
.btn-primary:not(:disabled):not(.disabled).active,
.show > .btn-primary.dropdown-toggle {
  color: #fff;
  background-color: var(--primary-color);
}

.btn-primary:not(:disabled):not(.disabled):active:focus,
.btn-primary:not(:disabled):not(.disabled).active:focus,
.show > .btn-primary.dropdown-toggle:focus {
  box-shadow: none;
  outline: none;
}

.btn-primary:focus,
.btn-primary.focus {
  color: #fff;
  background-color: var(--primary-color);
  outline: none;
}

.btn-primary:focus svg path,
.btn-primary.focus svg path {
  stroke: #fff;
}

.btn-primary svg path {
  stroke: #fff;
  transition: var(--transition-medium);
}

.btn-primary svg {
  transition: var(--transition-medium);
  position: relative;
  left: 0px;
}

.btn-primary:hover svg {
  position: relative;
  left: 10px;
  transition: var(--transition-medium);
}

.btn-primary:hover svg path {
  stroke: #fff;
  transition: var(--transition-medium);
}

.btn-primary:hover {
  background-color: var(--primary-color);
  transition: var(--transition-medium);
  color: #fff;
}

.btn-secondary {
  background-color: var(--secondary-btn-color);
  padding: 15px 20px;
  color: var(--secondary-btn-text-color);
  border: 1px solid var(--secondary-btn-border-color);
  display: flex;
  flex-direction: row;
  align-items: center;
  max-width: fit-content;
  gap: 25px;
  border-radius: var(--btn-radius);
  transition: var(--transition-medium);
}

.btn-secondary:hover {
  background-color: var(--secondary-btn-hover-color);
  color: var(--secondary-btn-hover-text-color);
  border: 1px solid var(--secondary-btn-hover-border-color);
  transition: var(--transition-medium);
}

.btn-secondary:hover {
  transition: var(--transition-medium);
  box-shadow: 0px 0px 10px var(--secondary-btn-hover-shadow-color);
}

.btn-secondary:hover svg path {
  stroke: var(--secondary-btn-hover-icon-color);
  transition: var(--transition-medium);
}

.btn-secondary:hover svg {
  position: relative;
  left: 10px;
  transition: var(--transition-medium);
}

.btn-secondary svg {
  position: relative;
  left: 0;
  transition: var(--transition-medium);
}

.btn-secondary svg path {
  stroke: var(--secondary-btn-icons-color);
  transition: var(--transition-medium);
}

.btn-secondary:not(:disabled):not(.disabled):active,
.btn-secondary:not(:disabled):not(.disabled).active,
.show > .btn-secondary.dropdown-toggle {
  color: var(--secondary-btn-hover-text-color);
  background-color: var(--secondary-btn-hover-color);
  border-color: var(--secondary-btn-hover-border-color);
}

.btn-secondary:not(:disabled):not(.disabled):active:focus,
.btn-secondary:not(:disabled):not(.disabled).active:focus,
.show > .btn-secondary.dropdown-toggle:focus {
  box-shadow: 0px 0px 10px var(--secondary-btn-hover-shadow-color);
}

.btn-secondary:focus,
.btn-secondary.focus {
  color: var(--secondary-btn-hover-text-color);
  background-color: var(--secondary-btn-hover-color);
  border-color: var(--secondary-btn-hover-border-color);
  box-shadow: 0px 0px 10px var(--secondary-btn-hover-shadow-color);
}

.module-button {
  display: inline-block;
  border-radius: var(--radius);
  transition: var(--transition-medium);
}

.navbar-brand .logo {
  max-width: 90px;
  transition: var(--transition-medium);
}

button:focus {
  outline: none;
}

header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 99999;
  background-color: #fff;
  padding: 10px 0;
  transition: var(--transition-medium);
  box-shadow: 0 0 10px -7px #000;
}
#main-navbar {
  padding: 0px;
}

#main-navbar .navbar-brand {
  padding: 0px;
  margin: 0px;
  position: absolute;
  bottom: 0;
  transform: translateY(calc(50% + 9.5px));
}
#main-navbar-collapse {
  align-items: initial;
}
#main-navbar-collapse .navbar-nav  .nav-item {
  display: flex;
  align-items: center;
  height: 100%;
}
#main-navbar-collapse .navbar-nav .dropdown-menu {
  margin-top: 0;
  border-radius: 0;
  padding: 0;
  background-color: var(--secondary-color);
  border-color: var(--primary-color);
}
#main-navbar-collapse .navbar-nav .dropdown-menu a {
  padding: 10px !important;
  width: 100%;
}
#main-navbar-collapse .navbar-nav .dropdown-menu a:before {
  bottom: 0;
  left: 0;
}

#main-navbar-collapse .navbar-nav  .nav-item:hover .dropdown-menu {
  display: block;

}
#main-navbar-collapse .navbar-nav .nav-link {
  color: var(--navbar-text-color);
  font-family: var(--font-regular);
  position: relative;
  font-size: 1.1rem;
}

#main-navbar-collapse .navbar-nav .nav-link::before {
  content: "";
  position: absolute;
  width: 0;
  height: 100%;
  border-bottom: 1px solid var(--primary-color);
  transition: var(--transition-medium);
}

#main-navbar-collapse .navbar-nav .nav-link:hover::before {
  width: 100%;
  transition: var(--transition-medium);
}

#main-navbar-collapse .btn-icons-navbar .navbar-btn {
  padding: 0.8rem 1rem;
  background-color: var(--primary-color);
  transition: var(--transition-medium);
  font-size: 1.1rem;
  color: #fff;
}

#main-navbar-collapse .btn-icons-navbar .navbar-icons {
  display: none;
}

#main-navbar-collapse .navbar-nav .main-nav-item .nav-link {
  padding: 0px;
}

#main-navbar-collapse .navbar-nav {
  margin-right: 50px;
}
#main-navbar-collapse .navbar-nav li {
  margin-right: 30px;
}
#main-navbar-collapse .navbar-nav li:last-child {
  margin-right: 0;
}
.safari button,
.safari [type="button"],
.safari [type="reset"],
.safari [type="submit"] {
  -webkit-appearance: initial;
}
.safari .quick-phone {
  display: flex;
}

header .navbar-icons a svg path {
  fill: var(--navbar-icons-color);
  transition: var(--transition-medium);
}

header .navbar-icons a:hover svg path {
  fill: var(--navbar-icons-hover-color);
  transition: var(--transition-medium);
}

header .navbar-btn:hover {
  text-decoration: none;
}
/* <--------------------------------------------------------- FOOTER ---------------------------------------------------------> */

footer {
  background-color: #f5f5f5;
}
.footer-inner {
  display: grid;
  grid-template-columns: repeat(4, auto);
}

.footer-all-content {
  padding: 50px 0;
  justify-content: space-between;
}
footer ul li a {
  color: #000;
  padding-top: 0 !important;
}


footer .footer-logo-section img {
  max-width: 90px;
  border: 2px solid #fff;
}

footer .footer-icons-section .module-image img {
  max-height: 20px;
}

footer .footer-contact-section ul {
  display: flex;
  flex-direction: column;
  /* gap: 10px; */
}
footer .footer-contact-section ul li {
  display: flex;
  align-items: center;
  margin-bottom: 10px;
  /* gap: 10px; */
}
footer .footer-contact-section ul li:last-child {
  margin-bottom: 0;
}
footer .footer-contact-section ul li svg {
  margin-right: 10px;
}

footer a:hover {
  color: #000000bd;
}

footer .footer-contact-section svg path {
  fill: var(--primary-color);
  transition: var(--transition-medium);
}
footer .copyright-footer {
  background: #fff;
  color: #000;
}
footer .copyright-footer .copyright-section {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  padding: 20px 0;
}

footer ul {
  display: flex;
  flex-direction: column;
}

footer .copyright-footer .copyright-section .footer-privacy-terms ul li a {
  font-family: var(--font-light);
}

footer .copyright-footer .copyright-section .copyright-text p {
  /* color: var(--p-color-light); */
  font-family: var(--font-light);
  margin: 0;
}
footer .copyright-footer .copyright-section .copyright-text a {
    color: #fff;
}

footer .footer-all-content .footer-links ul li a {
  position: relative;
}

footer .footer-all-content .footer-links ul li a:hover {
  text-decoration: none;
  color: var(--footer-text-hover-color);
}

footer .footer-all-content .footer-links ul li a::before {
  content: "";
  position: absolute;
  width: 0;
  height: 100%;
  bottom: -5px;
  border-bottom: 1px solid var(--primary-color);
  transition: var(--transition-medium);
}

footer .footer-all-content .footer-links ul li a:hover::before {
  width: 100%;
  transition: var(--transition-medium);
}

footer .footer-icons-section .module-image a {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
}

footer .footer-icons-section .module-image:hover {
  background-color: var(--primary-color);
  transition: var(--transition-medium);
}

footer .footer-icons-section .module-image:hover a img {
  filter: invert(100%);
  transition: var(--transition-medium);
}

footer .footer-icons-section .module-image a img {
  transition: var(--transition-medium);
}

/* <--------------------------------------------------------- HOMEPAGE ---------------------------------------------------------> */

/* <--------------- HERO ---------------> */

.homepage-hero-section {
  position: relative;
  min-height: 100vh;
  align-items: center;
  flex-direction: column;
  flex-wrap: wrap;
  align-content: flex-start;
  justify-content: center;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: right;
  overflow: hidden;
  padding: 0 !important;
}

.intro-video-col {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.intro-video-col .module-video,
.intro-video-col .module-video .video-js {
  width: 100%;
  height: 100%;
}
.intro-video-col .module-video video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.quick-phone-widget {
  z-index: 99;
}
.quick-phone {
  bottom: clamp(1.25rem,5.2vw,6.25rem);
  position: absolute;
  right: var(--col-gap);
  z-index: 1;
  text-decoration: none;
}
.quick-phone:hover {
  text-decoration: none;
}
.quick-phone:hover .quick-phone-title {
  background: #43a9c6;
}
.quick-phone:hover .quick-phone-title:before {
  border-color: transparent transparent #43a9c6;
}
.quick-phone:hover .quick-phone-icon {
  background: var(--secondary-color);
}
.quick-phone:hover .quick-phone-icon svg {
  fill: #fff;
}

.quick-phone-icon {
  flex-shrink: 0;
  line-height: 1;
  padding: 15px 25px;
  transition: all .3s ease-out 0s;
  background: #fff;
  transition: var(--transition-fast);
}
.quick-phone-icon svg {
  -webkit-animation: phone-ringing 2.2s ease-in-out infinite;
  animation: phone-ringing 2.2s ease-in-out infinite;
  transition: var(--transition);
}
@keyframes phone-ringing {
  0% {
    -webkit-transform: rotate(0) scale(1) skew(1deg);
    transform: rotate(0) scale(1) skew(1deg);
  }
  5% {
      -webkit-transform: rotate(-25deg) scale(1) skew(1deg);
      transform: rotate(-25deg) scale(1) skew(1deg);
  }
  10% {
      -webkit-transform: rotate(25deg) scale(1) skew(1deg);
      transform: rotate(25deg) scale(1) skew(1deg);
  }
  15% {
      -webkit-transform: rotate(-25deg) scale(1) skew(1deg);
      transform: rotate(-25deg) scale(1) skew(1deg);
  }
  20% {
      -webkit-transform: rotate(25deg) scale(1) skew(1deg);
      transform: rotate(25deg) scale(1) skew(1deg);
  }
  25% {
      -webkit-transform: rotate(0) scale(1) skew(1deg);
      transform: rotate(0) scale(1) skew(1deg);
  }
  100% {
      -webkit-transform: rotate(0) scale(1) skew(1deg);
      transform: rotate(0) scale(1) skew(1deg);
  }
}
.quick-phone-title {
  background-color: var(--primary-color);
  color: #fff;
  padding: 15px 30px;
  position: relative;
  transition: var(--transition-fast);
  font-weight: 500;
}
.quick-phone-title:before {
  border-color: transparent transparent var(--primary-color);
  border-style: solid;
  border-width: 0 0 16px 16px;
  bottom: 0;
  content: "";
  display: block;
  height: 0;
  left: 0;
  position: absolute;
  -webkit-transform: translateX(-100%);
  transform: translateX(-100%);
  transition: all .3s ease-out 0s;
  width: 0;
}



.custom-fickle {
  width: 100%;
}
.custom-fickle.fh {
  height: 100%;
}
.custom-fickle-inner {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  /* gap: 5rem; */
  height: 100%;
  padding: 4rem var(--col-gap);
  background: #fff;
  color: #000;
}
.custom-fickle-inner .card-top {
  margin-bottom: 5rem;
}
.custom-fickle-inner:before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #000;
  opacity: 0;
  pointer-events: none;
  transition: var(--transition-fast);
}
.custom-fickle-inner:hover:before {
  opacity: 0.05;
}
.custom-fickle.gray .custom-fickle-inner {
  background: var(--light-gray);
}
.custom-fickle.blue .custom-fickle-inner {
  background: var(--primary-color);
  color: #fff;
}
.custom-fickle .custom-fickle-inner:hover {
  color: #000;
}
.custom-fickle.blue .custom-fickle-inner:hover {
  color: #fff;
}

.custom-fickle .card-top {
  display: flex;
  flex-direction: column;
  /* gap: 20px; */
  z-index: 1;
}
.custom-fickle .card-top .card-top_header {
  margin-bottom: 20px;
}
.custom-fickle .card-top .fickle-title-wrapper > * {
  margin-bottom: 0;
}
.custom-fickle .card-top .fickle-title-wrapper h2 {
  font-size: calc(var(--title-size) * 0.7);
}
.custom-fickle .card-top .fickle-title-wrapper h3 {
  font-size: calc(var(--title-size) * 0.5);
  font-weight: 600;
}

.custom-fickle .card-bottom {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: flex-start;
  /* gap: 1rem; */
  font-size: calc(0.5 * var(--title-size));
  font-weight: 300;
  z-index: 1;
}
.custom-fickle .fickle-button {
  line-height: 100%;
  margin-bottom: 1rem;
}
.custom-fickle .card-bottom svg {
  transition: var(--transition-fast);
}
.custom-fickle.blue .card-bottom svg {
  fill: #fff;
}
.custom-fickle-inner:hover .card-bottom svg {
  transform: translateX(20px);
}


.intro-card-row {
  padding: 0 !important;
  margin-top: clamp(-360px,-18.75vw,-100px);
}
.intro-card-col {
  min-height: clamp(180px,37.5vw,720px);
  transition: var(--transition-fast);
}
.intro-card-col:hover {
  background: #269fbe;
}
.hp-s2-right {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 5rem var(--col-gap);
}

.intro-card .fickle-header {
  margin-bottom: 2rem;
}

.card-padding {
  padding: 4rem var(--col-gap);
}
.card-padding.gray {
  background: var(--light-gray);
}
.card-padding.primary {
  background: var(--primary-color);
  color: #fff;
}
.card-padding.primary a {
  color: #fff;
}
.card-padding.primary a:hover svg {
  transform: translateX(20px);
}

.section-title > * {
  font-size: calc(var(--title-size) * 0.7);
  margin-bottom: 20px;
}
.section-title.xl > * {
  font-size: calc(var(--title-size));
}
p:last-child {
  margin-bottom: 0;
}
.text-white > * {
  color: #fff;
}
em {
  font-style: normal;
}
.section-title strong {
  color: #fff;
}
.section-title.bg strong {
  background-color: var(--primary-color);
  padding: 0 10px;
}
.headline > * {
  margin-bottom: 0;
  margin: 0px;
  font-size: calc(0.45 * var(--title-size));
  font-weight: 300;
}
.headline {
  display: flex;
  align-items: center;
  /* gap: 2rem; */
  margin-bottom: 1rem;
}

.headline:before {
  content: '';
  position: relative;
  width: 74px;
  height: 1px;
  background: #000;
  margin-right: 2rem;
}





/* Homepage */
.hp-fickle-experience {
  height: 100%;
}
.hp-fickle-experience .fickle-title {
  font-size: calc(3 * var(--title-size));
  font-weight: 700;
}
.hp-fickle-experience .fickle-text-content > * {
  font-size: clamp(18px, 2vw, 20px)
}

.contact-form-section .row {
  padding: 0;
}
.contact-form-section .btn-section .col-12 {
  padding: 0;
}
.contact-form .contact-form-col {
  padding: 0;
}

.all-contact-form-section-title {
  padding: 50px 0;
  position: relative;
}

.all-contact-form-section-title::before {
  position: absolute;
  content: "";
  width: 100vw;
  height: 250%;
  top: 0;
  bottom: 0;
  left: -5vw;
  right: 0;
  background-color: var(--hero-background-color);
}

.all-contact-form-section-title .module-text h2 {
  color: var(--h2-secondary-color);
}

.all-contact-form-section {
  padding-left: 15px;
  padding-right: 15px;
}

.all-contact-form-section .contact-form-section {
  background-color: var(--white);
}

.all-contact-form-section .contact-form-section {
  padding: 40px;
}

.all-contact-form-section .btn-section {
  margin-bottom: 0px;
}

.all-contact-form-section .item-acceptance {
  margin-bottom: 40px;
  margin-top: 20px;
}

.contact-details .module-fickle {
  height: 100%;
}
.contact-details .module-fickle .custom-fickle-inner {
  justify-content: flex-end;
}
.contact-details .card-top {
  margin-bottom: 0;
  margin-top: 1rem;
  align-items: center;
}

/* <--------------------------------------------------------- ABOUT ---------------------------------------------------------> */

/* <--------------- SECTION-1 ---------------> */
.about-intro {
  justify-content: flex-end;
}
.intro-desc {
  max-width: clamp(300px,37.5vw,720px);
  background: var(--primary-color);
  padding: 4rem var(--col-gap);
  color: #fff;
}
.intro-desc .fickle-title {
  font-size: var(--title-size);
  margin-bottom: 0;
  font-weight: 600;
}
.about-section-1 {
  align-items: center;
}

.about-section-1 .about-section-1-img {
  padding-right: 55px;
  padding-bottom: 40px;
  padding-left: 50px;
  position: relative;
  display: flex;
  justify-content: flex-end;
}

.about-section-1 .about-section-1-img::before {
  position: absolute;
  content: "";
  width: 50%;
  height: 60%;
  max-width: 300px;
  max-height: 300px;
  bottom: 0;
  right: 15px;
  background-color: var(--primary-color);
  border-radius: var(--img-radius);
  z-index: -1;
}
.about-section-1 .about-section-1-img .module-image {
  width: 100%;
}
.about-section-1 .about-section-1-img img {
  border-radius: var(--img-radius);
  width: 100%;
  max-width: 700px;
  max-height: 600px;
  margin-left: auto;
  object-fit: cover;
}


/* <--------------------------------------------------------- CONTACT ---------------------------------------------------------> */
.contact-map {
  height: 100%;
}

.contact-details .custom-fickle-inner {
  flex-direction: column-reverse;
  text-align: center;
  padding: 2rem var(--col-gap);
  border-radius: 5px;
}
.contact-details .custom-fickle-inner:hover svg {
  transform: none;
}
.contact-details .custom-fickle-inner .fickle-text-description > * {
  font-weight: 500;
}
.contact-details .custom-fickle-inner .card-bottom {
  align-items: center;
}
.contact-details .custom-fickle-inner .card-bottom svg {
  min-height: 40px;
  width: auto;
  fill: var(--primary-color);
}


.w-auto {
  text-align: center;
}
.w-auto img {
  width: auto !important;
  max-width: 100%;
}
.mw-500 {
  max-width: 500px;
  margin: auto;
}
.padding-left {
  padding-left: 5vw;
}


.hp-services {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: 1fr 1fr;
}
.hp-services .module-fickle {
  display: flex;
  flex-direction: column;
  /* gap: calc(0.5 * var(--col-gap)); */
  justify-content: space-between;
}
.hp-services .module-fickle .fickle-content {
  display: flex;
  flex-direction: column;
  /* gap: 1.5rem; */
}

.hp-services .fickle-title a {
  font-size: calc(var(--title-size) * 0.4);
  font-weight: 600;
  color: #000;
}
.hp-services .card-top {
  height: 100%;
  justify-content: space-between;
}
.hp-services .module-fickle:nth-child(1) {
  grid-row: 1/2;
  grid-column: 1/2;
}
.hp-services .module-fickle:nth-child(2) {
  grid-row: 1/2;
  grid-column: 2/3;
}
.hp-services .module-fickle:nth-child(3) {
  grid-row: 2/3;
  grid-column: 1/2;
}
.hp-services .module-fickle:nth-child(4) {
  grid-row: 2/3;
  grid-column: 2/3;
}
.hp-services .module-fickle:nth-child(5) {
  grid-row: 2/3;
  grid-column: 3/4;
}

.hp-services .module-image {
  grid-row: 1/3;
  grid-column: 3/5;
}
.hp-services .module-image {
  position: relative;
  z-index: -1;
}
.hp-services .module-image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}


.hero-section .module-image {
  height: 100%;
}
.hero-section .module-image img {
  height: 100%;
  object-fit: cover;
}
.overlay {
  position: relative;
}
.overlay:before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(0deg, rgba(0,0,0,0) 0%, rgba(0,0,0,0.3) 0%, rgba(0,0,0,0) 100%);
}


/* About us */
.about-intro-card {
  position: absolute;
  bottom: 0;
  left: 0;
  height: auto;
  width: clamp(300px,37.5vw,720px);
}

.about-numbers .module-fickle {
  text-align: center;
  padding: calc(1.5 * var(--col-gap)) 0;
}
.about-numbers .fickle-item.fickle-title > * {
  font-size: calc(2.3 * var(--title-size));
  font-weight: 700;
  line-height: 100%;
}
.about-numbers .fickle-subtitle > * {
  font-size: clamp(16px, 2vw, 22px);
  font-weight: 300;
}

.bg-gray {
  background: var(--light-gray);
}
.team-img-col {
  display: flex;
  align-items: flex-end;
}
.team-img {
  position: sticky;
  bottom: 0;
  background: var(--light-gray);
  border-radius: 10px;
}
.team-desc-col {
  display: flex;
  flex-direction: column;
  /* justify-content: flex-start; */
  justify-content: center;
  /* height: 100%; */
  /* padding-top: 50vh; */
  padding-bottom: var(--col-gap);
}

.team-desc-col .section-title > * {
  font-size: calc(var(--title-size) * 0.9);
  font-weight: 700;
}

.team-desc ul {
  display: flex;
  flex-wrap: wrap;
  /* gap: 1.5rem; */
  padding-left: 0;
  margin-bottom: 0;
  list-style-type: none;
}
.team-desc ul li {
  margin-right: 1.5rem;
  margin-bottom: 1rem;
}
.team-desc ul li {
  font-weight: 500;
  display: flex;
  align-items: center;
  /* gap: 0.5rem; */
}
.team-desc ul li:before {
  content: '';
  position: relative;
  width: 10px;
  height: 10px;
  border-radius: 100%;
  background: var(--primary-color);
  margin-right: 0.5rem;
}

.team-gallery {
  display: grid;
  grid-template-columns: 1fr 1fr;
  overflow: hidden;
  gap: 0.5rem;
  pointer-events: none;
}
.team-gallery figure {
  margin-bottom: 0;
  /* background: var(--light-gray); */
}
.team-gallery figure a {
  padding-top: 100%;
  display: flex;
  position: relative;
}
.team-gallery figure a img {
  position: absolute;
  top: 0;
  left: 50%;
  width: auto;
  height: 100%;
  object-fit: contain;
  transform: translateX(-50%);
  background-image: linear-gradient(135deg, #f5f7fa 0%, #c3cfe2 100%);
  /* border-radius: 10px; */
}
/* .team-gallery figure:nth-child(3) img {
  object-position: left;
} */
/* .team-gallery figure:nth-child(4) img {
  object-position: right;
} */


/* Services Page */
.service-section .card-top {
  /* gap: 2rem; */
  height: 100%;
  justify-content: center;
  margin-bottom: 0;
}
.service-section .card-top .card-top_header {
  margin-bottom: 2rem;
}
.service-section .module-image {
  height: 100%;
}
.service-section .module-image img {
  height: 100%;
  object-fit: cover;
}
.bg-col {
  background-size: cover;
  background-position: center;
}


#numbers-section {
  display: none;
}
