/* ================
  Hero Section Carousel Component
 ================ */
.hero-section-carousel .hero-section {
  padding-block: 214px 310px;
  position: relative;
  overflow: hidden;
  isolation: isolate;
  height: 100%;
}

.hero-section .container,
.hero-small-section .container {
  position: relative;
  z-index: 3;
}

.hero-section .divider {
  border-bottom: 1px solid #fff;
  opacity: 15%;
  margin-block: 32px 24px;
}

.hero-section p {
  margin-bottom: 72px;
}

.hero-section .overlay,
.hero-small-section .overlay {
  background:
    radial-gradient(
      107.19% 546.91% at 100% 100%,
      rgba(3, 94, 155, 0.25) 0.01%,
      rgba(3, 94, 155, 0.5) 36.47%,
      #08283d 100%
    ),
    linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.5) 100%);
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 2;
  pointer-events: none;
}

.hero-section .blur-gradient-overlay,
.hero-small-section .blur-gradient-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 60%;
  height: 100%;
  z-index: 1;
  pointer-events: none;
  background-color: rgba(255, 255, 255, 0.02);
  mask-image: linear-gradient(
    to right,
    black 0%,
    rgba(0, 0, 0, 0.45) 60%,
    rgba(0, 0, 0, 0) 100%
  );
  -webkit-mask-image: linear-gradient(
    to right,
    black 0%,
    rgba(0, 0, 0, 0.45) 60%,
    rgba(0, 0, 0, 0) 100%
  );
}

.hero-section-carousel .carousel-indicators {
  bottom: 0;
  margin-bottom: 57px;
}

.hero-section-carousel .carousel-indicators [data-bs-target] {
  width: 120px;
  border-radius: 3px;
  height: 5px;
  opacity: 0.2;
  border: 0 !important;
}

.hero-section-carousel .carousel-indicators .active {
  opacity: 1;
}

@media (max-width: 991px) {
  .hero-section-carousel .hero-section {
    padding-top: 200px;
    padding-bottom: 240px;
  }

  .hero-section .blur-gradient-overlay,
  .hero-small-section .blur-gradient-overlay {
    width: 100%;
    height: 50%;
    left: 0;
    bottom: 0;
    top: initial;
    mask-image: linear-gradient(
      to top,
      black 0%,
      rgba(0, 0, 0, 0.45) 60%,
      rgba(0, 0, 0, 0) 100%
    );
    -webkit-mask-image: linear-gradient(
      to top,
      black 0%,
      rgba(0, 0, 0, 0.45) 60%,
      rgba(0, 0, 0, 0) 100%
    );
  }
}

@media (max-width: 767px) {
  .hero-section-carousel .hero-section {
    padding-top: 200px;
    padding-bottom: 125px;
  }
}

/* ================
  Hero Section Component
 ================ */
.hero-section {
  padding-block: 140px;
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

@media (max-width: 991px) {
  .hero-section {
    padding-top: 240px;
    padding-bottom: 80px;
  }
}

/* ================
  Hero Small Section Component
 ================ */
.hero-small-section {
  padding-block: 160px;
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.hero-small-section .divider {
  border-bottom: 1px solid #fff;
  opacity: 15%;
  margin-block: 24px;
}
/* ================
  Contact US Hero Section
 ================ */

.new-template .contact-buttons {
  width: 500px;
  margin-inline: auto;
}

@media (max-width: 580px) {
  .new-template .contact-buttons {
    width: auto;
    flex-direction: column;
    gap: 8px;
  }

  .btn-divider {
    display: none;
  }

  .btn-glass {
    width: 100%;
    justify-content: center;
  }
}

.new-template .btn-glass {
  background-color: #ffffff1a;
  backdrop-filter: blur(16px);
  color: white;
  font-size: 12px;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 11px 24px;
  line-height: 140%;
  vertical-align: middle;
  transition: 250ms ease-in-out;
}

.new-template .btn-glass:hover {
  background-color: #ffffff2d;
  color: white;
}

.new-template .btn-glass i {
  font-size: 20px;
}

.new-template .btn-divider {
  width: 0px;
  height: 25px;
  opacity: 0.24;
  border: 1px solid #b3cfe1;
}
/* ================
  Footer Section
 ================ */
.gradient-footer {
  background-color: #02426d;
  background-image: radial-gradient(
    37.73% 127.55% at 32.29% -27.55%,
    #066291 0%,
    #02426d 100%
  );
  color: white;
}

footer {
  padding-top: 96px;
  position: relative;
  overflow: hidden;
}
footer .img-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 510px;
}
footer .footer-logo {
  width: 225px;
}
footer h4 {
  position: relative;
  margin-bottom: 24px;
}
footer h4::before {
  content: "";
  position: absolute;
  bottom: -8px;
  background: var(--blue-200);
  height: 2px;
  width: 55px;
  border-radius: 20px;
}

@media (max-width: 1199px) {
  footer h4::before {
    left: 50%;
    transform: translateX(-50%);
  }

  .gradient-footer {
    background: radial-gradient(
      117.5% 127.55% at 32.29% -27.55%,
      #066291 0%,
      #02426d 100%
    );
  }

  footer .img-overlay {
    width: 720px;
  }
}

@media (max-width: 580px) {
  .gradient-footer {
    background: radial-gradient(
      117.5% 127.55% at 32.29% -27.55%,
      #066291 0%,
      #02426d 100%
    );
  }
  footer .img-overlay {
    width: 380px;
  }
  footer .flex-navigation-mobile {
    flex-direction: column;
    justify-content: start;
    text-align: start !important;
    gap: 48px !important;
  }
  footer h4::before {
    left: 0;
    transform: none;
  }
  footer .mobile-hidden {
    display: none;
  }
  footer .mobile-full-width {
    width: 100%;
  }
  footer .social-media-links {
    width: 100%;
  }
  footer .social-media-links h4 {
    text-align: start;
  }
  footer .footer-links {
    justify-content: start;
    flex-wrap: wrap;
  }
}

footer .footer-links {
  list-style: none;
  padding-left: 0;
}
footer .footer-links a {
  margin-bottom: 12px;
  color: white;
  display: block;
}
footer .divider,
footer .contact-divider {
  border: 1px solid #b3cfe1;
  margin-block: 48px;
  opacity: 15%;
}
footer .contact-divider {
  margin-block: 0;
  margin-inline: 24px;
  height: 16px;
}
.mini-footer {
  padding-block: 32px;
  background-color: #01263e;
  color: white;
  margin-top: 96px;
}
.mini-footer .contact-divider {
  margin-inline: 20px;
}

/* ================
  Ways Section
  Cards That Have Green Border Title
 ================ */

.ways .way-card {
  padding: 24px;
  padding-left: 12px;
}

.ways .way-card .way-title {
  border-left: 4px solid #2ba9b4;
  padding-left: 12px;
}

.ways .way-card p {
  margin-bottom: 8px;
}

.ways .way-card a {
  text-decoration: underline;
  text-align: start;
  padding-right: 0 !important;
}

.new-template .divider {
  border: 1px solid #b3cfe1;
  border-radius: 20px;
}
