.problems-section{

    position:relative;
    padding:140px 0;
    background:#0f1318;
    overflow:hidden;

}

.problems-glow{

    position:absolute;

    width:700px;
    height:700px;

    background:#76b852;

    opacity:.08;

    filter:blur(250px);

    top:-250px;
    right:-150px;

}

.problems-header{

    max-width:850px;

    margin:auto;

    text-align:center;

    margin-bottom:80px;

}

.problems-header h2{

    color:white;

    font-size:
    clamp(3rem,6vw,5rem);

    line-height:1.1;

    margin-bottom:25px;

}

.problems-header h2 span{

    display:block;

    color:#76b852;

}

.problems-header p{

    color:#b9c1ca;

    line-height:1.9;

    max-width:700px;

    margin:auto;

}

.problems-grid{

    display:grid;

    grid-template-columns:
    repeat(4,1fr);

    gap:25px;

}

.problem-card{

    position:relative;

    background:
    linear-gradient(
    135deg,
    rgba(255,255,255,.05),
    rgba(255,255,255,.02)
    );

    backdrop-filter:blur(20px);

    border:
    1px solid rgba(255,255,255,.06);

    border-radius:30px;

    padding:40px;

    transition:.5s;

    overflow:hidden;

}

.problem-card::before{

    content:"";

    position:absolute;

    width:150px;
    height:150px;

    border-radius:50%;

    background:
    rgba(118,184,82,.08);

    top:-60px;
    right:-60px;

}

.problem-card:hover{

    transform:
    translateY(-10px);

    border-color:
    rgba(118,184,82,.35);

}

.problem-icon{

    width:75px;
    height:75px;

    border-radius:22px;

    display:flex;

    align-items:center;
    justify-content:center;

    font-size:2rem;

    margin-bottom:25px;

    background:
    rgba(118,184,82,.12);

}

.problem-card h3{

    color:white;

    margin-bottom:15px;

    font-size:1.4rem;

}

.problem-card p{

    color:#b9c1ca;

    line-height:1.8;

}

.solution-banner{

    margin-top:80px;

    display:flex;

    justify-content:space-between;

    align-items:center;

    gap:40px;

    padding:50px;

    border-radius:35px;

    background:
    linear-gradient(
    135deg,
    rgba(118,184,82,.18),
    rgba(255,255,255,.03)
    );

    border:
    1px solid rgba(118,184,82,.15);

}

.solution-content span{

    color:#76b852;

    letter-spacing:2px;

    font-size:.85rem;

    font-weight:700;

}

.solution-content h3{

    color:white;

    font-size:2.2rem;

    margin:15px 0;

}

.solution-content p{

    color:#c5cbd3;

    max-width:700px;

    line-height:1.9;

}

.solution-banner a{

    display:inline-flex;

    align-items:center;
    justify-content:center;

    height:65px;

    padding:0 35px;

    border-radius:60px;

    background:#76b852;

    color:white;

    text-decoration:none;

    font-weight:600;

    transition:.4s;

}

.solution-banner a:hover{

    transform:
    translateY(-4px);

    box-shadow:
    0 20px 40px rgba(118,184,82,.25);

}






















.transformation-section{

    position:relative;

    padding:140px 0;

    background:#f5f5f5;

    overflow:hidden;

}

.transformation-glow{

    position:absolute;

    width:700px;
    height:700px;

    background:#76b852;

    opacity:.08;

    filter:blur(250px);

    top:-200px;
    left:-200px;

}

.transformation-header{

    max-width:900px;

    margin:auto;

    text-align:center;

    margin-bottom:90px;

}

.transformation-header h2{

    font-size:
    clamp(3rem,6vw,5rem);

    line-height:1.1;

    color:#111;

    margin-bottom:25px;

}

.transformation-header h2 span{

    display:block;

    color:#76b852;

}

.transformation-header p{

    color:#66707a;

    max-width:700px;

    margin:auto;

    line-height:1.9;

}

.transformation-wall{

    display:grid;

    gap:35px;

}

.transform-card{

    background:white;

    border-radius:35px;

    overflow:hidden;

    display:grid;

    grid-template-columns:
    1.1fr .9fr;

    min-height:420px;

    box-shadow:
    0 20px 60px rgba(0,0,0,.06);

    transition:.5s;

}

.transform-card:hover{

    transform:
    translateY(-10px);

}

.transform-images{

    display:grid;

    grid-template-columns:
    1fr 1fr;

}

.before,
.after{

    position:relative;

}

.before img,
.after img{

    width:100%;
    height:100%;

    object-fit:cover;

}

.before span,
.after span{

    position:absolute;

    top:20px;
    left:20px;

    padding:10px 18px;

    border-radius:50px;

    font-size:.8rem;

    font-weight:700;

    letter-spacing:1px;

}

.before span{

    background:#111;

    color:white;

}

.after span{

    background:#76b852;

    color:white;

}

.transform-content{

    padding:50px;

    display:flex;

    flex-direction:column;

    justify-content:center;

}

.location-tag{

    display:inline-flex;

    width:max-content;

    padding:10px 18px;

    border-radius:50px;

    background:
    rgba(118,184,82,.12);

    color:#76b852;

    font-size:.85rem;

    font-weight:700;

    margin-bottom:25px;

}

.transform-content h3{

    font-size:2rem;

    color:#111;

    margin-bottom:20px;

}

.transform-content p{

    color:#66707a;

    line-height:1.9;

    margin-bottom:25px;

}

.transform-content ul{

    display:grid;

    gap:12px;

    list-style:none;

    padding:0;

}

.transform-content ul li{

    display:flex;

    align-items:center;

    gap:12px;

    color:#111;

    font-weight:500;

}

.transform-content ul li::before{

    content:"✓";

    color:#76b852;

    font-weight:700;

}






























.lawn-program{

    position:relative;
    padding:140px 0;
    background:#0f1318;
    overflow:hidden;

}

.program-glow{

    position:absolute;

    width:700px;
    height:700px;

    background:#76b852;

    opacity:.08;

    filter:blur(250px);

    top:-250px;
    left:-150px;

}

.program-header{

    text-align:center;
    max-width:850px;
    margin:auto;

    margin-bottom:90px;

}

.program-header h2{

    color:white;

    font-size:
    clamp(3rem,6vw,5rem);

    line-height:1.1;

    margin-bottom:25px;

}

.program-header h2 span{

    display:block;

    color:#76b852;

}

.program-header p{

    color:#b8c1ca;

    max-width:700px;

    margin:auto;

    line-height:1.9;

}

.program-timeline{

    display:flex;

    align-items:center;

    justify-content:center;

    gap:20px;

    margin-bottom:80px;

}

.program-step{

    flex:1;

    background:
    linear-gradient(
    135deg,
    rgba(255,255,255,.05),
    rgba(255,255,255,.02)
    );

    border:
    1px solid rgba(255,255,255,.06);

    backdrop-filter:blur(20px);

    border-radius:30px;

    padding:35px;

    text-align:center;

}

.step-number{

    width:70px;
    height:70px;

    margin:auto;

    margin-bottom:20px;

    border-radius:20px;

    background:
    rgba(118,184,82,.15);

    color:#76b852;

    font-weight:700;

    font-size:1.5rem;

    display:flex;

    align-items:center;
    justify-content:center;

}

.program-step h3{

    color:white;

    margin-bottom:15px;

}

.program-step p{

    color:#b8c1ca;

    line-height:1.8;

}

.timeline-line{

    width:80px;
    height:2px;

    background:
    linear-gradient(
    to right,
    #76b852,
    rgba(118,184,82,.2)
    );

}

.program-features{

    display:grid;

    grid-template-columns:
    repeat(4,1fr);

    gap:25px;

}

.feature-card{

    background:
    rgba(255,255,255,.04);

    border:
    1px solid rgba(255,255,255,.06);

    border-radius:25px;

    padding:30px;

    text-align:center;

    transition:.4s;

}

.feature-card:hover{

    transform:translateY(-8px);

    border-color:#76b852;

}

.feature-card span{

    font-size:2rem;

}

.feature-card h4{

    color:white;

    margin-top:15px;

}

























.lawn-gallery{

    padding:140px 0;

    background:#f5f5f5;

}

.gallery-header{

    text-align:center;

    max-width:850px;

    margin:auto;

    margin-bottom:80px;

}

.gallery-header h2{

    font-size:
    clamp(3rem,6vw,5rem);

    line-height:1.1;

    color:#111;

    margin-bottom:20px;

}

.gallery-header h2 span{

    display:block;

    color:#76b852;

}

.gallery-header p{

    color:#66707a;

    line-height:1.9;

}

.masonry-gallery{

    columns:3 300px;

    column-gap:20px;

}

.gallery-item{

    break-inside:avoid;

    position:relative;

    overflow:hidden;

    border-radius:30px;

    margin-bottom:20px;

    cursor:pointer;

}

.gallery-item img{

    width:100%;

    display:block;

    transition:1s;

}

.gallery-item:hover img{

    transform:scale(1.08);

}

.gallery-info{

    position:absolute;

    left:0;
    right:0;
    bottom:0;

    padding:25px;

    background:
    linear-gradient(
    to top,
    rgba(0,0,0,.85),
    transparent
    );

}

.gallery-info h4{

    color:white;

    margin-bottom:8px;

}

.gallery-info span{

    color:#76b852;

}



















@media(max-width:1100px){
    .transform-card{

        grid-template-columns:1fr;

    }

    .transform-images{

        min-height:350px;

    }


    .problems-grid{

        grid-template-columns:
        repeat(2,1fr);

    }

}

@media(max-width:991px){

    .program-timeline{

        flex-direction:column;

    }

    .timeline-line{

        width:2px;
        height:60px;

    }

    .program-features{

        grid-template-columns:
        repeat(2,1fr);

    }

    .nav-dropdown{
        width:100%;
        flex-direction:column;
        align-items:flex-start;
    }

    .nav-dropdown-toggle{
        width:100%;
        text-align:left;
        padding:12px 0;
    }

    .nav-dropdown-menu{
        position:static;
        width:100%;
        margin-top:10px;

        opacity:1;
        visibility:visible;

        transform:none;

        display:none;

        pointer-events:auto;

        background:rgba(255,255,255,.04);
        border:none;
        box-shadow:none;
    }

    .nav-dropdown.open .nav-dropdown-menu{
        display:grid;
    }

}


@media(max-width:768px){
    .program-features{

        grid-template-columns:1fr;

    }

    .masonry-gallery{

        columns:1;

    }
    .transformation-section{

        padding:100px 0;

    }

    .transformation-header h2{

        font-size:2.5rem;

    }

    .transform-images{

        grid-template-columns:1fr;

    }

    .before,
    .after{

        min-height:220px;

    }

    .transform-content{

        padding:35px 25px;

    }

    .transform-content h3{

        font-size:1.7rem;

    }


    .problems-section{

        padding:100px 0;

    }

    .problems-grid{

        grid-template-columns:1fr;

    }

    .solution-banner{

        flex-direction:column;

        align-items:flex-start;

    }

    .solution-banner a{

        width:100%;

    }

    .problems-header h2{

        font-size:2.5rem;

    }

}