/*==================================================
    VGsof 2026
    Design System
==================================================*/

:root{

    /*=========
        Brand
    =========*/

    --primary:#007BF7;
    --primary-dark:#005FCC;
    --primary-light:#EAF4FF;

    /*=========
        Neutral
    =========*/

    --black:#000000;
    --white:#FFFFFF;

    --gray-50:#FAFAFA;
    --gray-100:#F5F7FA;
    --gray-200:#E5E7EB;
    --gray-300:#D1D5DB;
    --gray-400:#9CA3AF;
    --gray-500:#6B7280;
    --gray-700:#374151;
    --gray-900:#111827;

    /*=========
        Background
    =========*/

    --background:var(--white);
    --surface:#F8FAFC;

    /*=========
        Text
    =========*/

    --text:var(--gray-900);
    --text-light:var(--gray-500);

    /*=========
        Borders
    =========*/

    --border:#E5E7EB;

    /*=========
        Radius
    =========*/

    --radius-sm:8px;
    --radius-md:14px;
    --radius-lg:20px;
    --radius-xl:28px;

    /*=========
        Shadows
    =========*/

    --shadow-sm:0 2px 8px rgba(0,0,0,.05);

    --shadow-md:0 8px 25px rgba(0,0,0,.08);

    --shadow-lg:0 18px 50px rgba(0,0,0,.12);

    /*=========
        Container
    =========*/

    --container:1280px;

    /*=========
        Navbar
    =========*/

    --navbar-height:85px;

    /*=========
        Animation
    =========*/

    --transition:.35s ease;

}

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

html{

    scroll-behavior:smooth;

}

body{

    font-family:'Inter',sans-serif;

    background:var(--background);

    color:var(--text);

    overflow-x:hidden;

}

img{

    display:block;

    max-width:100%;

}

a{

    text-decoration:none;

    color:inherit;

}

ul{

    list-style:none;

}

button{

    border:none;

    outline:none;

    cursor:pointer;

    font-family:inherit;

}

.container{

    width:min(92%, var(--container));

    margin:auto;

}

section{

    padding:100px 0;

}

/*====================================================================================================
    NAVBAR
=====================================================================================================*/

.navbar{

    position:fixed;

    top:0;

    left:0;

    width:100%;

    height:85px;

    background:rgba(0,0,0,.92);

    backdrop-filter:blur(12px);

    z-index:9999;

    transition:.35s;

}

.nav-container{

    height:100%;

    display:flex;

    align-items:center;

    justify-content:space-between;

}

.logo{

    color:#FFF;

    font-size:2rem;

    font-weight:800;

    letter-spacing:-1px;

}
.nav-right{

    display:flex;

    align-items:center;

    gap:40px;

}

.nav-menu ul{

    display:flex;

    gap:45px;

}

.nav-menu a{

    color:#FFFFFF;

    font-size:15px;

    font-weight:500;

    transition:.3s;

    position:relative;

}

.nav-menu a::after{

    content:"";

    position:absolute;

    left:0;

    bottom:-8px;

    width:0;

    height:2px;

    background:#007BF7;

    transition:.3s;

}

.nav-menu a:hover{

    color:#007BF7;

}

.nav-menu a:hover::after{

    width:100%;

}

.btn-primary{

    padding:14px 28px;

    border-radius:50px;

    background:#007BF7;

    color:#FFF;

    font-weight:600;

    transition:.3s;

}

.btn-primary:hover{

    transform:translateY(-2px);

    background:#0067D3;

}

.menu-toggle{

    display:none;

    background:none;

    border:none;

    cursor:pointer;

}

.menu-toggle span{

    display:block;

    width:28px;

    height:3px;

    margin:6px;

    background:#FFF;

    border-radius:5px;

    transition:.35s;

}

@media(max-width:992px){

.nav-menu{

    position:fixed;

    top:85px;

    right:-100%;

    width:300px;

    height:calc(100vh - 85px);

    background:#000;

    transition:.4s;

}

.nav-menu.active{

    right:0;

}

.nav-menu ul{

    flex-direction:column;

    padding:40px;

    gap:30px;

}

.btn-primary{

    display:none;

}

.menu-toggle{

    display:block;

}

}

.menu-toggle.active span:nth-child(1){

    transform:translateY(9px) rotate(45deg);

}

.menu-toggle.active span:nth-child(2){

    opacity:0;

}

.menu-toggle.active span:nth-child(3){

    transform:translateY(-9px) rotate(-45deg);

}

/*=====================================================================================================
            HERO
======================================================================================================*/

#hero{

    position:relative;

    min-height:90vh;

    display:flex;

    align-items:center;

    background-image:url("../img/hero.jpg");

    background-size:cover;

    background-position:center right;

    overflow:hidden;

}

.hero-overlay{

    position:absolute;

    inset:0;

    background:linear-gradient(
        90deg,
        rgba(0,0,0,.92) 0%,
        rgba(0,0,0,.85) 35%,
        rgba(0,0,0,.55) 65%,
        rgba(0,0,0,.25) 100%
    );

}

.hero-content{

    position:relative;

    z-index:2;

}

.hero-text{

    max-width:620px;

    color:#FFF;

}

.hero-badge{

    display:inline-block;

    padding:10px 18px;

    margin-bottom:25px;

    background:rgba(255,255,255,.08);

    border:1px solid rgba(255,255,255,.12);

    border-radius:50px;

    color:#FFF;

    font-size:.90rem;

    backdrop-filter:blur(10px);

}

.hero-text h1{

    font-size:3.8rem;

    line-height:1.15;

    font-weight:800;

    margin-bottom:25px;

}

.hero-text p{

    font-size:1.2rem;

    color:#D6D6D6;

    line-height:1.8;

    margin-bottom:40px;

}

.hero-buttons{

    display:flex;

    gap:18px;

    flex-wrap:wrap;

}

.btn-secondary{

    display:inline-flex;

    align-items:center;

    justify-content:center;

    padding:15px 30px;

    border:2px solid rgba(255,255,255,.25);

    border-radius:50px;

    color:#FFF;

    transition:.3s;

}

.btn-secondary:hover{

    background:#FFF;

    color:#000;

}

@media(max-width:992px){

    #hero{

        min-height:100vh;

        background-position:70% center;

    }

    .hero-text{

        text-align:center;

        margin:auto;

    }

    .hero-text h1{

        font-size:2.8rem;

    }

    .hero-text p{

        font-size:1.05rem;

    }

    .hero-buttons{

        justify-content:center;

    }

}

@media(max-width:576px){

    .hero-text h1{

        font-size:2.2rem;

    }

    .hero-badge{

        font-size:.80rem;

    }

    .hero-text p{

        font-size:1rem;

    }

}

/*====================================================================================================
        SERVICIOS
====================================================================================================*/

#servicios{

    background:var(--surface);

}

.section-title{

    max-width:760px;

    margin:0 auto 70px;

    text-align:center;

}

.section-title span{

    color:var(--primary);

    font-weight:700;

    text-transform:uppercase;

    letter-spacing:1px;

    font-size:.9rem;

}

.section-title h2{

    font-size:2.8rem;

    margin:20px 0;

    color:var(--text);

}

.section-title p{

    color:var(--text-light);

    font-size:1.1rem;

    line-height:1.8;

}

.services-grid{

    display:grid;

    grid-template-columns:repeat(3,1fr);

    gap:30px;

}

.service-card{

    background:#FFF;

    padding:40px;

    border-radius:20px;

    border:1px solid var(--border);

    transition:.35s;

    position:relative;

    overflow:hidden;

}

.service-card::before{

    content:"";

    position:absolute;

    top:0;

    left:0;

    width:100%;

    height:4px;

    background:var(--primary);

    transform:scaleX(0);

    transition:.35s;

}

.service-card:hover{

    transform:translateY(-8px);

    box-shadow:var(--shadow-lg);

}

.service-card:hover::before{

    transform:scaleX(1);

}

.service-icon{

    width:70px;

    height:70px;

    border-radius:18px;

    background:var(--primary-light);

    display:flex;

    align-items:center;

    justify-content:center;

    font-size:2rem;

    margin-bottom:25px;

    transition:.3s;

}

.service-card:hover .service-icon{

    transform:scale(1.1);

}

.service-card h3{

    margin-bottom:18px;

    font-size:1.35rem;

}

.service-card p{

    color:var(--text-light);

    line-height:1.8;

}

@media(max-width:992px){

    .services-grid{

        grid-template-columns:repeat(2,1fr);

    }

}

@media(max-width:768px){

    .services-grid{

        grid-template-columns:1fr;

    }

    .section-title h2{

        font-size:2.2rem;

    }

}

/*================================================================================================
            NOSOTROS
================================================================================================*/

#nosotros{

    background:#FFFFFF;

}

.about-container{

    display:grid;

    grid-template-columns:1fr 1fr;

    gap:70px;

    align-items:center;

    margin-top:70px;

}

.about-image img{

    width:100%;

    border-radius:24px;

    box-shadow:var(--shadow-lg);

}

.about-content h3{

    font-size:2rem;

    margin-bottom:25px;

}

.about-content>p{

    color:var(--text-light);

    line-height:1.9;

    margin-bottom:40px;

}

.mission-vision{

    display:grid;

    grid-template-columns:1fr 1fr;

    gap:25px;

}

.info-card{

    padding:30px;

    border:1px solid var(--border);

    border-radius:18px;

    background:#FFF;

    transition:.35s;

}

.info-card:hover{

    transform:translateY(-6px);

    box-shadow:var(--shadow-md);

}

.info-card h4{

    color:var(--primary);

    margin-bottom:15px;

}

.info-card p{

    color:var(--text-light);

    line-height:1.8;

}

.values{

    display:grid;

    grid-template-columns:repeat(4,1fr);

    gap:25px;

    margin-top:80px;

}

.value-card{

    padding:35px;

    background:var(--surface);

    border-radius:20px;

    border:1px solid var(--border);

    transition:.35s;

}

.value-card:hover{

    transform:translateY(-8px);

    box-shadow:var(--shadow-md);

}

.value-card h4{

    margin-bottom:15px;

    font-size:1.15rem;

}

.value-card p{

    color:var(--text-light);

    line-height:1.8;

}

@media(max-width:992px){

    .about-container{

        grid-template-columns:1fr;

    }

    .mission-vision{

        grid-template-columns:1fr;

    }

    .values{

        grid-template-columns:repeat(2,1fr);

    }

}

@media(max-width:768px){

    .values{

        grid-template-columns:1fr;

    }

    .about-content h3{

        font-size:1.8rem;

    }

}

/*===================================================================================================
            PROCESO
===================================================================================================*/

#proceso{

    background:#0F172A;

    color:#FFF;

}

#proceso .section-title h2,
#proceso .section-title p{

    color:#FFF;

}

#proceso .section-title p{

    opacity:.75;

}

.process{

    position:relative;

    display:grid;

    grid-template-columns:repeat(4,1fr);

    gap:40px;

    margin-top:80px;

}

.process-line{

    position:absolute;

    top:42px;

    left:8%;

    right:8%;

    height:2px;

    background:rgba(255,255,255,.12);

}

.process-step{

    position:relative;

    z-index:2;

    text-align:center;

}

.step-number{

    color:var(--primary);

    font-size:.9rem;

    font-weight:700;

    margin-bottom:20px;

}

.step-icon{

    width:85px;

    height:85px;

    margin:auto;

    border-radius:50%;

    background:#1E293B;

    display:flex;

    align-items:center;

    justify-content:center;

    font-size:2rem;

    border:2px solid var(--primary);

    margin-bottom:25px;

    transition:.35s;

}

.process-step:hover .step-icon{

    background:var(--primary);

    transform:translateY(-8px);

}

.process-step h3{

    margin-bottom:18px;

    font-size:1.35rem;

}

.process-step p{

    color:rgba(255,255,255,.75);

    line-height:1.8;

}

@media(max-width:992px){

    .process{

        grid-template-columns:repeat(2,1fr);

    }

    .process-line{

        display:none;

    }

}

@media(max-width:768px){

    .process{

        grid-template-columns:1fr;

    }

}

/*===========================================================================================
        TECNOLOGÍAS
===========================================================================================*/

#tecnologias{

    background:#FFFFFF;

}

.features-grid{

    display:grid;

    grid-template-columns:repeat(4,1fr);

    gap:30px;

    margin-top:70px;

}

.feature-card{

    background:#FFF;

    padding:35px;

    border-radius:20px;

    border:1px solid var(--border);

    text-align:center;

    transition:.35s;

}

.feature-card:hover{

    transform:translateY(-8px);

    box-shadow:var(--shadow-lg);

}

.feature-icon{

    width:70px;

    height:70px;

    margin:auto;

    margin-bottom:25px;

    border-radius:18px;

    background:var(--primary-light);

    display:flex;

    align-items:center;

    justify-content:center;

    font-size:2rem;

    transition:.35s;

}

.feature-card:hover .feature-icon{

    background:var(--primary);

    color:#FFF;

}

.feature-card h3{

    margin-bottom:18px;

}

.feature-card p{

    color:var(--text-light);

    line-height:1.8;

}

.tech-stack{

    margin-top:90px;

    text-align:center;

}

.tech-stack h3{

    margin-bottom:40px;

    font-size:2rem;

}

.tech-grid{

    display:flex;

    flex-wrap:wrap;

    justify-content:center;

    gap:20px;

}

.tech-item{

    padding:16px 28px;

    border-radius:50px;

    background:var(--surface);

    border:1px solid var(--border);

    font-weight:600;

    transition:.3s;

    cursor:default;

}

.tech-item:hover{

    background:var(--primary);

    color:#FFF;

    border-color:var(--primary);

    transform:translateY(-5px);

}

@media(max-width:992px){

    .features-grid{

        grid-template-columns:repeat(2,1fr);

    }

}

@media(max-width:768px){

    .features-grid{

        grid-template-columns:1fr;

    }

    .tech-stack h3{

        font-size:1.6rem;

    }

}

/*======================================================================================
        TESTIMONIOS
======================================================================================*/

#clientes{

    background:var(--surface);

}

.testimonials{

    margin-top:70px;

    display:grid;

    grid-template-columns:repeat(3,1fr);

    gap:30px;

}

.testimonial-card{

    position:relative;

    background:#FFF;

    padding:40px;

    border-radius:22px;

    border:1px solid var(--border);

    transition:.35s;

    overflow:hidden;

}

.testimonial-card::before{

    content:"";

    position:absolute;

    top:0;

    left:0;

    width:100%;

    height:4px;

    background:var(--primary);

    transform:scaleX(0);

    transition:.35s;

}

.testimonial-card:hover{

    transform:translateY(-10px);

    box-shadow:var(--shadow-lg);

}

.testimonial-card:hover::before{

    transform:scaleX(1);

}

.quote{

    position:absolute;

    top:15px;

    right:25px;

    font-size:6rem;

    color:rgba(0,123,247,.08);

    font-family:Georgia, serif;

    line-height:1;

}

.stars{

    color:#FFC107;

    font-size:1.2rem;

    margin-bottom:25px;

}

.testimonial-text{

    color:var(--text-light);

    line-height:1.9;

    margin-bottom:35px;

    position:relative;

    z-index:2;

}

.client{

    display:flex;

    align-items:center;

    gap:18px;

}

.client-avatar{

    width:60px;

    height:60px;

    border-radius:50%;

    background:var(--primary);

    color:#FFF;

    display:flex;

    align-items:center;

    justify-content:center;

    font-weight:700;

    font-size:1rem;

}

.client h4{

    margin-bottom:5px;

    font-size:1rem;

}

.client span{

    color:var(--text-light);

    font-size:.9rem;

}

@media(max-width:992px){

    .testimonials{

        grid-template-columns:1fr;

    }

}

/*========================================================================================
        TRUST BAR
========================================================================================*/

.trust-bar{

    margin-top:80px;

    background:var(--primary);

    border-radius:24px;

    padding:50px;

    display:grid;

    grid-template-columns:repeat(5,1fr);

    gap:30px;

    text-align:center;

    color:#FFF;

    box-shadow:var(--shadow-lg);

}

.trust-item h3{

    font-size:2.4rem;

    font-weight:800;

    margin-bottom:12px;

}

.trust-item p{

    opacity:.9;

    line-height:1.6;

}

@media(max-width:992px){

    .trust-bar{

        grid-template-columns:repeat(2,1fr);

    }

}

@media(max-width:576px){

    .trust-bar{

        grid-template-columns:1fr;

        padding:40px 30px;

    }

}

/*========================================================================================
            CONTACTO
========================================================================================*/

#contacto{

    background:#0F172A;

    color:#FFF;

}

#contacto .section-title h2,
#contacto .section-title p{

    color:#FFF;

}

#contacto .section-title p{

    opacity:.8;

}

.contact-wrapper{

    display:grid;

    grid-template-columns:40% 60%;

    gap:60px;

    margin-top:70px;

}

.contact-info h3{

    font-size:2rem;

    margin-bottom:20px;

}

.contact-info>p{

    color:rgba(255,255,255,.75);

    line-height:1.8;

    margin-bottom:40px;

}

.contact-item{

    display:flex;

    align-items:center;

    gap:20px;

    margin-bottom:30px;

}

.contact-icon{

    width:60px;

    height:60px;

    background:rgba(255,255,255,.08);

    border:1px solid rgba(255,255,255,.12);

    border-radius:18px;

    display:flex;

    align-items:center;

    justify-content:center;

    font-size:1.5rem;

}

.contact-item strong{

    display:block;

    margin-bottom:6px;

}

.contact-item span{

    color:rgba(255,255,255,.70);

}

.contact-form{

    background:#FFF;

    padding:45px;

    border-radius:24px;

}

.form-row{

    display:grid;

    grid-template-columns:1fr 1fr;

    gap:20px;

    margin-bottom:20px;

}

.contact-form input,
.contact-form select,
.contact-form textarea{

    width:100%;

    padding:16px 18px;

    border:1px solid var(--border);

    border-radius:12px;

    font-size:1rem;

    outline:none;

    transition:.3s;

    font-family:inherit;

}

.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus{

    border-color:var(--primary);

    box-shadow:0 0 0 4px rgba(0,123,247,.15);

}

.contact-form textarea{

    resize:none;

    margin:20px 0 30px;

}

.contact-form .btn-primary{

    width:100%;

    justify-content:center;

}

@media(max-width:992px){

    .contact-wrapper{

        grid-template-columns:1fr;

    }

    .form-row{

        grid-template-columns:1fr;

    }

}

/*========================================================================================
            FOOTER
========================================================================================*/

footer{

    background:#000;

    color:#FFF;

    padding:80px 0 30px;

}

.footer-grid{

    display:grid;

    grid-template-columns:2fr 1fr 1fr 1fr;

    gap:50px;

}

.footer-about h3{

    font-size:2rem;

    margin-bottom:25px;

    color:var(--primary);

}

.footer-about p{

    color:rgba(255,255,255,.70);

    line-height:1.9;

    max-width:420px;

}

.footer-links h4{

    margin-bottom:25px;

    font-size:1.1rem;

}

.footer-links ul{

    display:flex;

    flex-direction:column;

    gap:15px;

}

.footer-links a{

    color:rgba(255,255,255,.70);

    transition:.3s;

}

.footer-links a:hover{

    color:var(--primary);

    padding-left:6px;

}

.footer-links li{

    color:rgba(255,255,255,.70);

}

.footer-bottom{

    margin-top:60px;

    padding-top:25px;

    border-top:1px solid rgba(255,255,255,.08);

    display:flex;

    justify-content:space-between;

    align-items:center;

    flex-wrap:wrap;

    gap:15px;

}

.footer-bottom p{

    color:rgba(255,255,255,.60);

    font-size:.95rem;

}

@media(max-width:992px){

    .footer-grid{

        grid-template-columns:1fr 1fr;

    }

}

@media(max-width:768px){

    .footer-grid{

        grid-template-columns:1fr;

        text-align:center;

    }

    .footer-about p{

        margin:auto;

    }

    .footer-bottom{

        flex-direction:column;

        text-align:center;

    }

}

/*=========================================================================================
        BOTÓN SCROLL TOP
=========================================================================================*/

#scrollTop{

    position:fixed;

    right:30px;

    bottom:30px;

    width:55px;

    height:55px;

    border:none;

    border-radius:50%;

    background:var(--primary);

    color:#FFF;

    font-size:1.4rem;

    cursor:pointer;

    box-shadow:0 12px 35px rgba(0,123,247,.35);

    display:flex;

    justify-content:center;

    align-items:center;

    transition:.35s;

    opacity:0;

    visibility:hidden;

    transform:translateY(20px);

    z-index:999;

}

#scrollTop.show{

    opacity:1;

    visibility:visible;

    transform:translateY(0);

}

#scrollTop:hover{

    transform:translateY(-6px);

    background:#0067d1;

}


/*=========================================================================================
        section-cta
=========================================================================================*/
.section-cta {
    text-align: center;
    margin-top: 40px;
    padding: 30px;
    background: #0f172a;
    border-radius: 12px;
    color: white;
}

.section-cta .btn-primary {
    display: inline-block;
    margin-top: 20px;
}