/* ======================================================
   RESET GENERAL
====================================================== */

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

html{
    scroll-behavior:smooth;
}

body{
    font-family:Inter,Arial,sans-serif;
    background:#0f172a;
    color:#e2e8f0;
    line-height:1.7;
}

img{
    max-width:100%;
    display:block;
}

a{
    text-decoration:none;
    color:inherit;
}

ul{
    list-style:none;
}


/* ======================================================
   VARIABLES
====================================================== */

:root{

    --primary:#3b82f6;
    --secondary:#60a5fa;

    --dark:#0f172a;
    --card:#1e293b;
    --light:#f8fafc;

    --border:rgba(255,255,255,.08);

}


/* ======================================================
   ESTILOS GLOBALES
====================================================== */

.container{
    width:90%;
    max-width:1200px;
    margin:auto;
}

section{
    padding:120px 0;
}

h1{
    font-size:2.8rem;
    line-height:1.15;
    margin-bottom:25px;
}

h2{
    font-size:2.5rem;
    margin-bottom:50px;
    text-align:center;
}

p{
    color:#cbd5e1;
}


/* ======================================================
   HEADER / NAVBAR
====================================================== */

.header{

    position:fixed;
    top:0;
    width:100%;

    z-index:1000;

    backdrop-filter:blur(15px);

    background:rgba(15,23,42,.85);

    border-bottom:1px solid var(--border);

}

.navbar{

    height:80px;

    display:flex;
    align-items:center;
    justify-content:space-between;

}

.brand{

    display:flex;
    align-items:center;
    gap:15px;

    font-size:1.2rem;
    font-weight:700;

}

.logo{

    width:50px;
    height:50px;

    object-fit:contain;

    border-radius:50%;
    border:2px solid var(--primary);

}

.nav-menu{

    display:flex;
    gap:35px;

}

.nav-menu a{

    position:relative;

    font-weight:500;

    transition:.3s;

}

.nav-menu a:hover{

    color:var(--secondary);

}

.nav-menu a::after{

    content:"";

    position:absolute;

    left:0;
    bottom:-5px;

    width:0;
    height:2px;

    background:var(--primary);

    transition:.4s;

}

.nav-menu a:hover::after{

    width:100%;

}


/* ======================================================
   HERO
====================================================== */

.hero{

    min-height:100vh;

    display:flex;
    align-items:center;

    padding-top:100px;

}

.hero-content{

    display:grid;

    grid-template-columns:1fr 1fr;

    align-items:center;

    gap:50px;

}

.tag{

    display:inline-block;

    padding:8px 18px;

    border-radius:30px;

    background:rgba(59,130,246,.15);

    margin-bottom:25px;

    color:var(--secondary);

}

.hero-text p{

    font-size:1.1rem;

    margin-bottom:30px;

}


.hero-text{

    max-width:520px;

}

/* Tarjeta visual Hero */

.hero-card{

     width:100%;
    max-width:450px;

    margin:auto;

    padding:55px 40px;

    background:var(--card);

    border:1px solid var(--border);

    border-radius:25px;

    display:flex;
    flex-direction:column;

    align-items:center;

    gap:35px;

    box-shadow:
    0 0 50px rgba(59,130,246,.15);

}

.hero-card img{

     width:220px;

    transition:.4s;

}

.hero-card:hover img{

    transform:scale(1.05);

}

.hero-info{

    display:flex;

    gap:15px;

    flex-wrap:wrap;

    justify-content:center;

}


.hero-image{

    display:flex;

    justify-content:center;

}


.info-box{

    display:flex;

    align-items:center;

    gap:10px;

    padding:12px 18px;

    background:rgba(59,130,246,.15);

    border-radius:30px;

    font-size:.9rem;

}


/* ======================================================
   BOTONES
====================================================== */

.hero-buttons{

    display:flex;

    gap:20px;

    margin-top:30px;

}

.btn{

    padding:14px 28px;

    border-radius:12px;

    background:var(--primary);

    display:inline-block;

    font-weight:600;

    cursor:pointer;

    transition:.4s;

}

.btn:hover{

    transform:translateY(-4px);

    box-shadow:
    0 15px 30px rgba(59,130,246,.35);

}

.btn-outline{

    background:transparent;

    border:1px solid var(--primary);

}


.hero-description{

    max-width:400px;

    font-size:1.1rem;

    margin-bottom:30px;

}



/* ======================================================
   SOBRE MI
====================================================== */

.about-content{

    display:flex;

    align-items:center;

    gap:60px;

    flex-wrap:wrap;

}

.about-image{

    flex:0 0 280px;

}

.about-image img{

    width:280px;
    height:280px;

    object-fit:cover;

    border-radius:20px;

    border:2px solid var(--primary);

    box-shadow:
    0 0 35px rgba(59,130,246,.2);

}

.about-text{

    flex:1;

}

.about-data{

    display:flex;

    gap:15px;

    flex-wrap:wrap;

    margin-top:25px;

}

.about-data span{

    padding:10px 15px;

    border-radius:30px;

    font-size:.9rem;

    background:rgba(59,130,246,.15);

    color:var(--secondary);

}


/* ======================================================
   TARJETAS GENERALES
====================================================== */

.cards{

    display:grid;

    grid-template-columns:
    repeat(auto-fit,minmax(280px,1fr));

    gap:30px;

}

.card{

    background:var(--card);

    padding:35px;

    border-radius:20px;

    border:1px solid var(--border);

    transition:.4s;

}

.card:hover{

    transform:translateY(-10px);

    border-color:var(--primary);

}

.card h3{

    margin-bottom:15px;

}


/* ======================================================
   BENEFICIOS
====================================================== */

.beneficios{

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

}


/* ======================================================
   PROYECTOS
====================================================== */

.projects{

    display:grid;

    grid-template-columns:
    repeat(auto-fit,minmax(340px,1fr));

    gap:35px;

}

.project-card{

    background:var(--card);

    border-radius:25px;

    overflow:hidden;

    border:1px solid var(--border);

    transition:.5s;

}

.project-card:hover{

    transform:translateY(-12px);

    border-color:var(--primary);

}

.project-image{

    height:250px;

    overflow:hidden;

}

.project-image img{

    width:100%;
    height:100%;

    object-fit:cover;

    transition:.7s;

}

.project-card:hover img{

    transform:scale(1.08);

}

.project-content{

    padding:25px;

}


/* ======================================================
   TECNOLOGIAS
====================================================== */

.skills{

    display:flex;

    justify-content:center;

    flex-wrap:wrap;

    gap:15px;

}

.skills span{

    padding:12px 20px;

    background:var(--card);

    border-radius:30px;

    border:1px solid var(--border);

    transition:.3s;

}

.skills span:hover{

    background:var(--primary);

    transform:scale(1.08);

}


/* ======================================================
   CONTACTO
====================================================== */

#contacto{

    text-align:center;

}

.contact-buttons{

    display:flex;

    justify-content:center;

    gap:20px;

    margin-top:30px;

}


/* ======================================================
   FOOTER
====================================================== */
/* ======================================================
   FOOTER
====================================================== */

.footer{

    background:#0b1220;

    border-top:1px solid var(--border);

    padding:70px 0 0;

}

/* Contenedor principal */

.footer-content{

    display:grid;

    grid-template-columns:1.4fr 1fr 1fr;

    gap:80px;

    align-items:start;

    padding-bottom:50px;

}

/* Títulos */

.footer h3,
.footer h4{

    color:var(--light);

    margin-bottom:20px;

}

/* Texto */

.footer p{

    color:#94a3b8;

    line-height:1.8;

}

/* Links rápidos */

.footer-links{

    display:flex;

    flex-direction:column;

    gap:15px;

}

.footer-links a{

    color:#94a3b8;

    transition:.3s;

    width:fit-content;

}

.footer-links a:hover{

    color:var(--secondary);

    transform:translateX(5px);

}

/* Redes */

.footer-social{

    display:flex;

    flex-direction:column;

}

.social-icons{

    display:flex;

    flex-wrap:wrap;

    gap:15px;

    margin-top:10px;

}

.social-icons a{

    width:45px;

    height:45px;

    display:flex;

    justify-content:center;

    align-items:center;

    border-radius:50%;

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

    border:1px solid var(--border);

    transition:.4s;

}

.social-icons a:hover{

    background:var(--primary);

    transform:translateY(-5px);

}

.social-icons i{

    color:white;

}

/* Barra inferior */

.footer-bottom{

    border-top:1px solid var(--border);

    padding:25px;

    text-align:center;

}

.footer-bottom p{

    color:#64748b;

}

/*Whatsapp Flotante*/

.whatsapp-float {
     position: fixed; /* fijo al viewport */
    bottom: 20px;     /* margen desde abajo */
    right: 20px;      /* margen desde la derecha */
    width: 60px;
    height: 60px;
    z-index: 9999;
    cursor: pointer;
    border-radius: 50%;
    background-color: #25D366;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 8px 20px rgba(0,0,0,0.3);
    transition: transform 0.3s ease, box-shadow 0.3s ease;

}

.whatsapp-float img {
    width: 100%;
    height: 100%;
    border-radius: 50%; /* círculo */
    box-shadow: 0 4px 6px rgba(0,0,0,0.3);
}

.whatsapp-float:hover {
    transform: scale(1.1); /* efecto hover */
}



/* ======================================================
   RESPONSIVE
====================================================== */

/* Tablets */

@media (max-width:900px){

    h1{
        font-size:2.5rem;
    }

    h2{
        font-size:2rem;
    }

    section{
        padding:90px 0;
    }

    /* HERO */

    .hero{
        min-height:auto;
        padding-top:150px;
    }

    .hero-content{
        grid-template-columns:1fr;
        text-align:center;
        gap:50px;
    }

    .hero-text{
        max-width:100%;
    }

    .hero-buttons{
        justify-content:center;
        flex-wrap:wrap;
    }

    .hero-card{
        max-width:400px;
    }

    .hero-card img{
        width:180px;
    }

    /* SOBRE MI */

    .about-content{
        flex-direction:column;
        text-align:center;
    }

    .about-data{
        justify-content:center;
    }

    /* FOOTER */

    .footer-content{
        grid-template-columns:1fr;
        text-align:center;
        gap:45px;
    }

    .footer-links{
        align-items:center;
    }

    .social-icons{
        justify-content:center;
    }

}


/* Celulares */

@media (max-width:700px){

    .container{
        width:92%;
    }

    .navbar{
        flex-direction:column;
        height:auto;
        padding:20px 0;
        gap:20px;
    }

    .nav-menu{
        flex-wrap:wrap;
        justify-content:center;
        gap:15px;
    }

    h1{
        font-size:2rem;
    }

    h2{
        font-size:1.8rem;
    }

    p{
        font-size:.95rem;
    }

    .hero-buttons{
        flex-direction:column;
        align-items:center;
    }

    .btn{
        width:100%;
        max-width:260px;
        text-align:center;
    }

    .hero-card{
        padding:35px 25px;
    }

    .info-box{
        width:100%;
        justify-content:center;
    }

    .projects{
        grid-template-columns:1fr;
    }

    .cards{
        grid-template-columns:1fr;
    }

}