@charset "UTF-8";
@font-face {
  font-family: 'Manrope';
  src: url("../fonts/Manrope-Medium.woff2") format("woff2"), url("../fonts/Manrope-Medium.woff") format("woff");
  font-weight: 500;
  font-style: normal;
  font-display: swap; }
@font-face {
  font-family: 'Manrope';
  src: url("../fonts/Manrope-Bold.woff2") format("woff2"), url("../fonts/Manrope-Bold.woff") format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap; }
@font-face {
  font-family: 'Manrope';
  src: url("../fonts/Manrope-Regular.woff2") format("woff2"), url("../fonts/Manrope-Regular.woff") format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap; }
@font-face {
  font-family: 'Manrope';
  src: url("../fonts/Manrope-SemiBold.woff2") format("woff2"), url("../fonts/Manrope-SemiBold.woff") format("woff");
  font-weight: 600;
  font-style: normal;
  font-display: swap; }
@font-face {
  font-family: 'Public Sans';
  src: url("../fonts/PublicSans-Medium.woff2") format("woff2"), url("../fonts/PublicSans-Medium.woff") format("woff");
  font-weight: 500;
  font-style: normal;
  font-display: swap; }
@font-face {
  font-family: 'Public Sans';
  src: url("../fonts/PublicSans-Bold.woff2") format("woff2"), url("../fonts/PublicSans-Bold.woff") format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap; }
@font-face {
  font-family: 'Public Sans';
  src: url("../fonts/PublicSans-Regular.woff2") format("woff2"), url("../fonts/PublicSans-Regular.woff") format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap; }
@font-face {
  font-family: 'Public Sans';
  src: url("../fonts/PublicSans-SemiBold.woff2") format("woff2"), url("../fonts/PublicSans-SemiBold.woff") format("woff");
  font-weight: 600;
  font-style: normal;
  font-display: swap; }
:root {
  --brand-green: rgba(0, 219, 149, 1);
  --crl-dark-green:rgba(45, 106, 79, 1);
  --soft-white: #f8f9fa;
  --clr-text-blue:rgba(68, 75, 90, 1);
  --clr-text-green:rgba(59, 74, 65, 1);
  --header-black: rgba(17, 24, 39, 1);
  --text-light-green: rgba(43, 43, 43, 0);
  --clr-light-green:rgba(216, 243, 220, 1);
  --soft-green:rgba(240, 250, 244, 1);
  --clr-light-gray:rgba(248, 249, 250, 1);
  --crl-gradient: linear-gradient(104.5deg, #1A3C34 0%, #2D6A4F 100%);
  --font-manrope:"Manrope";
  --font-sans:"Public Sans"; }

.bg-soft-green {
  background-color: var(--soft-green); }

.bg-primary-color {
  background-color: var(--brand-green); }

.bg-primary-dark {
  background-color: var(--crl-dark-green); }

.primary-color {
  color: var(--brand-green)!important; }

.primary-color-dark {
  color: var(--crl-dark-green)!important; }

.text-clr-green {
  color: var(--clr-text-green); }

.bg-light-gray {
  background-color: var(--clr-light-gray); }

html {
	    scroll-behavior: smooth;
  padding: 0!important;
  margin: 0!important;
  overflow-x: clip; }

*{
	cursor:none;
}

body {
  background-color: #ffffff;
	overscroll-behavior: none;
  overflow-x: clip;
  font-family: var(--font-sans);
  font-weight: 400;
  font-size: 16px;
	line-height:1.5;
  color: var(--text-blue); 

}

img{
	max-width:100%;
	height:auto;
}

img[src$=".svg"] {
    width: 100%;
    height: auto;
    max-width: 100%;
    transform: translateZ(0);
    -webkit-transform: translateZ(0);
    image-rendering: -webkit-optimize-contrast;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    shape-rendering: geometricPrecision;
}

/* Inline SVG responsive fix */
.svg-wrapper {
    width: 100%;
    height: auto;
    display: block;
}

.svg-wrapper svg {
    width: 100%;
    height: auto;
    display: block;
    transform: translateZ(0);
    -webkit-transform: translateZ(0);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    shape-rendering: geometricPrecision;
}

/* Fallback img tag */
.svg-img {
    width: 100%;
    height: auto;
    display: block;
    transform: translateZ(0);
    -webkit-transform: translateZ(0);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    image-rendering: -webkit-optimize-contrast;
}

ul {
  margin: 0;
  padding: 0; }

.bullet-list {
  list-style: disc;
  padding-left: 20px;
  margin-bottom: 16px; }

.primary-color {
  color: var(--brand-green); }

a {
  text-decoration: none; }

.breadcrumbs ul li {
  color: #00db95;
  position: relative;
  text-align: left; }
  .breadcrumbs ul li a {
    color: rgba(255, 255, 255, 0.55);
    text-decoration: none;
    transition: .3s ease-in-out; }
    .breadcrumbs ul li a:hover {
      color: #00db95; }
  .breadcrumbs ul li:not(:last-of-type) {
    padding-right: 24px; }
    .breadcrumbs ul li:not(:last-of-type):after {
      content: '\f054';
      position: absolute;
      font-family: FontAwesome;
      color: rgba(255, 255, 255, 0.55);
      top: 4px;
      right: 7px;
      font-size: 12px; }

/* Page Loader */

.loader {
    position: fixed;
    inset: 0;
    z-index: 99998;
    background: linear-gradient(100.61deg, #1A3C34 0%, #2D6A4F 60%, #3A8A6A 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: all;
}

.loader.visible{
	visibility:visible;
	opacity:1;
}

.loader--hidden {
    pointer-events: none;
    visibility: hidden;
}

.loader__logo {
    display: flex;
    align-items: center;
    gap: 8px;
}

.loader__icon {
    flex-shrink: 0;
    transform: scale(0);
    opacity: 0;
}

.loader__icon svg {
    width: 53px;
    height: auto;
    display: block;
}

.loader__text {
    opacity: 0;
    margin-bottom: -4px;
    overflow: hidden;
    max-width: 0;
}

.loader__text svg {
    width: 114px;
    height: auto;
    display: block;
}

/*---------------------base----------------------------*/
.block {
  padding: clamp(2.7rem, 4vw, 7rem) 0; }

.btn{
	transition:ease all 0.4s;
box-shadow:0 4px 15px rgba(0, 217, 153, 0.3);
}

.btn:hover{
	 transform: translateY(-1px);
}

.btn-primary, .btn-primary-green  {
  background-color:#00c288 !important;
  color: #fff !important;
  border: none;
  border-radius: 4px;
  padding: 10px 24px !important;
  font-size: 16px;
  font-weight: 600;
  transition: transform 0.2s ease, background 0.3s ease; }

.btn-primary:hover, .btn-primary-green:hover  {
  background-color:  var(--brand-green) !important;
  color: #fff !important;
  transform: translateY(-1px); }

.btn-white-custom  {
  background-color: #fff !important;
  color: #000 !important;
  border: .8px solid var(--clr-light-green);
  border-radius: 4px;
  padding: 10px 24px !important;
  font-size: 16px;
  font-weight: 600;
  transition: transform 0.2s ease, background 0.3s ease; }

.btn-white-custom:hover {
  background-color: var(--clr-light-green)!important;
  transform: translateY(-1px); }

.btn-light:hover{
	background-color:#d8f3dc;
	box-shadow:0 2px 15px rgba(255, 255, 255, 0.3);
}

.text-primary{
	color:#00cc88 !important;
}

/*---------------------base-end---------------------------*/
/*---------------------header-start---------------------------*/
/* --- Base Styles & Variables --- */
:root {
  --theme-mint: var(--brand-green);
  /* Exact green from your image */
  --theme-dark: #333333;
  --header-bg: rgba(244, 255, 251, 1); 
}

/* --- Base State: Header is already fixed, occupying no layout depth --- */
.site-header {
  position: fixed !important;
  /* Always fixed, meaning no layout footprint change later */
  top: 0;
  left: 0;
  width: 100%;
  background-color: var(--header-bg);
  border-bottom: 1px solid #d9d9d9;
  z-index: 1030;
  padding-top: 20px;    /* Explicit starting pad to transition cleanly down from */
  padding-bottom: 20px; /* Explicit starting pad */
  
  /* --- iOS GLITCH PROTECTOR --- */
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  
  transition: padding 0.3s cubic-bezier(0.16, 1, 0.3, 1), 
              background-color 0.3s ease, 
              box-shadow 0.3s ease, 
              border-color 0.3s ease; 
}

/* --- Push the rest of your page content down so it isn't hidden under the header initially --- */
body {
  padding-top: 70px;
  /* Match this roughly to the natural height of your header */ 
}
@media (max-width:991px){
  body {
    padding-top: 70px;
  }
}
@media (max-width:767px){
  body {
    padding-top: 50px;
  }
}


/* --- Sticky Active State: Merely changes cosmetic properties smoothly --- */
.site-header.sticky-active {
  padding-top: 10px !important;
  padding-bottom: 10px !important;
  background-color: var(--header-bg);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
  border-bottom-color: transparent;
  
  /* REMOVED keyframe translateY animation which was causing the iOS rendering glitch */
  animation: none !important; 
}

/* --- Desktop Navigation Base --- */
#desktop-menu {
  list-style: none;
  padding: 0;
  margin: 0; 
}

#desktop-menu li {
  position: relative;
  /* Anchors the absolutely positioned sub-menu */ 
}

/* Root level menu links */
#desktop-menu > ul > li > a {
  color: #666;
  font-size: 14px;
  font-weight: 500;
  text-decoration: none;
  transition: color 0.3s ease;
  display: flex;
  align-items: center;
  padding: 10px 0; 
}

#desktop-menu li a:hover {
  color: var(--theme-mint, #00cc88); 
}

#desktop-menu li.current-menu-item > a {
  color: var(--theme-mint, #00cc88); 
}

/* ==========================================================================
   Downward Chevron Arrow for Parent Menu Items
   ========================================================================== */
#desktop-menu li.menu-item-has-children > a::after {
  content: "";
  display: inline-block;
  width: 5px;
  height: 5px;
  margin-left: 8px;
  border-right: 1.5px solid currentColor;
  /* Dynamic inherit color changes on hover */
  border-bottom: 1.5px solid currentColor;
  transform: rotate(45deg);
  /* Rotates a square border structure into a chevron */
  transition: transform 0.3s ease;
  transform-origin: center 65%; 
}

/* Optional: Flips the chevron upward smoothly when hovering over the menu option */
#desktop-menu li.menu-item-has-children:hover > a::after {
  transform: rotate(-135deg); 
}

/* ==========================================================================
   WordPress Sub-Menu Dropdown on Hover
   ========================================================================== */
#desktop-menu ul.sub-menu {
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 340px;
  background-color: #ffffff;
  list-style: none;
  padding: 10px;
  margin: 0;
  border-radius: 8px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
  border: 1px solid rgba(0, 0, 0, 0.04);
  /* Hidden state with animation properties */
  opacity: 0;
  visibility: hidden;
  transform: translateY(10px);
  transition: opacity 0.3s ease, transform 0.3s cubic-bezier(0.16, 1, 0.3, 1), visibility 0.3s;
  z-index: 1000; 
}

/* Show Sub-Menu on Hover */
#desktop-menu li:hover > ul.sub-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0); 
}

/* Sub-Menu Links Layout & Styling */
#desktop-menu ul.sub-menu li a {
  display: inline-block;
  width: 100%;
  padding: 10px 20px;
  color: #333333;
  font-size: 13.5px;
  font-weight: 400;
  transition: background-color 0.2s ease, color 0.2s ease; 
}

/* Sub-Menu Link Hover Interaction */
#desktop-menu ul.sub-menu li a:hover {
  background-color: var(--brand-green);
  /* Light mint tint matching the theme */
  color: #fff; 
}

/* Support for Deeply Nested Sub-Menus (3rd level dropdowns) */
#desktop-menu ul.sub-menu ul.sub-menu {
  top: 0;
  left: 100%;
  margin-left: 1px; 
}

/* Sideways indicator chevron for secondary submenus (If applicable) */
#desktop-menu ul.sub-menu li.menu-item-has-children > a::after {
  transform: rotate(-45deg);
  margin-left: auto;
  /* Pushes arrow to the far right inside the drop box element container */ 
}

#desktop-menu ul.sub-menu li.menu-item-has-children:hover > a::after {
  transform: rotate(-45deg); 
}

/* --- Header Actions --- */
.header-actions .phone-link {
  font-size: 15px;
  color: var(--theme-dark) !important;
  transition: .4s ease-in-out; 
}

.header-actions .phone-link:hover {
  color: var(--brand-green) !important; 
}

.slicknav_menu {
  display: none; 
}

/* --- SlickNav: Isolated & Floating --- */
@media (max-width: 991px) {
  .slicknav_menu {
    display: block;
    background: transparent !important;
    padding: 0 !important;
  }

  .navbar-brand img {
    width: 70%;
  }

  #mobile-menu-wrapper {
    position: relative;
  }

  .slicknav_btn {
    background-color: transparent !important;
    margin: 0 !important;
    border-radius: 4px;
    text-shadow:unset;
  }
  
  .slicknav_menu .slicknav_menutxt{
    color:var(--brand-green);
    text-shadow:unset;
    margin-top: 3px;
  }
  
  .slicknav_menu .slicknav_icon{
    width:1.5em!important;
  }
  
  .slicknav_menu .slicknav_icon-bar{
    width:1.5em!important;
    background-color: var(--crl-dark-green);
    height: 3px;
    margin-bottom: 4px;
    margin-left: auto;
    margin-top: 0;
    text-align: right !important;
    box-shadow:unset!important;
  }
  
  .slicknav_menu .slicknav_icon-bar:nth-child(1){
    width:1.15em!important;
  }

  /* Full height, fixed right sidebar */
 .slicknav_nav {
    position: fixed !important;
    top: 0 !important;
    right: 0 !important;
    width: 300px;
    height: 100dvh !important;
    background: #fff !important;
    z-index: 9999999;

    padding: 70px 0 20px !important;

    transform: translateX(100%);
    -webkit-transform: translateX(100%);

    transition: transform .4s ease !important;
    -webkit-transition: -webkit-transform .4s ease !important;

    overflow-y: auto;
    -webkit-overflow-scrolling: touch;

    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;

    display: block !important;
}

.slicknav_open > .slicknav_nav,
.slicknav_menu.slicknav_open > .slicknav_nav {
    transform: translateX(0);
    -webkit-transform: translateX(0);
}

/* Apply hardware acceleration only to menu panel */
.slicknav_nav {
    will-change: transform;
}

.slicknav_btn {
    position: relative;
    z-index: 100001;
}

  .slicknav_menu.slicknav_open .slicknav_nav,
  .slicknav_open .slicknav_nav {
    right: 0 !important;
  }

  .slicknav_close_btn {
    position: absolute;
    top: 15px;
    right: 20px;
    font-size: 36px;
    line-height: 1;
    color: var(--theme-dark);
    background: none;
    border: none;
    cursor: pointer;
    z-index: 100000;
    padding: 0;
  }

  .slicknav_nav a {
    color: var(--theme-dark) !important;
    padding: 14px 20px !important;
    font-weight: 500 !important;
    margin: 0 !important;
    border-bottom:1px solid var(--soft-green);
  }

  .slicknav_nav a > a {
    padding: 0 !important;
  }

  .slicknav_nav a:hover, .slicknav_nav a:hover > a {
    color: #fff !important;
    background-color: var(--brand-green) !important;
    border-radius: 0 !important;
    text-decoration:none;
    border:none;
  }

  .slicknav_nav .current-menu-item > a,
	.current-menu-parent > a{
    color: #fff !important;
    background-color: var(--brand-green);
  }
	
	.current-menu-item .slicknav_row,
	.current-menu-parent .slicknav_row  a{
		color:#fff !important;
		border-bottom:none !important;
	}

  .slicknav_arrow {
    float: right;
    display: inline-block;
    position: relative;
    width: 14px;
    visibility: hidden; 
    color: var(--theme-dark);
    transition: color 0.2s ease;
  }

  .slicknav_arrow::after {
    visibility: visible; 
    position: absolute;
    right: 0;
    top: 0;
    font-family: "Font Awesome 5 Free", "Font Awesome 6 Free", "FontAwesome";
    font-weight: 900;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    line-height: 22px;
  }
  
  .slicknav_collapsed .slicknav_arrow::after {
    content: "\f078";
  }

  .slicknav_open .slicknav_arrow::after { 
    content: "\f078";
  }

  .slicknav_nav a:hover .slicknav_arrow {
    color: #ffffff !important;
  }
	
	.current-menu-parent .slicknav_row .slicknav_arrow,
	.current-menu-item .slicknav_row .slicknav_arrow{
		color:#fff;
	}
}

@media (max-width:767px){
	 .navbar-brand img {
    width: 100%;
  }
}
/*---------------------header-end---------------------------*/
/* Hero Wrapper */
.hero-wrapper {
  position: relative;
  height: 100vh;
  width: 100%;
  overflow: hidden;
  background: #f5fdf8; }

/* Dot Grid Overlay */
.dot-grid {
  position: absolute;
  inset: 0;
  z-index: 2;
  background-image: radial-gradient(circle, rgba(0, 0, 0, 0.09) 1px, transparent 1px);
  background-size: 28px 28px;
  pointer-events: none; }

.hero-wrapper .container {
  position: relative;
  z-index: 3; }
.hero-wrapper h1 {
	line-height:1;
}
.hero-wrapper h1 span{
	font-size:clamp(28px, 3vw, 40px);
	color: var(--brand-green);
}
/* Blob base */
.hero-wrapper .blob {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  will-change: transform, border-radius;
  z-index: 1;
  opacity: 0.75; }

/* Blob 1 ÔÇö top-left ÔåÆ bottom-right ÔåÆ top-right ÔåÆ left ÔåÆ loop */
.hero-wrapper .blob-1 {
  width: 500px;
  height: 500px;
  animation: travel-1 28s ease-in-out infinite, morph-1  10s ease-in-out infinite alternate, color-1  22s ease-in-out infinite alternate; }

.hero-wrapper .blob-2 {
  width: 420px;
  height: 420px;
  animation: travel-2 34s ease-in-out infinite, morph-2  13s ease-in-out infinite alternate, color-2  18s ease-in-out infinite alternate; }

.hero-wrapper .blob-3 {
  width: 280px;
  height: 280px;
  animation: travel-3 22s ease-in-out infinite, morph-3   8s ease-in-out infinite alternate, color-3  16s ease-in-out infinite alternate; }
@media (max-width:991px){
	.hero-wrapper {
		height:90vh;
	}
	.hero-wrapper .blob-1, .hero-wrapper .blob-2 , .hero-wrapper .blob-3  {
		animation:none;
	}
	.hero-wrapper .blob-1 {
	  width: 180px; /* Scaled down slightly to fit smaller screens gracefully */
	  height: 180px;
	  background-color: var(--brand-green); 
	  top: unset;
		bottom:-10%;
	  left: -10%;
	}

	.hero-wrapper .blob-2 {
	  width: 150px;
	  height: 150px;
	  background-color: var(--brand-green);
	  bottom: unset;
		top:-10%;
	  right: -10%;
	}

	.hero-wrapper .blob-3 {
	  display: none; /* Hide the third small bubble entirely on small screens to reduce rendering clutter */
	}
}
@media (max-width:767px){
	.hero-wrapper {
		height:85vh;
	}
}
@media (max-width:375px){   
	.hero-wrapper {
		height:100vh;
	}
}

@keyframes travel-1 {
  0% {
    transform: translate(-500px, -300px) scale(1); }
  20% {
    transform: translate(20vw, 15vh) scale(1.1); }
  40% {
    transform: translate(55vw, 55vh) scale(0.95); }
  60% {
    transform: translate(60vw, -100px) scale(1.08); }
  80% {
    transform: translate(-50px, 40vh) scale(1.05); }
  100% {
    transform: translate(-500px, -300px) scale(1); } }
@keyframes travel-2 {
  0% {
    transform: translate(calc(100vw - 200px), calc(100vh - 200px)) scale(1.05); }
  25% {
    transform: translate(30vw, -80px) scale(0.92); }
  50% {
    transform: translate(-80px, -80px) scale(1.12); }
  75% {
    transform: translate(25vw, 35vh) scale(1); }
  100% {
    transform: translate(calc(100vw - 200px), calc(100vh - 200px)) scale(1.05); } }
@keyframes travel-3 {
  0% {
    transform: translate(35vw, 30vh) scale(1); }
  20% {
    transform: translate(calc(100vw - 180px), -60px) scale(1.15); }
  40% {
    transform: translate(calc(100vw - 160px), calc(100vh - 160px)) scale(0.9); }
  60% {
    transform: translate(-60px, calc(100vh - 180px)) scale(1.2); }
  80% {
    transform: translate(-60px, -60px) scale(0.95); }
  100% {
    transform: translate(35vw, 30vh) scale(1); } }
@keyframes morph-1 {
  0% {
    border-radius: 50% 50% 50% 50% / 50% 50% 50% 50%; }
  25% {
    border-radius: 62% 38% 55% 45% / 48% 60% 40% 52%; }
  50% {
    border-radius: 44% 56% 42% 58% / 56% 42% 58% 44%; }
  75% {
    border-radius: 60% 40% 65% 35% / 38% 58% 44% 62%; }
  100% {
    border-radius: 38% 62% 50% 50% / 52% 46% 54% 48%; } }
@keyframes morph-2 {
  0% {
    border-radius: 50% 50% 50% 50% / 50% 50% 50% 50%; }
  33% {
    border-radius: 42% 58% 46% 54% / 60% 40% 54% 46%; }
  66% {
    border-radius: 56% 44% 60% 40% / 40% 56% 44% 60%; }
  100% {
    border-radius: 48% 52% 54% 46% / 44% 56% 46% 54%; } }
@keyframes morph-3 {
  0% {
    border-radius: 50% 50% 50% 50% / 50% 50% 50% 50%; }
  50% {
    border-radius: 66% 34% 54% 46% / 46% 64% 36% 54%; }
  100% {
    border-radius: 40% 60% 44% 56% / 60% 40% 58% 42%; } }
@keyframes color-1 {
  0% {
    background: radial-gradient(circle at 40% 40%, rgba(0, 230, 153, 0.6) 0%, rgba(0, 200, 140, 0.2) 50%, transparent 70%); }
  50% {
    background: radial-gradient(circle at 45% 40%, rgba(0, 210, 190, 0.55) 0%, rgba(0, 240, 200, 0.18) 50%, transparent 70%); }
  100% {
    background: radial-gradient(circle at 38% 44%, rgba(60, 245, 160, 0.58) 0%, rgba(0, 220, 130, 0.2) 50%, transparent 70%); } }
@keyframes color-2 {
  0% {
    background: radial-gradient(circle at 60% 60%, rgba(0, 210, 170, 0.55) 0%, rgba(0, 180, 130, 0.18) 50%, transparent 80%); }
  50% {
    background: radial-gradient(circle at 55% 62%, rgba(0, 230, 150, 0.52) 0%, rgba(20, 200, 160, 0.16) 50%, transparent 80%); }
  100% {
    background: radial-gradient(circle at 62% 58%, rgba(40, 240, 180, 0.5) 0%, rgba(0, 210, 140, 0.2) 50%, transparent 80%); } }
@keyframes color-3 {
  0% {
    background: radial-gradient(circle, rgba(100, 245, 190, 0.5) 0%, transparent 95%); }
  50% {
    background: radial-gradient(circle, rgba(0, 230, 180, 0.45) 0%, transparent 95%); }
  100% {
    background: radial-gradient(circle, rgba(140, 250, 200, 0.48) 0%, transparent 95%); } }

.outstanding-solution .card, .outstanding-solution .card img{
	transition: .3s ease;
}
.outstanding-solution .card:hover{
	background:var(--clr-light-green)!important;
	transform:translatey(-3px);
}
.outstanding-solution .card:hover img{
	transform:scale(1.07) rotate(-8deg);
}

/* --- Services Custom Grid Card System --- */
.service-card {
  background-color: #ffffff;
  transition:ease all 0.5s, background-color 0.4s cubic-bezier(0.16, 1, 0.3, 1), transform 1s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.4s ease;
  min-height: 280px; }

/* Card Child Element Default Color Variations */
.service-card .service-icon {
  color: #1a3c34;
  transition: color 0.3s ease; }

.service-card .service-title {
  color: #1a3c34;
  transition: color 0.3s ease; }

.service-card .service-excerpt {
  color: #666666 !important;
  transition: color 0.3s ease; }

.service-card .explore-link {
  font-size: 12px;
  color: var(--theme-mint, #00cc88);
  letter-spacing: 0.5px; }

/* Decorative progress bars on base cards */
.service-card .service-progress-bar {
  height: 3px;
  width: 100%;
  background-color: #f0f0f0;
  border-radius: 2px;
  overflow: hidden; }

.service-card .service-progress-bar .progress-fill {
  height: 100%;
  width: 35%;
  /* Default visual progress width indicator */
  background-color: var(--theme-mint, #00cc88);
  transition: width 0.5s ease, background-color 0.3s ease; }

.service-tag{
	color:#fff;
	font-size:12px;
	font-weight:600;
	padding:6px 12px;
	background-color:#00c288;
	border-radius:5px;
}

/* ==========================================================================
   HOVER INTERACTIONS (Transitions beautifully to dynamic light mint-green)
   ========================================================================== */
.service-card:hover {
  background-color: #f4fdfa;
  /* Ultra-light mint tint canvas matching your image */
  transform: translateY(-4px);
  box-shadow: 0 15px 35px rgba(0, 204, 136, 0.06) !important; }

/* Color updates inside the container on focus hover */
.service-card:hover .service-icon {
  color: var(--theme-mint, #00cc88); }

/* If you want the progress line indicator to expand dynamically on hover */
.service-card:hover .service-progress-bar .progress-fill {
  width: 100%; }



/* Keep text in place during scroll */
.sticky-top-content {
  position: sticky;
  top: 120px;
  /* Adjust based on your header height */ }

.step-count {
  color: #00d084;
  /* Your green accent color */
  font-weight: 700;
  font-size: 1.2rem;
  border-bottom: 2px solid #00d084; }

/* Stacking Container */
.stacking-images-container {
  display: flex;
  flex-direction: column;
  gap: 20px;
  /* Space between cards */ }

.stack-card {
  position: sticky;
  top: 100px;
  /* Where the card stops when scrolling */
  width: 100%;
  transition: transform 0.3s ease; }

/* This adds a slight "fan" effect or overlap look */
.stack-card:nth-child(1) {
  top: 100px; }

.stack-card:nth-child(2) {
  top: 130px; }

.stack-card:nth-child(3) {
  top: 160px; }

.stack-card:nth-child(4) {
  top: 190px; }

.stack-card img {
  background: #f8f9fa;
  display: block;
  width: 100%;
  object-fit: cover;
	border-radius:20px;
  }

/* Responsive fix */
@media (max-width: 991px) {
  .sticky-top-content {
    position: relative;
    top: 0; }

  .stack-card {
    position: relative;
    top: 0 !important;
    margin-bottom: 20px; } }
.stat-card {
  transition: transform 1s ease;
  min-height: 160px;
  display: flex;
  flex-direction: column;
  justify-content: center; }

.stat-card:hover {
  transform: translateY(-10px); }

.stat-icon {
  font-size: 1.5rem;
  position: absolute;
  top: 20px;
  right: 20px;
  opacity: 0.8; }

.stat-card p {
  font-size: 0.85rem;
  text-transform: capitalize; }

.stat-card h2 {
  color: #0d2d3e;
   }

.tech-stack-section {
  min-height: 560px;
  position: relative; }

.arc-container {
  position: absolute;
  top: -10%;
  /* Center of the rotation */
  left: 50%;
  transform: translate(-50%, -50%);
  width: 800px;
  /* Diameter of the arc */
  height: 800px;
  border-radius: 50%;
  pointer-events: none; }

.orbiting-item {
  position: absolute;
  top: 0;
  left: 50%;
  width: 60px;
  height: 60px;
  margin-left: -30px;
  transform-origin: 30px 420px;
  /* Pivots around the center of the arc container */
  animation: rotate-arc 20s linear infinite; }

.icon-inner {
  width: 60px;
  height: 60px;
  background: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.05);
  /* Counter-rotate the image so it stays upright */
  animation: counter-rotate 20s linear infinite; }

.icon-inner img {
  width: 30px;
  height: 30px;
  object-fit: contain; }

/* Keyframes to move icons around the circle */
@keyframes rotate-arc {
  from {
    transform: rotate(0deg); }
  to {
    transform: rotate(-360deg); } }
/* Keyframes to keep icons upright */
@keyframes counter-rotate {
  from {
    transform: rotate(0deg); }
  to {
    transform: rotate(-360deg); } }

@media (max-width: 991px) {
	.arc-container {
    top: initial;
    transform: translateX(-50%);
	}
	.orbiting-item {
        transform-origin: 30px 280px;    
    }
}
/* Mobile Adjustments */
@media (max-width: 768px) {

  .orbiting-item {
    transform-origin: 30px 200px; }
	.testimonial-nav-container{
		left:34%;		
	}
	.testimonial-nav-container{
	 bottom: 0!important;
    left: 0!important;
}
}

.testimonial-container {
  display: flex;
  justify-content: center;
  padding: 60px 20px;
  background: #f4f4f4; }

.testimonial-card {
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  max-width: 900px;
  background: transparent;
  align-items: center;
  position: relative;
  gap: 40px; }

/* The Yellow Circle Effect */
.testimonial-image {
  position: relative; }

.yellow-circle {
  background: #FFC107;
  border-radius: 50%;
  width: 300px;
  height: 300px;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  justify-content: center; }

.yellow-circle img {
  width: 90%;
  height: auto;
  /* This creates the 'pop out' effect if the image has a transparent background */
  margin-bottom: -10px; }

/* Content Styling */
.testimonial-content {
  position: relative; }

.linkedin-icon {
  display: inline-block;
  background: #002837;
  color: white;
  padding: 2px 6px;
  border-radius: 3px;
  text-decoration: none;
  font-size: 14px;
  font-weight: 600;
  margin-bottom: 10px;
  margin-bottom: 10px; }

.testimonial-header h3 {
  margin: 0;
  font-size: 24px;
  color: #333; }

.role {
  color: #888;
  margin: 5px 0 20px 0;
  font-size: 14px; }

.quote-text {
  font-style:italic; }

.quote-icon {
  position: absolute;
  right: 0;
  top: -10%;
  font-size: 120px;
  color: var(--brand-green);
  opacity: 1; }

/* Navigation Buttons */
.nav-arrows {
  margin-top: 30px; }

.swiper-nav-prev, .swiper-nav-next {
  padding: 2px 2px 4px; }

.nav-arrows button {
  background: var(--brand-green);
  border: none;
  color: white;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  cursor: pointer;
  margin-right: 10px;
  transition: transform 0.2s; }

.nav-arrows button:hover {
  transform: scale(1.1); }

.faq-container {
  background-color: #f0faff;
  /* Light blue tint from image */ }

.faq-wrapper {
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  /* Split 40/60 */
  gap: clamp(30px, 4vw, 60px);
  align-items: start; }

/* Typography */
.faq-intro h2 {
/*   font-size: 36px; */
  line-height: 1.2;
  color: #1a2b3c;
  margin-bottom: 20px; }

.faq-intro p {
  color: #667085;
  font-size: 16px;
  line-height: 1.6; }

/* Accordion Styling */
.faq-list {
  display: flex;
  flex-direction: column;
  gap: 15px; }

.faq-item {
  background: #ffffff;
  border-radius: 4px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
  overflow: hidden;
  transition: all 0.3s ease; }

.faq-question {
  padding: 20px 25px;
  list-style: none;
  /* Remove default marker */
  cursor: pointer;
  font-weight: 600;
  color: #1a2b3c;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 15px; }

.faq-question::-webkit-details-marker {
  display: none;
  /* Safari specific fix */ }

/* Custom Chevron */
.chevron::after {
  content: '';
  width: 8px;
  height: 8px;
  border-right: 2px solid #1a2b3c;
  border-bottom: 2px solid #1a2b3c;
  transform: rotate(45deg);
  transition: 0.3s ease; }

.faq-item[open] .chevron::after {
  transform: rotate(-135deg); }

.faq-answer {
  padding: 0 25px 25px 25px;
  color: #475467;
  line-height: 1.6;
  font-size: 14px; }

/* Remove default summary marker */
.faq-question {
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 25px;
  cursor: pointer; }

.faq-question::-webkit-details-marker {
  display: none; }

/* Icon Styling & Rotation */
.icon-wrapper {
  display: flex;
  align-items: center;
  transition: transform 0.3s ease; }

/* Rotate the arrow when the <details> is open */
.faq-item[open] .icon-wrapper {
  transform: rotate(180deg); }

/* Optional: Subtle Hover Effect */
.faq-item:hover {
  background-color: #fafbfc; }

/* Responsive */
@media (max-width: 768px) {
  .faq-wrapper {
    grid-template-columns: 1fr; } }
.blog-section {
  padding: clamp(2.7rem, 4vw, 7rem) 0;
  background-color: #fff;
  text-align: center; }

.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px; }

.blog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 30px;
  text-align: left; }

.blog-card {
  background: #fff;
  border-radius: 8px;
  /* Subtle rounding like image */
  overflow: hidden;
/*   box-shadow: 0 10px 30px rgba(0, 0, 0, 0.05); */
	transition: background-color 0.4s cubic-bezier(0.16, 1, 0.3, 1), transform 1s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.4s ease;
  }

.blog-card:hover {
    background: #f4fdfa;
  /* Ultra-light mint tint canvas matching your image */
  transform: translateY(-4px);
  box-shadow: 0 15px 35px rgba(0, 204, 136, 0.09) !important; }
}

.blog-thumbnail img {
  width: 100%;
  height: 230px;
  object-fit: cover;
  display: block; }

.blog-content {
  padding: 25px; }

.blog-date {
  display: block;
  color: #26C6DA;
  /* Teal color from image */
  font-size: 13px;
  margin-bottom: 10px;
  font-weight: 500; }

.blog-card-title {
  font-size: 18px;
  line-height: 1.4;
  margin-bottom: 15px;
  font-weight: 700; }

.blog-card-title a {
  text-decoration: none;
  color: #1a1a1a; }

.blog-excerpt p {
  color: #666;
  font-size: 14px;
  line-height: 1.6;
  margin-bottom: 20px; }

.read-more-link {
  color: #26C6DA;
  text-decoration: none;
  font-size: 14px;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 5px; }

.read-more-link:hover {
  text-decoration: underline; }

/* Responsive Tablet/Mobile */
@media (max-width: 768px) {
  .blog-grid {
    grid-template-columns: 1fr; } }
/* --- Common Page Banner Stylesheet Layout --- */
.about-page-banner {
  background: radial-gradient(circle at 80% 20%, #1e5a44 0%, #0d3023 60%, #061e16 100%);
  padding: clamp(3.5rem, 7vw, 6.25rem) 0 clamp(3.5rem, 10vw, 8.75rem) 0;
  min-height: 520px; }

/* Base Top Pill Elements */
.banner-pill-badge {
  background-color: rgba(255, 255, 255, 0.07);
  border: 1px solid rgba(255, 255, 255, 0.15);
  color: #5cdba5;
  font-size: 0.725rem;
  letter-spacing: 1.5px;
  border-radius: 50px;
  backdrop-filter: blur(4px); }

/* Primary Heading Rules */
.about-page-banner .banner-title {
  color: #ffffff;
  line-height: 1.25;
  font-size: calc(1.85rem + 1.5vw);
  letter-spacing: -0.03em; }

/* Structural text column optimization widths */
.banner-subtitles-wrapper {
  max-width: 780px; }

.about-page-banner .banner-subtitle {
  font-weight: 400;
  line-height: 1.65;
  letter-spacing: -0.01em;
  font-smoothing: antialiased;
  -webkit-font-smoothing: antialiased; }

/* Layer Isolation adjustments */
.about-page-banner .z-2 {
  z-index: 2; }

/* Color Palette Variables */
:root {
  --brand-green-light: #e8f5e9;
  --quote-bg: #164832; }

/* Custom Color Helpers */
.text-success-custom {
  color: var(--brand-green); }

.green-light-bg {
  background-color: var(--brand-green-light); }

/* --- Responsive Typography using clamp() --- */
/* clamp(min, preferred, max) */
.agency-title {
  line-height: 1.15; }

.agency-description p {
  
  line-height: 1.6; }

.quote-content p {
  font-size: clamp(0.95rem, 1.3vw, 1.2rem);
  max-width: 75%; }

.small-clamp-title {
  font-size: clamp(0.85rem, 1vw, 1rem); }

.extra-small-text {
  font-size: 0.75rem; }

/* --- Quote Block Styles --- */
.quote-banner {
  background-color: var(--quote-bg);
  min-height: 140px; }

.quote-icon {
  font-size: 2.5rem;
  color: rgba(255, 255, 255, 0.2);
  line-height: 0;
  margin-top: 15px; }

.quote-img {
  height: 100%;
  width: auto;
  max-height: 150px;
  object-fit: contain;
  z-index: 0;
  pointer-events: none; }

/* --- Graphics Arrangement --- */
.main-illustration-container {
  max-width: 500px;
  display: inline-block; }

/* Fallback element placeholder styling if no image uploaded */
.fallback-graphic {
  background-color: #ccebdf;
  width: 100%;
  aspect-ratio: 4 / 3;
  border: 8px solid #e1f5fe; }

/* Floating Badge Positioning */
.floating-badge {
  z-index: 2;
  min-width: 160px;
  border: 1px solid rgba(0, 0, 0, 0.05); }

.badge-top {
  top: -20px;
  right: -25px; }

.badge-bottom {
  bottom: -20px;
  left: -25px; }

/* Responsive adjustment for badges on small screens */
@media (max-width: 576px) {
  .badge-top {
    top: -10px;
    right: -10px; }

  .badge-bottom {
    bottom: -10px;
    left: -10px; }

  .floating-badge {
    padding: 0.5rem !important;
    min-width: auto; }

  .quote-content p {
    max-width: 60%; } }
/* Section Base Colors & Padding */
.trust-section {
  background-color: #F6F9F7;
  /* Light off-white green hue tint */
  padding-top: clamp(3.5rem, 6vw, 7rem);
  padding-bottom: clamp(3.5rem, 6vw, 7rem);
}

/* Fluid Main Title */
.section-main-title {
  font-size: clamp(1.75rem, 3.5vw, 2.75rem);
  font-weight: 700;
  color: #1e2622; }

/* Highlight color match for 'Theme Nepal' if styled using standard span rules */
.section-main-title span,
.section-main-title strong {
  color: #3b7a57; }

/* Card Structures */
.feature-card, .stat-card {
  background: #ffffff;
  border: 1px solid rgba(0, 0, 0, 0.03);
  border-radius: 16px;
  padding: clamp(1.5rem, 2.5vw, 2.25rem);
  transition: transform 1s ease, box-shadow 0.3s ease; }

.feature-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.04); }

/* Card Typography & Internals */
.card-number {
  font-size: clamp(2rem, 3vw, 2.75rem);
  font-weight: 800;
  line-height: 1;
  color: rgba(82, 183, 136, 0.12);
  /* Soft subtle green/gray number fill */ }

.card-badge {
  background-color: #00c288;
  color: #fff;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 4px 10px;
  border-radius: 6px;
  font-weight: 600; }

.card-icon-wrapper {
  width: 48px;
  height: 48px;
  background-color: #d8f3dc;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px; }

.card-title {
  font-size: clamp(1.15rem, 1.5vw, 1.35rem);
  font-weight: 700;
  color: #1e2622; }

.card-desc {
  color: #626e68;
  line-height: 1.6; }

/* Stat Box Layout Elements */
.stat-card {
  background: transparent;
  /* No card border fill background matching picture layout styling */
  border: none; }

.stat-number {
  font-size: clamp(2.8rem, 5vw, 3.75rem);
  font-weight: 800;
  color: #fff;
  /* Forest Deep Green Color Accent */
  line-height: 1; }

.stat-title {
  font-size: clamp(1rem, 1.3vw, 1.15rem);
  font-weight: 700;
  color: #2d6a4f; }

.stat-desc {
  font-size: clamp(0.85rem, 1.1vw, 0.95rem);
  color: #707c75;
  max-width: 280px; }

/* Container section wrapping settings */
.digital-solutions-section {
  background-color: #ffffff;
  padding-top: clamp(3rem, 6vw, 6rem);
  padding-bottom: clamp(3rem, 6vw, 6rem); }

/* Section Header Custom Sizing styling */
.solutions-title {
  font-size: clamp(1.75rem, 3.5vw, 2.5rem);
  font-weight: 700;
  color: #1e2421;
  line-height: 1.3; }

.solutions-title span {
  color: #2d6a4f;
  /* Deep Green Highlight */ }

/* 1. Base State: ALL cards start white with a light border */
.service-strip-card {
  background-color: #ffffff;
  border: 1px solid #c9d6d0;
  /* Muted Green/Gray border accent line */
  border-radius: 12px;
  padding: clamp(1.25rem, 2vw, 1.75rem) clamp(1.5rem, 2.5vw, 2rem);
  text-decoration: none;
  transition: background-color 0.3s ease, border-color 0.3s ease, transform 1s ease, box-shadow 0.3s ease; }

/* Layout text alignments inside flex structural row */
.card-inner-flex {
  width: 100%; }

.service-number {
  font-size: clamp(1.5rem, 2.5vw, 2.25rem);
  font-weight: 800;
  color: #e0eae5;
  /* Ghost light placeholder numbers */
  line-height: 1;
  transition: color 0.3s ease; }

.service-title {
  font-size: clamp(1rem, 1.3vw, 1.15rem);
  font-weight: 700;
  color: #1d2220;
  line-height: 1.4;
  transition: color 0.3s ease; }

/* 2. Hover State: Transforms the targeted card into the dark green accent block */
.service-strip-card:hover {
  background-color: #2b5c43;
  /* Solid Dark Forest Green */
  border-color: #2b5c43;
  transform: translateY(-2px);
  box-shadow: 0 12px 24px rgba(43, 92, 67, 0.15); }

/* Inverts number color to vivid neon green on hover */
.service-strip-card:hover .service-number {
  color: #00ffaa; }

/* Inverts title color to crisp white on hover */
.service-strip-card:hover .service-title {
  color: #ffffff; }

/* Accessibility settings support if users look using key tab systems */
.service-strip-card:focus-visible {
  outline: 2px solid #2b5c43;
  outline-offset: 3px; }

/* Base Section Settings */
.mission-vision-section {
  overflow: hidden;
}

/* Individual Block Split Styles */
.mission-block {
  background-color: #fafdfb;
  /* Extremely light off-white emerald tint */
  padding-top: clamp(3rem, 6vw, 8rem);
  padding-bottom: clamp(3rem, 6vw, 8rem); }

.vision-block {
  background-color: #2b5c43;
  /* Rich corporate green block edge-to-edge */
  padding-top: clamp(3rem, 6vw, 8rem);
  padding-bottom: clamp(3rem, 6vw, 8rem); }

/* Max Content Width and Padding Adjustments */
.split-content-wrapper {
  width: 100%;
  max-width: 570px;
  /* Locks lines nicely into paragraphs */
  padding-left: clamp(1.5rem, 5vw, 4rem);
  padding-right: clamp(1.5rem, 5vw, 4rem); }

/* Fluid Typography */
.split-title {
  font-size: clamp(2rem, 3.5vw, 3rem);
  font-weight: 700;
  color: #1e2421;
  line-height: 1.2; }

/* Dynamic Text Color Highlights matched from images */
.mission-block .split-title span {
  color: #2b5c43;
  /* Dark green accent for 'Mission' */ }

.vision-block .split-title span {
  color: #00ffaa;
  /* Light glowing mint tint accent for 'Vision' */ }

.split-desc {
  line-height: 1.65;
  color: #55625a; }

/* Overrides for text color inside the dark vision block */
.vision-block .split-desc {
  color: #d1e2d9 !important;
  /* Soft high-contrast text layout balance */ }

/* Desktop Only: Align contents perfectly with a standard standard 1140px / 1320px bootstrap frame layout grid */
@media (min-width: 768px) {
  .left-padding-handler {
    padding-right: clamp(2rem, 4vw, 5rem);
    padding-left: 15px;
    /* Aligns to your leftmost container rules */ }

  .right-padding-handler {
    padding-left: clamp(2rem, 4vw, 5rem);
    padding-right: 15px;
    /* Aligns to your rightmost container rules */ } }
/* Update your custom border assignment class */
.border-custom {
  border-color: #f3f6f5 !important; }

/* Ensure the grid alignment container cleanly flows rightward on desktop viewports */
@media (min-width: 992px) {
  .avatar-pile-container {
    padding-right: 0;
    padding-left: 12px; } }
/* Core Layout Wrapper */
.team-banner-section {
  background-color: #ffffff; }

/* Rounded Main Callout Frame Box */
.team-banner-card {
  background-color: #f3f6f5;
  /* Light soft grey/green layout fill */
  border-radius: 24px;
  padding: clamp(2rem, 4vw, 4.5rem) clamp(2rem, 5vw, 5rem); }

/* Top Mini Pill Badge */
.team-mini-badge {
  background-color: #e2ece8;
  color: #2b5c43;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  padding: 6px 14px;
  border-radius: 50px; }

.badge-dot {
  width: 6px;
  height: 6px;
  background-color: #2b5c43;
  border-radius: 50%; }

/* Fluid Typography Headers */
.team-banner-title {
  font-size: clamp(1.75rem, 3.5vw, 2.75rem);
  font-weight: 700;
  color: #1a211d;
  line-height: 1.25; }

.team-banner-title span {
  color: #2b5c43;
  /* Forest Green Accent Color Highlight */ }

.team-banner-desc {
  font-size: clamp(0.9rem, 1.1vw, 1.05rem);
  line-height: 1.65;
  color: #5a6660;
  max-width: 720px; }

/* The Overlapping Avatar Pile Stack */
.avatar-pile-container {
  padding-left: 15px;
  /* Safely accounts for first child overlap offsets */ }

.avatar-circle-pill {
  width: clamp(42px, 4.5vw, 54px);
  height: clamp(42px, 4.5vw, 54px);
  border-radius: 50%;
  border: 3px solid #f3f6f5;
  /* Matches layout box color seamlessly */
  margin-left: clamp(-18px, -1.5vw, -12px);
  /* Creates the overlapping ring effect */
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: clamp(0.75rem, 1vw, 0.9rem);
  font-weight: 700;
  user-select: none;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.04); }

/* Avatar Group Shading Mix Matching Stylesheet Color Archetypes */
.avatar-circle-pill.style-dark {
  background-color: #183024;
  color: #ffffff; }

.avatar-circle-pill.style-medium {
  background-color: #2b5c43;
  color: #ffffff; }

.avatar-circle-pill.style-light {
  background-color: #5cb88f;
  color: #ffffff; }

/* Beautiful Solid CTA Interaction Buttons */
.btn-team-cta {
  background-color: #2b5c43;
  color: #ffffff;
  text-decoration: none;
  font-weight: 600;
  font-size: clamp(0.9rem, 1.1vw, 1rem);
  padding: clamp(0.75rem, 1.2vw, 1rem) clamp(1.5rem, 2vw, 2.25rem);
  border-radius: 12px;
  display: inline-block;
  transition: background-color 0.25s ease, transform 1s ease, box-shadow 0.25s ease; }

.btn-team-cta:hover {
  background-color: #1d412e;
  color: #ffffff;
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(43, 92, 67, 0.2); }

.btn-team-cta:active {
  transform: translateY(0); }

/* Update your custom border assignment class */
.border-custom {
  border-color: #f3f6f5 !important; }

/* Ensure the grid alignment container cleanly flows rightward on desktop viewports */
@media (min-width: 992px) {
  .avatar-pile-container {
    padding-right: 0;
    padding-left: 12px; } }
#single-blog-page .hero-image-section .img-container {
  max-width: 805px;
  aspect-ratio: 805 / 450;
  border-radius: 16px;
  overflow: hidden;
  margin: auto; }

#single-blog-page .hero-image-section .img-container img {
  height: 100%;
  width: 100%;
  object-fit: cover;
  object-position: center; }

#single-blog-page .details-section a {
  color: var(--brand-green); }

#single-blog-page .details-section ul {
  padding-left: 20px; }

.side-card-title {
  border-bottom: 1.6px solid #d8f3dc;
  padding-bottom: 14px; }

.green-side-card-title {
  border-bottom: 1.6px solid rgba(255, 255, 255, 0.15);
  padding-bottom: 14px; }

.related-blogs .blog-item:not(:last-of-type) {
  padding-bottom: 1rem;
  border-bottom: 0.8px solid #e5eaf0; }

.related-blogs .blog-item {
  transition: .3s ease-in-out; }

.related-blogs .blog-item:hover {
  padding-left: 5px;
  cursor: pointer; }

/* ==========================================================================
   1. Shared / Base CTA Styles (The Layout)
   ========================================================================== */
/* ==========================================================================
   GLOBAL STRUCTURE & COMMON CTA STYLES
   ========================================================================== */
.cta-section {
  position: relative;
  overflow: hidden;
}

.cta-content {
  position: relative;
  z-index: 2; /* Keeps text layered above decorative background circles */
  max-width: 900px;
  margin: 0 auto;
}

.cta-content h2 {
  font-size: clamp(1.8rem, 2.5vw, 2.75rem);
  font-weight: 700;
	  max-width: 500px;
  letter-spacing: -0.5px;
	margin-left:auto;
	margin-right:auto;
  margin-bottom: 1rem;
}

/* Base Gradient Text styling logic */
.cta-content h2 .text-gradient {
/*   background: linear-gradient(135deg, #3cdbb2, #00a877);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent; */
	color:#00c288;
}

.cta-content p {
  margin-bottom: 2rem;
  max-width: 850px;
  margin-left: auto;
  margin-right: auto;
}

/* Ambient Corner Background Graphics */
.cta-section::before,
.cta-section::after {
  content: '';
  position: absolute;
  border-radius: 50%;
  opacity: 0.15;
  pointer-events: none;
}

.cta-section::before {
  width: 300px;
  height: 300px;
  top: -100px;
  left: -100px;
  background: radial-gradient(circle, rgba(0,112,67,1) 0%, rgba(255,255,255,0) 70%);
}

.cta-section::after {
  width: 400px;
  height: 400px;
  bottom: -150px;
  right: -100px;
  background: radial-gradient(circle, rgba(0,112,67,1) 0%, rgba(255,255,255,0) 70%);
}


/* ==========================================================================
   DARK VARIANT THEMING (Image 1)
   ========================================================================== */
.cta-section.dark {
  background: linear-gradient(135deg, #163e2b, #0c2419); /* Rich Dark Green Canvas */
}

.cta-section.dark .cta-content h2 {
  color: #ffffff;
}

.cta-section.dark .cta-content p {
  color: rgba(255, 255, 255, 0.75); /* Soft legible off-white text */
}

/* White Button configuration for Dark Skin Canvas */
.cta-section.dark .btn-white {
  background-color: #ffffff;
  color: #007043;
  font-weight: 600;
  padding: 12px 30px;
  border-radius: 4px;
  border: none;
  transition: all 0.3s ease;
}

.cta-section.dark .btn-white:hover {
  background-color: #f0f7f4;
  transform: translateY(-2px);
  box-shadow: 0 4px 15px rgba(0,0,0,0.15);
}


/* ==========================================================================
   LIGHT VARIANT THEMING (Image 2)
   ========================================================================== */
.cta-section.light {
  background-color: #f4f7f5; /* Light grey/green neutral canvas */
}

.cta-section.light .cta-content h2 {
  color: #1a2521; /* Dark slate text tone */
}

.cta-section.light .cta-content p {
  color: #55635e; /* Muted reading gray tone */
}

/* Green Solid Action Button for Light Canvas */
.cta-section.light .btn-primary-green {
  background-color: #00c288;
  color: #ffffff;
  font-weight: 600;
  padding: 12px 30px;
  border-radius: 4px;
  border: none;
  transition: all 0.3s ease;
}

.cta-section.light .btn-primary-green:hover {
  background-color: var(--brnad-green);
  transform: translateY(-2px);
  box-shadow: 0 4px 15px rgba(0, 194, 136, 0.25);
}


/* Base navigation row container line */
.custom-minimal-tabs {
  border-bottom: 1px solid #f0f0f0; /* Thin, light horizontal bar spanning across the view */
  padding-bottom: 0;
  gap: 1.5rem; /* Horizontal spacing between individual menu text items */
}

/* Individual tab button default/inactive layout */
.custom-minimal-tabs .nav-link {
  background: transparent !important;
  border: none !important;
  color: #7a828a !important; /* Muted slate grey text for inactive categories */
  font-size: 0.95rem;
  font-weight: 500;
  padding: 0.75rem 0.5rem;
  position: relative;
  border-radius: 0 !important;
  transition: color 0.25s ease;
}

/* Hover state interaction */
.custom-minimal-tabs .nav-link:hover {
  color: #007043 !important; /* Soft preview shift into brand green */
}

/* Active Selected Tab State */
.custom-minimal-tabs .nav-link.active {
  color: #007043 !important; /* Bold, solid brand green text */
  font-weight: 600;
}

/* Underline Indicator Bar for the Active Tab */
.custom-minimal-tabs .nav-link.active::after {
  content: '';
  position: absolute;
  bottom: -1px; /* Aligns exactly flush on top of the container's layout line */
  left: 0;
  width: 100%;
  height: 2px; /* Thick underline styling indicator */
  background-color: #007043; /* Brand green indicator color */
}

/* Layout alignment correction for cards */
.client-logo-card a {
  display: flex;
  flex-direction: column;
  height: 100%;
  align-items: center;
  justify-content: center;
}

/* Ensure link tags behave inside flex grid cards */
/* .client-logo-card a {
  display: flex;
  flex-direction: column;
  height: 100%;
  align-items: center;
  justify-content: center;
} */


.client-grid-section {
  background-color: #fff; }
  .client-grid-section .client-logo-card {
    background-color: var(--soft-green);
    aspect-ratio: 1 / 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: clamp(20px, 2vw, 30px);
    position: relative;
    border-radius: 4px;
    transition: transform 0.3s ease, box-shadow 0.3s ease; }
    .client-grid-section .client-logo-card:hover .visit-link {
      color: #fff !important; }
      .client-grid-section .client-logo-card:hover .visit-link:after {
        height: 100%; }
    .client-grid-section .client-logo-card .logo-wrapper {
      max-width: 100%;
      height: 60px;
      display: flex;
      align-items: center;
      justify-content: center; }
      .client-grid-section .client-logo-card .logo-wrapper img {
        max-height: 100%;
        width: auto;
        transition: all 0.3s ease; }
    .client-grid-section .client-logo-card .visit-link {
      position: absolute;
      bottom: 0;
      right: 0;
      font-size: clamp(13px, 1.5vw, 16px);
      font-weight: 700;
      padding: 8px clamp(13px, 2vw, 33px);
      color: #2d6a4f !important;
      text-decoration: none;
      letter-spacing: 0.5px;
      background: #fff;
      overflow: hidden;
      z-index: 1;
      transition: color 0.3s ease; }
      .client-grid-section .client-logo-card .visit-link svg {
        transform: rotate(-45deg); }
      .client-grid-section .client-logo-card .visit-link::after {
        content: '';
        position: absolute;
        left: 0;
        bottom: 0;
        width: 100%;
        height: 0;
        background-color: var(--brand-green);
        transition: height 0.4s ease;
        z-index: -1; }

.desc-mb-0 p:last-of-type {
  margin-bottom: 0; }

:root {
  --brand-mint: #00d999;
  --brand-dark-green: #2d5a4c;
  --card-bg: #f8fbfb; }

.section-title span {
  color: var(--brand-green); }

.section-title-dark span {
  color: var(--crl-dark-green); }

/* Info Cards */
.standard-card {
  background: var(--card-bg);
  border: 1px solid #f0f0f0;
  color: #333;
transition:ease all 0.4s;
}

.standard-card:hover {
  background: var(--brand-dark-green);
  color: #fff; }

.standard-card .icon-wrapper {
  height: 60px;
  width: 60px;
  background: #e6fbf5; }

.standard-card .icon-wrapper svg path {
  fill: #006c48; }

.standard-card:hover .icon-wrapper svg path {
  fill: #00db95; }

.standard-card:hover .icon-wrapper {
  background: rgba(255, 255, 255, 0.15); }

/* --- Open State (Green) --- */
.text-open {
  color: #00d999 !important;
  /* Your mint green */ }

/* --- CTA Section Context --- */
.contact-banner-section {
  /* Dynamic deep corporate green background wash mapping to image aesthetics */
  background: radial-gradient(circle at 85% 20%, #1e523c 0%, #173b2c 100%);
  min-height: clamp(340px, calc(25vw + 100px), 520px); }

/* --- Optimized Responsive Typography --- */
.contact-banner-section .main-heading {
  font-family: 'Manrope', sans-serif;
  font-size: clamp(1.85rem, 4.5vw, 3.2rem);
  line-height: 1.25;
  letter-spacing: -0.03em; }

.contact-banner-section .banner-paragraph {
  font-size: clamp(0.85rem, 1.2vw, 1.05rem);
  max-width: 580px;
  line-height: 1.6; }

/* --- Transparent Frosted Counter Cards --- */
.contact-banner-section .max-w-card {
  max-width: 200px;
  /* Limits size to preserve horizontal layout proportionality */ }

.contact-banner-section .counter-glass-card {
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: 12px;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  transition: transform 1s cubic-bezier(0.16, 1, 0.3, 1), background 0.3s ease; }

.contact-banner-section .counter-glass-card:hover {
  transform: translateY(-4px);
  background: rgba(255, 255, 255, 0.12); }

.contact-banner-section .counter-metric {
  font-size: clamp(1.35rem, 2.5vw, 1.85rem);
  line-height: 1.1;
  letter-spacing: -0.02em; }

.contact-banner-section .counter-label {
  font-size: clamp(0.725rem, 1vw, 0.85rem);
  white-space: nowrap; }

/* --- Responsive Decorative Background Circles --- */
.contact-banner-section .banner-circle {
  position: absolute;
  background: rgba(255, 255, 255, 0.035);
  border-radius: 50%;
  pointer-events: none;
  z-index: 1; }

.contact-banner-section .banner-circle.circle-left {
  width: clamp(180px, 30vw, 420px);
  height: clamp(180px, 30vw, 420px);
  bottom: -15%;
  left: -10%; }

.contact-banner-section .banner-circle.circle-right {
  width: clamp(250px, 45vw, 600px);
  height: clamp(250px, 45vw, 600px);
  top: -20%;
  right: -12%; }

/* Target small mobile screens to keep structural spacing tight */
@media (max-width: 575.98px) {
  .contact-banner-section .max-w-card {
    max-width: 50%; } }
.info-card .info-details a {
  color: var(--text-dark); } 

.dot-open {
  background-color: #00d999;
  box-shadow: 0 0 0 0 rgba(0, 217, 153, 0.7);
  animation: pulse-mint 2s infinite; }

/* --- Closed State (Red) --- */
.text-closed {
  color: #ff4d4d !important;
  /* Bright red */ }

.dot-closed {
  background-color: #ff4d4d;
  /* No pulse for closed state to keep it "static" */ }

/* --- Base Dot Style --- */
.status-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  display: inline-block; }

@keyframes pulse-mint {
  0% {
    box-shadow: 0 0 0 0 rgba(0, 217, 153, 0.7); }
  70% {
    box-shadow: 0 0 0 6px rgba(0, 217, 153, 0); }
  100% {
    box-shadow: 0 0 0 0 rgba(0, 217, 153, 0); } }
/* Fix SVG colors inside highlighted card */
.active-card svg {
  fill: #fff !important; }

.standard-card svg {
  fill: #00d999 !important; }

/* Form Styling */
.form-container {
  border-radius: 20px !important; }

.form-control, .form-select {
  background-color: #f9f9f9 !important;
  border: 1px solid #eee !important;
  padding: 14px 16px !important;
  font-size: 1rem;
  border-radius: 10px; }

.form-control:focus {
  box-shadow: none;
  border-color: var(--brand-green) !important;
  background-color: #fff !important; }

.btn-submit {
  font-weight: 600;
  padding: 16px !important;
  box-shadow: 0 4px 15px rgba(0, 217, 153, 0.3); }

/* Social Buttons */
.social-item {
  width: 38px;
  height: 38px;
  background: #fff;
  border: 1px solid #eee;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  color: #444;
  text-decoration: none;
  transition: 0.3s; }

.social-item:hover {
  background: var(--brand-mint);
  color: white;
  border-color: var(--brand-mint); }

.x-small {
  font-size: 11px; }

/* Responsive adjustments */
@media (max-width: 991px) {
  .form-container {
    padding: 30px !important; } }
.features-wrapper {
  /* Adjust background color to match your specific image tint */
  background-color: #f4fbf8; }

.icon-box {
  background: #ffffff;
  width: 60px;
  height: 60px;
  border-radius: 12px;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.03);
  /* Subtle depth */ }

.icon-box img {
  width: 32px;
  /* Control icon size within the box */
  height: auto; }

.feature-card h3 {
  margin-top: 15px;
  letter-spacing: -0.01em; }

.feature-card p {
  line-height: 1.5;
  color: #6c757d; }

/* Ensure border dividers between columns if needed */
/* #blog-page .common-page-banner .breadcrumbs ul{
	justify-content:flex-start!important;
} */
/* #blog-page .common-page-banner .banner-content {
  margin: initial;
  text-align: left; } */

.common-page-banner {
  position: relative;
  /* Set a minimum height instead of relying on top/bottom padding */
  min-height: clamp(340px, calc(25vw + 160px), 520px);
  /* Flexbox Centering */
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(100.61deg, #1A3C34 0%, #2D6A4F 60%, #3A8A6A 100%);
  color: #fff;
  overflow: hidden;
  text-align: center;
  /* --- Wave Logic --- */
  /* --- Decorative Circle Overlays --- */ }
  .common-page-banner .banner-content {
    max-width: 700px;
    margin: auto;
    position: relative;
    color: #fff;
    z-index: 5;
    padding: 0 20px;
    /* Side padding for mobile safety */
    /* We add a slight margin-top to visually balance the space
       taken up by the wave at the bottom */
    margin-bottom: 40px; }
  .common-page-banner .banner-title {
    font-size: clamp(32px, 5vw, 56px);
    font-weight: 700;
    color: #fff;
    margin-bottom: 12px; }
    .common-page-banner .banner-title span {
      color: #00c288 ; }
  .common-page-banner .banner-subtitle {
    font-size: 16px;
    opacity: 0.85;
    max-width: 600px;
    margin: 0 auto; }
  .common-page-banner .banner-wave-divider {
    position: absolute;
    bottom: -1px;
    left: 0;
    width: 100%;
    z-index: 10; }
    .common-page-banner .banner-wave-divider svg {
      display: block;
      width: 100%;
      height: clamp(20px, 4vw, 60px); }
    .common-page-banner .banner-wave-divider path {
      fill: #FFFFFF; }
  .common-page-banner .banner-circle {
    position: absolute;
    background: rgba(255, 255, 255, 0.03);
    border-radius: 50%;
    border-radius: 50%;
    z-index: 1;
    pointer-events: none; }
    .common-page-banner .banner-circle.circle-left {
      /* Minimum: 150px, Fluid Scale Engine: 20vw, Maximum: 300px */
      width: clamp(200px, 20vw, 300px);
      height: clamp(200px, 20vw, 300px);
      bottom: -50px;
      left: -80px;
      animation: floatSlowLeft 10s ease-in-out infinite alternate; }
    .common-page-banner .banner-circle.circle-right {
      /* Minimum: 220px, Fluid Scale Engine: 30vw, Maximum: 450px */
      width: clamp(320px, 30vw, 450px);
      height: clamp(320px, 30vw, 450px);
      top: -150px;
      right: -100px;
      animation: floatSlowRight 10s ease-in-out infinite alternate; }

@keyframes floatSlowLeft {
  0% {
    transform: translate(0, 0) scale(1); }
  50% {
    transform: translate(4%, -6%) scale(1.05); }
  100% {
    transform: translate(-2%, 4%) scale(0.98); } }
@keyframes floatSlowRight {
  0% {
    transform: translate(0, 0) scale(1); }
  50% {
    transform: translate(-3%, 5%) scale(0.95); }
  100% {
    transform: translate(3%, -3%) scale(1.03); } }
/* Honor operating system accessibility settings to freeze motion if visitors prefer reduced movement */
@media (prefers-reduced-motion: reduce) {
  .common-page-banner .banner-circle {
    animation: none !important; } }
/* Scoped Layout Styles */
.services-hero-section {
  background: linear-gradient(107.87deg, #1A3C34 0%, #2D6A4F 65%, #3A8A6A 100%);
  min-height: 600px; }

.glass-panel {
  background: rgba(255, 255, 255, 0.04);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  transition: transform 0.25s ease, background 0.25s ease; }

.glass-panel:hover {
  transform: translateY(-2px);
  background: rgba(255, 255, 255, 0.06); }

.max-w-lg {
  max-width: 500px; }

/* Ensure clean flex alignment scaling down on small break viewports */
@media (max-width: 575.98px) {
  .services-hero-section h1 {
    font-size: 2.2rem !important; }

  .glass-panel {
    padding: 1.25rem !important; } }
/* Custom adjustments targeting the UI design specifications */
.services-section h2 {
  letter-spacing: -0.03em; }

.services-section .text-success {
  color: #1e7e34 !important;
  /* Adjust tone to match the exact dark green brand color */ }

/* Customizing Card aesthetics */
.custom-service-card {
  border-color: #e9ecef !important;
  transition: transform 0.3s ease, box-shadow 0.3s ease; }

.custom-service-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.075) !important; }

/* Tag Styles */
.custom-service-tag {
  font-size: 0.75rem !important;
  color: #495057 !important;
  border-color: #dee2e6 !important;
  letter-spacing: -0.01em; }

/* Light Background tweaks for your Green Icons container */
.custom-service-card .icon-wrapper {
  background-color: #f4faf6 !important;
  /* Soft green-tinted background */ }

.avatar-group img:first-child {
  margin-left: 0 !important; }

.backdrop-blur {
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px); }

.team-section .member-card {
  border-radius: 15px;
  overflow: hidden;
  position: relative; }
  .team-section .member-card .member-img-wrapper {
    position: relative;
    aspect-ratio: 4 / 5; }
    .team-section .member-card .member-img-wrapper img {
      width: 100%;
      height: 100%;
      object-fit: cover; }
    .team-section .member-card .member-img-wrapper::after {
      content: '';
      position: absolute;
      inset: 0;
      background: linear-gradient(to top, rgba(26, 60, 52, 0.9) 0%, transparent 60%); }
  .team-section .member-card .member-info {
    position: absolute;
    bottom: 15px;
    left: 15px;
    z-index: 2;
    color: #fff; }
    .team-section .member-card .member-info h5 {
      font-family: var(--font-manrope);
      font-size: 16px;
      font-weight: 700;
      margin-bottom: 4px; }
    .team-section .member-card .member-info p {
      color: #b7e4c7;
      font-size: 12px;
      opacity: 0.8;
      margin: 0; }

/* Core Layout Cleanups */
.blog-archive-wrapper article {
  transition: transform 1s ease, box-shadow 0.25s ease; }

.featured-blog-card .badge {
  background-color: #49815d; }

.blog-archive-wrapper article:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 25px rgba(0, 77, 48, 0.05) !important; }

/* Custom WordPress Generated Pagination Overrides Styling */
.dynamic-pagination ul {
  display: flex;
  padding-left: 0;
  list-style: none;
  gap: 8px; }

.dynamic-pagination ul li a,
.dynamic-pagination ul li span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 8px;
  text-decoration: none;
  font-weight: 500;
  font-size: 0.85rem;
  color: #4a5568;
  background-color: #ffffff;
  border: 1px solid #e2e8f0;
  transition: all 0.2s ease; }

.dynamic-pagination ul li span.current {
  color: #ffffff !important;
  background-color: #00cc88 !important;
  border-color: #00cc88 !important; }

.dynamic-pagination ul li a:hover {
  background-color: #eafaf4;
  color: #00cc88;
  border-color: #00cc88; }

.service-banner {
  /* Rich organic green radial gradient setup */
  background-color: #0b261a;
  background-size: cover;
  background-position: center;
  padding: clamp(40px, 5vw, 100px) 0;
  min-height: 520px; }

/* Custom Typography & Layout tweaks */
.service-banner .small-title {
  font-size: 0.875rem;
  letter-spacing: 0.5px;
  color: #4ade80 !important;
  /* Targets the active bright green breadcrumb flavor */ }

.service-banner .banner-heading {
  letter-spacing: -1px;
  line-height: 1.15;
  color: #ffffff; }

.service-banner .banner-desc {
  font-size: 1.05rem;
  line-height: 1.6;
  max-width: 540px;
  color: rgba(255, 255, 255, 0.8) !important; }

/* Button overrides to ensure crisp styling */


/* Image entry animation/effects */
.banner-image-wrapper {
  animation: fadeInRight 0.8s ease-out forwards; }

.dynamic-banner-img {
  max-height: 420px;
  width: auto;
  object-fit: contain;
  filter: drop-shadow(0 20px 40px rgba(0, 0, 0, 0.3)); }

@keyframes fadeInRight {
  from {
    opacity: 0;
    transform: translate3d(30px, 0, 0); }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0); } }
/* Responsive adjustments */
@media (max-width: 991.98px) {
  .service-banner {
    text-align: center; }

  .service-banner .banner-desc {
    margin-left: auto;
    margin-right: auto; }

  .service-banner .banner-actions {
    justify-content: center; } }
/* Custom styling for the dynamic stats banner */
.dynamic-stats-section {
  background-color: var(--crl-dark-green);
  /* Matches the custom forest green shade */
  color: #ffffff; }

.dynamic-stats-section .stat-number {
  letter-spacing: -0.5px; }

.dynamic-stats-section .stat-label {
  font-size: 0.75rem;
  letter-spacing: 0.5px; }

/* Vertical dividers for desktop viewports */
@media (min-width: 768px) {
  .dynamic-stats-section .stat-item {
    position: relative; }

  .dynamic-stats-section .stat-item:not(:last-child)::after {
    content: "";
    position: absolute;
    right: 0;
    top: 20%;
    height: 60%;
    width: 1px;
    background-color: rgba(255, 255, 255, 0.25);
    /* Subtle white divider line */ } }
/* Custom properties to match the layout's aesthetic identity */
:root {
  --brand-emerald: #265a43;
  --brand-light-green: #e6f4ee; }

.text-success-custom {
  color: var(--brand-emerald); }

.seo-growth-section h2 {
  letter-spacing: -0.5px; }

.seo-growth-section .description-text p {
  font-size: 0.95rem;
  line-height: 1.65; }

/* Custom Circle Checkmarks styling */
.bullet-icon-wrapper {
  width: 22px;
  height: 22px;
  background-color: #49a87d;
  /* Slightly lighter accent green matching checks */
  color: #ffffff;
  border-radius: 50%;
  margin-top: 2px; }

.bullet-text {
  font-size: 0.95rem;
  line-height: 1.5; }

/* Fluid responsive adjustments for right-side mockup block */
.mockup-img-wrapper {
  max-width: 100%; }

.custom-mockup-shadow {
  /* Optional edge smoothing default if the asset has clean transparent margins */
  transition: transform 0.3s ease; }

.custom-mockup-shadow:hover {
  transform: translateY(-4px); }

/* --- Custom Variables & Theme Palettes --- */
:root {
  --bg-strategy-light: #f4fcf8;
  /* Soft mint-tinted clean background */
  --color-accent-green: #2a7e5c;
  /* Muted forest/emerald accent */
  --color-text-dark: #212529;
  /* Deep dark neutral body */
  --color-text-muted: #5f6661;
  /* Desaturated text layout */
  --timeline-line-color: #cbdcd4;
  /* Soft timeline track */
  /* Pixel Perfect Clamp Rules (Fluid Scale between 320px viewport -> 1440px viewport) */
  --fs-h3: clamp(1.15rem, 1.05rem + 0.4vw, 1.3rem);
  --fs-body: clamp(0.92rem, 0.88rem + 0.18vw, 1rem);
  --fs-badge: clamp(0.7rem, 0.65rem + 0.15vw, 0.78rem);
  --pad-section: clamp(2.7rem, 4vw, 5rem);
  --space-head: clamp(1.8rem, 3vw, 3rem); }

/* --- Structural Rules --- */
.strategy-timeline-section {
  background-color: var(--bg-strategy-light);
  padding: var(--pad-section) 0;
  color: var(--color-text-dark); }

.strategy-timeline-section .section-title {
  font-weight: 700;
  letter-spacing: -0.03em;
  color: var(--color-text-dark); }

/* Style injected via ACF <span> tags dynamically */
.strategy-timeline-section .section-title .text-accent {
  color: var(--color-accent-green); }

.strategy-timeline-section .section-intro {
  font-size: var(--fs-body);
  line-height: 1.6;
  color: var(--color-text-muted) !important; }

.strategy-timeline-section .mb-section-head {
  margin-bottom: var(--space-head); }

/* --- Modern Timeline Track Components --- */
.timeline-wrapper {
  position: relative;
  padding-left: 28px;
  /* Strict left layout spacing for the line alignment */ }

/* Continuous background timeline track */
.timeline-wrapper::before {
  content: '';
  position: absolute;
  left: 6px;
  top: 8px;
  bottom: 8px;
  width: 2px;
  background-color: var(--timeline-line-color);
  z-index: 1; }

.timeline-node {
  position: relative;
  margin-bottom: clamp(1.75rem, calc(1.25rem + 2vw), 2.75rem); }

.timeline-node:last-child {
  margin-bottom: 0; }

/* Node Anchor Points */
.timeline-marker {
  position: absolute;
  left: -28px;
  /* Pull backwards into track positioning */
  top: 0;
  display: block;
  z-index: 2;
  height: 14px; }

/* Compact visual marker circle over line */
.marker-dot {
  position: absolute;
  left: 2px;
  top: 3px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background-color: var(--color-accent-green);
  box-shadow: 0 0 0 4px var(--bg-strategy-light); }

/* Timeline Small Period Badge Placement */
.marker-badge {
  position: absolute;
  left: 24px;
  top: -1px;
  white-space: nowrap;
  display: inline-block;
  font-size: var(--fs-badge);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-accent-green); }

/* Right content box wrapping header and inner paragraphs */
.timeline-content {
  padding-top: 22px;
  /* Offsets height down comfortably under badge layout */ }

.timeline-content .node-title {
  font-size: var(--fs-h3);
  font-weight: 700;
  letter-spacing: -0.01em;
  margin-bottom: 0.5rem;
  color: var(--color-text-dark); }

.timeline-content .node-desc {
  font-size: var(--fs-body);
  line-height: 1.65;
  color: var(--color-text-muted) !important;
  margin: 0; }

/* --- Global Token Variables --- */
:root {
  --bg-theme-pure: #ffffff;
  --bg-mint-panel: #d5f2e3;
  /* Clean light green container background fill */
  --color-forest: #145338;
  /* Deep visual hierarchy headings */
  --color-accent-teal: #00b074;
  /* Vibrant brand progress meter fill */
  --color-body-dark: #2b302c;
  --color-muted-grey: #616b64;
  --color-border-line: #e3ebd7;
  /* Pixel Perfect Clamp Rules */
  --fs-tab-link: 0.9rem;
  --fs-desc-text:0.95rem;
  --fs-card-h4: clamp(0.9rem, 0.85rem + 0.15vw, 0.98rem);
  --pad-container: clamp(2.7rem, 4vw, 5rem);
  --space-header-gap: clamp(1.5rem, 3vw, 2.5rem);
  --space-nav-gap: clamp(2rem, 1.5rem + 3vw, 3.5rem); }

.services-tabs-section {
  background-color: var(--bg-theme-pure);
  padding: var(--pad-container) 0;
  color: var(--color-body-dark); }

.services-tabs-section .section-title {
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--color-forest); }

.services-tabs-section .section-title .text-accent {
  color: var(--color-accent-teal); }

.services-tabs-section .section-intro {
  font-size: var(--fs-desc-text);
  color: var(--color-muted-grey) !important; }

.services-tabs-section .mb-tabs-header {
  margin-bottom: var(--space-header-gap); }

.services-tabs-section .mb-tabs-nav-space {
  margin-bottom: var(--space-nav-gap); }

.other-services-section .card-image-wrap {
  width: 100%;
  aspect-ratio: 370 / 210;
  height: 210px;
  overflow: hidden; }

.other-services-section .card-image-wrap img {
  object-fit: cover;
  object-position: center;
  height: 100%;
  width: 100%; }

/* --- Bootstrap Tab Link Customizations --- */
.custom-bootstrap-tabs {
  border-bottom: 1px solid var(--color-border-line) !important;
  gap: 10px; }

.custom-bootstrap-tabs .nav-item {
  margin-bottom: -1px; }

.custom-bootstrap-tabs .nav-link {
  border: none !important;
  background: transparent !important;
  font-size: var(--fs-tab-link);
  font-weight: 600;
  color: var(--color-muted-grey) !important;
  padding: 12px 16px !important;
  position: relative;
  transition: color 0.25s ease; }

.custom-bootstrap-tabs .nav-link:hover {
  color: var(--color-forest) !important; }

.custom-bootstrap-tabs .nav-link.active {
  color: var(--color-forest) !important; }

/* Bottom tracking line for the active state item */
.custom-bootstrap-tabs .nav-link.active::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 16px;
  right: 16px;
  height: 3px;
  background-color: var(--color-accent-teal);
  border-radius: 2px; }

/* --- Content Content Elements --- */
.tab-main-desc {
	font-size: var(--fs-desc-text);}

/* Custom green plus list marker components */
.tab-bullets-list {
  display: flex;
  flex-column: normal;
  flex-direction: column;
  gap: 12px; }

.bullet-item {
  gap: 12px; }
/* 1. Remove the default browser bullets and reset padding */
.tab-bullets-list {
    list-style: none;
    padding-left: 0;
}

/* 2. Create space on the left of the item for your custom bullet */
.tab-bullets-list li {
    position: relative;
	padding-left:1.25rem;
    margin-bottom: 0.5rem; /* Optional: adds nice breathing room between rows */
}

/* 3. Build and position the custom bullet string element */
.tab-bullets-list li::before {
    content: "•"; /* Injects the bullet character */
    color: var(--brand-green);
    font-size: 1.5rem;
    line-height: 1;
    
    /* Absolute positioning engine for precision control */
    position: absolute;
    left: 0;
    
    /* --- VERTICAL POSITIONING ENGINE --- */
    top: 0px; /* Increase to push it down (e.g., 4px, 5px), decrease to pull it up */
}


.bullet-text {
  font-size: var(--fs-desc-text);
  line-height: 1.5;
  color: var(--color-body-dark); }

/* --- Right Side: Adaptive Accent Cards Matrix --- */
.mint-accent-panel {
  background-color: var(--bg-mint-panel);
  border-radius: 12px;
  padding: clamp(1.25rem, calc(1rem + 1.5vw), 2.25rem); }

.metric-card-node {
  background-color: var(--bg-theme-pure);
  border-radius: 8px;
  padding: 16px 20px;
  box-shadow: 0 4px 12px rgba(20, 83, 56, 0.03); }

.metric-icon-box {
  width: 36px;
  height: 36px;
  background-color: #f0f7f3;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-muted-grey); }

.metric-node-title {
  font-size: var(--fs-card-h4);
  font-weight: 700;
  color: var(--color-forest); }

.metric-node-subtitle {
  font-size: 0.78rem;
  color: var(--color-muted-grey) !important;
  margin-top: 1px; }

/* --- Progress Tracking Bar Indicators --- */
.horizontal-progress-bar-track {
  width: clamp(60px, calc(40px + 4vw), 100px);
  height: 5px;
  background-color: #e9ecef;
  border-radius: 10px;
  overflow: hidden; }

.horizontal-progress-fill {
  height: 100%;
  background-color: var(--color-accent-teal);
  border-radius: 10px; }

.progress-percentage-label {
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--color-forest);
  min-width: 36px;
  text-align: right; }

/* Responsive Overrides for Compact Viewports */
@media (max-width: 767.98px) {
  .custom-bootstrap-tabs {
    overflow-x: auto;
    white-space: nowrap;
    flex-wrap: nowrap;
    padding-bottom: 4px; }

  .custom-bootstrap-tabs .nav-link::after {
    left: 8px;
    right: 8px; }

  .card-right-progress {
    margin-left: auto; } }
/* --- Tokenized Palette Architecture --- */
:root {
  --bg-forest-base: #013322;
  /* Deep rich layout background */
  --color-text-pure: #ffffff;
  --color-text-alpha: #94bcab;
  /* Seafoam secondary desaturated text */
  --color-brand-cyan: #00d285;
  /* Vibrant accent highlights */
  /* Fluid Clamp Values (320px viewport -> 1440px viewport scale) */
  --fs-section-copy: clamp(0.95rem, 0.9rem + 0.15vw, 1.05rem);
  --fs-feat-title: clamp(1.05rem, 1rem + 0.2vw, 1.2rem);
  --pad-section-y: clamp(2.7rem, 4vw, 5rem); }

.features-stats-section {
  background-color: var(--bg-forest-base);
  padding: var(--pad-section-y) 0;
  color: var(--color-text-pure); }

.features-stats-section .section-main-heading {
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: -0.03em;
  color: var(--color-text-pure); }

.features-stats-section .section-main-heading .text-accent {
  color: var(--color-brand-cyan); }

.features-stats-section .section-narrative-text {
  font-size: var(--fs-section-copy);
  line-height: 1.65;
  color: var(--color-text-alpha); }

/* --- Left Column: Feature Items --- */
.feature-icon-badge {
  width: 42px;
  height: 42px;
  background-color: #05412d;
  border: 1px solid rgba(250, 250, 250, 0.08);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-brand-cyan); }

.feature-icon-badge svg {
  width: 20px;
  height: 20px; }

.feature-node-title {
  font-size: var(--fs-feat-title);
	font-family: var(--font-manrope);
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--color-text-pure); }

.feature-node-desc {
  line-height: 1.55;
  color: var(--color-text-alpha); }

/* --- Right Column: Image Presentation Layout --- */
.stats-image-wrapper {
  position: relative;
  width: 100%; }

.stats-mockup-graphic {
  max-width: 100%;
  height: auto;
  border-radius: 16px;
  /* Smooth corners to fit the mockup design */
  box-shadow: 0 15px 35px rgba(0, 0, 0, 0.2);
  transition: transform 0.3s ease; }

/* Micro interaction overlay effect for high fidelity desktop users */
.stats-mockup-graphic:hover {
  transform: translateY(-4px); }

/* ÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉ
   LEFT PANEL
ÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉ */
.bc-left {
  background: linear-gradient(160deg, #1c5c36 0%, #0f2a1a 100%);
  padding: 52px 40px;
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden; }

.bc-left::after {
  content: '';
  position: absolute;
  bottom: -80px;
  right: -80px;
  width: 260px;
  height: 260px;
  border-radius: 50%;
  background: rgba(52, 168, 100, 0.1);
  pointer-events: none; }

/* Brand */
.bc-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 48px; }

.bc-brand-icon {
  width: 36px;
  height: 36px;
  background: #2a9d54;
  border-radius: 9px;
  display: flex;
  align-items: center;
  justify-content: center; }

.bc-brand-icon svg {
  width: 18px;
  height: 18px;
  fill: #fff; }

.bc-brand-name {
  font-size: 16px;
  font-weight: 700;
  color: #fff; }

/* Heading */
.bc-heading {
  font-family: var(--font-manrope);
  font-size: 30px;
  font-weight: 800;
  color: #fff;
  line-height: 1.22;
  margin: 0 0 14px; }

.bc-heading em {
  color: #5dd68a;
  font-style: normal; }

/* Tagline */
.bc-tagline {
  color: rgba(255, 255, 255, 0.55);
  font-size: 13.5px;
  line-height: 1.75;
  margin: 0 0 40px; }

/* Info list */
.bc-info-list {
  list-style: none;
  margin: 0 0 40px;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 18px; }

.bc-info-row {
  display: flex;
  align-items: flex-start;
  gap: 14px; }

.bc-info-dot {
  width: 34px;
  height: 34px;
  flex-shrink: 0;
  border-radius: 9px;
  background: rgba(255, 255, 255, 0.07);
  border: 1px solid rgba(255, 255, 255, 0.1);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #5dd68a; }

.bc-info-dot svg {
  width: 15px;
  height: 15px; }

.bc-info-text {
  display: flex;
  flex-direction: column;
  gap: 2px; }

.bc-info-label {
  font-size: 10.5px;
  color: rgba(255, 255, 255, 0.35);
  letter-spacing: .8px;
  text-transform: uppercase; }

.bc-info-value {
  font-size: 13px;
  color: rgba(255, 255, 255, 0.82);
  font-weight: 500; }

/* Badges */
.bc-badge-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: auto;
  padding-top: 12px; }

.bc-badge {
  background: rgba(255, 255, 255, 0.07);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 20px;
  padding: 5px 12px;
  font-size: 11px;
  color: rgba(255, 255, 255, 0.6); }

/* ÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉ
   RIGHT PANEL
ÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉ */
.bc-right {
  background: #fff;
  padding: 52px 48px; }

.bc-right-header {
  margin-bottom: 30px; }

.bc-right-tag {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 1.8px;
  text-transform: uppercase;
  color: #2a9d54; }

.bc-right-title {
  font-family: var(--font-manrope);
  font-size: 24px;
  font-weight: 700;
  color: #111;
  margin: 5px 0 0; }

/* ÔöÇÔöÇ CF7 form overrides ÔöÇÔöÇ */
.bc-form-wrap .wpcf7 {
  margin: 0; }

.bc-form-wrap .wpcf7-form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px; }

/* Full-width fields */
.bc-form-wrap .wpcf7-form .full,
.bc-form-wrap .wpcf7-form p:has(textarea),
.bc-form-wrap .wpcf7-form p:last-of-type,
.bc-form-wrap .wpcf7-form .wpcf7-submit-wrap {
  grid-column: 1 / -1; }

.bc-form-wrap .wpcf7-form p {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 6px; }

/* Labels */
.bc-form-wrap .wpcf7-form label,
.bc-form-wrap label {
  font-size: 14px; 
  font-weight: 600;
  color: #555;
  letter-spacing: .1px;
  display: block;
  margin-bottom: 4px; }

/* Inputs, selects, textarea */
.bc-form-wrap input[type="text"],
.bc-form-wrap input[type="email"],
.bc-form-wrap input[type="tel"],
.bc-form-wrap input[type="url"],
.bc-form-wrap input[type="date"],
.bc-form-wrap input[type="number"],
.bc-form-wrap select,
.bc-form-wrap textarea {
  width: 100%;
  border: 1.5px solid #e8eae5;
  border-radius: 10px;
  padding: 11px 14px;
  font-size: 15px;
  color: #111;
  background: #fafbf9;
  outline: none;
  transition: border-color .2s, box-shadow .2s, background .2s;
  -webkit-appearance: none;
  appearance: none; }

.bc-form-wrap input::placeholder,
.bc-form-wrap textarea::placeholder {
  color: #b0b5aa; }

.bc-form-wrap input:focus,
.bc-form-wrap select:focus,
.bc-form-wrap textarea:focus {
  border-color: #2a9d54;
  background: #fff;
  box-shadow: 0 0 0 3.5px rgba(42, 157, 84, 0.1); }

.bc-form-wrap select {
  cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23aaa' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 36px; }

.bc-form-wrap textarea {
  resize: none;
  height: 100px;
  line-height: 1.65; }

/* Submit button */
.bc-form-wrap input[type="submit"],
.bc-form-wrap .wpcf7-submit {
  width: 100%;
  background: #00c288 ;
  color: #fff;
  border: none;
  border-radius: 11px;
  padding: 15px 24px;	
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  transition: opacity .2s, transform .15s, box-shadow .2s;
  letter-spacing: .2px;
  box-shadow: 0 6px 24px rgba(42, 157, 84, 0.3);
  display: block;
  margin-top: 4px; }

.bc-form-wrap input[type="submit"]:hover,
.bc-form-wrap .wpcf7-submit:hover {
  opacity: .92;
  transform: translateY(-1px);
  box-shadow: 0 10px 32px rgba(42, 157, 84, 0.35); }
 background:var(--brand-green);
.bc-form-wrap input[type="submit"]:active,
.bc-form-wrap .wpcf7-submit:active {
  transform: translateY(0); }

/* CF7 validation messages */
.bc-form-wrap .wpcf7-not-valid-tip {
  font-size: 11.5px;
  color: #e05252;
  margin-top: 3px; }

.bc-form-wrap .wpcf7-not-valid {
  border-color: #e05252 !important;
  background: #fff8f8 !important; }

.bc-form-wrap .wpcf7-response-output {
  grid-column: 1 / -1;
  border-radius: 10px;
  padding: 12px 16px;
  font-size: 13px;
  font-weight: 500;
  margin: 8px 0 0;
  border: none !important; }

.bc-form-wrap .wpcf7-mail-sent-ok {
  background: #eef9f0;
  color: #1c6e3a; }

.bc-form-wrap .wpcf7-mail-sent-ng,
.bc-form-wrap .wpcf7-spam-blocked {
  background: #fff0f0;
  color: #c0392b; }

/* Privacy note */
.bc-privacy-note {
  font-size: 11.5px;
  color: #b0b5aa;
  display: flex;
  align-items: center;
  gap: 5px;
  margin-top: 10px; }

.bc-privacy-note svg {
  width: 12px;
  height: 12px;
  flex-shrink: 0; }

/* No form warning */
.bc-no-form {
  background: #fff8e6;
  border: 1.5px solid #f0c060;
  border-radius: 10px;
  padding: 16px 20px;
  font-size: 13.5px;
  color: #7a5500;
  line-height: 1.6; }

/* ÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉ
   RESPONSIVE
ÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉÔòÉ */
@media (max-width: 800px) {
  .bc-wrap {
    grid-template-columns: 1fr; }

  .bc-left {
    padding: 40px 32px; }

  .bc-badge-row {
    margin-top: 28px; }

  .bc-right {
    padding: 40px 32px; }

  .bc-form-wrap .wpcf7-form {
    grid-template-columns: 1fr; }

  .bc-form-wrap .wpcf7-form p:has(textarea),
  .bc-form-wrap .wpcf7-form p:last-of-type {
    grid-column: 1; } }
@media (max-width: 480px) {
  .bc-page-bg {
    padding: 24px 16px; }

  .bc-left,
  .bc-right {
    padding: 32px 24px; }

  .bc-heading {
    font-size: 26px; } }

/* ============================================================
   GET A QUOTE SECTION
   ============================================================ */

/* ── Section background ── */


/* ── Deco circles ── */
/* .gaq-deco {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}
.gaq-deco--1 {
  top: -100px;
  right: -100px;
  width: 320px;
  height: 320px;
  background: rgba(255, 255, 255, 0.04);
}
.gaq-deco--2 {
  bottom: -60px;
  left: -60px;
  width: 220px;
  height: 220px;
  background: rgba(255, 255, 255, 0.03);
} */

/* ── Card wrapper ── */
.gaq-card {
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.14);
}

/* ── Left panel ── */
.gaq-left {
	position:relative;
   background: linear-gradient(107.87deg, #1A3C34 0%, #2D6A4F 65%, #3A8A6A 100%);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  border-right: 1px solid rgba(255, 255, 255, 0.1);
  padding: 52px 44px;
  display: flex;
  flex-direction: column;
}


.gaq-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(255, 255, 255, 0.10);
  color: #a8d5b5;
  font-family: var(--font-manrope);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  padding: 5px 13px;
  border-radius: 100px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  width: fit-content;
}

.gaq-badge i { font-size: 13px; }

.gaq-headline {
  font-family: var(--font-manrope);
  font-size: 36px;
  font-weight: 800;
  color: #ffffff;
  line-height: 1.15;
  letter-spacing: -0.02em;
}

.gaq-desc {
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 300;
  color: rgba(255, 255, 255, 0.60);
  line-height: 1.75;
}

.gaq-trust-list {
  list-style: none;
  padding: 0;
  margin: 0;
  padding-top: 20px;
}

.gaq-trust-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-sans);
  color: rgba(255, 255, 255, 0.72);
  padding: 5px 0;
  //border-bottom: 1px solid rgba(255, 255, 255, 0.07);
}

.gaq-trust-item:last-child { border-bottom: none; }

.gaq-trust-dot {
  width: 6px;
  height: 6px;
  background: #7ecda0;
  border-radius: 50%;
  flex-shrink: 0;
}

.gaq-left .floating-img{
	position: absolute;
    bottom: 0;
    max-width: 465px;
}

/* ── Right panel ── */
.gaq-right {
  background: #ffffff;
  padding: 48px 44px;
}

.gaq-form-eyebrow {
  font-family: var(--font-manrope);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--crl-dark-green);
  margin-bottom: 4px;
}

.gaq-form-heading {
  font-family: var(--font-manrope);
  font-size: 22px;
  font-weight: 800;
  color: var(--header-black);
  letter-spacing: -0.01em;
  margin-bottom: 4px;
}

.gaq-form-sub {
  font-family: var(--font-sans);
  font-size: 13px;
  color: var(--clr-text-blue);
  margin-bottom: 24px;
}

.gaq-req { color: #1a9957; }

.gaq-no-form {
  font-size: 13px;
  color: var(--clr-text-blue);
}

/* ── CF7 field styles ──
   Apply class:gaq-input and class:gaq-textarea
   inside the CF7 form builder                   */
.gaq-cf7-wrap .wpcf7-form p { margin: 0; }
.gaq-cf7-wrap .wpcf7-form br { display: none; }

.gaq-cf7-wrap .wpcf7-form-control-wrap {
  display: block;
}

/* Field labels — add these manually in CF7 HTML tab */
.gaq-cf7-wrap .gaq-label {
  font-family: var(--font-manrope);
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--clr-text-green);
  display: block;
  margin-bottom: 6px;
}

/* Inputs */
.gaq-cf7-wrap .gaq-input,
.gaq-cf7-wrap input.gaq-input[type="text"],
.gaq-cf7-wrap input.gaq-input[type="email"],
.gaq-cf7-wrap input.gaq-input[type="tel"],
.gaq-cf7-wrap input.gaq-input[type="url"] {
  width: 100%;
  background: var(--soft-green);
  border: 1.5px solid var(--clr-light-green);
  border-radius: 10px;
  padding: 10px 14px;
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 400;
  color: var(--header-black);
  transition: border-color 0.15s, box-shadow 0.15s;
  outline: none;
  box-shadow: none;
}

.gaq-cf7-wrap input.gaq-input::placeholder {
  color: rgba(68, 75, 90, 0.38);
  font-weight: 300;
}

.gaq-cf7-wrap input.gaq-input:focus {
  background: #fff;
  border-color: #1a9957;
  box-shadow: 0 0 0 3px rgba(26, 153, 87, 0.10);
}

/* Textarea */
.gaq-cf7-wrap textarea.gaq-textarea {
  width: 100%;
  background: var(--soft-green);
  border: 1.5px solid var(--clr-light-green);
  border-radius: 10px;
  padding: 10px 14px;
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 400;
  color: var(--header-black);
  resize: none;
  height: 84px;
  line-height: 1.55;
  outline: none;
  transition: border-color 0.15s, box-shadow 0.15s;
}

.gaq-cf7-wrap textarea.gaq-textarea::placeholder {
  color: rgba(68, 75, 90, 0.38);
  font-weight: 300;
}

.gaq-cf7-wrap textarea.gaq-textarea:focus {
  background: #fff;
  border-color: #1a9957;
  box-shadow: 0 0 0 3px rgba(26, 153, 87, 0.10);
}

/* Submit button */
.gaq-cf7-wrap input.gaq-btn[type="submit"] {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--crl-gradient);
  color: #fff;
  border: none;
  border-radius: 10px;
  padding: 12px 22px;
  font-family: var(--font-manrope);
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
  transition: opacity 0.15s, transform 0.10s;
  appearance: none;
  -webkit-appearance: none;
}

.gaq-cf7-wrap input.gaq-btn[type="submit"]:hover  { opacity: 0.88; }
.gaq-cf7-wrap input.gaq-btn[type="submit"]:active { transform: scale(0.98); }

/* Validation */
.gaq-cf7-wrap .wpcf7-not-valid-tip {
  font-family: var(--font-sans);
  font-size: 11px;
  color: #dc2626;
  margin-top: 4px;
  display: block;
}

.gaq-cf7-wrap .wpcf7-response-output {
  font-family: var(--font-sans);
  font-size: 13px;
  border-radius: 8px !important;
  padding: 10px 14px !important;
  margin-top: 12px !important;
}

.gaq-cf7-wrap .wpcf7-spinner { display: none !important; }

/* ── Responsive ── */
@media (max-width: 991px) {
  .gaq-left {
    padding: 40px 28px;
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.10);
  }
  .gaq-right    { padding: 36px 28px; }
  .gaq-headline { font-size: 28px; }
}
/* ==========================================================================
   ── Career table
   ========================================================================== */
@media (max-width: 767px) {
	 .career-table thead {
        display: none; /* Hide table header */
    }

    .career-table,
    .career-table tbody,
    .career-table tr,
    .career-table td {
        display: block;
        width: 100%;
    }

    .career-table tr {
        margin-bottom: 15px;
        border: 1px solid #ccc;
        padding: 15px;
        border-radius: 8px;
        background: #fff!important;
    }
	
    .career-table td {
        display: flex;
/*         justify-content: space-between; */
        border: none;
		text-align:left!important;
		padding
		background: #fff!important;
/*         border-bottom: 1px solid #eee; */
    }
	.career-table td:last-of-type a {
		padding:12px 16px;
		margin-top:20px;
		background:var(--brand-green);
		color:#fff!important;
		display:inline-block;
		width:100%;
		text-align:center;
		transition:.4s ease;
	}
	.career-table td:last-of-type a:hover {
		background:var(--crl-dark-green);
		transform:translatey(-3px);
	}
	.table-striped>tbody>tr:nth-of-type(odd)>* {
		--bs-table-bg-type: #fff;
	}
	.career-table td::before{
		min-width:120px;
	}
	table tbody tr td{
		padding:8px 6px!important;
	}
    .career-table td:last-child {
        border-bottom: none;
    }
	
	.table-striped>tbody>tr:nth-of-type(odd)>*{
		--bs-table-accent-bg:#fff!important;
	}
    /* Add labels before each field */
    .career-table td:nth-child(1)::before {
        content: "Job Title :";
        font-weight: 600;
    }

    .career-table td:nth-child(2)::before {
        content: "Openings :";
        font-weight: 600;
    }


    .career-table td:nth-child(3)::before {
        content: "Apply Before :";
        font-weight: 600;
    }

   
	
	table tbody tr td:not(:first-of-type){
		text-align:left;
	}
}
/* ==========================================================================
   ── Career Form Wrapper
   ========================================================================== */
.career-form-wrap {
  max-width: 560px;
  margin: 0 auto;
  padding: 2rem;
  background: #ffffff;
  border: 1px solid var(--clr-light-gray);
  border-radius: 12px;
  font-family: var(--font-sans), sans-serif;
}

/* ── Field Groups ── */
/* Target the Contact Form 7 select field inside your form group */
.form-select {
  display: block;
  width: 100%;
  padding: 0.375rem 2.25rem 0.375rem 0.75rem; /* Extra right padding makes room so text never overlaps the arrow */
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  color: #212529;
  background-color: #fff;
  
  /* 1. Clear out the missing/broken default browser asset wrapper */
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  
  /* 2. Inject a clean, scalable custom drop chevron SVG as a background image asset */
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23333333' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right 0.75rem center; /* Snaps the arrow to the right edge vertically centered */
  background-size: 16px 12px;
  
  border: 1px solid #ced4da;
  border-radius: 0.375rem;
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

/* Add a clean focus state indicator when users click it open */
.form-select:focus {
  border-color: var(--brand-green, #007043);
  outline: 0;
  box-shadow: 0 0 0 0.25rem rgba(0, 112, 67, 0.15); /* Soft glowing green boundary matching your theme */
}

.cf7-field-group {
  margin-bottom: 1.25rem;
}

.cf7-field-group label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--clr-text-blue);
  margin-bottom: 6px;
  font-family: var(--font-manrope), sans-serif;
}

.cf7-req {
  color: #e24b4a; /* Kept standard validation red for global form warning accessibility */
}

/* ── Text, Email & Textarea Inputs ── */
.cf7-input,
.wpcf7-form-control.form-control, .form-select { /* Added native CF7 class mapping to cover textareas */
  width: 100% !important;
  padding: 10px 14px !important;
  font-size: 14px !important;
  color: var(--header-black) !important;
  background-color: var(--soft-green) !important;
  border: 1px solid var(--clr-light-green) !important;
  border-radius: 8px !important;
  box-sizing: border-box !important;
  transition: border-color 0.2s, box-shadow 0.2s !important;
  outline: none !important;
}

.cf7-input:focus,
.wpcf7-form-control.form-control:focus {
  border-color: var(--crl-dark-green) !important;
  background: #ffffff !important;
  box-shadow: 0 0 0 3px rgba(45, 106, 79, 0.15) !important;
}

/* ── File Upload ── */
.cf7-upload-zone {
  border: 1.5px dashed var(--clr-text-blue);
  border-radius: 8px;
  padding: 1.25rem 1rem;
  text-align: center;
  background: var(--clr-light-gray);
  transition: background 0.15s, border-color 0.15s;
}

.cf7-upload-zone:hover {
  background: var(--soft-green);
  border-color: var(--crl-dark-green);
}

.cf7-file-input {
  font-size: 13px !important;
  color: var(--clr-text-green) !important;
}

.cf7-upload-hint {
  margin: 8px 0 0;
  font-size: 12px;
  color: var(--clr-text-blue);
  opacity: 0.8;
}

/* ── Submit Button ── */
.cf7-submit-wrap {
  margin-top: 1.5rem;
}

.cf7-btn {
  width: 100% !important;
  padding: 12px !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  color: #ffffff !important;
  background: var(--crl-dark-green) !important;
  border: none !important;
  border-radius: 8px !important;
  cursor: pointer !important;
  font-family: var(--font-manrope), sans-serif;
  transition: background 0.2s, transform 0.1s, box-shadow 0.2s !important;
}

.cf7-btn:hover {
  background: var(--header-black) !important;
  box-shadow: 0 4px 12px rgba(17, 24, 39, 0.15);
}

.cf7-btn:active {
  transform: scale(0.98) !important;
}

/* ── Validation & Response Messages ── */
.wpcf7-not-valid-tip {
  font-size: 12px !important;
  color: #e24b4a !important;
  margin-top: 4px !important;
  font-weight: 500;
}

.wpcf7-response-output {
  margin-top: 1rem !important;
  padding: 10px 14px !important;
  font-size: 13px !important;
  border-radius: 8px !important;
  border: 2px solid var(--brand-green) !important;
  background: var(--soft-green) !important;
  color: var(--crl-dark-green) !important;
}
.career-form-wrap ::placeholder{
	color: rgba(255, 255, 255, 0.4);
}

/*Careers*/
/* Careers Details Layout Adjustments */
.career-details .description ul {
  list-style: disc;
  margin-bottom: 30px;
  padding-left: 20px;
}

/* Fixed selector rule: Matches headings nested inside the content wrapper */
.career-details .description :is(h2, h3, h4, h5, h6) {
  color: var(--primary-color);
  margin-bottom: 14px;
  margin-top: 24px;
  font-weight: 700;
}

.career-details .description li:not(:last-of-type) {
  margin-bottom: 8px;
}

/* Modal close icon element positioning overrides */
#applyForm .btn-close {
  background: none !important;
  font-size: 1.25rem;
  opacity: 0.7;
  transition: opacity 0.2s ease;
}
#applyForm .btn-close:hover {
  opacity: 1;
}
       
/*general*/

    /* 2. Global Section Configuration */
    .general-page {
        background-color: var(--soft-white);
        font-family: var(--font-sans);
        color: var(--clr-text-blue);
        line-height: 1.75;
    }

    .general-section {
        padding-top: 5rem;
        padding-bottom: 5rem;
    }

    /* 3. Header styling */
    .page-main-title {
        font-family: var(--font-manrope);
        color: var(--header-black);
        font-weight: 800;
        margin-bottom: 2.5rem;
        position: relative;
        padding-bottom: 1rem;
    }
    
    /* Decorative subtle underline border using your dark green */
    .page-main-title::after {
        content: '';
        position: absolute;
        bottom: 0;
        left: 0;
        width: 60px;
        height: 4px;
        background-color: var(--crl-dark-green);
        border-radius: 2px;
    }

    /* 4. WordPress Content Typography Engine Styles */
    .wysiwyg-content p {
        font-size: 1.05rem;
        margin-bottom: 1.5rem;
        color: var(--clr-text-blue);
    }

    /* Subheadings spacing and color */
    .wysiwyg-content h1, 
    .wysiwyg-content h2, 
    .wysiwyg-content h3, 
    .wysiwyg-content h4, 
    .wysiwyg-content h5, 
    .wysiwyg-content h6 {
        font-family: var(--font-manrope);
        color: var(--header-black);
        font-weight: 700;
        margin-top: 2.5rem;
        margin-bottom: 1rem;
        line-height: 1.3;
    }
    
    .wysiwyg-content h2 { font-size: 2rem; }
    .wysiwyg-content h3 { font-size: 1.5rem; }

    /* Lists styling (Unordered & Ordered) */
    .wysiwyg-content ul, 
    .wysiwyg-content ol {
        margin-bottom: 2rem;
        padding-left: 1.5rem;
    }

    .wysiwyg-content li {
        margin-bottom: 0.5rem;
        color: var(--clr-text-green);
    }

    /* Target custom bullet highlights using brand colors */
    .wysiwyg-content ul li::marker {
        color: var(--crl-dark-green);
    }
    
    .wysiwyg-content ol li::marker {
        color: var(--clr-text-blue);
        font-weight: bold;
    }

    /* Blockquote treatments for editorial elegance */
    .wysiwyg-content blockquote {
        background-color: var(--soft-green);
        border-left: 4px solid var(--brand-green);
        padding: 1.5rem 2rem;
        margin: 2rem 0;
        border-radius: 0 0.5rem 0.5rem 0;
        font-style: italic;
    }
    
    .wysiwyg-content blockquote p {
        margin-bottom: 0;
        color: var(--clr-text-green);
    }

/*footer*/
.footer-section {
  position: relative;
  overflow: hidden; }
.footer-brand img{
	width:clamp(50%, 55vw, 70%);
}
.footer-section .container,
.footer-section .footer-bottom {
  position: relative;
  z-index: 1; }

.blob {
  position: absolute;
  border-radius: 50%;
  filter: blur(70px);
  pointer-events: none;
  will-change: transform; }

/* Starts bottom-left ÔåÆ moves to top-right */
.blob-1 {
  width: 300px;
  height: 300px;
  background: #1a7a55;
  opacity: 0.5;
  bottom: -60px;
  left: -60px;
  animation: blobMoveA 8s linear infinite alternate, hue1 6s ease-in-out infinite alternate; }

/* Starts top-right ÔåÆ moves to bottom-left */
.blob-2 {
  width: 280px;
  height: 280px;
  background: #2ecc89;
  opacity: 0.3;
  top: -60px;
  right: -60px;
  animation: blobMoveB 8s linear infinite alternate, hue2 6s ease-in-out infinite alternate; }

/* blob-1: bottom-left to top-right */
@keyframes blobMoveA {
  0% {
    transform: translate(0px, 0px); }
  100% {
    transform: translate(calc(100vw - 180px), calc(-100% - 60px)); } }
/* blob-2: top-right to bottom-left */
@keyframes blobMoveB {
  0% {
    transform: translate(0px, 0px); }
  100% {
    transform: translate(calc(-100vw + 180px), calc(100% + 60px)); } }
@keyframes hue1 {
  0% {
    background: #1a7a55; }
  50% {
    background: #22a870; }
  100% {
    background: #0f6e3a; } }
@keyframes hue2 {
  0% {
    background: #2ecc89; }
  50% {
    background: #16a86a; }
  100% {
    background: #3de09a; } }
.footer-section {
  background: #02321c;
  color: rgba(255, 255, 255, 0.8);
  font-size: 14px; }
  .footer-section .footer-title {
    color: #fff;
    font-weight: 700;
    margin-bottom: 25px;
    font-size: 18px; }
  .footer-section .footer-text {
    line-height: 1.6;
    color: rgba(255, 255, 255, 0.7); }
  .footer-section a {
    color: rgba(255, 255, 255, 0.7);
    text-decoration: none;
    transition: color 0.3s ease; }
    .footer-section a:hover {
      color: #52D0A8;
      /* Your brand green */ }
  .footer-section .social-icons a {
    font-size: 18px;
    color: #fff;
}
    .footer-section .social-icons a:not(:last-of-type) {
      border-right: 1px solid #d9d9d9;
      padding-right: 15px; }
    .footer-section .social-icons a:hover {
      color: #52D0A8;
}
  .footer-section .footer-links li {
    margin-bottom: 15px; }
    .footer-section .footer-links li a {
      color: rgba(255, 255, 255, 0.7);
      text-decoration: none;
      transition: color 0.3s ease; }
      .footer-section .footer-links li a:hover {
        color: #52D0A8; }
  .footer-section .footer-contact-item {
    margin-bottom: 10px; }

/*# sourceMappingURL=styles.css.map */

.partner-slider-section{
	position:relative;
}

.partner-slider-section:before{
	content:"";
	position:absolute;
	top:0;
	left:0;
	width:100%;
	height:100%;
/* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#ffffff+0,ffffff+100&1+0,0.5+7,0+26,0+70,0.5+93,1+100 */
background: linear-gradient(to right,  rgba(255,255,255,1) 0%,rgba(255,255,255,0.5) 7%,rgba(255,255,255,0) 26%,rgba(255,255,255,0) 70%,rgba(255,255,255,0.5) 93%,rgba(255,255,255,1) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */

z-index:9;
}

.partner-slider-section .swiper-slide{
	margin-left:50px;
}

.partner-slider-section .swiper-slide img{
	width:120px;
}

/* Cursor */
.custom-cursor {
    position: fixed;
    top: 0;
    left: 0;
    width: 28px;
    height: 28px;
    border: 1px solid #00c288 ; /* replace with your color */
    border-radius: 50%;
    pointer-events: none;
    z-index: 99999;
    will-change: transform, opacity;
    transition: transform 0.1s ease, opacity 0.2s ease;
}

.custom-cursor--hover {
    transform: translate(-50%, -50%) scale(1.15);
	background:rgba(0, 194, 136, 0.15);
}

.custom-cursor--hidden {
    opacity: 0;
}

.custom-cursor__dot {
    position: fixed;
    top: 0;
    left: 0;
    width: 5px;
    height: 5px;
    background: #00c288 ; /* replace with your color */
    border-radius: 50%;
    pointer-events: none;
    z-index: 99999;
    will-change: transform, opacity;
    transition: opacity 0.2s ease;
}

/* .custom-cursor__dot--hidden {
    opacity: 0;
} */