/*=========================================
Mwansa & Mitra
style.css
Part 1
==========================================*/

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

html{
    scroll-behavior:smooth;
}

body{
    font-family:'Poppins',sans-serif;
    background:#f6fbf7;
    color:#243524;
    line-height:1.7;
    overflow-x:hidden;
}

img{
    max-width:100%;
    display:block;
}

a{
    text-decoration:none;
    color:inherit;
}

ul{
    list-style:none;
}

.container{
    width:min(1200px,90%);
    margin:auto;
}

section{
    padding:100px 0;
}

/*=========================================
Colours
==========================================*/

:root{

--green:#1E5631;
--green2:#2F7D44;
--green3:#5DAA68;
--light:#F4FFF5;
--white:#ffffff;
--grey:#666;
--shadow:0 20px 40px rgba(0,0,0,.12);

}

/*=========================================
Header
==========================================*/

header{

position:fixed;

top:0;
left:0;
width:100%;

z-index:999;

background:rgba(255,255,255,.92);

backdrop-filter:blur(16px);

box-shadow:0 5px 20px rgba(0,0,0,.08);

}

.nav-container{

display:flex;

align-items:center;

justify-content:space-between;

height:90px;

}

.logo img{

height:65px;

transition:.3s;

}

.logo img:hover{

transform:scale(1.05);

}

nav ul{

display:flex;

gap:35px;

}

nav a{

font-weight:500;

position:relative;

transition:.3s;

}

nav a::after{

content:"";

position:absolute;

left:0;
bottom:-6px;

height:3px;
width:0;

background:var(--green2);

transition:.35s;

}

nav a:hover{

color:var(--green);

}

nav a:hover::after{

width:100%;

}

.menu-btn{

display:none;

font-size:1.8rem;

cursor:pointer;

color:var(--green);

}

/*=========================================
Hero
==========================================*/

.hero{

position:relative;

height:100vh;

display:flex;

align-items:center;

justify-content:center;

text-align:center;

background:url("../images/hero.jpg")
center center/cover no-repeat;

}

.hero-overlay{

position:absolute;

top:0;
left:0;

width:100%;
height:100%;

background:

linear-gradient(

135deg,

rgba(14,60,31,.85),

rgba(40,120,60,.60)

);

}

.hero-content{

position:relative;

z-index:10;

width:min(850px,90%);

color:white;

animation:fadeUp 1.2s ease;

}

.hero-logo{

width:170px;

margin:0 auto 35px;

filter:drop-shadow(0 15px 25px rgba(0,0,0,.3));

}

.hero h1{

font-size:3.6rem;

font-weight:700;

margin-bottom:25px;

line-height:1.2;

}

.hero p{

font-size:1.2rem;

opacity:.96;

margin-bottom:40px;

}

/*=========================================
Buttons
==========================================*/

.hero-buttons{

display:flex;

justify-content:center;

gap:20px;

flex-wrap:wrap;

}

.btn{

padding:16px 38px;

background:var(--green);

color:white;

border-radius:40px;

font-weight:600;

transition:.35s;

box-shadow:var(--shadow);

}

.btn:hover{

transform:translateY(-5px);

background:var(--green2);

}

.btn-outline{

padding:16px 38px;

border:2px solid white;

border-radius:40px;

font-weight:600;

transition:.35s;

color:white;

}

.btn-outline:hover{

background:white;

color:var(--green);

}

/*=========================================
Section Titles
==========================================*/

.section-title{

text-align:center;

margin-bottom:70px;

}

.section-title h2{

font-size:2.7rem;

color:var(--green);

margin-bottom:12px;

}

.section-title p{

max-width:700px;

margin:auto;

color:#666;

}

/*=========================================
Animations
==========================================*/

@keyframes fadeUp{

0%{

opacity:0;

transform:translateY(50px);

}

100%{

opacity:1;

transform:translateY(0);

}

}

@keyframes float{

0%{

transform:translateY(0);

}

50%{

transform:translateY(-10px);

}

100%{

transform:translateY(0);

}

}

/*=========================================
Glass Card
==========================================*/

.glass{

background:rgba(255,255,255,.20);

backdrop-filter:blur(12px);

border:1px solid rgba(255,255,255,.2);

border-radius:20px;

}

/*=========================================
Top Button
==========================================*/

#topBtn{

position:fixed;

right:30px;

bottom:30px;

width:55px;

height:55px;

border:none;

border-radius:50%;

background:var(--green);

color:white;

font-size:20px;

cursor:pointer;

display:none;

box-shadow:var(--shadow);

transition:.3s;

}

#topBtn:hover{

background:var(--green2);

transform:translateY(-5px);

}

/*=========================================
Stats
=========================================*/

.stats{
    background:linear-gradient(135deg,#1E5631,#2F7D44);
    color:#fff;
}

.stats .container{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:30px;
}

.stat-card{
    background:rgba(255,255,255,.08);
    border:1px solid rgba(255,255,255,.15);
    backdrop-filter:blur(10px);
    border-radius:20px;
    padding:40px;
    text-align:center;
    transition:.35s;
}

.stat-card:hover{
    transform:translateY(-10px);
    background:rgba(255,255,255,.15);
}

.stat-card h2{
    font-size:3rem;
    margin-bottom:10px;
    font-weight:700;
}

.stat-card p{
    opacity:.9;
}

/*=========================================
About
=========================================*/

.about{
    background:#fff;
}

.about-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:80px;
    align-items:center;
}

.about h2{
    color:var(--green);
    font-size:2.6rem;
    margin-bottom:25px;
}

.about p{
    margin-bottom:20px;
    color:#555;
}

.about-image img{
    border-radius:25px;
    box-shadow:0 25px 60px rgba(0,0,0,.18);
    transition:.4s;
}

.about-image img:hover{
    transform:scale(1.02);
}

/*=========================================
Services
=========================================*/

.services{
    background:#f7fbf7;
}

.services-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:35px;
}

.service-card{
    background:white;
    padding:45px 35px;
    border-radius:22px;
    box-shadow:0 15px 35px rgba(0,0,0,.08);
    text-align:center;
    transition:.35s;
    cursor:pointer;
}

.service-card:hover{
    transform:translateY(-12px);
    box-shadow:0 25px 55px rgba(0,0,0,.15);
}

.service-card i{
    font-size:3rem;
    color:var(--green2);
    margin-bottom:25px;
}

.service-card h3{
    color:var(--green);
    margin-bottom:15px;
    font-size:1.4rem;
}

.service-card p{
    color:#666;
}

/*=========================================
Why Choose Us
=========================================*/

.why{
    background:white;
}

.why-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:30px;
}

.why-grid div{
    padding:35px;
    text-align:center;
    border-radius:20px;
    background:#f8fbf8;
    transition:.35s;
}

.why-grid div:hover{
    background:var(--green);
    color:white;
    transform:translateY(-10px);
}

.why-grid i{
    font-size:3rem;
    color:var(--green2);
    margin-bottom:20px;
    transition:.35s;
}

.why-grid div:hover i{
    color:white;
}

.why-grid h3{
    margin-bottom:15px;
}

/*=========================================
Reviews
=========================================*/

.reviews{
    background:linear-gradient(135deg,#1E5631,#3b8b54);
}

.reviews .section-title h2,
.reviews .section-title p{
    color:white;
}

.reviews-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:30px;
}

.review{
    background:white;
    border-radius:22px;
    padding:35px;
    box-shadow:0 20px 45px rgba(0,0,0,.15);
    transition:.35s;
    color:#444;
}

.review:hover{
    transform:translateY(-10px);
}

.review:first-line{
    color:#FFD54F;
    font-size:1.4rem;
}

.review strong{
    display:block;
    margin-top:20px;
    color:var(--green);
}

/*=========================================
Floating Effects
=========================================*/

.service-card,
.review,
.stat-card{
    animation:fadeUp .8s ease;
}

/*=========================================
Quote Form
=========================================*/

.quote{
    background:#f5faf5;
}

.quote h2{
    text-align:center;
    color:var(--green);
    margin-bottom:50px;
    font-size:2.8rem;
}

#quoteForm{
    max-width:900px;
    margin:auto;
    background:white;
    padding:50px;
    border-radius:25px;
    box-shadow:0 20px 50px rgba(0,0,0,.08);
}

#quoteForm input,
#quoteForm textarea{
    width:100%;
    padding:18px 20px;
    margin-bottom:25px;
    border:1px solid #d8e5d8;
    border-radius:12px;
    font-family:Poppins,sans-serif;
    font-size:16px;
    transition:.3s;
    outline:none;
}

#quoteForm textarea{
    min-height:180px;
    resize:vertical;
}

#quoteForm input:focus,
#quoteForm textarea:focus{
    border-color:var(--green2);
    box-shadow:0 0 15px rgba(46,125,80,.15);
}

#quoteForm button{
    width:100%;
    padding:18px;
    border:none;
    background:linear-gradient(135deg,var(--green),var(--green2));
    color:white;
    font-size:18px;
    font-weight:600;
    border-radius:50px;
    cursor:pointer;
    transition:.35s;
}

#quoteForm button:hover{
    transform:translateY(-3px);
    box-shadow:0 15px 35px rgba(0,0,0,.18);
}

/*=========================================
Contact
=========================================*/

.contact{
    background:white;
}

.contact h2{
    text-align:center;
    color:var(--green);
    margin-bottom:60px;
    font-size:2.8rem;
}

.contact-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:35px;
}

.contact-grid div{
    background:#f7fbf7;
    padding:40px;
    border-radius:20px;
    text-align:center;
    transition:.35s;
    box-shadow:0 10px 30px rgba(0,0,0,.05);
}

.contact-grid div:hover{
    transform:translateY(-10px);
    background:var(--green);
    color:white;
}

.contact-grid i{
    font-size:42px;
    color:var(--green2);
    margin-bottom:20px;
    transition:.3s;
}

.contact-grid div:hover i{
    color:white;
}

.contact-grid h3{
    margin-bottom:15px;
}

/*=========================================
Footer
=========================================*/

footer{
    background:#163f23;
    color:white;
    text-align:center;
    padding:60px 0;
}

.footer-logo{
    width:120px;
    margin:auto;
    margin-bottom:25px;
}

footer p{
    opacity:.8;
    font-size:15px;
}

/*=========================================
Scrollbar
=========================================*/

::-webkit-scrollbar{
    width:10px;
}

::-webkit-scrollbar-track{
    background:#eef6ef;
}

::-webkit-scrollbar-thumb{
    background:var(--green2);
    border-radius:20px;
}

::-webkit-scrollbar-thumb:hover{
    background:var(--green);
}

/*=========================================
Responsive
=========================================*/

@media(max-width:1100px){

.services-grid{
grid-template-columns:repeat(2,1fr);
}

.why-grid{
grid-template-columns:repeat(2,1fr);
}

.stats .container{
grid-template-columns:repeat(2,1fr);
}

.contact-grid{
grid-template-columns:1fr;
}

}

@media(max-width:900px){

.about-grid{
grid-template-columns:1fr;
}

.reviews-grid{
grid-template-columns:1fr;
}

.hero h1{
font-size:2.8rem;
}

.hero p{
font-size:1.05rem;
}

nav{
display:none;
}

.menu-btn{
display:block;
}

}

@media(max-width:768px){

.services-grid{
grid-template-columns:1fr;
}

.stats .container{
grid-template-columns:1fr;
}

.hero{
padding:0 25px;
}

.hero h1{
font-size:2.2rem;
}

.section-title h2{
font-size:2.2rem;
}

.about h2,
.quote h2,
.contact h2{
font-size:2.2rem;
}

#quoteForm{
padding:35px 25px;
}

}

@media(max-width:480px){

.hero-logo{
width:120px;
}

.hero-buttons{
flex-direction:column;
}

.btn,
.btn-outline{
width:100%;
}

.stat-card{
padding:25px;
}

.service-card{G
padding:35px 25px;
}

.contact-grid div{
padding:30px;
}

}

/*=========================================
End of CSS
=========================================*/

/* JavaScript Classes */

.hidden{

opacity:0;

transform:translateY(40px);

transition:all .8s ease;

}

.show{

opacity:1;

transform:translateY(0);

}

.mobile-nav{

display:block !important;

position:absolute;

top:90px;

left:0;

width:100%;

background:white;

padding:30px;

box-shadow:0 20px 40px rgba(0,0,0,.1);

}

.mobile-nav ul{

display:flex;

flex-direction:column;

gap:25px;

}

.active{

color:var(--green);

font-weight:600;

}

.pulse{

animation:pulse 1s;

}

@keyframes pulse{

0%{

transform:scale(1);

}

50%{

transform:scale(1.05);

}

100%{

transform:scale(1);

}

}

.loaded{

animation:fadeUp .8s;

}