/*------------------------------------------------------------------
Project:	Nantes - multi purpose one-page template
Version:	1.0
Last change:	18/02/2016 [...]
Designed by:	MOOZ Themes / www.MOOZthemes.com
Primary use:	One page
-------------------------------------------------------------------*/

/* main font for menu. */
@import url(http://fonts.googleapis.com/css?family=Raleway:100,300,400,500,700,900);
/* font for headings, text, tags */
@import url(http://fonts.googleapis.com/css?family=Open+Sans:300,400,500,600,700,800);

/*--------------------
Color customizations
change these colors to change overlays
--------------------*/

.mz-module:hover .ot-circle.color1 {
	color: #69c624;
}
.mz-module:hover .ot-circle.color2 {
	color: #69c624;
}
.mz-module:hover .ot-circle.color3 {
	color: #69c624;
}
.mz-module:hover .ot-circle.color4 {
	color: #69c624;
}

/*--------------------
1. General
--------------------*/

body {
	margin: 0px;
	font-family: 'Nunito Sans', Helvetica, Arial, Lucida, sans-serif;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	font-weight: 300;
	letter-spacing: 0.4px;
	font-family: 'Nunito Sans', Helvetica, Arial, Lucida, sans-serif;
	color: #2f4d38;
}

p {
	font-family: 'Nunito Sans', Helvetica, Arial, Lucida, sans-serif;
	font-size: 15px;
	font-weight: 300;
	line-height: 23px;
	letter-spacing: 0.2px;
	color: #000;
}

.dark-bg p {
color: #B1B1B1;	
}

a:hover, a:focus, a:active, a.active {
	color: #69c624;
}
a, a:hover, a:focus, a:active, a.active {
	outline: 0;
}

.container-fluid {
    padding-right: 0;
    padding-left: 0;
}

::selection {
	text-shadow: none;
	background: #d7d8d9;
}

@media (min-width: 768px) {
	section {
		padding: 150px 0;
	}
}

section {
	padding: 70px 0;
}

ul {
	padding-left: 0;
	padding-top: 10px;	
}

ul li {
    list-style: none;
    padding-bottom: 0px;
    font-family: 'Nunito Sans', Helvetica, Arial, Lucida, sans-serif;
    font-size: 16px;
    font-weight: 500;
    line-height: 23px;
    letter-spacing: 0.2px;
    color: #000000;
}

section ul li:before {
	font-family: 'Nunito Sans', Helvetica, Arial, Lucida, sans-serif;
	font-weight: normal;
	font-style: normal;
	display: inline-block;
	text-decoration: inherit;
	padding-right: 7px;
	color: #69c624;
}

/*--------------------
1.1 Reset bootstrap
--------------------*/

.row-0-gutter {
    margin-left: -13px;
    margin-right: -13px;
}

.col-0-gutter {
	padding: 5px;
}

/*--------------------
2. Navigation
--------------------*/
.navbar-brand img {
 height: 100%;
 width: 100%;
 display: block;  /* Removes any inline or extra space around the image */
 max-width: 100%; /* Ensure the image doesn't exceed the container width */

}
.navbar-default {
	background-color: #fff;
	border-color: transparent
}
.navbar-default .navbar-brand {
	color: #fff;
	font-family: 'Nunito Sans', Helvetica, Arial, Lucida, sans-serif;
	padding: 0px;
	margin-left: 10px;
}
.navbar-default .navbar-brand:hover,.navbar-default .navbar-brand:focus,.navbar-default .navbar-brand:active,.navbar-default .navbar-brand.active {
	color: #69c624
}
.navbar-default .navbar-collapse {
	border-color: rgba(255,255,255,.02)
}
.navbar-default .navbar-toggle {
	background-color: #69c624;
	border-color: #69c624
}
.navbar-default .navbar-toggle .icon-bar {
	background-color: #fff
}
.navbar-default .navbar-toggle:hover,.navbar-default .navbar-toggle:focus {
	background-color: #69c624
}
.navbar-default .nav li a {
	font-family: 'Nunito Sans', Helvetica, Arial, Lucida, sans-serif;
	text-transform: uppercase;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 1px;
	color: #333;
}
.navbar-default .nav li a:hover,.navbar-default .nav li a:focus {
	color: #69c624;
	outline: 0
}

.navbar-default .navbar-nav>.active>a {
	border-radius: 0;
	color: #ffffff;
	background-color: #69c624
}
.navbar-default .navbar-nav>.active>a:hover,.navbar-default .navbar-nav>.active>a:focus {
	color: #fff;
	background-color: #69c624
}


@media (min-width: 768px) {
    .navbar-default {
        background-color: rgba(255, 255, 255, 0.65);
        padding: 5px 0;
        border: 0;
    }
	}
	

    .navbar-default .navbar-brand {
        font-size: 2em;
        margin-top: 10px;
        margin-left: 10px;
    }
    
    .navbar-default.navbar-shrink {
        background-color: #FFFFFF;
        border-bottom: 1px solid #828282;
        padding: 5px 0;
    }
    
    .navbar-default.navbar-shrink .navbar-brand {
        font-size: 1.5em;
        margin-top: 10px;
    }


    @media (max-width: 480px) {
      .navbar-brand img {
        max-width: 80px; /* Scale down the logo to fit smaller screens */
        margin: 0 auto; /* Center the logo horizontally */
      }
    }


/* -------------- Header -------------------------- */

.header {
  margin-top: 80px;
}

/* Image container styles */
.image-container {
  position: relative;
  width: 100%;
  height: 500px; /* Adjusted height for desktop */
}

/* Background image styles */
.background-image {
  width: 100%;
  height: 100%;
  max-height: 500px;
  object-fit: cover;
  opacity: 0.8;
}

/* Centered sliding text container */
.sliding-text-container {
  position: absolute;
  overflow: hidden; /* Hide the text as it slides out of view */
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  color: #000; /* Text color */
  z-index: 10;
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  padding: 0 15px 20px 0px; /* Added padding for small screens */
  
}

/* Sliding text style */
.intro-text {
  position: absolute;
  opacity: 0;
  animation: slideText 9s infinite;
  color: #000;
  white-space: nowrap;
  text-align: center;
}

/* Animation delays for each text item */
.intro-text:nth-child(1) { animation-delay: 0s; }
.intro-text:nth-child(2) { animation-delay: 3s; }
.intro-text:nth-child(3) { animation-delay: 6s; }

@keyframes slideText {
  0%, 15% { opacity: 0; transform: translateX(100%); }  /* Start off-screen to the right */
  20%, 45% { opacity: 1; transform: translateX(0); }    /* Fully visible in the center */
  50%, 100% { opacity: 0; transform: translateX(-100%); } /* Slide out to the left */
}

/* Intro lead-in text */
.intro-lead-in {
  font-size: 28px;
  margin-bottom: 10px;
  font-weight: 500;
}

.intro-heading {
  font-size: 38px;
  font-weight: 900;
  letter-spacing: -0.4px;
}

/* Button styling */
.intro-button-container {
  margin-top: 15%;
}

.intro-button {
  padding: 13px 30px;
  font-size: 18px;
  font-weight: bold;
  background-color: #69c624;
  border: 2px solid #69c624;
  color: white;
  text-decoration: none;
  border-radius: 5px;
  transition: background-color 0.3s ease;
}

.intro-button:hover {
  background-color: transparent;
  border-color: #69c624;
  color: #69c624;
  text-decoration: none;
  border: 2px solid #69c624;
}

.intro-button-new {
  padding: 13px 30px;
  font-size: 18px;
  font-weight: bold;
  background-color: transparent;
  border: 2px solid #69c624;
  color: #69c624;
  text-decoration: none;
  border-radius: 5px;
  transition: background-color 0.3s ease, border-color 0.3s ease, color 0.3s ease;
}

.intro-button-new:hover {
  background-color: #69c624;
  border-color: #69c624;
  color: #ffffff;
  text-decoration: none;
}

/* Responsive styling */
@media (max-width: 1200px) {
  .intro-heading {
    font-size: 34px;
  }
  .intro-lead-in {
    font-size: 24px;
  }
  .intro-button, .intro-button-new {
    font-size: 16px;
    padding: 10px 25px;
  }
}

@media (max-width: 992px) {
  .image-container {
    height: 500px; /* Adjusted height for tablets */
  }
  .intro-heading {
    font-size: 30px;
  }
  .intro-lead-in {
    font-size: 20px;
  }
  .intro-button, .intro-button-new {
    font-size: 15px;
    padding: 9px 22px;
  }
  .intro-text {
    padding-bottom: 10px;
  }
}

@media (max-width: 767px) {
  .image-container {
    height: 400px; /* Adjusted height for smaller screens */
  }
  .intro-lead-in {
    font-size: 16px;
    font-weight: 500;
  }
  .intro-heading {
    font-size: 24px;
    font-weight: 700;
  }
  .intro-button, .intro-button-new {
    font-size: 14px;
    padding: 8px 20px;
  }
  .intro-button-container {
    margin-top: 25%;
  }
  .intro-text {
    padding-bottom: 10px;
  }
}

@media (max-width: 480px) {
  .image-container {
    height: 300px; /* Adjusted height for extra-small screens */
  }
  .intro-heading {
    font-size: 18px;
  }
  .intro-lead-in {
    font-size: 14px;
  }
  .intro-button, .intro-button-new {
    font-size: 13px;
    padding: 7px 18px;
  }
  .intro-text {
    padding-bottom: 10px;
  }
}

/* Static heading container for smaller screens */
.static-text-container {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
}

/* Static heading style */
.static-heading {
  font-size: 38px;
  font-weight: 900;
  letter-spacing: -0.4px;
  color: #000;
}



/*--------------------
4. Sections
--------------------*/

.section-title h2 {
	font-size: 30px;
	color: #2f4d38;
	font-weight: 700;
	letter-spacing: -0.4px;
	position: relative;
	margin: 0 0 50px 0;
	padding-bottom: 15px;
}

.section-title h2:after {
	left: 50%;
	z-index: 1;
	width: 60px;
	height: 3px;
	content: " ";
	bottom: -5px;
	margin-left: -30px;
	text-align: center;
	position: absolute;
	background: #2f4d38;
}

.dark-bg .section-title h2 {
	color: #fff;
}


.section-title p {
	font-size: 18px;
	font-weight: 300;
	line-height: 31px;
	margin: 10px 100px 30px 100px;
}

/* Media query for tablets and smaller devices */
@media (max-width: 768px) {
	.section-title h2 {
		font-size: 35px;
		margin: 0 0 40px 0;
		padding-bottom: 10px;
	}
	
	.section-title p {
		font-size: 16px;
		margin: 20px 50px 50px 50px;
	}
}

/* Media query for mobile devices */
@media (max-width: 480px) {
	.section-title h2 {
		font-size: 28px;
		margin: 0 0 30px 0;
		padding-bottom: 8px;
	}
	
	.section-title p {
		font-size: 14px;
		margin: 20px 10px 40px 10px;
		line-height: 28px;
	}
}

/*--------------------
4.1. CTA sectoin
--------------------*/

.section-cta {
	padding: 40px 0;
	color: #fff;
	background-color: #fcbe03;
}

.section-cta h2 {
	color: #fff;
	font-size: 23px;
	font-weight: 300;
	margin: 0 0 20px;
}

.button-cta {
	border: 2px solid #fff;
	padding: 10px 50px;
	font-size: 16px;
	letter-spacing: 1.5px;
	text-transform: uppercase;
	font-weight: 800;
	color: #fff;
	display: inline-block;

	-webkit-transition: all .4s ease; /* Safari and Chrome */
	-moz-transition: all .5s ease; /* Firefox */
	-o-transition: all .5s ease; /* IE 9 */
	-ms-transition: all .5s ease; /* Opera */
	transition: all .5s ease;

}
.button-cta:hover {
	color: #000;
	background-color: #fff;	
	text-decoration: none;
}
/*--------------------
4.1. About
--------------------*/

#about {
    position: relative;
    background-image: url("../images/bg.png"); /* Set your background image path */
    background-color: #69c624;
    background-size: cover; /* Make sure the image covers the entire section */
    background-position: center center; /* Center the background image */
    background-attachment: fixed; /* Make the background image fixed when scrolling */
    padding: 60px 0;
	z-index: 3;
}


#about .container {
    position: relative;
    z-index: 2; /* Ensures content appears above the overlay */
}

.about:before {
    color: var(--bs-light);
}



.light-bg .section-title p {
    color: #000;
    font-weight: 400;
    padding: 10px;
}

.mz-module {
    position: relative;
    margin-bottom: 30px;
}

.mz-module-about {
    border: 1px solid #E6E6EA;
    min-height: 20px;
    padding: 0px;
    background-color: rgba(239, 239, 241, 0.9);
    transition: all 0.3s ease-in-out;
    z-index: 2;
    text-align: center;
	margin: 10px;
}

.mz-module-about:hover {
    box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.1);
}

/* Image styling */
.img-rect {
    height: 250px;
    width: 100%;
    object-fit: cover;
    margin-bottom: 15px;
}

.mz-module-about h3 {
    font-weight: 500;
    font-size: 19px;
    color: #333;
    margin-top: 10px;
}

/* Button styling */
.mz-module-button {
    background-color: #B6B6C3;
    padding: 15px;
    text-transform: uppercase;
    font-weight: 700;
    font-size: 12px;
    display: block;
    position: absolute;
    bottom: 0px;
    left: 0;
    right: 0;
    opacity: 0;
    color: #fff;
    transition: all 0.3s;
}

.mz-module:hover .mz-module-button {
    bottom: -45px;
    opacity: 1;
}

.mz-module-button:hover {
    background-color: #1a1a1a;
    color: #fff;
    text-decoration: none;
}


/* RESPONSIVE STYLES */
@media (max-width: 992px) {
    .mz-module-about {
        min-height: 220px;
    }
}

@media (max-width: 768px) {
    .mz-module-about {
        min-height: 200px;
    }

    .mz-module-about h3 {
        font-size: 17px;
    }
}

@media (max-width: 576px) {
    .mz-module-about {
        min-height: 180px;
        padding: 15px;
    }

    .img-rect {
        height: 200px;
        width: 300px;
    }
}



/*--------------------
4.2. Featured
--------------------*/

.featured-item {
    margin-bottom: 30px;
    height: auto; /* Let the height adjust dynamically */
    display: flex; /* Use flexbox to align items */
    align-items: center; /* Vertically center content */
    flex-wrap: wrap; /* Allow content to wrap on smaller screens */
}

.featured-icon {
    font-size: 22px;
    border-radius: 50%;
    width: 55px;
    height: 55px;
    background-color: #2f4d38;
    line-height: 50px;
    text-align: center;
    margin-right: 15px; /* Space between the icon and text */
}

.featured-text {
    text-align: left;
    flex: 1; /* Make text container flexible */
}

.featured-text h4 {
    color: #47474C;
    font-size: 17px;
    font-weight: 700;
}

.featured-text p {
    color: #747377;
    margin-top: 7px;
    font-size: 15px;
    line-height: 21px;
    font-weight: 500;
}

/* Section background styling */
.section-features {
    background-image: url("../images/green-bg-2.jpg"); /* Replace with the actual image path */
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    padding: 40px; /* Adjust padding for larger screens */
    color: #fff; /* Adjust text color to enhance readability */
    text-align: left; /* Ensure text is aligned to the left */
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center; /* Center content for better mobile view */
}

@media (max-width: 1024px) {
    .section-features {
        padding: 30px; /* Slightly reduced padding for tablet screens */
    }

    .featured-item {
        margin-bottom: 20px; /* Slightly smaller margin for tablet screens */
    }

    .featured-text {
        font-size: 16px; /* Adjust text size for tablets */
        margin-left: 85px; /* Maintain spacing */
        text-align: left; /* Keep text aligned left */
    }

    .featured-icon {
        width: 50px;
        height: 50px;
        font-size: 20px; /* Adjust icon size */
        line-height: 50px; /* Ensure proper vertical alignment */
    }
}

@media (max-width: 768px) {
    .section-features {
        padding: 20px; /* Further reduced padding for smaller devices */
        text-align: center; /* Center-align text for smaller screens */
    }

    .featured-item {
        flex-direction: column; /* Stack items vertically on small screens */
        align-items: center; /* Center-align the items */
    }

    .featured-text {
        font-size: 18px; /* Reduce text size for smaller screens */
        margin-left: 0; /* Remove left margin */
        text-align: center; /* Center text for better appearance on smaller devices */
        padding-top: 10px; /* Add top padding for spacing */
    }

    .featured-icon {
        margin-bottom: 20px; /* Increase spacing below the icon */
        width: 60px; /* Resize icon images for better fit */
        height: 60px;
        font-size: 24px; /* Increase icon size for clarity */
    }
}

@media (max-width: 480px) {
    .section-features {
        padding: 15px; /* Even smaller padding for mobile devices */
    }

    .featured-item {
        margin-bottom: 15px; /* Add spacing between items */
    }

    .featured-text {
        font-size: 16px; /* Further reduce text size */
        padding: 0 10px; /* Add some horizontal padding for readability */
        margin-top: 10px; /* Add top margin to create space above text */
    }

    .featured-icon {
        margin-bottom: 15px; /* Add spacing below the icon */
        margin-right: 0; /* Ensure no right margin for better alignment */
        width: 50px; /* Slightly smaller icons for mobile screens */
        height: 50px;
        font-size: 22px; /* Adjust icon font size */
    }
}


/*--------------------
4.2. Skills
--------------------*/

.section-text h3 {
	margin: 0 0 30px;
	font-weight: 800;
	color: #5D5D5D;
}

.section-text h4 {
    margin: 0 0 20px;
    font-weight: 700;
    font-size: 17px;
}

.dark-bg .section-text h3 {
	color: #dfdfdf;
}

.dark-bg .section-text h4 {
	color: #dfdfdf;
}

/*--------------------
4.3. Portfolio
--------------------*/
figure {
	position: relative;
	overflow: hidden;
	margin: 0 1px 1px 0;
	background: #726FB9;
	text-align: center;
	cursor: pointer;
}

figcaption {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 30%;
}

.ot-portfolio-item figure figcaption > a {
	z-index: 1000;
	text-indent: 200%;
	white-space: nowrap;
	font-size: 0;
	opacity: 0;
}

.ot-portfolio-item figure figcaption, .ot-portfolio-item figure figcaption > a {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

figure.effect-bubba {
	background: #69c624;
	margin-bottom: 1px;
}

figure.effect-bubba img {
	opacity: 0.90;
	-webkit-transition: opacity 0.35s;
	transition: opacity 0.35s;
	width: 100%; /* Make image width 100% of the container */
	height: auto; /* Maintain aspect ratio */
	object-fit: cover; /* Ensure the image covers the area */
}

figure.effect-bubba:hover img {
	opacity: 0.4;
}

figure.effect-bubba figcaption::before,
figure.effect-bubba figcaption::after {
	position: absolute;
	content: '';
	opacity: 0;
	-webkit-transition: opacity 0.35s, -webkit-transform 0.35s;
	transition: opacity 0.35s, transform 0.35s;
}

figure.effect-bubba figcaption::before {
	border-top: 1px solid #fff;
	border-bottom: 1px solid #fff;
	-webkit-transform: scale(0,1);
	transform: scale(0,1);
}

figure.effect-bubba figcaption::after {
	border-right: 1px solid #fff;
	border-left: 1px solid #fff;
	-webkit-transform: scale(1,0);
	transform: scale(1,0);
}

figure.effect-bubba h2 {
	opacity: 0;
	color: #fff;
	font-size: 15px;
	font-weight: 700;
	text-transform: uppercase;
	padding-top: 20%;
	-webkit-transition: -webkit-transform 0.35s;
	transition: transform 0.35s;
	-webkit-transform: translate3d(0,-20px,0);
	transform: translate3d(0,-20px,0);
}

figure.effect-bubba p {
	color: #fff;
	font-size: 13px;
	font-weight: 500;
	padding: 20px 2.5em;
	opacity: 0;
	-webkit-transition: opacity 0.35s, -webkit-transform 0.35s;
	transition: opacity 0.35s, transform 0.35s;
	-webkit-transform: translate3d(0,20px,0);
	transform: translate3d(0,20px,0);
}

figure.effect-bubba:hover figcaption::before,
figure.effect-bubba:hover figcaption::after {
	opacity: 1;
	-webkit-transform: scale(1);
	transform: scale(1);
}

figure.effect-bubba:hover h2,
figure.effect-bubba:hover p {
	opacity: 1;
	-webkit-transform: translate3d(0,0,0);
	transform: translate3d(0,0,0);
}

/* For mobile devices (480px and below) */
@media (max-width: 480px) {
	figure {
		margin: 10px;
	}

	figure.effect-bubba h2 {
		font-size: 12px;
		padding-top: 15%;
	}
  .effect-bubba img {
      max-width: 380px;
  }

	figure.effect-bubba p {
		font-size: 11px;
		padding: 8px 1.2em;
	}

	figure.effect-bubba figcaption::before,
	figure.effect-bubba figcaption::after {
		top: 10px;
		right: 10px;
		bottom: 10px;
		left: 10px;
	}
}

/* For tablet devices (up to 768px) */
@media (max-width: 768px) {
	figure.effect-bubba h2 {
		font-size: 14px;
		padding-top: 20%;
	}

	figure.effect-bubba p {
		font-size: 12px;
		padding: 10px 1.5em;
	}
}

/* For large screens and desktops */
@media (min-width: 1200px) {
	.ot-portfolio-item {
		padding: 10px;
	}
}


/*--------------------
4.5. Partners Slider
--------------------*/


.section-title p {
    color: #2f4d38;
    font-weight: 400;
}

.owl-portfolio .owl-controls {
    position: absolute;
    left: 0;
    top: 38%;
    width: 100%;
}

.owl-portfolio .owl-controls .owl-nav [class*=owl-] {
    padding: 8px 17px;
    background: rgba(0, 0, 0, 0.18);
    border-radius: 0;
    margin: 0;
    font-size: 20px;
    z-index:1000;
}

.owl-portfolio .owl-controls .owl-nav [class*=owl-]:hover {
    background: #000;
    color: #fff;
    text-decoration: none;
}

.owl-portfolio .owl-controls .owl-prev {
    float: left;
}

.owl-portfolio .owl-controls .owl-next {
    float: right;
}

.owl-portfolio-item {
    text-align: center;
    display: inline-block;
}

.partner-logo {
    height: 80px;
    text-align: center;
    display: inline-block;
}

.partner-logo img {
    height: 100%;
    width: auto !important;
}

.owl-dots .owl-dot.active span, .owl-theme .owl-dots .owl-dot:hover span {
    background: #FCBE03;
}

.owl-theme .owl-dots .owl-dot span {
    width: 30px;
    height: 5px;
    margin: 15px 7px 0 7px;
    background: #d6d6d6;
    display: block;
    -webkit-backface-visibility: visible;
    -webkit-transition: opacity 200ms ease;
    -moz-transition: opacity 200ms ease;
    -ms-transition: opacity 200ms ease;
    -o-transition: opacity 200ms ease;
    transition: opacity 200ms ease;
    -webkit-border-radius: 30px;
    -moz-border-radius: 30px;
    border-radius: 0;
}

.owl-theme .owl-dots .owl-dot.active span, .owl-theme .owl-dots .owl-dot:hover span {
    background: #69c624;
}

/* Add margin for images */
.ot-portfolio-item {
    text-align: center;
    display: inline-block;
    margin: 5px 5px 5px 15px; /* Adjust this value to control spacing between images */
}

/* Responsive Styles */

/* For tablets and smaller screens (768px and below) */
@media (max-width: 768px) {
	.partner-logo {
		height: 60px;
	}

	.owl-portfolio .owl-controls .owl-nav [class*=owl-] {
		font-size: 16px;
		padding: 5px 10px;
	}

	/* Hide arrows for mobile views */
	.owl-portfolio .owl-controls .owl-prev, 
	.owl-portfolio .owl-controls .owl-next {
		display: none;
	}

	/* Adjust margin for smaller screens */
	.ot-portfolio-item {
		margin: 10px; /* Adjust margin for tablets */
	}
}

/* For mobile devices (480px and below) */
@media (max-width: 480px) {
	.partner-logo {
		height: 50px;
	}

	/* Hide controls for mobile */
	.owl-portfolio .owl-controls {
		display: none;
	}
	
	/* Adjust dot size for mobile */
	.owl-theme .owl-dots .owl-dot span {
		width: 20px;
		height: 4px;
	}

	/* Adjust margin for mobile */
	.ot-portfolio-item {
		margin: 5px; /* Adjust margin for mobile */
	}
}


/* Styling for the "View All Projects" button */
.view-more-btn {
    padding: 12px 25px;
    background-color: #69c624;
    color: #ffffff;
    border: none;
    border-radius: 5px;
    font-size: 16px;
    cursor: pointer;
    margin-top: 20px;
    transition: background-color 0.3s ease;
}

.view-more-btn:hover {
    background-color: #69c624;
	color: #ffffff;
}


/*--------------------
4.7. Contacts
--------------------*/

section#contact form {
	margin-top: 15px;
}
section#contact.form-group {
margin-bottom: 25px;
}

section#contact .form-group input, section#contact .form-group textarea {
	padding: 15px;
	border: 1px solid #fff;
	border-radius: 0;
	-webkit-box-shadow: inset 0 1px 1px rgba(0,0,0,.075);
	box-shadow: inset 0 0px 0px rgba(0,0,0,.075);
	font-size: 13px;
}

.contact h3 {
	margin-bottom: 30px;
}

.contact p {
	font-size: 13px;
}

.contact .day {
	display: inline-block;
	width: 80px;
}

.contact i {
	margin-right: 5px;
}



/*--------------------
6. Modal
--------------------*/

.modal-content {
	border-radius: 0;	
}
.modal-header .close {
	font-size: 30px;	
}
.modal-title {	
	text-transform: uppercase;
	font-size: 23px;
}

.modal-body {
	padding: 0;
}

.modal-body p {
	margin: 30px 20px;
	color: #2D2D2D;		
}

.modal-works {
font-size: 11px;
	letter-spacing: 1px;
	text-transform: uppercase;
	font-weight: 500;
	color: #fff;
	margin: 25px 20px;
}

.modal-works span {
	background-color: #69c624;
	margin-right: 15px;
	padding: 5px 10px;
}

/*--------------------
7. Components
--------------------*/

.btn-xl:hover, .btn-xl:focus, .btn-xl:active, .btn-xl.active, .open .dropdown-toggle.btn-xl {
	color: #fff;
	background-color: #dfdfdf;
	border-color: #dfdfdf;
}

.btn:hover, .btn:focus, .btn:active, .btn.active, .open .dropdown-toggle.btn {
	color: #fff;
	background-color: #dfdfdf;
	border-color: #dfdfdf;
}

.btn {
	display: inline-block;
	padding: 8px 20px;
	margin-bottom: 0;
	font-size: 14px;
	font-weight: 400;
	line-height: 1.42857143;
	text-align: center;
	white-space: nowrap;
	vertical-align: middle;
	-ms-touch-action: manipulation;
	touch-action: manipulation;
	cursor: pointer;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
	background-image: none;
	border: 1px solid transparent;
	border-radius: 0px;
	background-color: #FCBE03;
}

.btn-xl {
color: #fff;
    background-color: #FCBE03;
    /* border-color: #726FB9; */
    font-family: 'Nunito Sans', Helvetica, Arial, Lucida, sans-serif;
    text-transform: uppercase;
    font-weight: 800;
    border-radius: 0;
    letter-spacing: 2px;
    font-size: 16px;
    padding: 17px 45px;
}

/* Back to top button
---------------------------------- */
#back-top {
	position: fixed;
	z-index: 1000;
	bottom: 40px;
	right: 50px;
}
#back-top a {
	width: 60px;
	height: 60px;
	display: block;
	text-align: center;
	font: 11px/100% Arial, Helvetica, sans-serif;
	text-transform: uppercase;
	text-decoration: none;
	color: #FFFFFF;
	background: #A9A9B1;
	/* background color transition */
	-webkit-transition: 1s;
	-moz-transition: 1s;
	transition: 1s;
}
#back-top a:hover {
	background: #69c624;
}
/* arrow icon (span tag) */
#back-top i {
	margin-top: 15px;
	font-size: 28px;
}

@media only screen
and (min-width : 320px)
and (max-width : 480px) {
#back-top {
	position: fixed;
	bottom: 10px;
	right: 30px;
}
#back-top a {
	width: 40px;
	height: 40px;
}
#back-top i {
	margin-top: 7px;
	font-size: 20px;
}
}

.header-right {
    display: flex;
    justify-content: flex-end; /* Aligns the button to the right */
    padding: 10px; /* Adds some padding around the container */
    margin-top: -8px;
}

.phone-btn {
    background-color: #69c624; /* Green background */
    color: #ffffff !important; /* White text color */
    padding: 10px 15px; /* Top/bottom and left/right padding */
    border-radius: 5px; /* Rounded corners */
    text-decoration: none; /* Removes underline */
    font-size: 16px; /* Font size */
    transition: background-color 0.3s; /* Smooth transition for hover effect */
}

.phone-btn:hover {
    background-color: #69c624 !important; /* Darker green on hover */
	text-decoration: none;
  color: #ffffff !important;
}

@media (max-width: 768px) { /* Adjust the max-width as needed */
    .header-right {
        display: none; /* Hides the header-right container on mobile devices */
    }
}

/*--------------------------------------------------------------
#0.5	footer
--------------------------------------------------------------*/

.footer-logo {
  text-align: center; /* Center the logo */
  margin-right: 60%;
  margin-bottom: 15px; /* Add space below the logo */
}

.footer-logo img {
  height: 100%;
  width: 100%;
}


.site-footer {
  background-color: #000;
  position: relative;
  font-size: 18px;
  overflow: hidden;
}

.site-footer h3 {
  color: #fff;
  font-size: 18px;
  font-weight: 500;
}

.site-footer p,
.site-footer li {
  color: #fff;
}

.site-footer .upper-footer {
  padding: 20px 0;
}

.site-footer .widget-title {
  margin-bottom: 30px;
}

.site-footer .widget-title h3 {
  font-size: 18px;
  text-transform: capitalize;
  padding-bottom: 0.4em;
}

.site-footer .social-icons a {
  font-size: 18px;
  color: #fff;
  margin: 0 10px;
  transition: color 0.3s ease;
}

.site-footer .social-icons a:hover {
  color: #69c624; /* Adjust hover effect */
}

.site-footer .about-widget {
  max-width: 250px;
}

.site-footer .link-widget ul {
  width: 50%;
  float: left;
  list-style: none;
}

.site-footer .link-widget ul li {
  margin-top: 15px;
}

.site-footer .link-widget ul a {
  color: #fff;
  font-weight: 500;
  text-decoration: none;
}

.site-footer .link-widget ul a:hover {
  text-decoration: none;
}

.site-footer .contact-widget ul li span {
  font-weight: 500;
}

.site-footer .map-container iframe {
  width: 100%;
  height: 200px;
  border: none;
}
.contact-widget ul li {
  padding-bottom: 25px; 
}
.copy {
  text-align: center;
  padding-top: 10px;
}
.copy a {
  font-size: 14px;
  color: #ffffff;
}

@media (max-width: 991px) {
  .site-footer .upper-footer {
      padding: 60px 0;
  }

  .site-footer .upper-footer .col {
      margin-bottom: 40px;
  }

}

@media (max-width: 767px) {
  .site-footer .upper-footer .col {
      margin-bottom: 20px;
      
  }

  .site-footer .widget-title {
      margin-bottom: 20px;
  }

  .site-footer .social-icons {
      text-align: center;
  }


  .site-footer .copy {
      padding-top: 20px;
      padding-left: 20px;
  }
}
@media (max-width: 767px) {
  /* Align text and items to the left for mobile view */
  .site-footer h3,
  .site-footer p,
  .site-footer li,
  .site-footer .social-icons,
  .site-footer .copy,
  .footer-logo {
    text-align: left !important; /* Override center alignment */
  }
  .site-footer h3 {
  margin-top: 30px;
  font-size: 20px;
  font-weight: 700;
}

  .site-footer .link-widget ul {
    width: 100%; /* Make the links stack vertically */
    float: none; /* Remove float for alignment */
    
  }

  .site-footer .social-icons {
    margin-top: 20px; /* Add spacing for better readability */
  }

  .site-footer .social-icons a {
    display: inline-block;
    margin: 5px; /* Adjust margin for smaller spacing */
  }

  .site-footer .about-widget {
    max-width: 100%; /* Allow the about section to use full width */
  }

  .site-footer .map-container iframe {
    height: 150px; /* Reduce height for smaller screens */
  }

  .contact-widget ul li {
    padding-bottom: 15px; /* Adjust padding for compact view */
  }

  .copy {
    text-align: center; /* Align copyright text to the left */
    padding-top: 20px;
    margin-left: 10px;
  }
}



  /*-----------------------------------------------------------
  #0.6	about-us-section
--------------------------------------------------------------*/
/* About Us Section Styling */
.about-us-section {
  padding: 20px 10px 20px 10px;
  background: #ffffff;
}

.about-us-section h2 {
  font-size: 32px;
  color: #333;
  margin-bottom: 20px;
}

.about-us-section .details p {
  color: #333;
  font-size: 18px;
  line-height: 1.5;
  margin-bottom: 20px;
}

/* Custom Button Styling */
.custom-btn {
  background-color: #69c624;
  color: #ffffff;
  padding: 12px 32px;
  font-size: 18px;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  transition: background-color 0.3s ease;
}
.about-img {
  max-width: 600px !important;
}

.custom-btn:hover {
  background-color: #4da61c;
}

/* Image Holder Styling */
.img-holder {
  margin-bottom: 20px;
}

.about-img-large {
  width: 100%;
  max-width: 600px;
  max-height: 400px;
  border-radius: 8px;
  margin-top: 10%;
}

.small-images {
  display: flex;
  gap: 40px;
}

.about-img-small {
  width: 100%;
  max-width: 280px;
  min-height: 180px;
  border-radius: 8px;
  object-fit: cover;
}

/* Responsive Flexbox Layout */
.about-us-section .row {
  display: flex;
  flex-direction: column; /* Stack by default */
}


/* RESPONSIVE STYLES */

/* For Tablets and larger devices */
@media (min-width: 768px) {
    .about-us-section .row {
        flex-direction: row; /* Switch to row layout */
        justify-content: space-between; /* Distribute space between left and right columns */
    }
    .col-md-6 {
      flex: 1;
  }
    .about-us-section .left-col,
    .about-us-section .right-col {
        flex: 1; /* Ensure both columns are equally sized */
        padding: 0 20px; /* Add padding between columns */
    }
    
    /* Adjust heading size on medium screens */
    .about-us-section h2 {
        font-size: 28px; /* Slightly smaller for tablets */
    }
}

/* For Larger Devices (Desktops) */
@media (min-width: 991px) {
    .about-us-section .right-col {
        margin-top: 0; /* Remove the margin on larger screens */
    }
    .about-img {
        max-width: 500px; /* Set max-width of the image for larger screens */
    }

    .about-us-section h2 {
        font-size: 36px; /* Larger font size for desktops */
    }
}

/* For Very Small Devices (Phones in Portrait Mode) */
@media (max-width: 480px) {
    .about-us-section .details p {
        font-size: 14px; /* Smaller text for small screens */
    }

    .about-us-section h2 {
        font-size: 24px; /* Reduce heading size */
    }

    .custom-btn {
        font-size: 16px; /* Smaller button text */
        padding: 12px 25px; /* Adjust padding for small screens */
    }

    .about-img {
        max-width: 100%; /* Ensure the image fills the container on small screens */

    }
    .about-img-small {
      min-height: 150px;
    }

}

/*--------company info----------*/
/* Company Info Section Styling */
.company-info-section {
  padding: 40px 20px;
  background: #ffffff;
}

.company-info-section h2 {
  font-size: 32px;
  color: #333;
  margin-bottom: 20px;
}

.company-info-section .company-details p {
  color: #333;
  font-size: 14px;
  line-height: 1.6;
  margin-bottom: 20px;
  text-align: justify; /* Justify text for a polished look */
}

/* Custom Button Styling */
.custom-button {
  background-color: #69c624;
  color: #ffffff;
  padding: 12px 32px;
  font-size: 18px;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  transition: background-color 0.3s ease;
  display: block;
  margin: 0 ; /* Center button */
  align-items: left;
}

.company-img {
  max-width: 600px !important;
  max-height: 600px !important;
  border-radius: 8px;
}

.custom-button:hover {
  background-color: #4da61c;
}

/* Image Holder Styling */
.image-holder {
  margin-bottom: 20px;
  text-align: center; /* Center images */
}

.company-img-large {
  width: 100%;
  max-width: 600px;
  max-height: 400px;
  border-radius: 8px;
}

.image-gallery {
  display: flex;
  gap: 40px;
  justify-content: center; /* Center gallery images */
}

.company-img-small {
  width: 100%;
  max-width: 280px;
  border-radius: 8px;
  object-fit: cover;
}

/* Responsive Flexbox Layout */
.company-info-section .row {
  display: flex;
  flex-direction: column;
}

.company-img {
  width: 100%;
  max-width: 600px;
  height: 400px;
  border-radius: 8px;
  display: block;
  margin: 0 auto; /* Center-align images within their container */
}

/* RESPONSIVE STYLES */

/* For Small Phones (Portrait) */
@media (max-width: 576px) {
    .company-info-section h2 {
        font-size: 24px;
    }
    .company-info-section .company-details p {
        font-size: 14px;
    }
    .custom-button {
        font-size: 16px;
        padding: 10px 20px;
    }
    .image-gallery {
        flex-direction: column; /* Stack images vertically */
        gap: 20px;
    }
    .company-img { 
     height: 250px;
    }
}

/* For Medium Devices (Tablets) */
@media (min-width: 768px) {
    .company-info-section .row {
        flex-direction: row;
        justify-content: space-between;
    }
    .col-md-6 {
        flex: 1;
    }
    .company-info-section .company-left-col,
    .company-info-section .company-right-col {
        flex: 1;
        padding: 0 20px;
    }
    .company-img {
        max-width: 100px;
    }
    .company-info-section h2 {
        font-size: 28px;
    }
}

/* For Large Devices (Desktops) */
@media (min-width: 992px) {
    .company-info-section .company-right-col {
        margin-top: 0;
    }
    .company-img {
        max-width: 500px;
    }
    .company-info-section h2 {
        font-size: 36px;
    }
    .company-info-section .company-details p {
        font-size: 18px;
    }
}



  /*---------- testimonial Slider Styling */
/* General Slider Styling */
.testimonial-slider {
    position: relative;
    max-width: 100%;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 50px;
	margin-top: 0px;
    text-align: center;
    overflow: hidden;
}

.testimonial-slide {
    display: none;
    padding: 20px 20px 20px 20px;
    background: #EFEFF1;
    border-radius: 10px;
    box-shadow: 0px 5px 15px rgba(0, 0, 0, 0.1);
    transition: opacity 0.5s ease-in-out;
}

.testimonial-slide.active {
    display: block;
    opacity: 1;
}

.testimonial-content {
    font-size: 18px;
    font-style: italic;	
    color: #69c624;
    margin-bottom: 15px;
	font-weight: 500;
}

.testimonial-author {
    font-size: 16px;
    font-weight: bold;
    color: #69c624;
}

/* Slider Controls */
.prev, .next {
    cursor: pointer;
    position: absolute;
    top: 50%;
    padding: 16px;
    margin-top: -22px;
    color: #123;
    font-weight: bold;
    font-size: 18px;
    transition: 0.3s;
    border: none;
    background-color: transparent;
    user-select: none;
}

.prev {
    left: 0;
}

.next {
    right: 0;
}

.prev:hover, .next:hover {
    color: #777;
}

/* Responsive styling */
@media (max-width: 600px) {
    .testimonial-content {
        font-size: 16px;
    }

    .testimonial-author {
        font-size: 14px;
    }
}

/*--------------------------------------------------------------
#1.2	fun-fact-section
--------------------------------------------------------------*/
.fun-fact-section {
  background-color: #ffffff;
  padding: 60px 0;
  text-align: center;
  margin-bottom: 40px;
}

/* Fun Fact Grids */
.fun-fact-grids {
  display: flex;
  justify-content: center; /* Center grids on all screen sizes */
  flex-wrap: wrap;
  gap: 20px; /* Adds space between the grids */
}

/* Individual Grid Styles */
.fun-fact-section .grid {
  flex: 1;
  max-width: 220px; /* Default max width */
  width: 100%; /* Make all grids the same width */
  margin: 20px;
  padding: 20px;
  background-color: #ffffff;
  border-radius: 8px;
  box-shadow: 0 0 15px rgba(0, 0, 0, 0.1);
}

/* Grid Info Section */
.fun-fact-section {
  background-color: #ffffff;
  padding: 0px 0;
  text-align: center;
}

/* Fun Fact Grids */
.fun-fact-grids {
  display: flex;
  justify-content: center; /* Center grids on all screen sizes */
  flex-wrap: wrap;
  gap: 20px; /* Adds space between the grids */
}

/* Individual Grid Styles */
.fun-fact-section .grid {
  flex: 1;
  max-width: 220px; /* Default max width */
  width: 100%; /* Make all grids the same width */
  margin: 20px;
  padding: 20px;
  background-color: #ffffff;
  border-radius: 8px;
  box-shadow: 0 0 15px rgba(0, 0, 0, 0.1);
}

/* Grid Info Section */
.fun-fact-section .info {
  text-align: center;
}

.fun-fact-section .info i {
  font-size: 50px;
  color: #007bff;
  margin-bottom: 20px;
}

/* Heading Style */
.fun-fact-section h3 {
  font-size: 36px;
  font-weight: bold;
  color: #69c624;
  margin: 0 0 10px;
}

/* Paragraph Text */
.fun-fact-section p {
  font-size: 16px;
  color: #2f4d38;
  font-weight: bold;
}

/* Odometer Number Styling */
.odometer {
  font-weight: bold;
  font-size: 36px;
  color: #69c624;
}

.odometer.inside .odometer-digit {
  font-size: 36px;
}

/* RESPONSIVE STYLES */

/* For Very Small Devices (Phones in Portrait Mode) */
@media (max-width: 480px) {
  .fun-fact-section {
      padding: 40px 10px; /* Reduce padding for small devices */
  }

  .fun-fact-section h3 {
      font-size: 28px; /* Smaller heading font size */
  }

  .fun-fact-section p {
      font-size: 14px; /* Reduce paragraph font size */
  }

  /* Change layout to vertical stacking on mobile devices */
  .fun-fact-section .grid {
      max-width: 100%; /* Full width for each grid */
      width: 100%; /* 1 grid per row */
      padding: 15px; /* Adjust padding */
      margin-top: 10px; /* Ensure there is space between items */
  }

  .fun-fact-section .info i {
      font-size: 40px; /* Smaller icon size */
  }
}

/* For Small Devices (Phones in Landscape Mode) */
@media (max-width: 768px) {
  .fun-fact-section h3 {
      font-size: 32px; /* Smaller heading font size */
  }

  /* Change layout to vertical stacking on small landscape devices */
  .fun-fact-section .grid {
      max-width: 100%; /* Full width for each grid */
      width: 100%; /* 1 grid per row */
      padding: 15px; /* Adjust padding */
      margin-top: 10px; /* Add margin for spacing between grids */
  }

  .fun-fact-section .info i {
      font-size: 40px; /* Smaller icon size */
  }
}

/* For Medium Screens (Tablets) */
@media (min-width: 768px) and (max-width: 991px) {
  .fun-fact-section h3 {
      font-size: 32px; /* Slightly smaller font size for tablets */
  }

  .fun-fact-section p {
      font-size: 18px; /* Increase font size for better readability */
  }

  /* Default layout for tablets */
  .fun-fact-section .grid {
      max-width: 48%; /* Two grids per row on tablets */
      width: 48%;
      padding: 15px;
      margin-top: 10px;
  }
}

/* For Large Screens (Desktops) */
@media (min-width: 991px) {
  .fun-fact-section h3 {
      font-size: 40px; /* Increase heading size for large screens */
  }

  .fun-fact-section p {
      font-size: 18px; /* Maintain larger paragraph font size */
  }

  .fun-fact-section .grid {
      max-width: 300px; /* Larger max-width for grid items on desktops */
      width: 100%; /* Keep all grids the same size */
  }

  .fun-fact-grids {
      justify-content: space-between; /* Spread out the grids on larger screens */
  }
}



/*---certificate---*/
/* styles.css */
.banner {
    background-color: #69c624;
    color: white;
    text-align: center;
    padding: 50px 20px;
}

.banner h1 {
    font-size: 28px;
    font-weight: bold;
    margin: 0 0 20px;
}

.banner p {
    font-size: 18px;
    margin: 10px auto;
    line-height: 1.6;
}

.certifications {
    margin-top: 30px;
}

.certifications img {
    width: 120px;
    height: auto;
    margin: 0 10px;
    vertical-align: middle;
	border-radius: 50px;
}

/* Optional background pattern */
body::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-image: url('background_pattern.png');
    opacity: 0.1;
    z-index: -1;
}

  
.image-full-bg {
  max-height: 350px;
	height: 500px;
	overflow: hidden;
	border-radius: 0px; /* Rounded corners */
	box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.2); /* Shadow effect */
  }
  
  .image-full-bg img {
	width: 100%;
	height: 500px;
	display: block;
	transition: transform 0.3s ease; /* Smooth zoom on hover */
  }
  
  .image-full-bg img:hover {
	transform: scale(1.05); /* Slight zoom on hover */
  }

  /* Responsive Styles */
@media (max-width: 991px) {
  .image-full-bg {
    max-height: 300px;
  }

  .image-full-bg img {
    height: auto;
  }
}

@media (max-width: 767px) {
  .image-full-bg {
    max-height: 250px;
  }
}

@media (max-width: 480px) {
  .image-full-bg {
    max-height: 200px;
  }
  .image-full-bg img {
    min-height: 200px;
  }
}

  /*-----request-quote 
  -------*/
  .request-quote-a {
      padding-bottom: 45px;  
	}

  .request-quote {
    background-color: #69c624;
    color: white;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 20px;
    position: relative;
    font-size: 20px;
	margin-top: -50px;
	margin-bottom: -60px;
}

.quote-text {
    margin-left: 20%;
    font-weight: bold;

}

.request-quote p {
	color: #FFFFFF !important;
	font-size: 20px;
}

.quote-button {
    padding: 15px 30px;
    background-color: black;
    color: white;
    text-decoration: none;
    font-weight: bold;
    font-size: 18px;
    border-radius: 4px;
    transition: background-color 0.3s;
	 margin-right: 20%;
}

.quote-button:hover {
  background-color: black;
  color: white;
  text-decoration: none;
}

/* Optional background pattern */
.request-quote::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-image: url('path/to/background_pattern.png');
    background-repeat: repeat;
    opacity: 0.1;
    z-index: -1;
}

/* Responsive adjustments */

/* For medium devices (tablets and smaller screens) */
@media (max-width: 992px) {
    .request-quote {
        padding: 15px;
        flex-direction: column; /* Stack the elements vertically */
        text-align: center;
    }

    .quote-text {
        margin-left: 0;
        margin-bottom: 10px; /* Add spacing between text and button */
        font-size: 18px; /* Slightly smaller text size for medium devices */
    }

    .quote-button {
        margin-right: 0;
        margin-top: 10px;
        font-size: 16px; /* Slightly smaller font size for the button */
        padding: 12px 25px; /* Adjust padding for medium screens */
    }

    .request-quote p {
        font-size: 18px; /* Reduce font size for smaller screens */
    }
}

/* For smaller tablets and larger mobile phones */
@media (max-width: 768px) {
    .request-quote {
        padding: 15px;
        flex-direction: column; /* Stack vertically for better layout */
        text-align: center;
    }

    .quote-text {
        margin-left: 0;
        margin-bottom: 15px;
        font-size: 16px; /* Reduce text size further */
    }

    .quote-button {
        margin-top: 15px;
        font-size: 16px;
        padding: 10px 20px; /* Adjust button padding */
    }

    .request-quote p {
        font-size: 16px; /* Reduce paragraph font size for smaller devices */
    }
}

/* For mobile devices */
@media (max-width: 480px) {
    .request-quote {
        padding: 10px;
        flex-direction: column;
        text-align: center;
    }

    .quote-text {
        margin-left: 0;
        margin-bottom: 0px;
        font-size: 14px; /* Further reduce font size for mobile screens */
    }

    .quote-button {
        margin-top: 15px;
        font-size: 14px; /* Smaller font size for mobile */
        padding: 10px 10px 10px 10px; /* Further reduce button padding */
		   margin-bottom:20px;
    }

    .request-quote p {
        font-size: 14px; /* Smaller font size for mobile screens */
    }
}

/*-----content --------*/
.content {
  width: 100%; /* Make content full-width */
  padding: 20px;
  background-color: #fff;
  box-sizing: border-box; /* Ensures padding is included in the full width */
}

.main-heading {
  font-size: 30px;
  color: #2f4d38;
  text-align: left;
  font-weight: 700;
  letter-spacing: -0.4px;
}

.main-heading , .paragraph {
  margin: 10px;
}

.divider {
  width: 150px;
  height: 4px;
  background-color: #27ae60;
  border: none;
  margin: 0;
  margin-bottom: 20px;
  margin-left: 10px;
}

.subheading {
  font-size: 28px;
  color: #2f4d38;
  margin-top: 20px;
  letter-spacing: -0.4px;
  margin-bottom: 10px;
}

.paragraph {
  font-size: 18px;
  color: #555;
  line-height: 1.6;
  margin-bottom: 40px;
  letter-spacing: -0.4px;
}

.highlight {
  color: #27ae60;
  font-weight: bold;
}

/* Main section */
.vision-mission {
  padding: 10px;
}

.vision-mission p {
  color: #000;
  
}


/* Section styling */
.section {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 20px;
  width: 100%;
  box-sizing: border-box;
}

.section .text {
  width: 50%;
  padding-right: 10px;
}

.section .text h2 {
  font-size: 30px;
  margin-bottom: 10px;
  color: #333;
}

.section .text p {
  font-size: 18px;
  margin-top: 20px;
  color: #333;
  line-height: 1.5;

}

.section .image {
  width: 50%;
  margin: 10px;
}

.section .image img {
  width: 100%;
  max-height: 350px;
  border-radius: 8px;
}

/* Reverse order for the second section */
.reverse {
  flex-direction: row-reverse;
}

/* Responsiveness */
@media (max-width: 768px) {
  .section {
      flex-direction: column;
      padding: 10px 20px;
  }

  .section .text, .section .image {
      width: 100%;
      padding-right: 0;
  }

  .section .text h2 {
      font-size: 20px
  }
  .vision-mission p {
    color: #333;
    line-height: 1.6;
  }

  .section .text p {
      font-size: 16px;
  }
}


/*-----contact-us----*/
.contact-pg-section {
  padding-bottom: 35px;
}

@media (max-width: 991px) {
  .contact-pg-section {
    padding-bottom: 100px;
  }
}

@media (max-width: 767px) {
  .contact-pg-section {
    padding-bottom: 80px;
  }
}

.contact-pg-section form input,
.contact-pg-section form select,
.contact-pg-section form textarea {
  background: #fff;
  width: 100%;
  height: 55px;
  border: 2px solid #ebedef;
  border-radius: 0;
  box-shadow: none !important;
}

@media (max-width: 991px) {
  .contact-pg-section form input,
  .contact-pg-section form select,
  .contact-pg-section form textarea {
    height: 45px;
  }
}

.contact-pg-section form input:focus,
.contact-pg-section form select:focus,
.contact-pg-section form textarea:focus {
  border-color: #69c624;
}

.contact-pg-section form textarea {
  height: 180px;
}

.contact-pg-section form {
  margin: 0 -15px;
  overflow: hidden;
}

.contact-pg-section form ::-webkit-input-placeholder {
  color: #9d9c9c;
}

.contact-pg-section form :-moz-placeholder {
  color: #9d9c9c;
}

.contact-pg-section form ::-moz-placeholder {
  color: #9d9c9c;
}

.contact-pg-section form :-ms-input-placeholder {
  color: #9d9c9c;
}

.contact-pg-section form select {
  display: inline-block;
  color: #a9a9a9;
  cursor: pointer;
  padding: 6px 12px;
  font-size: 15px;
}

.contact-pg-section form > div {
  width: calc(50% - 30px);
  float: left;
  margin: 0 15px 30px;
}

@media (max-width: 600px) {
  .contact-pg-section form > div {
    width: calc(100% - 30px);
    float: none;
  }
}

.contact-pg-section form .fullwidth {
  width: calc(100% - 30px);
  float: none;
  clear: both;
}

.contact-pg-section .office-info {
  background-color: #ffffff;
  position: relative;
  padding: 2  0px 45px;
  margin-top: -10px;
}

@media (max-width: 1199px) {
  .contact-pg-section .office-info {
    margin-left: 0;
  }
}

@media (max-width: 991px) {
  .contact-pg-section .office-info {
    margin-top: 0;
  }
}

.contact-pg-section .office-info h2 {
  color: #2f4d38;
  font-size: 28px;
  font-weight: 700;
}

.contact-pg-section .office-info a li {
  color: #2f4d38;
  font-weight: bold;
}

.contact-pg-section .office-info li {
  font-size: 14px;
  color: #2f4d38;
}

.contact-pg-section .office-info li i {
  color: #2f4d38;
  display: inline-block;
  padding-right: 5px;
}

.contact-pg-section .office-info ul > li + li {
  margin-top: 8px;
}

.contact-pg-section .office-info p {
  color: #000;
  margin-left: 0px;
}

.contact-pg-section .office-info ul {
  list-style: none;
  padding-left: 0;
}

.contact-pg-section .office-info ul li {
  font-size: 16px;
  margin-bottom: 10px;
}


.full-width-map {
  width: 100%;
  height: 500px; /* You can adjust the height as needed */
  position: relative;
}

/* Responsive map iframe */
.full-width-map iframe {
  width: 100%;
  height: 100%;
  border: none;
}

/*-----Product-------*/
.product-page-poly {
  display: flex;
  height: 60vh; /* Adjusted to take about 70% of viewport height */
  flex-direction: row;
  align-items: center;
  justify-content: center;
  border-bottom: 0.1px solid #69c624;
  box-sizing: border-box;
}

/* Default layout: Text on left, Slider on right */
.product-page-poly:not(.alternate-layout) {
  flex-direction: row-reverse;
}

/* Slider Container */
.slider-poly {
  flex: 1;
  max-width: 50%; /* Take half of the width */
  max-height: 100%; /* Ensure the slider fits within the section */
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 30px; 
}

.slider {
  display: flex;
  height: 100%;
}

.slider img {
  max-height: 400px;
}
.slide {
  width: 100%;
  height: auto;
  max-height: 100%; /* Maintain image proportions */
  object-fit: cover;
  display: none;
}

.slide.active {
  display: block;
}

.slider-controls {
  position: absolute;
  top: 50%;
  width: 100%;
  display: flex;
  justify-content: space-between;
  transform: translateY(-50%);
}

.arrow {
  background-color: #69c624;
  color: white;
  border: none;
  padding: 10px;
  cursor: pointer;
  font-size: 24px;
  transition: background-color 0.3s;
}

.arrow:hover {
  background-color: #69c624;
  color: white;
}

/* Right Content Container */
.content-poly {
  flex: 1;
  max-width: 50%; /* Take half of the width */
  padding: 20px;
  display: flex;
  flex-direction: column;
  align-items: left;
  justify-content: left;
  background-color: #ffffff;
  text-align: left;
  box-sizing: border-box;
  margin-left:30px; 
}

.content-poly h2 h3 {
  font-size: 28px; /* Adjusted font size for the title */
  margin-bottom: 15px;
  font-weight: 700px;
  color: #2f4d38;
}

.content-poly p {
  font-size: 18px; /* Adjusted font size for the description */
  color: #000;
  line-height: 1.6;
  max-width: 600px;
}



/* Mobile Layout for screens under 480px */
@media (max-width: 480px) {
  .product-page-poly {
    flex-direction: column; /* Stack content vertically */
    height: auto;
    align-items: center; /* Center-align content */
    justify-content: center;
    padding: 10px;
  }

  .slider-poly {
    max-width: 100%; /* Full width on mobile */
    max-height: 200px; /* Adjust slider height */
    margin: 0;
  }

  .content-poly {
    max-width: 100%; /* Full width for text */
    margin: 0;
    padding: 10px;
    text-align: justify; /* Center-align text on mobile */
  }

  .content-poly h2,
  .content-poly h3 {
    font-size: 20px; /* Reduced font size */
    margin-bottom: 10px;
  }

  .content-poly p {
    font-size: 14px;
    line-height: 1.4; /* Adjusted line height */
  }

  .slider img {
    max-height: 180px; /* Limit image height */
    object-fit: cover; /* Cover fit for mobile */
  }


  .arrow {
    padding: 8px;
    font-size: 20px;
  }
}

/* Tablet Layout for screens under 768px */
@media (max-width: 768px) {
  .product-page-poly {
    flex-direction: column; /* Stack content vertically */
    height: auto;
    padding: 15px;
  }

  .slider-poly,
  .content-poly {
    max-width: 100%; /* Full width for both slider and content */
    margin: 0;
    padding: 15px;
  }

  .content-poly h2,
  .content-poly h3 {
    font-size: 24px;
  }

  .content-poly p {
    font-size: 16px;
    line-height: 1.5;
  }

  .slider img {
    max-height: 250px;
  }
}

/* Hide mobile text by default */
.mobile-text {
  display: none;
}

/* Show desktop text by default */
.desktop-text {
  display: block;
}

/* Mobile View Adjustments */
@media (max-width: 768px) {
  /* Hide desktop text on mobile */
  .desktop-text {
      display: none;
  }

  /* Show mobile text below slider on mobile */
  .mobile-text {
      display: block;
      padding: 10px;
      text-align: justify; /* Optional: Center align text for mobile */
  }

  /* Additional mobile styling (optional) */
  .mobile-text h2 {
      font-size: 24px;
      padding-left: 15px;
  }
   .mobile-text .divider {
    margin-left: 15px;
  }
  .mobile-text h3 {
    font-size: 24px;
    padding-left: 15px;
  }

  .mobile-text p {
    font-size: 16px;
    line-height: 1.5;
    padding: 15px;
  }

  .mobile-text ul {
      font-size: 14px;
      padding-left: 20px; /* Indent for list items */
  }
}


/*-----gallery----*/
/* Row for image grouping */
.row {
  justify-content: center;
  margin: 10px 0;
}
.gallery {
  padding-top: 50px;
}

/* Responsive styles */
@media screen and (max-width: 768px) {
  .row {
      flex-wrap: wrap; /* Stack images */
  }
}

@media screen and (max-width: 576px) {
  .gallery-img {
      width: calc(100% - 20px); /* Full width images on small screens */
      margin: 5px;
  }

  .modal-image {
      width: 90%;
      margin-top: 70%;
  }
}

/*--------Services-----------*/

.service-container {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  padding: 20px;
  justify-content: center;
}

.service-box {
  background-color: #ffffff;
  border-radius: 8px;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
  padding: 20px;
  width: 100%;
  max-width: 450px;
  text-align: center;
  position: relative;
}

.service-icon {
  width: 50px;
  height: 50px;
  margin-bottom: 15px;
}

.service-box h3 {
  font-size: 1.2em;
  color: #0d1b4c;
  margin-bottom: 10px;
}

.service-description {
  font-size: 0.9em;
  color: #666666;
  margin-bottom: 15px;
}

.read-more {
  background-color: #f0f4ff;
  border: none;
  color: #69c624;
  padding: 8px 15px;
  border-radius: 20px;
  cursor: pointer;
  font-size: 0.9em;
  margin-top: 10px;
}

.more-text {
  display: none;
  font-size: 0.9em;
  color: #666666;
  margin-top: 10px;
}

/* Responsive Design */
@media (min-width: 768px) {
  .service-container {
      gap: 15px;
  }
  .service-box {
      width: calc(50% - 15px); /* Two columns on tablet */
  }
}

@media (min-width: 1024px) {
  .service-box {
      width: calc(33.33% - 15px); /* Three columns on larger screens */
  }
}

/*----Gallery----*/
.horizontal-scroll {
  display: flex;
  overflow-x: auto; /* Allow horizontal scrolling */
  scroll-snap-type: x mandatory;
  scrollbar-width: none; /* Hide scrollbar in Firefox */
}

.horizontal-scroll::-webkit-scrollbar {
  display: none; /* Hide scrollbar in Chrome, Safari */
}

.horizontal-scroll img {
  width: 100%; /* Full viewport width */
  min-width: 400px;
  max-height: 300px;
  min-height: 300px;
  margin: 50px 40px 50px 30px;
  height: 100%; /* Full viewport height */
  object-fit: cover;
  scroll-snap-align: start;
  flex-shrink: 0;
  padding: 10px;
}

.dots-container {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 20px;
  position: relative;
}

/* Dot styling */
.dot {
  height: 12px;
  width: 12px;
  background-color: lightgray;
  border-radius: 50%;
  margin: 0 6px;
  cursor: pointer;
  transition: background-color 0.3s ease;
}

.dot.active {
  background-color: darkgray;
}


/* Responsive adjustments */
@media (min-width: 768px) {
  .horizontal-scroll img {
    max-width: 300px;
    max-height: 200px;
    margin: 20px;
  }
  
}

@media (min-width: 1024px) {
  .horizontal-scroll img {
    max-width:300px;
    max-height: 200px;
    margin: 30px;
  }
}



/*----Menu----*/
.navbar {
  list-style: none;
  padding: 0;
  margin: 0;
}

.navbar hr {
margin-top: 4px;
margin-bottom: 4px;
background-color: #27ae60;
margin: 0;
}

.menu-item {
  position: relative;
}

.menu-item > a {
  text-decoration: none;
  font-weight: bold;
  color: #382cf7;
  padding: 15px;
  display: block;
}

.sub-menu {
  display: none; /* Hidden by default */
  position: absolute;
  top: 100%;
  left: 0;
  background: #fff;
  padding: 10px;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
  z-index: 1000;
  white-space: nowrap;
  flex-direction: row;

}

.sub-menu .column {
  flex: 1;
  padding: 0 15px;
}

.sub-menu .column li {
  list-style: none;
  margin-bottom: 10px;
}

.sub-menu .column li a {
  text-decoration: none;
  color: #000;
}

.sub-menu .column li a:hover {
  text-decoration: none;
}

/* Show the submenu on hover */
.menu-item-has-children:hover .sub-menu {
  display: flex; /* Displays the submenu */
}

/* Responsive styling for smaller screens */
@media (max-width: 991px) {
  .sub-menu {
      flex-direction: column; /* Stack columns vertically on small screens */
      position: static; /* Keep in-flow for mobile */
  }
  .sub-menu .column {
      margin: 10px 0;
  }
}

/*-------services-----*/
.services-container {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin: 20px;
}

.service-item {
  padding: 15px;
  border: 0.5px solid #ddd;
  background-color: #f8f8f8;
  padding-left: 50px;
  font-size: 16px;
  text-decoration: none;
  font-weight: 600;
  display: flex;
  align-items: center;
}

.services-container a {
  color: #000;
  text-decoration: none;
}

.icon img {
  width: 13px;
  height: 13px;
  margin-right: 10px;
  object-fit: contain;
  display: inline-block;
}

.service-item.active .icon img {
  filter: grayscale(0%); /* Example for active styling */
}

.service-item:hover {
  background-color: #69c624;
  color: #ffffff;
}

.service-item:hover .icon img {
  transform: scale(1.1); /* Slight scaling effect on hover */
}

/* Responsive Design */

/* For screens smaller than 768px (tablets and smaller devices) */
@media (max-width: 768px) {
  .services-container {
      grid-template-columns: repeat(2, 1fr); /* 2 columns for medium devices */
  }

  .service-item {
      padding-left: 30px; /* Adjust padding for smaller screens */
  }

  .icon img {
      width: 25px;
      height: 25px; /* Smaller icons */
  }
}

/* For screens smaller than 480px (smartphones) */
@media (max-width: 480px) {
  .services-container {
      grid-template-columns: 1fr; /* 1 column for smaller screens */
  }

  .service-item {
      padding-left: 20px; /* Adjust padding for smaller screens */
      font-size: 14px; /* Slightly smaller font size */
  }

  .icon img {
      width: 20px;
      height: 20px; /* Even smaller icons */
  }
}
