/**
* Template Name: Medicio
* Updated: Sep 18 2023 with Bootstrap v5.3.2
* Template URL: https://bootstrapmade.com/medicio-free-bootstrap-theme/
* Author: BootstrapMade.com
* License: https://bootstrapmade.com/license/
*/

/*--------------------------------------------------------------
# General
--------------------------------------------------------------*/

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@500&display=swap');

@import url('https://fonts.googleapis.com/css2?family=Dancing+Script:wght@400..700&family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');

@import url('https://fonts.googleapis.com/css2?family=Dancing+Script:wght@400..700&family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&family=Open+Sans:ital,wght@0,300..800;1,300..800&family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');


@import url('https://fonts.googleapis.com/css2?family=Karla:ital,wght@0,200..800;1,200..800&family=Lora:ital,wght@0,400..700;1,400..700&display=swap');

@import url('https://fonts.googleapis.com/css2?family=Karla:ital,wght@0,200..800;1,200..800&family=Lora:ital,wght@0,400..700;1,400..700&family=Poetsen+One&display=swap');

@import url('https://fonts.googleapis.com/css2?family=Cactus+Classical+Serif&display=swap');

@import url('https://fonts.googleapis.com/css2?family=Azeret+Mono:ital,wght@0,100..900;1,100..900&family=Cactus+Classical+Serif&display=swap');

@import url('https://fonts.googleapis.com/css2?family=Azeret+Mono:ital,wght@0,100..900;1,100..900&family=Cactus+Classical+Serif&family=Kanit:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');

@import url('https://fonts.googleapis.com/css2?family=Azeret+Mono:ital,wght@0,100..900;1,100..900&family=Cactus+Classical+Serif&family=Kanit:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&family=Lora:ital,wght@0,400..700;1,400..700&display=swap');


@import url('https://fonts.googleapis.com/css2?family=Rubik:ital,wght@0,300..900;1,300..900&display=swap');


@import url('https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&family=Rubik:ital,wght@0,300..900;1,300..900&display=swap');


@import url('https://fonts.googleapis.com/css2?family=Inter:wght@100..900&family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&family=Rubik:ital,wght@0,300..900;1,300..900&display=swap');

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@100..900&family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&family=Roboto+Condensed:ital,wght@0,100..900;1,100..900&family=Rubik:ital,wght@0,300..900;1,300..900&display=swap');

@import url('https://fonts.googleapis.com/css2?family=Lora:ital,wght@0,400..700;1,400..700&display=swap');

@import url('https://fonts.googleapis.com/css2?family=Mulish:ital,wght@0,200..1000;1,200..1000&display=swap');

@import url('https://fonts.googleapis.com/css2?family=Mukta+Vaani:wght@200;300;400;500;600;700;800&display=swap');

@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Mulish:ital,wght@0,200..1000;1,200..1000&display=swap');

body {
  /* font-family: "Open Sans", sans-serif; */
  font-family: 'Inter', sans-serif;
  color: #444444;
}

a {
  color: #01a084;
  text-decoration: none;
}

a:hover {
  color: #037a69;
  text-decoration: none;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: "Roboto", sans-serif;
}

/*--------------------------------------------------------------
# Preloader
--------------------------------------------------------------*/
#preloader {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 9999;
  overflow: hidden;
  background: #fff;
}

#preloader:before {
  content: "";
  position: fixed;
  top: calc(50% - 30px);
  left: calc(50% - 30px);
  border: 6px solid #01a084;
  border-top-color: #ecf8f9;
  border-radius: 50%;
  width: 60px;
  height: 60px;
  animation: animate-preloader 1s linear infinite;
}

@keyframes animate-preloader {
  0% {
    transform: rotate(0deg);
  }

  100% {
    transform: rotate(360deg);
  }
}

/*--------------------------------------------------------------
# Back to top button
--------------------------------------------------------------*/


.back-to-top {
  position: fixed;
  visibility: hidden;
  opacity: 0;
  right: 15px;
  bottom: 15px;
  z-index: 996;
  background: #01a084;
  width: 40px;
  height: 40px;
  border-radius: 4px;
  transition: all 0.4s;
}

.back-to-top i {
  font-size: 28px;
  color: #fff;
  line-height: 0;
}

.back-to-top:hover {
  background: #5ec6ca;
  color: #fff;
}

.back-to-top.active {
  visibility: visible;
  opacity: 1;
}

/*--------------------------------------------------------------
# Disable aos animation delay on mobile devices
--------------------------------------------------------------*/
@media screen and (max-width: 768px) {
  [data-aos-delay] {
    transition-delay: 0 !important;
  }
}

/*--------------------------------------------------------------
# Top Bar
--------------------------------------------------------------*/
#topbar {
  background: #01a084;
  color: #fff;
  height: 40px;
  font-size: 16px;
  font-weight: 600;
  z-index: 996;
  transition: all 0.5s;
}

#topbar.topbar-scrolled {
  top: -40px;
}

#topbar i {
  padding-right: 6px;
  line-height: 0;
}

/*--------------------------------------------------------------
# Header
--------------------------------------------------------------*/
#header {
  transition: all 0.5s;
  z-index: 997;
  /* padding: 20px 0; */
  /* top: 40px; */
  box-shadow: 0px 2px 15px rgba(0, 0, 0, 0.1);
}

@media (max-width: 992px) {
  #header {
    /* padding: 15px 0; */
  }
}

#header.header-scrolled {
  top: 0;
}

#header .logo {
  font-size: 28px;
  margin: 0;
  padding: 0;
  line-height: 1;
  font-weight: 600;
  letter-spacing: 0.5px;
  text-transform: uppercase;
}

#header .logo a {
  color: #555555;
}

#header .logo img {
  width: 130px;
  height: 130px;
}

/**
* Appointment Button
*/
.appointment-btn {
  width: Fixed (151px)px;
  height: Hug (45px)px;
  top: 68px;
  left: 1103px;
  padding: 6px 19px 6px 19px;
  gap: 10px;
  border-radius: 2px;
  opacity: 0px;
  color: #ffffff;
  background: #0079FF;
  font-weight: 600;
  margin-left: 60px;


}

.appointment-btn:hover {
  background: #F98122;
  color: #fff;
}

.appointment_btn_mobile {

  width: Fixed (151px)px;
  height: Hug (45px)px;
  top: 68px;
  left: 1103px;
  padding: 6px 19px 6px 19px;
  gap: 10px;
  border-radius: 2px;
  border: none;
  opacity: 0px;
  color: #ffffff !important;
  background: #0079FF;
  font-weight: 600;


}

.appointment_btn_mobile:hover {
  background: #F98122;
  color: #fff;
}


@media (max-width: 768px) {
  .appointment-btn {
    margin: 0 15px 0 0;
    padding: 6px 15px;
  }
}

/*--------------------------------------------------------------
# Navigation Menu
--------------------------------------------------------------*/
/**
* Desktop Navigation 
*/
.navbar {
  padding: 0;

}

.navbar ul {
  margin: 0;
  padding: 0;
  display: flex;
  list-style: none;
  align-items: center;
}


@media (min-width:1200px) {
  .navbar ul {
    margin: 0;
    /* padding-left: 80px;   */
    display: flex;
    list-style: none;
    align-items: center;
  }
}

.navbar li {
  position: relative;
}

@media (min-width:1200px) {

  .navbar a,
  .navbar a:focus {
    /* padding: 10px 40px 10px 30px !important; */


  }

}

.nav_logo {
  width: 35%;

}

@media (min-width:990px) and (max-width:1200px) {
  .nav_logo {
    margin-left: 70px;
    width: 35%;

  }
}

@media (min-width:1200px) and (max-width:1440px) {
  .nav_logo {
    margin-left: 110px;
    width: 35%;

  }
}

@media (min-width:1440px) {
  .nav_logo {
    margin-left: 170px;
    width: 35%;

  }
}

.navbar a,
.navbar a:focus {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-family: "Mulish", sans-serif;
  font-size: 15px;
  color: #ffffff;
  white-space: nowrap;
  transition: 0.3s;
  font-weight: 6 00;
  padding: 10px 10px 10px 30px;

}

.navbar a i,
.navbar a:focus i {
  font-size: 12px;
  line-height: 0;
  margin-left: 5px;
}

.navbar a:hover,
.navbar .active,
.navbar .active:focus,
.navbar li:hover>a {
  color: #F98122;
}

.navbar .dropdown ul {
  display: block;
  position: absolute;
  left: 14px;
  top: calc(100% + 30px);
  margin: 0;
  padding: 10px 0;
  z-index: 99;
  opacity: 0;
  visibility: hidden;
  background: #fff;
  box-shadow: 0px 0px 30px rgba(127, 137, 161, 0.25);
  transition: 0.3s;
  border-radius: 4px;
}

.navbar .dropdown ul li {
  min-width: 200px;
}

.navbar .dropdown ul a {
  padding: 10px 20px;
  text-transform: none;
}

.navbar .dropdown ul a i {
  font-size: 20px;
}

.navbar .dropdown ul a:hover,
.navbar .dropdown ul .active:hover,
.navbar .dropdown ul li:hover>a {
  color: #01a084;
}

.navbar .dropdown:hover>ul {
  opacity: 1;
  top: 100%;
  visibility: visible;
}

.navbar .dropdown .dropdown ul {
  top: 0;
  left: calc(100% - 30px);
  visibility: hidden;
}

.navbar .dropdown .dropdown:hover>ul {
  opacity: 1;
  top: 0;
  left: 100%;
  visibility: visible;
}

@media (max-width: 1366px) {
  .navbar .dropdown .dropdown ul {
    left: -90%;
  }

  .navbar .dropdown .dropdown:hover>ul {
    left: -100%;
  }
}

/* 
  Mobile Navigation 
*/
.mobile-nav-toggle {
  color: #ffffff;
  font-size: 28px;
  cursor: pointer;
  display: none;
  line-height: 0;
  transition: 0.5s;
}

.mobile-nav-toggle.bi-x {
  color: #fff;
}

@media (max-width: 991px) {
  .mobile-nav-toggle {
    display: block;
  }

  .navbar ul {
    display: none;
  }
}

.navbar-mobile {
  position: fixed;
  overflow: hidden;
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  background: rgba(60, 60, 60, 0.9);
  transition: 0.3s;
  z-index: 999;
}

.navbar-mobile .mobile-nav-toggle {
  position: absolute;
  top: 15px;
  right: 15px;
}

.navbar-mobile ul {
  display: block;
  position: absolute;
  top: 55px;
  right: 15px;
  bottom: 15px;
  left: 15px;
  padding: 10px 0;
  border-radius: 8px;
  background-color: #fff;
  overflow-y: auto;
  transition: 0.3s;
}

.navbar-mobile a,
.navbar-mobile a:focus {
  padding: 10px 20px;
  font-size: 15px;
  color: #555555;
}

.navbar-mobile a:hover,
.navbar-mobile .active,
.navbar-mobile li:hover>a {
  color: #F98122;
}

.navbar-mobile .dropdown ul {
  position: static;
  display: none;
  margin: 10px 20px;
  padding: 10px 0;
  z-index: 99;
  opacity: 1;
  visibility: visible;
  background: #fff;
  box-shadow: 0px 0px 30px rgba(127, 137, 161, 0.25);
}

.navbar-mobile .dropdown ul li {
  min-width: 200px;
}

.navbar-mobile .dropdown ul a {
  padding: 10px 20px;
}

.navbar-mobile .dropdown ul a i {
  font-size: 12px;
}

.navbar-mobile .dropdown ul a:hover,
.navbar-mobile .dropdown ul .active:hover,
.navbar-mobile .dropdown ul li:hover>a {
  color: #01a084;
}

.navbar-mobile .dropdown>.dropdown-active {
  display: block;
}




@media (max-width: 991px) {

  /* 1. Ensure the container spreads items to the edges */
  #header .container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
  }

  /* 2. Show the toggle */
  .mobile-nav-toggle {
    display: block;
    /* Ensure it's clickable and has space */
    padding-left: 15px;
    z-index: 9999;
  }

  /* 3. Make sure the logo doesn't shrink too much */
  .logo_mobile {
    width: 50% !important;
  }


}

/* Ensure the navbar container itself doesn't block the layout */
.navbar {
  padding: 0;
  display: flex;
  align-items: center;
}

@media (max-width: 991px) {
  #header .container {
    padding-left: 20px;
    padding-right: 20px;

  }
}

/*--------------------------------------------------------------
# Hero Section
--------------------------------------------------------------*/
#hero {
  width: 100%;
  height: 100vh;
  background-color: rgba(60, 60, 60, 0.8);
  overflow: hidden;
  position: relative;
}

#hero .carousel,
#hero .carousel-inner,
#hero .carousel-item,
#hero .carousel-item::before {
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
}

#hero .carousel-item {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  display: flex;
  justify-content: center;
  align-items: flex-end;
}

#hero .container {
  text-align: center;
  background: rgba(255, 255, 255, 0.9);
  padding-top: 30px;
  padding-bottom: 30px;
  margin-bottom: 50px;
  border-top: 4px solid #01a084;
}

@media (max-width: 1200px) {
  #hero .container {
    margin-left: 50px;
    margin-right: 50px;
  }
}

#hero h2 {
  color: #2f2f2f;
  margin-bottom: 20px;
  font-size: 36px;
  font-weight: 700;
}

#hero p {
  margin: 0 auto 30px auto;
  color: #555555;
}

#hero .carousel-inner .carousel-item {
  transition-property: opacity;
  background-position: center top;
}

#hero .carousel-inner .carousel-item,
#hero .carousel-inner .active.carousel-item-start,
#hero .carousel-inner .active.carousel-item-end {
  opacity: 0;
}

#hero .carousel-inner .active,
#hero .carousel-inner .carousel-item-next.carousel-item-start,
#hero .carousel-inner .carousel-item-prev.carousel-item-end {
  opacity: 1;
  transition: 0.5s;
}

#hero .carousel-inner .carousel-item-next,
#hero .carousel-inner .carousel-item-prev,
#hero .carousel-inner .active.carousel-item-start,
#hero .carousel-inner .active.carousel-item-end {
  left: 0;
  transform: translate3d(0, 0, 0);
}

#hero .carousel-control-next-icon,
#hero .carousel-control-prev-icon {
  background: none;
  font-size: 30px;
  line-height: 0;
  width: auto;
  height: auto;
  background: rgba(63, 187, 192, 0.8);
  border-radius: 50px;
  transition: 0.3s;
  color: rgba(255, 255, 255, 0.5);
  width: 54px;
  height: 54px;
  display: flex;
  align-items: center;
  justify-content: center;


}

#hero .carousel-control-next-icon:hover,
#hero .carousel-control-prev-icon:hover {
  background: #01a084;
  color: rgba(255, 255, 255, 0.8);
}

#hero .carousel-indicators li {
  list-style-type: none;
  cursor: pointer;
  background: #fff;
  overflow: hidden;
  border: 0;
  width: 12px;
  height: 12px;
  border-radius: 50px;
  opacity: 0.6;
  transition: 0.3s;
}

#hero .carousel-indicators li.active {
  opacity: 1;
  background: #01a084;
}

#hero .btn-get-started {
  font-family: "Roboto", sans-serif;
  font-weight: 500;
  font-size: 14px;
  letter-spacing: 1px;
  display: inline-block;
  padding: 14px 32px;
  border-radius: 4px;
  transition: 0.5s;
  line-height: 1;
  color: #fff;
  background: #01a084;
}

#hero .btn-get-started:hover {
  background: #037a69;
}

@media (max-width: 992px) {
  #hero {
    height: 100vh;
  }

  #hero .container {
    margin-top: 100px;
  }
}

@media (max-width: 768px) {
  #hero h2 {
    font-size: 28px;
  }
}

@media (min-width: 1024px) {

  #hero .carousel-control-prev,
  #hero .carousel-control-next {
    width: 5%;
  }
}

@media (max-height: 500px) {
  #hero {
    height: 160vh;
  }
}




.hero_lineheight {
  /* Set the desired height for the line itself */
  line-height: 50px;

}

.hero_para {
  font-size: 15px;

}


@media (max-width: 767px) {
  .get_in_touch {
    margin-left: auto;
    margin-right: auto;
    display: inline-block;
    /* Ensures it honors the auto margins */
  }




}


@media (max-width: 770px) {
  .mobile_padding {
    padding-left: 33px;
    padding-right: 33px
  }

  .hero_lineheight {
    /* Set the desired height for the line itself */
    line-height: 38px;

  }

  .mobile-banner-container {
    position: relative;
    width: 100%;
    min-height: 85vh;
    /* Takes up 80% of the screen height */
    background-image: url('../img/marine/mobile_banner.png');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    display: flex;
    align-items: center;
    /* Centers text vertically */
    justify-content: center;
    /* Centers text horizontally */
  }

  /* Optional: Dark overlay to make text more readable */
  .banner-overlay {

    width: 100%;
    height: 100%;
    position: absolute;
    top: -10%;
    left: 0;
    display: flex;
    align-items: center;
    padding: 20px;
  }

  .banner-text {
    position: relative;
    z-index: 2;
    text-align: center;
    /* Center text alignment */
    color: #ffffff;
  }


  .banner-text-mobile {
    position: relative;
    z-index: 2;
    text-align: left;
    /* Center text alignment */
    color: #ffffff;
    margin-top: -100px !important;
  }

  .hero_heading {
    font-size: 28px;
    font-weight: bold;
    color: #ffffff;
    margin-bottom: 15px;
  }

  .hero_para {
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: 10px;
  }

  .hero_para_desc {
    font-size: 15px;
    line-height: 1.5;
    margin-bottom: 25px;
    color: rgba(255, 255, 255, 0.9);
  }

  .banner_btn {
    padding: 12px 30px;
    border-radius: 50px;
  }
}

.banner-container {
  /* KEY: Makes this container the reference point for the text */
  position: relative;
  /* This ensures the container only takes up the space of the image, 
       though img-fluid/Bootstrap often handles this. */
  display: inline-block;
}

@media (min-width: 1200px) {

  .hero_heading {
    font-size: 50px;
    font-weight: bold;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
  }
}

@media (min-width: 992px) and (max-width: 1200px) {

  .hero_heading {
    font-size: 42px;
    font-weight: bold;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
  }
}


@media (min-width: 770px) and (max-width: 992px) {

  .hero_heading {
    font-size: 30px;
    font-weight: bold;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
  }
}




.banner-image,
.banner-image-mobile {
  /* Ensure the image takes up the full width of its container */
  width: 100%;
  height: auto;
  display: block;
  /* Removes any default spacing issues */
}



.banner-text {
  /* KEY: Takes it out of the normal flow and allows precise positioning */
  position: absolute;
  /* Example: Center the text in the middle of the banner */
  top: 45%;
  left: 50%;
  /* Use transform to truly center the element relative to its own size */
  transform: translate(-50%, -50%);

  /* Basic styling for the text */
  color: white;
  /* Make the text visible against the dark banner */
  text-align: center;
  padding: 20px;
  /* z-index: 10; */
  /* Ensures the text sits above the image */
}

/* --- UPDATED CSS --- */


#new-gallery .container {
  /* Increase left and right padding for the desktop view */
  padding-left: 50px !important;
  padding-right: 50px !important;
  /* Adjust '50px' to whatever size you need */
}





.pading_minus_top {
  margin-top: -30px;
}

/* You might want to remove the padding for smaller screens */
@media (max-width: 768px) {
  #new-gallery .container {
    padding-left: 15px !important;
    /* Reset to standard mobile padding */
    padding-right: 15px !important;
  }
}

#new-gallery {
  /* Updated path for better compatibility: Using /assets/... is safer if your CSS is in a subfolder */
  background-image: url('../img/marine/bg_curve_line.png');

  /* Ensure the image covers the section without repeating */
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;

  /* Keep other styling as needed */
  min-height: 600px;
  position: relative;
}

/* Optional: Darken the background slightly for better text contrast */
#new-gallery::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  /* Removed background comment */
  z-index: 0;
}


/* 2. Positioning Container for Individual Images (EQUAL HEIGHTS HERE) */
.image-overlay-container {
  position: relative;
  overflow: hidden;
  /* --- NEW/UPDATED FOR EQUAL HEIGHT --- */
  height: 300px;
  /* SET YOUR DESIRED FIXED HEIGHT HERE (e.g., 300px) */
  border-radius: 10px;
  /* Optional: Adds rounded corners seen in your output */
}



.gallery-img {
  width: 100%;
  /* --- NEW/UPDATED FOR EQUAL HEIGHT --- */
  height: 100%;
  object-fit: cover;
  /* Forces image to cover the container without distorting */
  display: block;
}

/* 3. Text Overlay Styling (UNCHANGED) */
.image-text {
  position: absolute;
  color: white;
  padding: 15px;
  z-index: 2;
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.8);
}

/* Specific position: Bottom Left Corner (UNCHANGED) */
.image-text.bottom-left {
  bottom: 0;
  left: 0;
  text-align: left;
}



@media (min-width:1200px) {
  .paddinng_container {
    padding-left: 150px !important;
    padding-right: 150px !important;
  }

}




@media (min-width:1400px) {

  .poadding_left_div {
    padding-right: 100px;
  }

  .image-overlay-container_welding_man {
    position: relative;
    overflow: hidden;
    height: 380px;
    /* Increased slightly to fit all your address text */
    border-radius: 20px;

    /* --- BACKGROUND IMAGE SETTINGS --- */
    background-image: url('../img/marine/welding_man.png');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;

    /* Optional: adds a light tint so text is easier to read */
    background-blend-mode: overlay;
    margin-left: 50px;
    margin-right: 50px
  }

  .image_text_welding_card.full_box {


    padding-left: 50px;
  }

}


@media (max-width:768px) {

  .poadding_left_div {
    padding-right: 20px;
    padding-left: 20px;
  }
}


@media (min-width:1200px) and (max-width:1400px) {

  .poadding_left_div {
    padding-right: 45px;
  }

  .image-overlay-container_welding_man {
    position: relative;
    overflow: hidden;
    height: 400px;
    /* Increased slightly to fit all your address text */
    border-radius: 20px;

    /* --- BACKGROUND IMAGE SETTINGS --- */
    background-image: url('../img/marine/welding_man.png');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;

    /* Optional: adds a light tint so text is easier to read */
    background-blend-mode: overlay;
    margin-left: 50px;
    margin-right: 0px
  }

  .image_text_welding_card.full_box {


    padding-left: 50px;
  }

}


@media (min-width:990px) and (max-width:1200px) {

  .image-overlay-container_welding_man {
    position: relative;
    overflow: hidden;
    height: 420px;
    /* Increased slightly to fit all your address text */
    border-radius: 20px;

    /* --- BACKGROUND IMAGE SETTINGS --- */
    background-image: url('../img/marine/welding_man.png');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;

    /* Optional: adds a light tint so text is easier to read */
    background-blend-mode: overlay;
    margin-left: 50px;

  }

  .image_text_welding_card.full_box {


    padding-left: 35px;
  }
}

@media (min-width:770px) and (max-width:990px) {


  .image-overlay-container_welding_man {
    position: relative;
    overflow: hidden;
    height: 400px;
    /* Increased slightly to fit all your address text */
    border-radius: 20px;

    /* --- BACKGROUND IMAGE SETTINGS --- */
    background-image: url('../img/marine/welding_man.png');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;

    /* Optional: adds a light tint so text is easier to read */
    background-blend-mode: overlay;
    margin-left: 50px;

  }

  .image_text_welding_card.full_box {


    padding-left: 30px;
  }
}


@media (max-width:770px) {


  .image-overlay-container_welding_man {
    position: relative;
    overflow: hidden;
    height: 400px;
    /* Increased slightly to fit all your address text */
    border-radius: 20px;

    /* --- BACKGROUND IMAGE SETTINGS --- */
    background-image: url('../img/marine/welding_man.png');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;

    /* Optional: adds a light tint so text is easier to read */
    background-blend-mode: overlay;
    margin-left: -4px;
    margin-top: 20px;

  }

  .image_text_welding_card.full_box {}
}

.construction_heading {
  color: #0364B2;
  font-weight: bold;
  margin-top: 15px;
  margin-bottom: 30px;
}

.need_mrg_top {
  margin-top: 30px;

}

.need_mrg_btm {
  margin-bottom: 30px;

}



.inter_font_black_weldig_card {
  font-family: "Inter", sans-serif;
  font-weight: 500;
  /* 'medium' is 500 */
  font-size: 15px;
  color: #5A5A5A;
  margin-bottom: 2px;
  /* Tightens the address lines */
}

@media (min-width:770px) {
  .image_text_welding_card {
    position: absolute;

  }
}

.image_text_welding_card {

  color: white;
  padding: 15px;
  z-index: 2;
}

/* Optional: Make the titles slightly smaller (UNCHANGED) */
.image-text h4 {
  margin-bottom: 5px;
  font-size: 1.2rem;
}

.image-text p {
  font-size: 0.9rem;
}

/* --------------------------- 
# Sections General
--------------------------------------------------------------*/
section {
  padding: 50px 0;
  overflow: hidden;
}

.section-bg {
  background-color: rgba(238, 238, 238, 0.686)
}

.section-title {
  text-align: center;
  padding-bottom: 30px;
}

.section-title h2 {
  font-family: "Mukta Vaani";
  font-size: 39px;
  font-weight: 800;
  line-height: 48.36px;
  letter-spacing: -0.02em;
  text-align: center;



}


@media (min-width:1400px) {

  .ourservices_heading {
    padding-left: 400px;
    padding-right: 400px;
    color: #0364B2;
  }
}

@media (min-width:1200px) and (max-width:1400px) {

  .ourservices_heading {
    padding-left: 350px;
    padding-right: 350px;
    color: #0364B2;
  }
}

@media (min-width:992px) and (max-width:1200px) {

  .ourservices_heading {
    padding-left: 280px;
    padding-right: 280px;
    color: #0364B2;
  }
}

@media (min-width:770px) and (max-width:992px) {

  .ourservices_heading {
    padding-left: 150px;
    padding-right: 150px;
    color: #0364B2;
  }
}

.ourservices_heading {

  color: #0364B2;
}

/* .section-title h2::after {
  content: "";
  position: absolute;
  display: block;
  width: 50px;
  height: 3px;
  background: #0598d2;
  bottom: 0;
  left: calc(50% - 25px);
} */

.section-title p {
  margin-bottom: 0;
}

/*--------------------------------------------------------------
# Breadcrumbs
--------------------------------------------------------------*/
.breadcrumbs {
  padding: 20px 0;
  background-color: #ecf8f9;
  min-height: 40px;
  margin-top: 120px;
}

@media (max-width: 992px) {
  .breadcrumbs {
    margin-top: 70px;
  }
}

.breadcrumbs h2 {
  font-size: 24px;
  font-weight: 300;
  margin: 0;
}

@media (max-width: 992px) {
  .breadcrumbs h2 {
    margin: 0 0 10px 0;
  }
}

.breadcrumbs ol {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: 14px;
}

.breadcrumbs ol li+li {
  padding-left: 10px;
}

.breadcrumbs ol li+li::before {
  display: inline-block;
  padding-right: 10px;
  color: #6c757d;
  content: "/";
}

@media (max-width: 768px) {
  .breadcrumbs .d-flex {
    display: block !important;
  }

  .breadcrumbs ol {
    display: block;
  }

  .breadcrumbs ol li {
    display: inline-block;
  }
}

/*--------------------------------------------------------------
# Featured Services
--------------------------------------------------------------*/
.featured-services .icon-box {
  padding: 30px;
  position: relative;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 0 29px 0 rgba(68, 88, 144, 0.12);
  transition: all 0.3s ease-in-out;
  border-radius: 8px;
  z-index: 1;
}

.featured-services .icon-box::before {
  content: "";
  position: absolute;
  background: #d9f1f2;
  right: 0;
  left: 0;
  bottom: 0;
  top: 100%;
  transition: all 0.3s;
  z-index: -1;
}

.featured-services .icon-box:hover::before {
  background: #01a084;
  top: 0;
  border-radius: 0px;
}

.featured-services .icon {
  margin-bottom: 15px;
}

.featured-services .icon i {
  font-size: 48px;
  line-height: 1;
  color: #01a084;
  transition: all 0.3s ease-in-out;
}

.featured-services .title {
  font-weight: 700;
  margin-bottom: 15px;
  font-size: 18px;
}

.featured-services .title a {
  color: #111;
}

.featured-services .description {
  font-size: 15px;
  line-height: 28px;
  margin-bottom: 0;
}

.featured-services .icon-box:hover .title a,
.featured-services .icon-box:hover .description {
  color: #fff;
}

.featured-services .icon-box:hover .icon i {
  color: #fff;
}

/*--------------------------------------------------------------
# Cta
--------------------------------------------------------------*/
.cta {
  background: #01a084;
  color: #fff;
  background-size: cover;
  padding: 60px 0;
}

.cta h3 {
  font-size: 28px;
  font-weight: 700;
}

.cta .cta-btn {
  font-family: "Roboto", sans-serif;
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 1px;
  display: inline-block;
  padding: 10px 35px;
  border-radius: 25px;
  transition: 0.5s;
  margin-top: 10px;
  border: 2px solid #fff;
  color: #fff;
}

.cta .cta-btn:hover {
  background: #fff;
  color: #01a084;
}

/*--------------------------------------------------------------
# About Us
--------------------------------------------------------------*/
.about .content h3 {
  font-weight: 600;
  font-size: 26px;
}

.about .content ul {
  list-style: none;
  padding: 0;
}

.about .content ul li {
  padding-bottom: 10px;
}

.about .content ul i {
  font-size: 20px;
  padding-right: 4px;
  color: #0598d2;
}

.about .content p:last-child {
  margin-bottom: 0;
}

/*--------------------------------------------------------------
# Counts
--------------------------------------------------------------*/
.counts {
  padding-bottom: 30px;
}

.counts .count-box {
  box-shadow: -10px -5px 40px 0 rgba(0, 0, 0, 0.1);
  padding: 30px;
  width: 100%;
}

.counts .count-box i {
  display: block;
  font-size: 30px;
  color: #01a084;
  float: left;
}

.counts .count-box span {
  font-size: 42px;
  line-height: 24px;
  display: block;
  font-weight: 700;
  color: #555555;
  margin-left: 50px;
}

.counts .count-box p {
  padding: 30px 0 0 0;
  margin: 0;
  font-family: "Roboto", sans-serif;
  font-size: 14px;
}

.counts .count-box a {
  font-weight: 600;
  display: block;
  margin-top: 20px;
  color: #7b7b7b;
  font-size: 15px;
  font-family: "Poppins", sans-serif;
  transition: ease-in-out 0.3s;
}

.counts .count-box a:hover {
  color: #01a084;
}

/*--------------------------------------------------------------
# Features
--------------------------------------------------------------*/
.features .icon-box h4 {
  font-size: 20px;
  font-weight: 700;
  margin: 5px 0 10px 60px;
}

.features .icon-box i {
  font-size: 48px;
  float: left;
  color: #01a084;
}

.features .icon-box p {
  font-size: 15px;
  color: #848484;
  margin-left: 60px;
}

.features .image {
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  min-height: 400px;
}

/*--------------------------------------------------------------
# Services
--------------------------------------------------------------*/
.services .icon-box {
  margin-bottom: 20px;
  text-align: center;
}

.services .icon {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 80px;
  height: 80px;
  margin-bottom: 20px;
  background: #fff;
  border-radius: 50%;
  transition: 0.5s;
  color: #01a084;
  overflow: hidden;
  box-shadow: 0px 0 25px rgba(0, 0, 0, 0.15);
}

.services .icon i {
  font-size: 36px;
  line-height: 0;
}

.services .icon-box:hover .icon {
  box-shadow: 0px 0 25px rgba(63, 187, 192, 0.3);
}

.services .title {
  font-weight: 600;
  margin-bottom: 15px;
  font-size: 18px;
  position: relative;
  padding-bottom: 15px;
}

.services .title a {
  color: #444444;
  transition: 0.3s;
}

.services .title a:hover {
  color: #01a084;
}

.services .title::after {
  content: "";
  position: absolute;
  display: block;
  width: 50px;
  height: 2px;
  background: #01a084;
  bottom: 0;
  left: calc(50% - 25px);
}

.services .description {
  line-height: 24px;
  font-size: 14px;
}

/*--------------------------------------------------------------
# Appointments
--------------------------------------------------------------*/
.appointment .php-email-form {
  width: 100%;
}

.appointment .php-email-form .form-group {
  padding-bottom: 8px;
}

.appointment .php-email-form .validate {
  display: none;
  color: red;
  margin: 0 0 15px 0;
  font-weight: 400;
  font-size: 13px;
}

.appointment .php-email-form .error-message {
  display: none;
  color: #fff;
  background: #76dfbc;
  text-align: left;
  padding: 15px;
  font-weight: 600;
}

.appointment .php-email-form .error-message br+br {
  margin-top: 25px;
}

.appointment .php-email-form .sent-message {
  display: none;
  color: #fff;
  background: #18d26e;
  text-align: center;
  padding: 15px;
  font-weight: 600;
}

.appointment .php-email-form .loading {
  display: none;
  background: #fff;
  text-align: center;
  padding: 15px;
}

.appointment .php-email-form .loading:before {
  content: "";
  display: inline-block;
  border-radius: 50%;
  width: 24px;
  height: 24px;
  margin: 0 10px -6px 0;
  border: 3px solid #18d26e;
  border-top-color: #eee;
  animation: animate-loading 1s linear infinite;
}

.appointment .php-email-form input,
.appointment .php-email-form textarea,
.appointment .php-email-form select {
  border-radius: 0;
  box-shadow: none;
  font-size: 14px;
  padding: 10px !important;
  font-family: "Mulish", sans-serif;

}

.appointment .php-email-form input:focus,
.appointment .php-email-form textarea:focus,
.appointment .php-email-form select:focus {
  border-color: #01a084;
}

.appointment .php-email-form input,
.appointment .php-email-form select {
  height: 44px;
}

.appointment .php-email-form textarea {
  padding: 10px 12px;
}

.appointment .php-email-form button[type=submit] {
  background: #01539D;
  border: 0;
  padding: 10px 35px;
  color: #fff;
  transition: 0.4s;
  border-radius: 50px;
  font-family: "Mulish", sans-serif;

}

.appointment .php-email-form button[type=submit]:hover {
  background: #0598d2;
}

/*--------------------------------------------------------------
# Departments
--------------------------------------------------------------*/
.departments .nav-tabs {
  border: 0;
}

@media (min-width:768px) {
  .departments .nav-link {
    border: 0;
    padding: 20px;
    color: #555555;
    border-radius: 0;
    border-left: 5px solid #fff;
    cursor: pointer;
  }




  .departments .nav-link h4 {
    font-size: 18px;
    font-weight: 800;
    transition: 0.3s;
    font-family: "Roboto Condensed", sans-serif;
  }
}

@media (max-width:768px) {
  .departments .nav-link {
    border: 0;

    color: #555555;
    border-radius: 0;
    border-left: 5px solid #fff;
    cursor: pointer;
  }


  .departments .nav-link h4 {
    font-size: 12px;
    font-weight: 800;
    transition: 0.3s;
    font-family: "Roboto Condensed", sans-serif;
  }
}

.departments .nav-link p {
  font-size: 14px;
  margin-bottom: 0;
}

.departments .nav-link:hover h4 {
  color: #01539D
}

.departments .nav-link.active {
  background: rgba(239, 239, 239, 0.695);
  border-color: #0598d2;
}

.departments .nav-link.active h4 {
  color: #0598d2;

}

.departments .tab-pane.active {
  animation: slide-down 0.5s ease-out;
}

.departments .tab-pane img {
  float: left;
  max-width: 300px;
  padding: 0 15px 15px 0;
}

.departments .tab-pane img {
  float: none;
  padding: 0 0 15px 0;
  max-width: 100%;
}

@media (min-width: 768px) {



  .departments .tab-pane h3 {
    font-family: "Mulish";
    font-size: 20px;
    font-weight: 800;
    line-height: 60px;
    letter-spacing: -0.02em;
    text-align: left;
    color: #4A4A4A;

  }
}

@media (max-width: 768px) {



  .departments .tab-pane h3 {
    font-family: "Mulish";
    font-size: 20px;
    font-weight: 800;
    letter-spacing: -0.02em;
    text-align: left;
    color: #4A4A4A;

  }
}

.departments .tab-pane p {
  color: #777777;
}

.departments .tab-pane p:last-child {
  font-family: "Mulish" !important;
  font-size: 16px;
  font-weight: 600;
  line-height: 20.08px;
  letter-spacing: -0.02em;
  text-align: left;
  color: #9A9A9A;
}

@keyframes slide-down {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}

/*--------------------------------------------------------------
# Testimonials
--------------------------------------------------------------*/
.testimonials .testimonials-carousel,
.testimonials .testimonials-slider {
  overflow: hidden;
}

.testimonials .testimonial-item {
  box-sizing: content-box;
  min-height: 320px;
}


/* .testimonials .testimonial-item h3 {
  font-size: 18px;
  font-weight: bold;
  margin: 10px 0 5px 45px;
  color: #111;
} */

.testimonials .testimonial-item h4 {
  font-size: 14px;
  color: #999;
  margin: 0 0 0 45px;
}

.testimonials .testimonial-item .quote-icon-left,
.testimonials .testimonial-item .quote-icon-right {
  color: #0598d2;
  font-size: 26px;
}

.testimonials .testimonial-item .quote-icon-left {
  display: inline-block;
  left: -5px;
  position: relative;
}

.testimonials .testimonial-item .quote-icon-right {
  display: inline-block;
  right: -5px;
  position: relative;
  top: 10px;
}

/* .testimonials .testimonial-item p {

  margin: 0 15px 0 15px;
  padding: 20px 20px 60px 20px;
  
  position: relative;
  border-radius: 6px;
  position: relative;
  z-index: 1;
  font-family: "Poetsen One", sans-serif;

} */

.testimonials .swiper-pagination {
  margin-top: 20px;
  position: relative;
}

.testimonials .swiper-pagination .swiper-pagination-bullet {
  width: 12px;
  height: 12px;
  background-color: #fff;
  opacity: 1;
  border: 1px solid #0598d2;
}

.testimonials .swiper-pagination .swiper-pagination-bullet-active {
  background-color: #0598d2;
}

/*--------------------------------------------------------------
# Doctors
--------------------------------------------------------------*/
.doctors .member {
  margin-bottom: 20px;
  overflow: hidden;
  text-align: center;
  border-radius: 4px;
  background: #fff;
  box-shadow: 0px 2px 15px rgba(63, 187, 192, 0.1);
}

.doctors .member .member-img {
  position: relative;
  overflow: hidden;
}

.doctors .member .social {
  position: absolute;
  left: 0;
  bottom: 0;
  right: 0;
  height: 40px;
  opacity: 0;
  transition: ease-in-out 0.3s;
  background: rgba(255, 255, 255, 0.85);
  display: flex;
  align-items: center;
  justify-content: center;
}

.doctors .member .social a {
  transition: color 0.3s;
  color: #555555;
  margin: 0 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.doctors .member .social a i {
  line-height: 0;
}

.doctors .member .social a:hover {
  color: #01a084;
}

.doctors .member .social i {
  font-size: 18px;
  margin: 0 2px;
}

.doctors .member .member-info {
  padding: 25px 15px;
}

.doctors .member .member-info h4 {
  font-weight: 700;
  margin-bottom: 5px;
  font-size: 18px;
  color: #555555;
}

.doctors .member .member-info span {
  display: block;
  font-size: 13px;
  font-weight: 400;
  color: #aaaaaa;
}

.doctors .member .member-info p {
  font-style: italic;
  font-size: 14px;
  line-height: 26px;
  color: #777777;
}

.doctors .member:hover .social {
  opacity: 1;
}

/*--------------------------------------------------------------
# Gallery
--------------------------------------------------------------*/
.gallery {
  overflow: hidden;
}

.gallery .swiper-pagination {
  margin-top: 20px;
  position: relative;
}

.gallery .swiper-pagination .swiper-pagination-bullet {
  width: 12px;
  height: 12px;
  background-color: #fff;
  opacity: 1;
  border: 1px solid #01a084;
}

.gallery .swiper-pagination .swiper-pagination-bullet-active {
  background-color: #01a084;
}

.gallery .swiper-slide-active {
  text-align: center;
}

@media (min-width: 992px) {
  .gallery .swiper-wrapper {
    padding: 40px 0;
  }

  .gallery .swiper-slide-active {
    border: 6px solid #01a084;
    padding: 4px;
    background: #fff;
    z-index: 1;
    transform: scale(1.2);
    margin-top: 10px;
  }
}

/*--------------------------------------------------------------
# Pricing
--------------------------------------------------------------*/
.pricing .box {
  padding: 20px;
  background: #fff;
  text-align: center;
  box-shadow: 0px 0px 4px rgba(0, 0, 0, 0.12);
  border-radius: 4px;
  position: relative;
  overflow: hidden;
}

.pricing h3 {
  font-weight: 400;
  margin: -20px -20px 20px -20px;
  padding: 20px 15px;
  font-size: 16px;
  font-weight: 600;
  color: #777777;
  background: #f8f8f8;
}

.pricing h4 {
  font-size: 36px;
  color: #01a084;
  font-weight: 600;
  font-family: "Poppins", sans-serif;
  margin-bottom: 20px;
}

.pricing h4 sup {
  font-size: 20px;
  top: -15px;
  left: -3px;
}

.pricing h4 span {
  color: #bababa;
  font-size: 16px;
  font-weight: 300;
}

.pricing ul {
  padding: 0;
  list-style: none;
  color: #444444;
  text-align: center;
  line-height: 20px;
  font-size: 14px;
}

.pricing ul li {
  padding-bottom: 16px;
}

.pricing ul i {
  color: #01a084;
  font-size: 18px;
  padding-right: 4px;
}

.pricing ul .na {
  color: #ccc;
  text-decoration: line-through;
}

.pricing .btn-wrap {
  margin: 20px -20px -20px -20px;
  padding: 20px 15px;
  background: #f8f8f8;
  text-align: center;
}

.pricing .btn-buy {
  background: #01a084;
  display: inline-block;
  padding: 8px 35px 10px 35px;
  border-radius: 4px;
  color: #fff;
  transition: none;
  font-size: 14px;
  font-weight: 400;
  font-family: "Roboto", sans-serif;
  font-weight: 600;
  transition: 0.3s;
}

.pricing .btn-buy:hover {
  background: #037a69;
}

.pricing .featured h3 {
  color: #fff;
  background: #01a084;
}

.pricing .advanced {
  width: 200px;
  position: absolute;
  top: 18px;
  right: -68px;
  transform: rotate(45deg);
  z-index: 1;
  font-size: 14px;
  padding: 1px 0 3px 0;
  background: #01a084;
  color: #fff;
}

/*--------------------------------------------------------------
# Frequently Asked Questioins
--------------------------------------------------------------*/
.faq {
  padding: 60px 0;
}

.faq .faq-list {
  padding: 0;
  list-style: none;
}

.faq .faq-list li {
  border-bottom: 1px solid #d9f1f2;
  margin-bottom: 20px;
  padding-bottom: 20px;
}

.faq .faq-list .question {
  display: block;
  position: relative;
  font-family: #01a084;
  font-size: 18px;
  line-height: 24px;
  font-weight: 400;
  padding-left: 25px;
  cursor: pointer;
  color: #32969a;
  transition: 0.3s;
}

.faq .faq-list i {
  font-size: 16px;
  position: absolute;
  left: 0;
  top: -2px;
}

.faq .faq-list p {
  margin-bottom: 0;
  padding: 10px 0 0 25px;
}

.faq .faq-list .icon-show {
  display: none;
}

.faq .faq-list .collapsed {
  color: black;
}

.faq .faq-list .collapsed:hover {
  color: #01a084;
}

.faq .faq-list .collapsed .icon-show {
  display: inline-block;
  transition: 0.6s;
}

.faq .faq-list .collapsed .icon-close {
  display: none;
  transition: 0.6s;
}

/*--------------------------------------------------------------
# Contact
--------------------------------------------------------------*/
.contact .info-box {
  color: #444444;
  text-align: center;
  box-shadow: 0 0 20px rgba(214, 215, 216, 0.5);
  padding: 20px 0 30px 0;
}

.contact .info-box i {
  font-size: 32px;
  color: #01539D;
  border-radius: 50%;
  padding: 8px;
  border: 2px dotted #01539D;
}

.contact .info-box h3 {
  font-size: 20px;
  color: #777777;
  font-weight: 700;
  margin: 10px 0;
  font-family: "Roboto Condensed", sans-serif;
}

.contact .info-box p {
  padding: 0;
  line-height: 24px;
  font-size: 14px;
  margin-bottom: 0;
  font-family: "Roboto Condensed", sans-serif;
  font-weight: 900;
}

.contact .php-email-form {
  box-shadow: 0 0 20px rgba(214, 215, 216, 0.5);
  padding: 30px;
}

.contact .php-email-form .error-message {
  display: none;
  color: #fff;
  background: #60d8e0;
  text-align: left;
  padding: 15px;
  font-weight: 600;
}

.contact .php-email-form .error-message br+br {
  margin-top: 25px;
}

.contact .php-email-form .sent-message {
  display: none;
  color: #fff;
  background: #18d26e;
  text-align: center;
  padding: 15px;
  font-weight: 600;
}

.contact .php-email-form .loading {
  display: none;
  background: #fff;
  text-align: center;
  padding: 15px;
}

.contact .php-email-form .loading:before {
  content: "";
  display: inline-block;
  border-radius: 50%;
  width: 24px;
  height: 24px;
  margin: 0 10px -6px 0;
  border: 3px solid #18d26e;
  border-top-color: #eee;
  animation: animate-loading 1s linear infinite;
}

.contact .php-email-form input,
.contact .php-email-form textarea {
  border-radius: 4px;
  box-shadow: none;
  font-size: 14px;
  font-family: "Mulish", sans-serif !important;


}

.contact .php-email-form input:focus,
.contact .php-email-form textarea:focus {
  border-color: #01a084;
}

.contact .php-email-form input {
  padding: 10px 15px;
}

.contact .php-email-form textarea {
  padding: 12px 15px;
}

.contact .php-email-form button[type=submit] {
  background: #01539D;
  border: 0;
  padding: 10px 30px;
  color: #fff;
  transition: 0.4s;
  border-radius: 4px;
  font-family: "Azeret Mono", monospace;

}

.contact .php-email-form button[type=submit]:hover {
  background: #0598d2;
}

@keyframes animate-loading {
  0% {
    transform: rotate(0deg);
  }

  100% {
    transform: rotate(360deg);
  }
}

/*--------------------------------------------------------------
# Footer
--------------------------------------------------------------*/


/* Footer Main Styling */
#footer {
  color: #fff;
  font-size: 14px;
}

@media (min-width:1200px) and (max-width:1400px) {

  .first_footer_logo_div {
    padding-left: 120px;

  }
}

@media (min-width:1400px) {
  .first_footer_logo_div {
    padding-left: 120px;
    padding-right: 120px;
  }
}

#footer .footer-top {
  /* Using your specific gradient values */
  background: linear-gradient(to right, #003058 100%, #2b6b9fe3 130%);
  padding: 80px 0 30px 0;
}

#footer .footer-logo {
  max-width: 200px;
}

#footer .footer-description {
  line-height: 24px;
  margin-top: 5px;
  color: rgba(255, 255, 255, 0.8);
}

@media (min-width:768px) {
  #footer h4 {
    font-size: 16px;
    font-weight: bold;
    position: relative;
    padding-bottom: 12px;
    margin-top: 40px;
    margin-bottom: 20px;
  }
}

@media (max-width:768px) {
  #footer h4 {
    font-size: 16px;
    font-weight: bold;
    position: relative;

    margin-top: -10px;

  }

  .need_padding_footer {
    padding-left: 20px;
    padding-right: 20px;

  }
}



#footer .footer-links ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

#footer .footer-links ul li {

  display: flex;
  align-items: center;
}

/* Bullet points from Figma */
#footer .footer-links ul li::before {
  content: "•";
  color: #fff;
  font-size: 18px;
  padding-right: 10px;
}

#footer .footer-links ul a {
  color: rgba(255, 255, 255, 0.8);
  transition: 0.3s;
  text-decoration: none;
}

#footer .footer-links ul a:hover {
  color: #fff;
  padding-left: 5px;
}

/* Bottom Bar Styling */

@media (min-width:990px) {

  #footer .footer-bottom {
    padding: 30px 96px 10px 96px;
  }
}

#footer .agency-name {
  font-weight: bold;
  color: #fff;
}

/* Mobile Adjustments */
@media (max-width: 768px) {
  #footer .footer-top {
    padding: 40px 0 20px 0;
  }

  #footer .footer-links {
    margin-bottom: 30px;
  }
}




@media (min-width:700px) {

  /* Style for the WhatsApp link */
  .whatsapp-link {
    width: 50px;
    height: 50px;
    position: fixed;
    bottom: 45px;
    right: 20px;
    background-color: #25d366;
    color: #fff;
    /* padding: 5px; */
    border-radius: 50%;
    text-decoration: none;
    font-size: 35px;
    text-align: center;
  }

  #scrollBtn {
    display: none;
    position: fixed;
    bottom: 115px;
    right: 25px;
    z-index: 999;
    padding: 9px 15px 9px 15px;
    /* padding: 10px 15px; */
    background-color: #F98122;
    color: white;
    border: none;
    border-radius: 50%;
    cursor: pointer;
  }
}

@media (max-width:700px) {

  /* Style for the WhatsApp link */
  .whatsapp-link {
    width: 50px;
    height: 50px;
    position: fixed;
    bottom: 70px;
    right: 20px;
    background-color: #25d366;
    color: #fff;
    /* padding: 5px; */
    border-radius: 50%;
    text-decoration: none;
    font-size: 35px;
    text-align: center;
  }

  #scrollBtn {
    display: none;
    position: fixed;
    bottom: 125px;
    right: 25px;
    z-index: 999;
    padding: 9px 15px 9px 15px;
    /* padding: 10px 15px; */
    background-color: #F98122;
    color: white;
    border: none;
    border-radius: 50%;
    cursor: pointer;
  }
}






.need_below_space {
  margin-bottom: 40px !important;
}

.cor_med {
  padding-top: 100px;

}



.para_font {
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  line-height: 25px;
}



.scrollable-div {
  height: 120vh;

  overflow-y: auto;
  padding-right: 15px;

}



.about_heading {
  font-family: "Mukta Vaani", sans-serif;

  font-weight: 800;
  font-size: 32px;
  color: #0364B2;
  ;
}



@media (min-width:992px) {

  .content_padding {
    padding-left: 100px !important;
    padding-right: 100px;
  }

  .img_padding {
    padding-left: 100px !important;
  }



  .dr_welcome_text {
    font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
    font-size: 38px !important;
    font-weight: 700;

    text-align: left;
    color: #0364B2;
    margin-top: -6px;
  }



  .border_line_solid {

    width: 94px;
    height: 7px;
    top: 2394px;
    left: 196px;
    gap: 0px;
    background: #9943B1;


  }

  .last_padding_text {
    /* padding-right: 200px; */
  }

}

.border_line_solid {

  width: 94px;
  height: 7px;
  top: 2394px;
  left: 196px;
  gap: 0px;


  background: #9943B1;


}

@media (max-width:992px) {

  .dr_welcome_text {
    font-weight: 700;

    letter-spacing: 0.20000000298023224px;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
    font-size: 25px;
    text-align: left;
    color: #0364B2;
  }

}

@media (min-width:992px) {
  .client_heading {
    font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
    font-size: 38px !important;
    font-weight: 700;
    text-align: left;
    color: #0364B2;
    margin-top: -6px;
  }

  .inter_font_black_client {
    font-family: "Inter", sans-serif;
    font-weight: medium;
    font-size: 15px;
    color: #5A5A5A;
  }
}

@media (min-width:768px) and (max-width:992px) {
  .client_heading {
    font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
    font-size: 25px !important;
    font-weight: 700;

    text-align: left;
    color: #0364B2;
    margin-top: -6px;
  }

  .inter_font_black_client {
    font-family: "Inter", sans-serif;
    font-weight: medium;
    font-size: 15px;
    color: #5A5A5A;
  }
}

@media (max-width:768px) {

  .client_heading {
    margin-bottom: 20px;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
    color: #0364B2;

    /* Adds space when items stack on mobile */
  }

  .inter_font_black_client {
    font-family: "Inter", sans-serif;
    font-weight: medium;
    font-size: 15px;
    color: #5A5A5A;
    text-align: center;
  }
}

.inter_font_black {
  font-family: "Inter", sans-serif;
  font-weight: medium;
  font-size: 15px;
  color: #5A5A5A;

}




.inter_font_black_bold {
  font-family: "Inter", sans-serif;
  font-weight: bold;
  font-size: 15px;
  color: #5A5A5A;

}

.contact_line_hight {
  margin-top: -15px !important;
}

.get_in_touch {

  font-family: "Inter", sans-serif;
  font-size: 14px;
  font-weight: medium;
  /* line-height: 22.02px; */
  padding: 8px 10px 8px 10px;

  border-radius: 20px;
  color: #ffffff;
  background-color: #F98122;
}


@media (min-width:768px) {
  .White_bg_btn {

    font-family: "Inter", sans-serif;
    font-size: 14px;
    font-weight: medium;
    /* line-height: 22.02px; */
    padding: 8px 30px 8px 30px;
    border: none;
    border-radius: 20px;
    color: #3D7FC4;
    background-color: #ffffff;
    margin-bottom: 10px;
  }

}

@media (max-width:768px) {
  .White_bg_btn {

    font-family: "Inter", sans-serif;
    font-size: 14px;
    font-weight: medium;
    /* line-height: 22.02px; */
    padding: 8px 30px 8px 30px;
    border: none;
    border-radius: 20px;
    color: #ffffff;
    background-color: #F98122;
    margin-bottom: 10px;
  }

}

@media (min-width:1200px) {

  .inter_font_white {
    font-family: "Inter", sans-serif;
    font-weight: medium;
    font-size: 15px;
    padding: 0px 150px 0px 150px;
    color: #ffffff;

  }

  .team_heading {
    padding-left: 200px;
    padding-right: 200px;
    font-weight: bold;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
  }
}

@media (min-width:992px) and (max-width:1200px) {

  .team_heading {
    padding-left: 100px;
    padding-right: 100px;
    font-weight: bold;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
  }
}

.gallery_btn {
  background-image: linear-gradient(to right, #3B7AC0 0%, #0B5CB1 100%);
  margin-top: 15px;
  border-radius: 5px;
  border: none;
  color: #ffffff;
  font-family: 'Inter', sans-serif;
  font-weight: bold;
  padding: 8px 15px 8px 15px;

}

.gallery_btn:hover {
  background-image: #F98122;
  margin-top: 15px;
  border-radius: 5px;
  border: none;
  color: #ffffff;
  font-family: 'Inter', sans-serif;
  font-weight: bold;
  padding: 8px 15px 8px 15px;

}

/* 1. Styling the Background Container */
.team_bg_img {

  margin-top: 120px;
  /* Set the height so the background image is visible */
  height: 600px;

  /* Set the background image (Adjust the path as needed) */
  background-image: url('../img/marine/team_bg.png');

  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  border-radius: 20px;
  /* Use Flexbox properties to prepare for centering the content */
  display: flex;
  justify-content: center;
  /* Centers content horizontally */
  align-items: center;
  /* Centers content vertically */

  /* Optional: Ensure the text sits on top */
  position: relative;
  z-index: 1;
}

/* Optional: Add an overlay for better text readability */
.team_bg_img::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;

  /* Dark overlay (40% opacity) */
  z-index: -1;
  /* Place the overlay behind the text */
}

/* 2. Styling the Centered Text */
.centered-text {
  color: white;
  /* Choose a contrasting color */
  text-align: center;
  max-width: 80%;
  /* Ensure text doesn't span the full width of the container */
}

@media (min-width:770px) {

  .centered-text h2 {
    font-size: 2.5rem;
    margin-bottom: 10px;
    text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.8);
  }
}

@media (max-width:770px) {

  .centered-text h2 {
    font-size: 24px;
    margin-bottom: 10px;
    text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.8);
  }
}

.navbar_bg {
  padding-top: 20px;
  padding-bottom: 20px;
  background: #3C83BD;
}

.last_text {
  font-family: "Montserrat";
  font-size: 14px;
  font-weight: 600;
  line-height: 24px;
  letter-spacing: 0.20000000298023224px;
  text-align: left;
  color: #ffffff !important;

}

.colr_purple {
  color: #A256B0;
}


@media (min-width:768px) {
  .onl_top {
    padding-top: 80px;
  }
}

@media (max-width:768px) {
  .onl_top {
    padding-bottom: 40px;
  }
}



.blogs_home {
  font-family: "Mukta Vaani";
  font-size: 39px;
  font-weight: 800;
  line-height: 48.36px;
  letter-spacing: -0.02em;
  text-align: left;
  color: #353535;

}

.view_more_btn {

  font-family: "Mulish", sans-serif;
  font-size: 18px;
  font-weight: 700;
  line-height: 22.59px;
  letter-spacing: 0.03em;
  text-align: left;

  color: #0E84D6;

}


.tetniomial_section_bg {
  background-color: #E7F3FE80;
}


.name_testmonial {
  font-family: "Montserrat";
  font-size: 14.47px;
  font-weight: 700;
  line-height: 21.7px;
  letter-spacing: 0.09041916579008102px;
  text-align: center;
  color: #252B42;

}

/* Example of increasing specificity */
.testimonials .swiper-button-next,
.testimonials .swiper-button-prev {
  color: #E7F3FE80;
  ;
  background: linear-gradient(180deg, #0F88DC 0%, #0E84D6 100%);
  padding: 3px;
  height: 30px;
  width: 30px;
  font-size: 6px;
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
}

.testimonials .swiper-button-next:hover,
.testimonials .swiper-button-prev:hover {
  background: linear-gradient(180deg, #0E84D6 0%, #0F88DC 100%);
}

.service_text {


  text-align: center;


  font-family: "Inter", sans-serif;
  font-weight: medium;
  font-size: 15px;
  color: #5A5A5A;

}

.service_text_blog {

  font-family: "Mulish";
  font-size: 16px;
  font-weight: 600;
  line-height: 20.08px;
  letter-spacing: -0.02em;
  text-align: center;
  color: #9A9A9A;


}

@media (min-width:1200px) {

  .service_text_blog,
  .service_text {
    padding-left: 350px;
    padding-right: 350px;
  }
}

@media (min-width:992px) and (max-width:1200px) {

  .service_text_blog,
  .service_text {
    padding-left: 250px;
    padding-right: 250px;
  }
}

.sevice_bg_color {

  background: #EEF7F9;

}

.contaner_inner {
  margin-top: -150px;
}

@media (min-width:1200px) {

  .only_padding_on_left {
    padding-left: 150px !important;

  }

  .only_padding_on_right {
    padding-left: 150px !important;
    padding-right: 150px !important;
  }

}

@media (min-width:992px) and (max-width:1200px) {

  .only_padding_on_left {
    padding-left: 100px !important;

  }

  .only_padding_on_right {
    padding-left: 100px !important;
    padding-right: 100px !important;
  }

}

@media (min-width:768px) and (max-width:992px) {

  .only_padding_on_left {
    padding-left: 50px !important;

  }

  .only_padding_on_right {
    padding-left: 80px !important;
    padding-right: 80px !important;
  }

}


.flex-column {
  background-color: white;
}

.service_img_radius {
  border-radius: 12px;
}


.img_icon_logo {
  font-family: "Lora", serif !important;
  color: #9943B1;
  font-weight: 1000;
  text-align: center;
  font-size: 20px;
}

.degrees_logo_txt {
  font-size: 12px;
  text-align: center;
  margin-top: -20px;
}

.side_logo_text {
  margin-left: -30px;
}


@media (max-width:768px) {
  .side_logo_text {
    display: none;
  }
}

@media (min-width:768px) and (max-width:992px) {
  .img_icon_logo {
    font-family: "Lora", serif !important;
    color: #9943B1;
    font-weight: 1000;
    text-align: center;
    font-size: 18px;
  }

  .degrees_logo_txt {
    font-size: 10px;
    text-align: center;
    margin-top: -20px;
  }
}


@media (min-width:992px) and (max-width:1200px) {
  .img_icon_logo {
    font-family: "Lora", serif !important;
    color: #9943B1;
    font-weight: 1000;
    font-size: 16px;
    text-align: center;
  }

  .degrees_logo_txt {
    font-size: 10px;
    text-align: center;
    margin-top: -20px;
  }
}


.txt_ask {
  margin-left: -60px;
}

/*** change blocks**/



.blog_main_btn {
  /* Initial styles for the button */
  border-width: 0px;
  color: black;
  border-radius: 22px;
  padding: 9px 22px;
  font-weight: 800;
  background-color: transparent;
  /* initial background color */

  /* Add transition to smooth the hover effects */
  transition: background-color 0.4s ease, color 0.4s ease, border-radius 0.4s ease;
  margin-bottom: 14px;
}

.blog_main_btn:hover {
  border-width: 0px;
  color: white;
  border-radius: 22px;
  padding: 9px 22px;
  font-weight: 800;
  margin-bottom: 14px;

  background-color: rgb(0, 0, 31);
  /* Dark background on hover */
}

.box-title {
  color: #28386a !important;
}

.box-title:hover {
  color: #072bbc !important;
}

.blog-card-text {
  color: #ffffff !important;
  font-weight: 700;
}

.blog-card-text:hover {
  color: #070707 !important;

  font-weight: 700;

}

.post-desc {
  color: #848e9f;
}

.card_bg_div_box {
  /* Initial styles for the card */
  box-shadow: none;
  /* No shadow by default */
  transition: box-shadow 0.3s ease;
  /* Smooth transition for the box-shadow */
  padding: 20px;
}

.card_bg_div_box:hover {
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
  /* Shadow when hovering */
  padding: 20px;
}

.blog_box_image {
  border-radius: 12px;
}

.background_sidebar {
  background-color: #94beeb;
}

.redirect_section {
  text-align: center;
  margin-top: 30px;
  margin-bottom: 10px;

}

.new_space {
  margin-top: 190px !important;
}

.redirect_blog_srivice {
  background-color: rgb(105, 199, 236);
  color: White;
  font-weight: 900;
  border: none;
  margin: 5px;
  margin-bottom: 10px;
  border-radius: 3px;
  padding: 3px 15px;

}

@media (min-width:992px) and (max-width:1200px) {

  .video_tag_messures {
    width: 475px !important;
    height: 228px !important;
  }
}


@media (min-width:1200px) and (max-width:1400px) {

  .video_tag_messures {
    width: 560px !important;
    height: 273px !important;
  }
}


@media (min-width:1400px) {

  .video_tag_messures {
    width: 646px !important;
    height: 317px !important;
  }
}


.logo img {
  width: 50px;
  height: 50px;
}


.shadow_box {
  box-shadow: 0px 2px 15px rgba(0, 0, 0, 0.1);

}

.pan {
  margin-top: 150px;
}


/* faq stylings  */
.accordion {
  /* border: 1px solid #ddd; */
  border-radius: 5px;
  max-width: 500px;
  margin: 20px auto;
  font-family: Arial, sans-serif;
}

.accordion-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 15px 20px;
  cursor: pointer;
  background-color: #f5f5f5;
  font-size: 18px;

}

.faq_section {
  margin-bottom: 20px !important;
}




.accordion-icon {
  font-size: 22px;
  transition: transform 0.3s ease;
}

.accordion-icon.rotate {
  transform: rotate(45deg);
}

.accordion-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease;
  padding: 0 20px;
  background-color: #E7F3FE80;
}

.accordion-content.open {
  max-height: 500px;
  /* adjust as needed */
  padding: 15px 20px;
}

.faq_heading_section {
  font-size: 20px !important;
  color: #A256B0;
  font-weight: 600;
}









/* Slider Container Styling */
.clients-slider {}


.margin_alignes_gallery {
  margin-top: -60px;
  margin-bottom: -170px;
  background-color: #f9f9f9;

}

.margin_alignes_services {
  margin-top: -60px;
  margin-bottom: -70px;


}

.mySwiper {
  width: 100%;
  padding-bottom: 40px;
  /* Space for pagination dots */
}

.swiper-slide {
  display: flex !important;
  justify-content: center;
  align-items: center;

}

.swiper-slide img {
  max-width: 100%;
  height: auto;
  /* Adjust grayscale/opacity if you want a professional logo look */

}

.swiper-slide img:hover {
  filter: grayscale(0%);
  opacity: 1;
}

/* Pagination Dot Color */
.swiper-pagination-bullet-active {
  background-color: #0364B2 !important;
}


.swiper-pagination {
  margin-top: 50px !important;
}



/* 1. Add space at the bottom of the slider container */
.mySwiper {
  padding-bottom: 40px !important;
  /* This creates space for the dots */
  position: relative;
}

/* 2. Move dots from 'absolute' to 'relative' so they sit below the image */
.mySwiper .swiper-pagination {
  position: relative !important;
  bottom: 0 !important;
  margin-top: 15px;
  /* Space between the image and the dots */
  display: flex;
  justify-content: center;
  align-items: center;
}

/* 3. Style the dots to match your Marine Blue theme */
.swiper-pagination-bullet {
  width: 12px;
  height: 12px;
  background: #555 !important;
  /* Gray for inactive */
  opacity: 0.5;
}

.swiper-pagination-bullet-active {
  background: #0364B2 !important;
  /* Your Marine Blue for active */
  opacity: 1;
  width: 14px;
  /* Slightly larger active dot */
  height: 14px;
}



















/* marine About page */
/* --- About Us Section --- */
.about-us-section {
  padding: 80px 0 60px 0;
  background: #fff;
}

.about-title {
  font-size: 32px;
  font-weight: 700;
  margin-bottom: 5px;
  color: #000;
}

.about-subtitle {
  font-size: 38px;
  font-weight: 800;
  margin-bottom: 25px;
  color: #000;
}

.about-description {
  font-size: 18px;
  line-height: 1.6;
  color: #444;
  max-width: 850px;
  /* Limits width for readability like in Figma */
}

/* Button with exact Figma Gradient */
.about-btn {
  background: #0079FF;
  color: #fff;
  padding: 10px 28px;
  border-radius: 6px;
  font-weight: 600;
  border: none;
  display: inline-block;
  transition: 0.3s ease-in-out;
}

.about-btn:hover {
  filter: brightness(1.1);
  color: #fff;
  background-color: #F98122;
}

/* --- Our Mission Overlap Styles --- */
.mission-section {
  padding: 40px 0 100px 0;
  margin-bottom: -20px;
}

.mission-banner {

  /* Matching the curved edges in Figma */
  width: 100%;
}

.mission-card-wrapper {
  display: flex;
  justify-content: center;
  margin-top: -45px;
  /* Pulls the card up into the image */
  position: relative;
  z-index: 10;
  padding: 0 15px;
}

.text_card_container {
  background: #FAFAFA;
  padding: 50px 70px;
  box-shadow: 0px 15px 40px rgba(0, 0, 0, 0.1);
  max-width: 850px;
  text-align: left;
  border-radius: 8px;
}

.text_card_heading {
  color: #0364B2;
  /* Marine Blue */
  font-weight: 800;
  font-size: 36px;
  margin-bottom: 20px;
}

.text_card_para {
  font-size: 19px;
  line-height: 1.5;
  color: #333;
  margin-bottom: 0;
}

/* --- Mobile Response (Upto 768px) --- */
@media (max-width: 768px) {
  .about-us-section {
    text-align: left;
    padding: 60px 15px 30px 15px;
  }

  .about-subtitle {
    font-size: 30px;
  }

  .mission-card-wrapper {
    margin-top: -40px;
    /* Reduced overlap for mobile screens */
  }

  .text_card_container {
    padding: 35px 20px;
  }

  .text_card_heading {
    font-size: 28px;
  }

  .text_card_para {
    font-size: 16px;
  }
}



















/* --- Services Header --- */
.services-main-title {
  font-weight: 800;
  font-size: 38px;
  color: #111;
  line-height: 1.2;
}

.services-main-desc {
  max-width: 600px;
  color: #555;
  font-size: 16px;
}

/* Figma Button Gradient */
.services-btn-gradient {
  background: linear-gradient(90deg, #3B7AC0 0%, #0B5CB1 100%);
  color: white;
  padding: 12px 30px;
  border-radius: 6px;
  font-weight: 600;
  border: none;
}

/* --- Services List & Overlap --- */
.service-img {
  width: 100%;
  border-radius: 4px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
}

.service-text-card {
  background: #F0F7FF;
  /* Light blue background from Figma */
  padding: 40px;
  position: relative;
  z-index: 10;
  border-radius: 4px;
}

.service-title {
  color: #0364B2;
  font-weight: 700;
  font-size: 26px;
  margin-bottom: 15px;
}

.service-para {
  font-size: 15px;
  line-height: 1.6;
  color: #444;
}

.service-accent-line {
  width: 100%;
  height: 4px;
  background: #3B7AC0;
  margin-top: 20px;
}



/* DESKTOP OVERLAP LOGIC */
@media (min-width: 992px) {

  .service-row {
    padding-left: 100px;
    padding-right: 100px;
  }

  .card-right {
    margin-left: -80px;
    /* Pulls card over the image */
  }

  .card-left {
    margin-right: -80px;
    /* Pulls card over the image in reverse row */
  }

  .service-row {
    margin-bottom: 100px !important;
  }
}

/* MOBILE VIEW */
@media (max-width: 991px) {
  .service-text-card {
    margin: -30px 15px 0 15px;
    /* Sits below the image with slight upward overlap */
    padding: 30px 20px;
    text-align: left;
  }

  .services-main-title {
    font-size: 30px;
  }
}

.service-row {
  padding-left: 20px;
  padding-right: 20px;
}


/* --- Services Header Styles --- */
.services-main-title {
  font-weight: 800;
  font-size: 42px;
  color: #111;
  line-height: 1.1;
  margin-top: 15px;
}

.services-main-desc {
  max-width: 700px;
  color: #666;
  font-size: 16px;
  margin-bottom: 25px;
}

/* Figma Button Gradient */
.services-btn-gradient {
  background: linear-gradient(90deg, #3B7AC0 0%, #0B5CB1 100%);
  color: white !important;
  padding: 12px 35px;
  border-radius: 6px;
  font-weight: 600;
  border: none;
  display: inline-block;
  transition: 0.3s;
}

/* --- Service Rows & Overlap --- */
.service-img {
  width: 100%;
  border-radius: 8px;
  /* Slightly curved edges like Figma */
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
}

.service-text-card {
  background: #F0F7FF;
  /* Exact light blue from Figma */
  padding: 50px;
  position: relative;
  z-index: 10;
  border-radius: 4px;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.05);
}

.service-title {
  color: #0364B2;
  font-weight: 800;
  font-size: 30px;
  margin-bottom: 20px;
}

.service-para {
  font-size: 16px;
  line-height: 1.6;
  color: #444;
}

.service-accent-line {
  width: 100%;
  height: 4px;
  background: #3B7AC0;
  margin-top: 25px;
}

/* DESKTOP OVERLAP (992px and up) */
@media (min-width: 992px) {
  .service-row {
    margin-bottom: 120px !important;
  }

  /* Pulls the card to the left to overlap the image */
  .card-right {
    margin-left: -100px;
  }

  /* Pulls the card to the right to overlap the image in reversed rows */
  .card-left {
    margin-right: -100px;
  }
}

/* MOBILE VIEW (Stacked) */
@media (max-width: 991px) {
  .service-text-card {
    margin: -40px 15px 0 15px;
    /* Creates the upward overlap on mobile */
    padding: 30px 20px;
  }

  .services-main-title {
    font-size: 32px;
  }

  .service-row {
    margin-bottom: 60px !important;
  }
}









/* --- Facilities Section Styles --- */
.facilities-section {
  background-color: #fff;
}

/* Styles for the text block container */
.facility-text-block {
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: 100%;
  /* Ensures the block matches the image height on desktop */
}


/* Heading styles */
.facility-title {
  color: #0364B2;
  /* Marine blue color */
  font-weight: 700;
  font-size: 1.75rem;
  margin-bottom: 1rem;
}

/* Paragraph text styles */
.facility-text {
  color: #555;
  font-size: 1rem;
  line-height: 1.6;
  margin-bottom: 0;
}

/* --- Desktop-Specific Styles (Large Devices) --- */
/* Applies the unique rounded corners only on screens wider than 991px */
@media (min-width: 992px) {

  .rounded-right-c {
    background-image: linear-gradient(to left, #eaf4ff, #eaf4ff, #eaf5ff, #ebf5ff, #ebf5ff, #edf6ff, #f0f6ff, #f2f7ff, #f6f9ff, #fafbff, #fdfdff, #ffffff);
  }

  .rounded-left-c {
    background-image: linear-gradient(to right, #eaf4ff, #eaf4ff, #eaf5ff, #ebf5ff, #ebf5ff, #edf6ff, #f0f6ff, #f2f7ff, #f6f9ff, #fafbff, #fdfdff, #ffffff);

  }

  /* Rounds the right side of the block */
  .rounded-right-c {
    border-top-right-radius: 120px;
    border-bottom-right-radius: 120px;
  }

  /* Rounds the left side of the block */
  .rounded-left-c {
    border-top-left-radius: 120px;
    border-bottom-left-radius: 120px;
  }

  /* Adds a slight overlap effect for a more dynamic look */
  .rounded-right-c {
    margin-left: -30px;
  }

  .rounded-left-c {
    margin-right: -30px;
  }

  .facility-text-block {
    z-index: 1;
    position: relative;
  }
}

/* --- Mobile-Specific Styles (Small Devices) --- */
/* Adjusts the layout for screens smaller than 992px */
@media (max-width: 991px) {



  .rounded-right-c {
    background-image: linear-gradient(to top, #eaf4ff, #eaf4ff, #eaf5ff, #ebf5ff, #ebf5ff, #edf6ff, #f0f6ff, #f2f7ff, #f6f9ff, #fafbff, #fdfdff, #ffffff);
  }

  .rounded-left-c {
    background-image: linear-gradient(to top, #eaf4ff, #eaf4ff, #eaf5ff, #ebf5ff, #ebf5ff, #edf6ff, #f0f6ff, #f2f7ff, #f6f9ff, #fafbff, #fdfdff, #ffffff);

  }

  .facility-text-block {
    border-radius: 70px;
    /* Replaces specific corners with uniform rounded corners */
    text-align: center;
    /* Centers text for mobile */
    padding: 30px !important;
    /* Adjusts padding for smaller screens */
  }

  /* Resets margin used for desktop overlap */
  .rounded-right-c,
  .rounded-left-c {
    margin: 0;
  }
}


/* Container for the text block */
.facility-text-block {

  padding: 40px 50px;
  max-width: 450px;
  /* Keeps the capsule shape tight */
  transition: all 0.3s ease;
}

.facility-img {
  border-radius: 15px;
  width: 100%;
  object-fit: cover;
}

.facility-title {
  color: #0060B1;
  /* Specific blue from design */
  font-weight: 700;
  font-size: 24px;
  margin-bottom: 12px;
}

.facility-text {
  color: #555;
  font-size: 15px;
  line-height: 1.6;
  margin-bottom: 0;
}






.footer-link {
  color: inherit;
  text-decoration: none;
  font-size: 0.95em;
  transition: 0.3s;
}

.footer-link:hover {
  color: #007bff;
  /* Or your brand primary color */
  text-decoration: underline;
}

/* Specific styling to keep the agency logo and text subtle */
.credits small {
  color: #ffffff !important;
  font-weight: bold;
}

.agency-logo {

  z-index: 999999;
}








.hero-carousel {
  position: relative;
  height: 100vh;
  /* Ensures it takes the full height of the screen */
  width: 100%;
  overflow: hidden;
  background-color: #000;
  /* Prevents white flashes between slides */
}

.carousel-container {
  width: 100%;
  height: 100%;
}

.slide {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: opacity 1.2s ease-in-out;
  /* Smoother transition */
  display: flex;
  align-items: center;
  justify-content: center;
}

.slide.active {
  opacity: 1;
  z-index: 1;
}

/* --- THE VIDEO FIX --- */
.bg-video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  /* 'cover' ensures no gaps, 'contain' ensures no cropping. 
       For a hero section, 'cover' is usually best but we need to center it. */
  object-fit: cover;
  object-position: center;
  /* Keeps the center of the video visible */
  z-index: -1;
}

/* Blue Tint Overlay (Matches your image) */
.slide::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  /* background: linear-gradient(rgba(14, 82, 153, 0.7), rgba(14, 82, 153, 0.7)); */
  z-index: 0;
}

.overlay-content {
  position: relative;
  z-index: 2;
  color: #ffffff;
  text-align: center;
  padding: 0 15px;
  max-width: 900px;
}