/* --- HERO SLIDER  --- */
.hero-slider {
    position: relative;
    width: 100%;
    min-height: 300px;
    background: none;
    margin-bottom: 0;
    padding: 0;
    overflow: hidden;
}
.hero-slider-bg {
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    width: 100%;
    height: 100%;
    background: url('../img/banner1.jpg') center/cover no-repeat;
    z-index: 1;
}
.hero-logo-overlay {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 320px;
    height: 320px;
    object-fit: contain;
    opacity: 0.18;
    z-index: 2;
    pointer-events: none;
}
.hero-slider-content {
    position: absolute;
    left: 0;
    bottom: 70px; /* lifted slightly so content below is visible */
    z-index: 3;
    width: 100%;
    max-width: 100vw;
    padding: 1.2rem 0 1.2rem 4vw; /* reduced vertical padding to lift text */
    text-align: left;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}
.hero-title {
    font-family: var(--bs-font-sans-serif, 'Barlow', Arial, sans-serif);
    font-weight: 700;
    font-size: 5.4rem; /* doubled size */
    line-height: 1.02;
    color: #fff;
    margin-bottom: 0.5rem;
    text-shadow: 0 2px 20px rgba(0,0,0,0.22);
}
.hero-title,
.hero-tagline {
    /* Responsive, matching hero sizing for title and its second line */
    font-size: clamp(2rem, 6vw, 3.6rem);
    line-height: 1.02;
    font-weight: 700;
}

.hero-tagline {
    color: #f39129 !important;
    /* slightly reduced size compared to the main title */
    font-size: clamp(1.6rem, 5.2vw, 3.2rem);
    margin-bottom: 1rem;
    text-shadow: 0 2px 16px rgba(0,0,0,0.06);
    display: block;
}

/* smaller lead text under hero title when present */
#hero-slider .lead {
    font-size: clamp(1rem, 2.5vw, 1.2rem);
    margin-bottom: 1rem;
    opacity: 0.95;
}

/* Slightly reduce orange hero text size on the About page sliders */
.about-page .hero-tagline {
    font-size: clamp(1.4rem, 4.6vw, 2.6rem);
}

/* Balance and equalize Sustainability cards on About page */
#sustainability .row.g-4 {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 24px;
}

#sustainability .col-lg-4 {
    display: flex;
}

#sustainability .service-box {
    background: var(--brand-on);
    border-radius: 12px;
    padding: 22px;
    box-shadow: 0 10px 30px rgba(9,31,34,0.04);
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
    flex: 1 1 320px;
    min-height: 220px;
    text-align: center;
}

#sustainability .service-box img,
#sustainability .service-box i {
    margin-bottom: 12px;
}

#sustainability .service-box h5 {
    margin-top: 12px;
    margin-bottom: 8px;
    color: var(--brand-dark);
}

/* Global card hover: green fading shadow and slight lift */
.feature-card, .service-box, .card-compact, .blog-teaser, .review, .card {
    transition: transform .36s cubic-bezier(.2,.9,.3,1), box-shadow .36s ease;
    will-change: transform;
}
.feature-card:hover, .service-box:hover, .card-compact:hover, .blog-teaser:hover, .review:hover, .card:hover {
    transform: translateY(-8px);
    box-shadow: 0 18px 40px rgba(9,31,34,0.12), 0 0 34px rgba(31,111,65,0.08);
}

/* Slight image zoom on hover for images inside cards */
.feature-card img, .service-box img, .card-compact img, .blog-teaser img, .review img {
    transition: transform .45s ease;
    will-change: transform;
}
.feature-card:hover img, .service-box:hover img, .card-compact:hover img, .blog-teaser:hover img, .review:hover img {
    transform: scale(1.035);
}

@media (max-width: 768px) {
    .hero-logo-overlay {
        width: 180px;
        height: 180px;
    }
    .hero-slider-content {
        padding: 0.8rem 0 0.8rem 3vw;
    }
    .hero-title {
        font-size: 3rem; /* scaled mobile size */
    }
}

/* Additional responsive breakpoints for tablet / laptop */
@media (max-width: 1200px) {
    .hero-title { font-size: 4.2rem; }
}

@media (max-width: 992px) {
    .hero-title { font-size: 3.6rem; }
}

/* Make large background images and panels adapt nicely on medium screens */
@media (max-width: 992px) {
    .slide .hero-bg { object-position: center top; }
}

/* --- ABOUT SECTION (About Page) --- */
.about-section {
    padding: 2.5rem 0 1.5rem 0;
    background: #fff;
}
.about-card {
    max-width: 700px;
    margin: 0 auto;
    background: #fff;
    border-radius: 1rem;
    box-shadow: 0 2px 16px rgba(0,0,0,0.04);
    padding: 2rem 1.5rem 1.5rem 1.5rem;
}
.about-card h6 {
    font-size: 1rem;
    font-weight: 600;
    color: var(--bs-primary, #4cba4a);
    letter-spacing: 1.5px;
    margin-bottom: 0.5rem;
}
.about-card h1 {
    font-size: 2rem;
    font-weight: 700;
    color: var(--bs-dark, #222);
    margin-bottom: 1rem;
}
.about-card p {
    color: var(--bs-secondary, #444);
    font-size: 1.05rem;
    margin-bottom: 0.7rem;
}
/* Polished About/Mission/Sustainability styles */
.about-section { background: linear-gradient(135deg, var(--brand-light) 0%, #fff 100%); position: relative; overflow: hidden; }
.about-pattern { background-image: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%231f6f41' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E"); background-repeat: repeat; opacity: .12; }
.about-card { background: white; border-radius: 24px; box-shadow: var(--shadow-sm); position: relative; z-index: 1; }
.about-icon { font-size: 1.8rem; }
.feature-item { transition: transform .3s ease, box-shadow .3s ease; border-radius: 16px; }
.feature-item:hover { transform: translateY(-8px); box-shadow: 0 12px 24px rgba(76,186,74,0.08); }

.mission-vision { background: var(--brand-light); }
.mission-card, .vision-card { border-radius: 20px; transition: all .3s ease; background: white; }
.mission-card:hover, .vision-card:hover { transform: translateY(-8px); box-shadow: var(--shadow-md) !important; }
.icon-circle { width: 100px; height: 100px; border-radius: 50%; background: rgba(76,186,74,0.08); display:flex;align-items:center;justify-content:center; transition: all .3s ease; margin: 0 auto; }
.mission-card:hover .icon-circle, .vision-card:hover .icon-circle { background: var(--brand-secondary); transform: rotateY(360deg); }
.mission-card .icon-circle i, .vision-card .icon-circle i { color: var(--brand-secondary); transition: color .3s ease; }
.mission-card:hover .icon-circle i, .vision-card:hover .icon-circle i { color: #fff; }

/* Vision goals: center the goals block and align icons/text in a two-column grid */
.vision-card .vision-goals-list {
    display: grid;
    row-gap: 0.9rem;
    justify-content: center; /* center the whole block inside the card */
    padding: 0;
    margin: 0 auto;
    width: 100%;
    max-width: 420px; /* comfortable reading width */
}
.vision-card .vision-goals-list li {
    display: grid;
    grid-template-columns: 28px 1fr; /* fixed icon column + fluid text column */
    align-items: center;
    column-gap: 0.75rem;
    color: var(--bs-dark, #111);
    font-weight: 600;
    width: 100%;
}
.vision-card .vision-goals-list li i {
    justify-self: center;
    color: var(--brand-green);
    font-size: 1.05rem;
}

.sustainability-card { background: white; border-radius: 20px; box-shadow: var(--shadow-sm); transition: all .3s ease; border: 1px solid rgba(0,0,0,0.04); height: 100%; }
.sustainability-card:hover { transform: translateY(-8px); box-shadow: var(--shadow-md); }
.icon-box { width: 90px; height: 90px; margin: 0 auto; background: linear-gradient(135deg, rgba(76,186,74,0.1) 0%, rgba(76,186,74,0.05) 100%); border-radius: 50%; display:flex;align-items:center;justify-content:center; transition: all .3s ease; }
.sustainability-card:hover .icon-box { transform: scale(1.06) rotate(4deg); }
.icon-box i { color: var(--brand-secondary); transition: color .3s ease; }
.sustainability-card:hover .icon-box i { color: #fff; }

/* Ensure sustainability card text uses the standard readable size like other pages */
.sustainability-card p, .sustainability-card .small, .sustainability-card .text-muted {
    font-size: 1rem;
    line-height: 1.6;
    color: rgba(0,0,0,0.72) !important;
}
.sustainability-card h5 {
    font-size: 1.05rem;
    margin-bottom: .6rem;
}

/* Small title logo used beside section headings */
.title-logo {
    width: 48px;
    height: auto;
    object-fit: contain;
    border-radius: 8px;
    border: 2px solid rgba(31,111,65,0.06);
    box-shadow: 0 6px 18px rgba(31,111,65,0.06);
}

/* Logo shown next to the top page title */
.page-title-logo {
    width: 64px;
    height: 64px;
    object-fit: contain;
    border-radius: 10px;
    border: 2px solid rgba(31,111,65,0.06);
    box-shadow: 0 8px 24px rgba(31,111,65,0.06);
}

/* small responsive tweaks */
@media (max-width: 768px) {
    .about-card { padding: 1.2rem; }
    .icon-box { width: 72px; height: 72px; }
}

/* About page logo + heading visibility fixes */
.about-logo { width: 110px; height: auto; display: inline-block; border-radius: 8px; box-shadow: 0 6px 18px rgba(31,111,65,0.08); }
.about-section h6, .about-section h1, .about-section h5, .about-section h4 { color: #1b1b1b; }
.mission-vision h2, #sustainability .display-5, #sustainability h2, .mission-card h3, .vision-card h3 { color: #1b1b1b; }
.sustainability-card h5, .feature-item h5 { color: #111; }

/* Ensure small muted text remains readable */
.about-section .text-muted, .mission-vision .text-muted, #sustainability .text-muted { color: rgba(0,0,0,0.6) !important; }
/* Revert/override inserted page/title logo classes (keep about logo visible) */
.page-title-logo, .title-logo { display: none !important; }
@media (max-width: 576px) {
    .about-card {
        padding: 1.2rem 0.5rem 1rem 0.5rem;
    }
    .about-card h1 {
        font-size: 1.2rem;
    }
}
@import url('https://fonts.googleapis.com/css2?family=Barlow:wght@400;500;600;700&display=swap');

body {
    font-family: "barlow", sans-serif;
    line-height: 1.7;
    color: var(--text-muted);
}

h1,h2,h3,h4,h5,h6 {
    font-weight: 700;
    color: #fcfcfc;
    
}

a {
    color: var(--brand-dark);
    text-decoration: none;
    transition: all 0.4s ease;
    font-weight: 500;
}



img {
    width: 100%;
}

/* =========================
   ABOUT PAGE LOGO
========================= */

.about-brand {
    background-color: #ffffff;
}

.about-logo {
    width: 250px;
    height: 250px;
    object-fit: contain;
    border-radius: 50%;
    border: 3px solid var(--brand-green);
    padding: 10px;
}
.nav-image {
    width: 50px;
    height: 50px;
    object-fit: contain;
    border-radius: 50%;
    border: none;
    padding: 10px;
}

section {
    padding-top: 80px;
    padding-bottom: 80px;
}

.bg-cover {
    background-position: center !important;
    background-size: cover !important;
}

.intro {
    margin-bottom: 40px;
}

.intro h6 {
    font-weight: 400;
    color: var(--brand-green);
}

.intro p {
    max-width: 500px;
    margin: auto;
}


/* NAVBAR */
.top-nav {
    background-color: #ffffff;
    padding-top: 5px;
    padding-bottom: 5px;
}

.top-nav p {
    margin-bottom: 0%;
    display: inline-block;
    margin-right: 16px;
    color: var(--brand-dark);
}

.top-nav i,
.top-nav span {
    vertical-align: middle;
}


.social-links a {
    width: 34px;
    height: 34px;
    background-color: rgba(255, 255, 255, 0.3);
    display: inline-flex;
    align-items: center;
    justify-content:center ;
    color: white;
    font-size: 20px;
    border-radius: 100%;
}

.social-links a:hover {
    background-color: white;
    color: var(--brand-green);
}

.navbar {
    box-shadow: 0px 6px 30px rgba(0, 0, 0, 0.08);
}


.navbar .navbar-nav .nav-link {
    color: var(--brand-dark);
}

.navbar .navbar-nav .nav-link:hover,
.navbar .navbar-nav .nav-link:active {
    color: var(--brand-green);
}

/* For the green top-nav variant keep white hovered/active links — scope under .top-nav */
.top-nav .navbar-nav .nav-link[href="#home"]:hover,
.top-nav .navbar-nav .nav-link[href="about.html"]:hover,
.top-nav .navbar-nav .nav-link[href="pricing.html"]:hover,
.top-nav .navbar-nav .nav-link[href="#stations-map"]:hover {
    color: var(--brand-green) !important;
}

/* Also ensure active, focused and programmatic :active nav links appear white when inside .top-nav */
.top-nav .navbar-nav .nav-link.active,
.top-nav .navbar-nav .nav-link:active,
.top-nav .navbar-nav .nav-link:focus {
    color: var(--brand-green) !important;
}

.navbar-brand {
    font-weight: 700;
    font-size: 26px;
    color: var(--brand-dark);
}

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

/* Brand layout: logo next to text */
.navbar-brand{
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

/* small logo next to brand text */
.nav-logo{
    width: 36px;
    height: 36px;
    object-fit: cover;
    border-radius: 50%;
    display: inline-block;
    border: 2px solid var(--brand-on);
    background: var(--brand-on);
    padding: 2px;
}

/* navbar-specific button sizing */
.nav-btn{
    padding: 6px 12px !important;
    border-radius: 20px !important;
    font-size: 0.95rem !important;
}

/* Station marker using site logo 
.station-div-icon {
    /* keep Leaflet default icon CSS minimal 
}*/
.station-marker{
    width: 40px;
    height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: white;
    border-radius: 50%;
    box-shadow: 0 4px 8px rgba(0,0,0,0.15);
    border: 2px solid rgba(76,186,74,0.95);
    overflow: hidden;
}
.station-marker img{
    width: 32px;
    height: 32px;
    object-fit: cover;
    display: block;
    border-radius: 50%;
}

/* Station popup styling */
.station-popup{
    width: 260px;
}
.station-popup-row{
    display:flex;
    gap:12px;
    align-items:center;
}
.station-popup-img{
    width:64px;
    height:64px;
    object-fit:cover;
    border-radius:6px;
    flex-shrink:0;
}
.station-popup-title{
    font-weight:700;
    margin-bottom:6px;
}
.station-popup-available{
    color:var(--brand-green);
    font-weight:600;
    margin-bottom:8px;
}
.station-popup-available.no-bikes{ color:var(--danger); }
.station-popup-actions .station-cta{
    padding:6px 10px;
    border-radius:14px;
    font-size:0.9rem;
}
.leaflet-popup-content {
    padding:8px 10px;
}
.leaflet-popup-tip { /* make tip small */
    width: 12px !important;
    height: 8px !important;
}

/* BTN */
.btn {
    padding: 9px 24px;
    font-weight: 500;
}

.btn-brand {
    background-color: var(--brand-green);
    color: white;
    border-color: var(--brand-green);
}

.btn-brand:hover {
    color: white;
    background-color: var(--brand-green-dark);
}

/* App CTA: ensure Android and iOS buttons match size and spacing */
.app-cta {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1.25rem;
    font-size: 1rem;
    border-radius: 6px;
}
.app-cta i { font-size: 1.05rem; }


/* SLIDER */
#hero-slider h1 {
    font-weight: 700 !important;
}
.slide1{
    background-color: var(--brand-dark); /* fallback while image loads */
}

.slide2{
    background-color: var(--brand-dark); /* fallback while image loads */
}

/* Hero positioned background image to avoid background-image flash */
.slide .hero-bg{
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    z-index: 0;
    display: block;
}

/* LQIP blur style: show small blurred image, then swap to full-res and remove blur */
.slide .hero-bg.lqip{
    filter: blur(8px) saturate(0.95);
    transform: scale(1.02);
    transition: filter 600ms ease, transform 600ms ease, opacity 400ms ease;
    opacity: 1;
}
.slide .hero-bg.loaded{
    filter: none;
    transform: none;
}

/* Dark overlay for better text contrast */
.slide::after{
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(9,32,50,0.6) 0%, rgba(9,32,50,0.3) 50%, rgba(31,111,65,0.7) 100%);
    z-index: 1;
}

/* Ensure slide content sits above background and overlay */
.slide > .container{
    position: relative;
    z-index: 2;
}

/* CTA improvements */
.btn-brand{
    padding: 12px 28px;
    font-size: 1.05rem;
}
.btn-outline-light{
    opacity: 0.95;
    border-width: 1.5px;
}

/* About_2 specific tweaks: tighter cards, readable headings */
.about-2 .card{
    padding: 28px;
    box-shadow: 0 6px 22px rgba(0,0,0,0.06);
}
.about-2 .intro h6{
    color: var(--brand-green);
}
.about-2 h2{
    font-size: 2rem;
    margin-bottom: 8px;
}
.about-2 .service-box{
    padding: 20px;
}

/* Respect user reduced motion */
@media (prefers-reduced-motion: reduce){
    .slide .hero-bg,
    .slide .hero-bg.lqip{
        transition: none !important;
        animation: none !important;
        filter: none !important;
        transform: none !important;
    }
}

/* =========================
   HERO FIX — PREVENT LAYOUT SHIFT
========================= */

#hero-slider,
#hero-slider .item {
    min-height: 100vh;
    display: flex;
    align-items: center;
}

#hero-slider {
    overflow: hidden;
}


/* OWL CAROUSEL */
.owl-prev,
.owl-next {
    position: absolute;
    top: 50%;
    width: 60px !important;
    height: 60px !important;
    display: grid;
    place-items: center;
    background-color: rgba(255, 255, 255, 0.3) !important;
    margin-top: -30px !important;
    color: white !important;
    font-weight: 700 !important;
    font-size: 12px !important;
    border-radius: 100px !important;
}

.owl-prev {
    left: 0;
}

.owl-next {
    right: 0;
}

.owl-next:hover,
.owl-prev:hover {
    background-color: var(--brand-green) !important;
}

/* INFOBOX */
.info-box {
    display: flex;
    align-items: center;
    line-height: 16px;
}

.info-box img {
    width: 90px;
    margin-right: 24px;
}

/* MILESTONE */

/* Navbar glass + scroll progress */
#mainNavbar.scrolled{background-color:rgba(255,255,255,0.92);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);box-shadow:0 6px 18px rgba(0,0,0,0.08)}
#scrollProgress{position:fixed;left:0;top:0;height:4px;background:linear-gradient(90deg,var(--brand-green),var(--brand-green-dark));width:0;z-index:1051}

/* New hero carousel & slide styles */
.hero-section{background:linear-gradient(135deg,var(--brand-green) 0%,var(--brand-green-dark) 60%);color:#fff;padding:60px 0}
.hero-slide{position:relative;overflow:hidden}
.hero-left .badge-geo{display:inline-block;background:rgba(255,255,255,0.08);padding:6px 10px;border-radius:999px;margin-bottom:16px}
.hero-left h1{font-weight:700;font-size:48px;line-height:1.02;color:#fff}
.hero-left p.lead{opacity:0.95;color:rgba(255,255,255,0.95)}
.app-badges img{height:48px;margin-right:8px}
.trust-row{margin-top:18px;display:flex;gap:12px;align-items:center}
.trust-row .trust{background:rgba(255,255,255,0.08);padding:8px 12px;border-radius:8px;color:#fff}
.hero-right{position:relative}
.hero-mockup{max-width:420px;margin:0 auto;transform:translateY(0);transition:transform .6s cubic-bezier(.2,.9,.2,1)}
.floating-stat{position:absolute;background:rgba(255,255,255,0.95);color:#111;padding:10px 14px;border-radius:10px;box-shadow:0 8px 18px rgba(0,0,0,0.12);transition:transform .35s ease,opacity .35s ease}
.floating-stat.top-right{top:12%;right:12%}
.floating-stat.bottom-right{bottom:10%;right:20%}
.floating-stat.bottom-right-2{bottom:22%;right:6%}
.floating-stat.small{width:140px}

@media(max-width:991px){
    .hero-left h1{font-size:32px}
    .floating-stat{display:none}
    .hero-section{padding:36px 0}
}

/* quick-stats */
.quick-stats{background:linear-gradient(90deg,var(--brand-green-dark),var(--brand-green));color:#fff}
.quick-stats .container{max-width:1100px}

/* small utility tweaks */
.hero-slide .btn-outline-light{border-color:rgba(255,255,255,0.18);color:#fff}

/* Contact modal left cover and hidden status */
.modal-left-cover{background-image:url('../img/c2.jpg');min-height:300px;background-size:cover;background-position:center}
#contactStatus{display:none;margin-top:8px}


#milestone{
    background: linear-gradient(rgba(var(--brand-green-rgb), 0.9), rgba(var(--brand-green-rgb), 0.9)), url(../img/banner2.jpg);
}

#milestone .display-4,
#milestone p{
    color: white;
}

#milestone .display-4 {
    font-weight: 700;
}

/* SERVICES */
.service-box {
    padding: 32px;
    box-shadow: 0px 6px 30px rgba(0, 0, 0, 0.08);
    text-align: center;
}

.service-box img {
    width: unset;
}

.service-box h5 {
    margin-top: 24px;
    margin-bottom: 12px;
}

/* PROJECT */

#project-slider .owl-next,
#project-slider .owl-prev {
    background-color: rgba(255, 255, 255, 0.5) !important;
}

#project-slider .owl-next:hover,
#project-slider .owl-prev:hover {
    background-color: var(--brand-green) !important;
}

.project {
    position: relative;
}

.project .overlay {
    background: linear-gradient(to bottom, rgba(9, 32, 50, 0), rgba(9, 32, 50, 0.8));
    position: absolute;
    width: 100%;
    height: 240px;
    bottom: 0;
    left: 0;
}

.project .content {
    position: absolute;
    width: 100%;
    bottom: 0;
    left: 0;
    padding: 32px;
}

.project h1,
.project h6 {
    color: white;
}

.project h6 {
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.project h6::before {
    content: '';
    height: 2px;
    width: 24px;
    background-color: var(--brand-green);
    display: inline-block;
    vertical-align: middle;
    margin-right: 12px;
}

/* REVIEW */
#reviews {
    background: linear-gradient(to bottom, rgba(9, 32, 50, 0.8), rgba(9, 32, 50, 0.8)), url(../img/banner1.jpg);
}

.review {
    max-width: 900px;
    margin: auto;
    text-align: center;
}

.review img {
    width: 85px !important;
    border-radius: 1000px;
    margin: auto;
}

.review h4 {
    margin-top: 16px;
}

.review h4,
.review p {
    color: white;
}

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

.review p {
    margin-top: 28px;
}

.owl-dot.active span {
    background-color: var(--brand-green) !important;
}

/* BLOG-POST */
.blog-post {
    position: relative;
}

.blog-post .tag {
    padding: 3px 10px;
    background-color: var(--brand-green);
    color: white;
    border-radius: 100px;
    top: 20px;
    left: 20px;
    position: absolute;
}

.blog-post img {
    margin-bottom: 12px;
}

.blog-post h4 {
    margin-top: 12px;
    margin-bottom: 12px;
}

.blog-post small {
    color: var(--brand-green);
    text-decoration: underline;
    text-transform: uppercase;
}

/* FOOTER */
footer {
    padding-top: 80px;
    padding-bottom: 20px;
    color: white;
    text-align: center;
    background: linear-gradient(to bottom, rgba(9, 32, 50, 0.8), rgba(9, 32, 50, 0.8)), url(../img/banner1.jpg);
}

footer .navbar-brand {
    color: white;
    margin-bottom: 24px;
    display: inline-block;
}

.footer-top{
    margin-bottom: 40px;
}

.footer-bottom {
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    padding-top: 20px ;
}

footer .social-links a {
    margin-left: 5px;
    margin: 5px;
}

/* FORM */
.form-control:focus {
    box-shadow: none;
    border-color: var(--brand-green);
}

/* Contact modal map container */
#contactMap {
    min-height: 300px;
    width: 100%;
    height: 100%;
}

/* Ensure the left column of the contact modal keeps a constrained height to avoid modal overflow */
.modal .bg-cover {
    overflow: hidden;
}

/* If Leaflet controls still cause small overflow, cap the modal body height and allow internal scroll */
#contactModal .modal-body{
    max-height: 80vh;
    overflow: hidden;
}
#contactModal .modal-body .col-lg-8{
    overflow-y: auto;
}

/* Floating WhatsApp FAB */
.whatsapp-fab{
    position: fixed;
    right: 18px;
    bottom: 18px;
    z-index: 1060;
    background: var(--brand-green);
    color: var(--brand-on);
    width: 56px;
    height: 56px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    box-shadow: 0 8px 20px rgba(0,0,0,0.18);
    text-decoration: none;
    font-size: 20px;
}
.whatsapp-fab:hover{ transform: translateY(-3px); }

/* Ensure Contact modal headings are readable on light backgrounds */
#contactModal .modal-content h1,
#contactModal h1 {
    color: var(--brand-dark) !important;
}

/* Make modal body text readable and left-aligned, and remove internal container gutters */
#contactModal .modal-content,
#contactModal .modal-body,
#contactModal .modal-content p,
#contactModal .modal-content label,
#contactModal .modal-content .form-control {
    color: var(--brand-dark) !important;
    text-align: left;
}

/* Remove the default container padding inside the modal so the map can reach the edge */
#contactModal .container-fluid {
    padding-left: 0;
    padding-right: 0;
}

/* Make contact modal behave like a page on small screens */
@media (max-width: 768px) {
    #contactModal .modal-content {
        height: 100vh;
        border-radius: 0;
        display: flex;
        flex-direction: column;
    }
    #contactModal .modal-body{
        max-height: none;
        overflow: auto;
        padding: 0.5rem 1rem 1rem 1rem;
        flex: 1 1 auto;
    }
    #contactMap { min-height: 40vh; }
}

@media (max-width: 768px) {
    /* Add comfortable inner padding for form column so inputs don't touch screen edges */
    #contactModal .modal-body .col-lg-8 {
        padding-left: 1rem;
        padding-right: 1rem;
    }
    #contactModal .modal-body .form-control {
        margin-bottom: 0.75rem;
    }
    /* Slightly reduce wide fixed FABs so they don't overlap modal edges */
    .whatsapp-fab{ right: 12px; bottom: 12px; }
}

/* Ensure modal overlays are above sticky navbars and FABs */
#contactModal {
    z-index: 2005 !important;
}
.modal-backdrop.show {
    z-index: 2000 !important;
}

/* HOW IT WORKS SECTION */

.how-it-works .step-box {
    background: #ffffff;
    padding: 20px 15px;
    border-radius: 12px;
    margin-bottom: 20px;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.how-it-works .step-box:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.08);
}

.step-number {
    width: 32px;
    height: 32px;
    margin: 0 auto 12px;
    background-color: rgba(var(--brand-green-rgb), 0.15);
    color: var(--brand-green);
    border-radius: 50%;
    font-weight: 500;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.85rem;
    opacity: 0.75;
}

.step-box h6 {
    font-weight: 600;
    margin-top: 12px;
    color: #000;
    font-size: 1.05rem;
}

.step-box p {
    font-size: 1.05rem;
    color: #555;
    line-height: 1.6;
}
/* HOW IT WORKS – ICONS & TYPOGRAPHY */

.step-icon {
    font-size: 28px;
    color: var(--brand-green);
    margin-bottom: 10px;
    display: block;
}

.step-box p {
    font-size: 1.05rem; 
    line-height: 1.6;
    color: #555;
}

/* Optional: make section headline stronger */
#about h2 {
    font-size: 2.2rem;
    font-weight: 700;
}
@media (max-width: 768px) {
    .step-box {
        padding: 25px 20px;
    }

    .step-icon {
        font-size: 48px;
    }

}
/* Mission & Vision */
        .mission-vision .card {
            border: none;
            text-align: center;
            padding: 30px 20px;
            background: #f9f9f9;
            border-radius: 12px;
            box-shadow: 0 6px 25px rgba(0,0,0,0.05);
            margin-bottom: 20px;
        }

        .mission-vision .card h5 {
            color: var(--brand-dark);
            font-weight: 600;
            margin-bottom: 15px;
        }

        .mission-vision .card p {
            color: #444;
            font-size: 1rem;
        }

        /* Milestone */
        #milestone{
            background: linear-gradient(rgba(var(--brand-green-rgb), 0.9), rgba(var(--brand-green-rgb), 0.9)), url(./img/milestone-bg.jpg);
            background-size: cover;
            color: white;
        }
        #milestone .display-4{
            font-weight: 700;
            font-size: 2.2rem;
        }
        #milestone p{
            margin-top: 5px;
        }
     /* Sustainability */
        .service-box {
            padding: 32px;
            box-shadow: 0px 6px 30px rgba(0, 0, 0, 0.08);
            text-align: center;
            border-radius: 12px;
            background: #fff;
        }
        .service-box img {
            width: 60px;
            margin-bottom: 15px;
        }
        .service-box h5 {
            margin-top: 12px;
            margin-bottom: 12px;
            font-weight: 600;
            color: var(--brand-dark);
        }
        .service-box p {
            color: #444;
            font-size: 1rem;
        }
/* Team */
        .team-member {
            text-align: center;
            margin-bottom: 30px;
        }
        .team-member img {
            width: 150px;
            height: 150px;
            border-radius: 50%;
            object-fit: cover;
            margin-bottom: 15px;
        }
        .team-member h6 {
            font-weight: 600;
            margin-bottom: 5px;
            color: var(--brand-dark);
        }
        .team-member p {
            font-size: 0.95rem;
            color: var(--text-muted);
        }

        .map-container {
        width: 100%;
        max-width: 1600px; /* optional: limits the map width */

        height: 600px;
        border-radius: 12px;
        margin: 0 auto; /* centers horizontally */
        padding: 0 20px; /* optional internal padding */
    }



.how-it-works {
    gap: 24px;
    overflow-x: auto;
    display: flex;

}

/* STEP CARD */
.step-box {
    flex: 0 0 280px; /* forces horizontal cards */
    background: #ffffff;
    padding-top: 80px;
    padding: 36px 28px;
    border-radius: 18px;
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.06);
    scroll-snap-align: start;
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.step-box:hover {
    transform: translateY(-6px);
    box-shadow: 0 28px 60px rgba(0, 0, 0, 0.08);
}

/* FOOTER */
.site-footer {
    background: var(--brand-dark);
    color: #d6dce3;
    padding-top: 70px;
    padding-bottom: 30px;
    background: linear-gradient(to bottom, rgba(9, 32, 50, 0.8), rgba(9, 32, 50, 0.8)), url(../img/banner1.jpg);
}

.footer-brand {
    font-size: 1.5rem;
    font-weight: 700;
    color: #ffffff;
    margin-bottom: 15px;
}

.footer-title {
    font-size: 0.95rem;
    font-weight: 600;
    color: #ffffff;
    margin-bottom: 15px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.footer-text {
    font-size: 0.95rem;
    line-height: 1.6;
    color: #b9c3cf;
}

.footer-links {
    list-style: none;
    padding: 0;
    margin: 0;
}

.footer-links li {
    margin-bottom: 10px;
}

.footer-links a {
    color: #b9c3cf;
    font-size: 0.95rem;
    transition: color 0.3s ease;
}

.footer-links a:hover {
    color: var(--brand-green);
}

.footer-contact {
    font-size: 0.95rem;
    margin-bottom: 10px;
    color: #b9c3cf;
}

.footer-contact i {
    margin-right: 8px;
    color: var(--brand-green);
}

.footer-social a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    background: rgba(255, 255, 255, 0.1);
    color: #ffffff;
    border-radius: 50%;
    margin-right: 8px;
    transition: background 0.3s ease, color 0.3s ease;
}

.footer-social a:hover {
    background: var(--brand-green);
    color: #ffffff;
}

/* Footer social variant for light backgrounds (modals) */
.footer-social.light a {
    background: var(--muted-2);
    color: var(--brand-dark);
}
.footer-social.light a:hover{
    background: var(--brand-green);
    color: var(--brand-on);
}

.footer-bottom {
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    margin-top: 40px;
    padding-top: 20px;
    text-align: center;
    font-size: 0.9rem;
    color: #b9c3cf;
}


/* PASSWORD STRENGTH */
.password-strength .strength-bar {
    width: 100%;
    height: 6px;
    background: #e5e7eb;
    border-radius: 4px;
    overflow: hidden;
    margin-bottom: 6px;
}

.password-strength .strength-fill {
    height: 100%;
    width: 0%;
    background: #ef4444;
    transition: width 0.3s ease, background 0.3s ease;
}

/* Rules */
.password-rules {
    list-style: none;
    padding-left: 0;
    font-size: 0.9rem;
}

.password-rules li {
    color: #9ca3af;
    margin-bottom: 6px;
}

.password-rules li.valid {
    color: var(--brand-green);
}
.auth-icon {
    font-size: 48px;
    color: var(--brand-green);
}

#about .about-card {
            background-color: #f9f9f9;
            border-radius: 20px;
            padding: 40px 30px;
            margin: 30px auto;
            max-width: 900px;
            box-shadow: 0 4px 20px rgba(0,0,0,0.1);
        }

        /* Mission & Vision hover effect */
        .mission-vision .card:hover {
            transform: scale(1.05);
            transition: transform 0.3s ease;
        }

        /* Team hover effect */
        .team-member img {
            border-radius: 50%;
            transition: transform 0.3s ease;
        }

        .team-member img:hover {
            transform: scale(1.05);
        }

        /* Milestone counters */
        .counter {
            font-weight: 700;
            font-size: 2.5rem;
            color: var(--brand-green);
        }

        /* Centralized brand variables (used across CSS) */
        :root {
            --brand-green: #1f6f41;
            --brand-green-dark: #125033;
            --brand-green-rgb: 31,111,65;
            --brand-green-10: rgba(31,111,65,0.1);
            --brand-green-20: rgba(31,111,65,0.2);
            --brand-green-light: #3a8b5a;
            --brand-green-lighter: #6fb98b;
            --brand-orange: #F7931E;
            --brand-orange-rgb: 247,147,30;
            --brand-dark: #091f32;
            --brand-on: #FFFFFF;
            --bg-muted: #F7F7F7;
            --text-muted: #516171;
            --muted-1: #f9fafb;
            --muted-2: #f9f9f9;
            --muted-border: #e5e7eb;
            --danger: #ef4444;
            --brand-primary: #4cba4a;
            --brand-secondary: #2f855a;
            --brand-light: #f8faf9;
            --brand-gray: #6b7280;
            --shadow-sm: 0 4px 16px rgba(0,0,0,0.04);
            --shadow-md: 0 12px 32px rgba(0,0,0,0.08);
        }

        /* small utility */
        .text-brand-green { color: var(--brand-green) !important; }

