*{
margin:0;
padding:0;
box-sizing:border-box;
font-family:'Poppins',sans-serif;
scroll-behavior:smooth;
}

body{
background:#f7fafc;
color:#2d3748;
}

header{

position:fixed;
width:100%;
top:0;
left:0;
background:white;
box-shadow:0 5px 15px rgba(0,0,0,.08);
z-index:999;

}

.container{

width:90%;
max-width:1200px;
margin:auto;

}

nav{

display:flex;
justify-content:space-between;
align-items:center;
height:75px;

}

.logo{

font-size:30px;
font-weight:700;
color:#0d6efd;

}

.logo span{

color:#00b894;

}

nav ul{

display:flex;
list-style:none;
gap:40px;

}

nav ul li a{

text-decoration:none;
font-weight:500;
color:#444;
transition:.3s;

}

nav ul li a:hover{

color:#0d6efd;

}

.menu{

display:none;
font-size:28px;
cursor:pointer;

}

/******** HERO **********/

.hero{

height:100vh;

display:flex;
align-items:center;

background:linear-gradient(135deg,#0d6efd,#00b894);

color:white;

}

.hero-content{

display:grid;
grid-template-columns:1fr 1fr;
gap:60px;
align-items:center;

}

.hero h1{

font-size:55px;
margin-bottom:20px;

}

.hero p{

font-size:20px;
line-height:1.8;
margin-bottom:35px;

}

.btn{

display:inline-block;
padding:15px 35px;
background:white;
color:#0d6efd;
text-decoration:none;
font-weight:600;
border-radius:50px;
transition:.4s;

}

.btn:hover{

transform:translateY(-4px);

}

.hero img{

width:90%;
border-radius:20px;
box-shadow:0 20px 40px rgba(0,0,0,.25);
opacity: 0.6;

}

/************/

section{

padding:100px 0;

}

.title{

text-align:center;
font-size:40px;
margin-bottom:60px;
color:#0d6efd;

}

/******** NOSOTROS ******/

.about{

display:grid;
grid-template-columns:repeat(2,1fr);
gap:60px;
align-items:center;

}

.about img{

width:100%;
border-radius:20px;

}

.about p{

font-size:18px;
line-height:1.9;

}

/******** PRODUCTOS ******/

.cards{

display:grid;
grid-template-columns:repeat(auto-fit,minmax(350px,1fr));
gap:30px;

}

.card{

background:white;
padding:30px;
border-radius:18px;
box-shadow:0 10px 25px rgba(0,0,0,.08);
transition:.4s;

text-align:center;

}

.card:hover{

transform:translateY(-10px);

}

.card img{
    width: 300px;
}
.card i{

font-size:55px;
color:#00b894;
margin-bottom:20px;

}

.card h3{

margin-bottom:15px;

}

/******** CONTACTO ********/

.contact{

display:grid;
grid-template-columns:1fr 1fr;
gap:50px;

}

.contact-info{

display:flex;
flex-direction:column;
gap:20px;
justify-content:center;

}

.contact-info div{

display:flex;
gap:15px;
font-size:18px;

}

.contact-info i{

color:#0d6efd;
font-size:25px;

}

form{

background:white;
padding:35px;
border-radius:20px;
box-shadow:0 10px 30px rgba(0,0,0,.08);

}

form input,
form textarea{

width:100%;
padding:15px;
margin-bottom:20px;
border:1px solid #ddd;
border-radius:10px;
font-size:16px;

}

form textarea{

height:150px;
resize:none;

}

button{

width:100%;
padding:15px;
border:none;
background:#0d6efd;
color:white;
font-size:18px;
border-radius:10px;
cursor:pointer;
transition:.3s;

}

button:hover{

background:#0056d6;

}

footer{

background:#0d6efd;
color:white;
text-align:center;
padding:30px;

}

.wa{
    position:fixed;
    right:20px;
    bottom:20px;
    background:#25D366;
    color:#fff;
    width:60px;
    height:60px;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:30px;
    text-decoration:none
}

/******** RESPONSIVE ******/

@media(max-width:900px){

.hero-content,
.about,
.contact{

grid-template-columns:1fr;

}

.hero{

padding-top:90px;
height:auto;
padding-bottom:70px;

}

.hero h1{

font-size:40px;

}

nav ul{

position:absolute;
top:75px;
left:-100%;
background:white;
width:100%;
flex-direction:column;
padding:30px;
transition:.4s;

}

nav ul.active{

left:0;

}

.menu{

display:block;

}

}