/*========================================

TELCOSAFE SOLUTIONEC

Versión 1.0

========================================*/


:root{

--primary:#0057FF;

--secondary:#081F3F;

--accent:#00B8FF;

--white:#ffffff;

--light:#F5F7FA;

--dark:#101820;

--text:#4d5562;

}


*{

margin:0;

padding:0;

box-sizing:border-box;

}


html{

scroll-behavior:smooth;

}


body{

font-family:'Poppins',sans-serif;

background:#fff;

color:var(--dark);

overflow-x:hidden;

}


section{

padding:100px 0;

}


img{

max-width:100%;

display:block;

}


a{

text-decoration:none;

}


ul{

list-style:none;

}

/*==================================================
                NAVBAR
==================================================*/

#navbar{
    transition: .4s;
    padding:18px 0;
    background: transparent;
}

#navbar.scrolled{
    background: rgba(8,31,63,.95);
    backdrop-filter: blur(12px);
    box-shadow:0 8px 25px rgba(0,0,0,.15);
    padding:10px 0;
}

.navbar-brand img{
    height:55px;
}

.nav-link{
    color:#fff !important;
    font-weight:500;
    margin:0 10px;
    transition:.3s;
}

.nav-link:hover{
    color:var(--accent)!important;
}

.btn-primary{
    background:var(--primary);
    border:none;
    transition:.3s;
}

.btn-primary:hover{
    background:var(--accent);
    transform:translateY(-3px);
}

.mega-menu{
    width:700px;
    border-radius:20px;
}

.mega-menu h6{
    color:var(--secondary);
    font-weight:700;
    margin-bottom:15px;
}

.mega-menu .dropdown-item{
    padding:8px 0;
    color:#555;
}

.mega-menu .dropdown-item:hover{
    background:none;
    color:var(--primary);
}


/*==================================================
                    HERO
==================================================*/

.hero{

    position:relative;

    min-height:100vh;

    display:flex;

    align-items:center;

    overflow:hidden;

    padding-top:120px;

    padding-bottom:90px;

}

.hero-video{

    position:absolute;

    width:100%;

    height:100%;

    object-fit:cover;

    z-index:-3;

}

.hero-overlay{

    position:absolute;

    inset:0;

    background:linear-gradient(
        120deg,
        rgba(5,20,45,.90),
        rgba(8,31,63,.75),
        rgba(0,87,255,.45)
    );

    z-index:-2;

}

.hero-subtitle{

    color:#00B8FF;

    letter-spacing:2px;

    font-weight:600;

}

.hero-title{

    font-size:72px;

    font-weight:800;

    line-height:1.1;

    color:#ffffff;

    margin-top:20px;

}

.hero-text{

    font-size:22px;

    color:#d9d9d9;

    line-height:1.9;

    max-width:700px;

    margin-top:25px;

}

.hero-tags{

    display:flex;

    flex-wrap:wrap;

    gap:10px;

}

.hero-tags span{

    padding:10px 20px;

    border:1px solid rgba(255,255,255,.3);

    color:#fff;

    border-radius:50px;

    backdrop-filter:blur(15px);

    background:rgba(255,255,255,.08);

}

.hero-img{

    width:100%;

    max-width:620px;

    border-radius:30px;

    box-shadow:0 35px 80px rgba(0,87,255,.35);

    animation:flotar 5s ease-in-out infinite;

    margin-left:650px;

    position:relative;

}

.scroll-down{

    position:absolute;

    bottom:35px;

    left:50%;

    transform:translateX(-50%);

    color:#fff;

    font-size:30px;

    animation:subirBajar 2s infinite;

}

@keyframes flotar{

0%,100%{

transform:translateY(0);

}

50%{

transform:translateY(-20px);

}

}

@keyframes subirBajar{

0%,100%{

transform:translate(-50%,0);

}

50%{

transform:translate(-50%,12px);

}

}

.hero-tags{

display:flex;

flex-wrap:wrap;

gap:15px;

margin-top:30px;

}

.hero-tags span{

background:rgba(255,255,255,.08);

border:1px solid rgba(255,255,255,.15);

backdrop-filter:blur(20px);

padding:12px 22px;

border-radius:50px;

color:#fff;

font-size:14px;

transition:.4s;

}

.hero-tags span:hover{

background:var(--primary);

transform:translateY(-6px);

box-shadow:0 15px 30px rgba(0,87,255,.35);

cursor:pointer;

}

/*==============================
        ESTADÍSTICAS
==============================*/

.stats{

    background:#fff;

    margin-top:-70px;

    position:relative;

    z-index:20;

}

.stat-card{

    background:#fff;

    padding:40px 25px;

    border-radius:20px;

    box-shadow:0 20px 50px rgba(0,0,0,.08);

    transition:.4s;

}

.stat-card:hover{

    transform:translateY(-12px);

}

.stat-card h2{

    color:#0057FF;

    font-size:48px;

    font-weight:800;

}

.stat-card p{

    margin-top:10px;

    color:#666;

    font-size:18px;

}

/*=========================================
            ESTADISTICAS
=========================================*/

.stats{

    background:#ffffff;

    padding:90px 0;

}

.stat-card{

    background:#fff;

    border-radius:25px;

    padding:45px 30px;

    text-align:center;

    transition:.4s;

    box-shadow:0 15px 40px rgba(0,0,0,.08);

}

.stat-card:hover{

    transform:translateY(-10px);

    box-shadow:0 20px 50px rgba(0,87,255,.18);

}

.stat-card h2{

    color:var(--primary);

    font-size:60px;

    font-weight:800;

}

.stat-card p{

    color:#666;

    margin-top:10px;

    font-size:22px;

}

/*=========================================
            SERVICIOS PREMIUM
=========================================*/

.services{

    background:#f7f9fc;

    padding:120px 0;

}

.section-subtitle{

    color:#0ea5ff;

    font-weight:700;

    letter-spacing:2px;

}

.section-title{

    font-size:48px;

    font-weight:800;

    margin:15px 0;

}

.section-text{

    color:#666;

    max-width:800px;

    margin:auto;

    margin-bottom:60px;

}

/* TARJETA */

.service-card{

    background:#ffffff;

    border-radius:22px;

    padding:25px;

    height:100%;

    overflow:hidden;

    text-align:center;

    border:1px solid #eef2f7;

    box-shadow:0 15px 40px rgba(0,0,0,.08);

    transition:.45s;

}

.service-card:hover{

    transform:translateY(-12px);

    box-shadow:0 25px 60px rgba(0,87,255,.25);

}

/* IMAGEN */

.service-card img{

    width:100%;

    height:190px;

    object-fit:cover;

    border-radius:15px;

    transition:.5s;

}

.service-card:hover img{

    transform:scale(1.08);

}

/* ICONO */

.service-icon{

    font-size:55px;

    color:#0057FF;

    margin-top:20px;

    margin-bottom:15px;

    transition:.4s;

}

.service-card:hover .service-icon{

    transform:scale(1.15);

    color:#00B8FF;

}

/* TITULO */

.service-card h4{

    font-size:32px;

    font-weight:700;

    margin-bottom:18px;

}

/* TEXTO */

.service-card p{

    color:#666;

    line-height:1.8;

    font-size:18px;

}

/* BOTON */

.service-btn{

    display:inline-block;

    margin-top:20px;

    padding:10px 25px;

    border-radius:50px;

    background:#0057FF;

    color:#fff;

    font-weight:600;

    transition:.3s;

}

.service-btn:hover{

    background:#00B8FF;

    color:#fff;

}

/*=========================================
            WHY US
=========================================*/

.why-us{

padding:120px 0;

background:#fff;

}

.why-item{

margin-top:25px;

font-size:20px;

font-weight:500;

display:flex;

align-items:center;

gap:15px;

}

.why-item i{

color:#0057ff;

font-size:24px;

}

/*=========================================
            PROYECTOS
=========================================*/

/*==================================================
                PROYECTOS
==================================================*/

.project-card{

    position:relative;

    overflow:hidden;

    border-radius:20px;

    cursor:pointer;

    box-shadow:0 15px 40px rgba(0,0,0,.12);

}

.project-card img{

    width:100%;

    height:350px;

    object-fit:cover;

    transition:.5s;

}

.project-overlay{

    position:absolute;

    inset:0;

    background:linear-gradient(to top,
    rgba(8,31,63,.95),
    rgba(8,31,63,.20));

    color:#fff;

    display:flex;

    flex-direction:column;

    justify-content:flex-end;

    padding:30px;

    opacity:0;

    transition:.4s;

}

.project-overlay span{

    color:#00B8FF;

    font-weight:600;

    margin-bottom:10px;

}

.project-overlay h4{

    font-weight:700;

    margin-bottom:15px;

}

.project-overlay p{

    color:#ddd;

    margin-bottom:20px;

}

.project-card:hover img{

    transform:scale(1.12);

}

.project-card:hover .project-overlay{

    opacity:1;

}

/*==========================================
            BRANDS
==========================================*/

.brands{

background:#ffffff;

overflow:hidden;

}

.section-subtitle{

color:#0d6efd;

font-size:15px;

font-weight:700;

letter-spacing:2px;

text-transform:uppercase;

}

.section-title{

font-size:52px;

font-weight:800;

margin-top:15px;

color:#0b1628;

}

.section-description{

max-width:750px;

margin:auto;

margin-top:20px;

font-size:18px;

color:#6b7280;

}

.brands-slider{

overflow:hidden;

position:relative;

padding:30px 0;

}

.brands-track{

display:flex;

align-items:center;

gap:80px;

width:max-content;

animation:sliderBrands 35s linear infinite;

}

.brands-track img{

height:60px;

filter:grayscale(100%);

opacity:.75;

transition:.35s;

}

.brands-track img:hover{

filter:none;

opacity:1;

transform:scale(1.1);

}

@keyframes sliderBrands{

0%{

transform:translateX(0);

}

100%{

transform:translateX(-50%);

}

}

/*=========================================
            TESTIMONIOS
=========================================*/

.testimonials{

    padding:120px 0;

    background:#f8f9fc;

}

.testimonial-card{

    background:#fff;

    border-radius:20px;

    padding:35px;

    text-align:center;

    transition:.4s;

    box-shadow:0 15px 40px rgba(0,0,0,.08);

}

.testimonial-card:hover{

    transform:translateY(-10px);

    box-shadow:0 25px 60px rgba(0,87,255,.20);

}

.testimonial-img{

    width:90px;

    height:90px;

    border-radius:50%;

    object-fit:cover;

    margin:auto;

    margin-bottom:20px;

}

.testimonial-card h5{

    font-weight:700;

}

.testimonial-card small{

    color:#0057FF;

    font-weight:600;

}

.stars{

    color:#FFC107;

    font-size:22px;

    margin-top:15px;

}
/*=========================================
            CTA PREMIUM
=========================================*/

.cta{
    padding:100px 0;
    background:#f5f8fd;
}

.cta-box{

    position:relative;
    overflow:hidden;

    border-radius:35px;

    padding:80px 70px;

    background:linear-gradient(135deg,#0d6efd 0%,#0b56d8 45%,#082f75 100%);

    box-shadow:0 30px 70px rgba(13,110,253,.25);

}

/* Luces de fondo */

.cta-box::before{

    content:"";

    position:absolute;

    width:550px;
    height:550px;

    right:-180px;
    top:-180px;

    border-radius:50%;

    background:rgba(255,255,255,.08);

}

.cta-box::after{

    content:"";

    position:absolute;

    width:280px;
    height:280px;

    left:-100px;
    bottom:-120px;

    border-radius:50%;

    background:rgba(255,255,255,.05);

}

.cta-box>*{

    position:relative;

    z-index:2;

}

.cta-badge{

    display:inline-flex;

    align-items:center;

    gap:10px;

    padding:10px 18px;

    border-radius:50px;

    background:rgba(255,255,255,.12);

    color:#fff;

    font-size:.85rem;

    font-weight:700;

    letter-spacing:1px;

    margin-bottom:25px;

}

.cta h2{

    color:#fff;

    font-size:3.3rem;

    font-weight:800;

    line-height:1.15;

    margin-bottom:20px;

}

.cta-line{

    width:90px;

    height:5px;

    background:#fff;

    border-radius:20px;

    margin-bottom:25px;

}

.cta p{

    color:rgba(255,255,255,.92);

    font-size:1.22rem;

    line-height:1.8;

    margin-bottom:35px;

}

/* Características */

.cta-features{

    display:grid;

    grid-template-columns:repeat(2,1fr);

    gap:18px;

}

.feature{

    display:flex;

    align-items:center;

    gap:14px;

    color:#fff;

    font-weight:600;

}

.feature i{

    width:48px;

    height:48px;

    border-radius:50%;

    background:rgba(255,255,255,.15);

    display:flex;

    align-items:center;

    justify-content:center;

    font-size:18px;

}

/* Botones */

.cta-buttons{

    display:flex;

    flex-direction:column;

    gap:22px;

    align-items:center;

    justify-content:center;

}

.btn-whatsapp,
.btn-quote{

    width:100%;

    max-width:360px;

    display:flex;

    justify-content:center;

    align-items:center;

    gap:12px;

    padding:20px 30px;

    border-radius:60px;

    text-decoration:none;

    font-size:1.25rem;

    font-weight:700;

    transition:.35s;

}

.btn-whatsapp{

    background:#25D366;

    color:#fff;

}

.btn-whatsapp:hover{

    background:#20be5c;

    color:#fff;

    transform:translateY(-6px);

}

.btn-quote{

    background:#fff;

    color:#0d6efd;

}

.btn-quote:hover{

    background:#f1f5ff;

    color:#0d6efd;

    transform:translateY(-6px);

}

.cta-buttons small{

    color:rgba(255,255,255,.85);

    text-align:center;

    font-size:.95rem;

}

/* Responsive */

@media(max-width:991px){

.cta-box{

padding:60px 35px;

text-align:center;

}

.cta h2{

font-size:2.4rem;

}

.cta-line{

margin:auto auto 25px;

}

.cta-features{

grid-template-columns:1fr;

margin-bottom:35px;

}

.cta-buttons{

margin-top:40px;

}

}

@media(max-width:576px){

.cta{

padding:70px 0;

}

.cta-box{

padding:45px 25px;

}

.cta h2{

font-size:2rem;

}

.cta p{

font-size:1rem;

}

.btn-whatsapp,
.btn-quote{

font-size:1rem;

padding:16px 20px;

}

}

/*=========================================
            CONTACTO
=========================================*/

.contact{

    padding:120px 0;

    background:#ffffff;

}

.contact-info{

    background:#081F3F;

    color:#fff;

    padding:40px;

    border-radius:20px;

    height:100%;

}

.contact-info h4{

    margin-bottom:30px;

    font-weight:700;

}

.contact-item{

    display:flex;

    gap:15px;

    margin-bottom:25px;

    align-items:center;

}

.contact-item i{

    font-size:22px;

    color:#00B8FF;

}

.contact-form{

    background:#fff;

    padding:35px;

    border-radius:20px;

    box-shadow:0 15px 40px rgba(0,0,0,.08);

}

.contact-form .form-control{

    border-radius:12px;

    padding:15px;

}

/*==================================================
                    FOOTER PREMIUM
==================================================*/

.footer{

    position:relative;
    overflow:hidden;

    padding:90px 0 35px;

    background:linear-gradient(135deg,#071A39 0%,#0D2F63 45%,#0A1832 100%);

    color:#fff;

}

/* Luces del fondo */

.footer::before{

    content:"";

    position:absolute;

    width:420px;
    height:420px;

    background:#0d6efd;

    opacity:.12;

    filter:blur(120px);

    top:-180px;
    left:-120px;

    border-radius:50%;

}

.footer::after{

    content:"";

    position:absolute;

    width:350px;
    height:350px;

    background:#00d4ff;

    opacity:.08;

    filter:blur(120px);

    right:-100px;
    bottom:-120px;

    border-radius:50%;

}

/* Todo encima */

.footer .container{

    position:relative;
    z-index:2;

}

/* Línea superior */

.footer{

    border-top:4px solid transparent;

    border-image:linear-gradient(90deg,#0d6efd,#00d4ff,#0d6efd)1;

}

/* Logo */

.footer img{

    max-width:220px;

}

/* slogan */

.footer-slogan{

    color:#4da3ff;

    font-weight:700;

    letter-spacing:2px;

    text-transform:uppercase;

    font-size:13px;

}

/* texto */

.footer p{

    color:#d8dfea;

    line-height:1.8;

    font-size:16px;

}

/* títulos */

.footer h5{

    color:#fff;

    font-size:23px;

    font-weight:700;

    margin-bottom:30px;

}

/* listas */

.footer ul{

    padding:0;

    list-style:none;

}

.footer ul li{

    margin-bottom:14px;

}

.footer ul li a{

    color:#d8dfea;

    text-decoration:none;

    transition:.3s;

}

.footer ul li a:hover{

    color:#0d6efd;

    padding-left:8px;

}

/* badges */

.footer-badges{

    display:flex;

    flex-wrap:wrap;

    gap:10px;

}

.footer-badges span{

    background:rgba(255,255,255,.08);

    padding:10px 16px;

    border-radius:40px;

    font-size:14px;

    color:#fff;

}

.footer-badges i{

    color:#00d4ff;

    margin-right:6px;

}

/* contacto */

.footer p a{

    color:#d8dfea;

    text-decoration:none;

    transition:.3s;

}

.footer p a:hover{

    color:#0d6efd;

}

.footer p i{

    width:26px;

    color:#00d4ff;

}

/* redes */

.social-icons{

    display:flex;

    gap:14px;

    flex-wrap:wrap;

}

.social-icons a{

    width:54px;

    height:54px;

    border-radius:50%;

    display:flex;

    justify-content:center;

    align-items:center;

    text-decoration:none;

    color:#fff;

    font-size:22px;

    transition:.35s;

}

/* Colores oficiales */

.facebook{

    background:#1877F2;

}

.instagram{

    background:linear-gradient(45deg,#F58529,#DD2A7B,#8134AF,#515BD4);

}

.linkedin{

    background:#0A66C2;

}

.youtube{

    background:#FF0000;

}

.tiktok{

    background:#111;

}

.whatsapp-social{

    background:#25D366;

}

/* Hover */

.social-icons a:hover{

    transform:translateY(-8px) scale(1.08);

    box-shadow:0 18px 30px rgba(0,0,0,.35);

}

/* Divider */

.footer-divider{

    margin:55px 0 30px;

    border-color:rgba(255,255,255,.08);

}

/* Bottom */

.footer-bottom{

    color:#d8dfea;

    font-size:15px;

}

.footer-bottom a{

    color:#d8dfea;

    text-decoration:none;

    transition:.3s;

}

.footer-bottom a:hover{

    color:#00d4ff;

}

/* Responsive */

@media(max-width:991px){

.footer{

text-align:center;

}

.footer-badges{

justify-content:center;

}

.social-icons{

justify-content:center;

}

.footer-bottom{

text-align:center;

}

}

/*=========================================
        BOTONES FLOTANTES
=========================================*/

.whatsapp{

position:fixed;

right:25px;

bottom:25px;

width:65px;

height:65px;

background:#25D366;

color:#fff;

border-radius:50%;

display:flex;

justify-content:center;

align-items:center;

font-size:34px;

z-index:99999;

box-shadow:0 15px 40px rgba(0,0,0,.25);

transition:.3s;

}

.whatsapp:hover{

transform:scale(1.12);

color:#fff;

}

#topBtn{

position:fixed;

right:25px;

bottom:105px;

width:55px;

height:55px;

border:none;

background:#0057FF;

color:#fff;

border-radius:50%;

display:none;

font-size:20px;

z-index:99999;

transition:.3s;

box-shadow:0 15px 40px rgba(0,0,0,.25);

}

#topBtn:hover{

background:#00B8FF;

}

/*=========================================
            MEGA MENU
=========================================*/

.mega-menu{

width:900px;

left:50% !important;

transform:translateX(-50%);

border:none;

border-radius:20px;

margin-top:20px;

box-shadow:0 25px 60px rgba(0,0,0,.15);

}

.mega-menu h5{

font-weight:700;

margin-bottom:20px;

color:#081F3F;

}

.mega-menu .dropdown-item{

padding:12px 0;

transition:.3s;

font-weight:500;

}

.mega-menu .dropdown-item:hover{

padding-left:12px;

background:none;

color:#0057FF;

}

.hero::before{

content:"";

position:absolute;

width:700px;

height:700px;

background:radial-gradient(circle,#0057ff55,transparent);

right:-250px;

top:-180px;

filter:blur(80px);

z-index:-1;

}

.hero::after{

content:"";

position:absolute;

width:500px;

height:500px;

background:radial-gradient(circle,#00B8FF33,transparent);

left:-180px;

bottom:-200px;

filter:blur(90px);

z-index:-1;

}

/*=========================================
        LINK ACTIVO
=========================================*/

.nav-link.active{

    color:#00B8FF !important;

    font-weight:700;

}

/*=========================================
                BLOG
=========================================*/

.blog{

    padding:120px 0;

    background:#F7F9FC;

}

.blog-card{

    background:#ffffff;

    border-radius:20px;

    overflow:hidden;

    box-shadow:0 15px 40px rgba(0,0,0,.08);

    transition:.4s;

    height:100%;

}

.blog-card:hover{

    transform:translateY(-10px);

    box-shadow:0 25px 60px rgba(0,87,255,.18);

}

.blog-card img{

    width:100%;

    height:240px;

    object-fit:cover;

    transition:.5s;

}

.blog-card:hover img{

    transform:scale(1.08);

}

.blog-content{

    padding:30px;

}

.blog-category{

    display:inline-block;

    background:#0057FF;

    color:#fff;

    padding:8px 18px;

    border-radius:50px;

    font-size:13px;

    font-weight:600;

    margin-bottom:18px;

}

.blog-content h4{

    font-size:24px;

    font-weight:700;

    margin-bottom:15px;

    color:#081F3F;

    line-height:1.4;

}

.blog-content p{

    color:#666;

    line-height:1.8;

    margin-bottom:25px;

}

.blog-btn{

    color:#0057FF;

    font-weight:700;

    text-decoration:none;

    transition:.3s;

}

.blog-btn:hover{

    color:#00B8FF;

}

/*=========================================
          ABOUT INFO BOX
=========================================*/

.about-info-box{

    background:#fff;

    padding:22px;

    border-radius:18px;

    box-shadow:0 15px 40px rgba(0,0,0,.08);

    transition:.35s;

}

.about-info-box:hover{

    transform:translateY(-6px);

    box-shadow:0 20px 45px rgba(0,87,255,.15);

}

.about-icon{

    width:60px;

    height:60px;

    min-width:60px;

    background:#0057ff;

    color:#fff;

    border-radius:50%;

    display:flex;

    align-items:center;

    justify-content:center;

    font-size:22px;

    margin-right:18px;

}

.about-info-box h5{

    font-weight:700;

    color:#081F3F;

    margin-bottom:10px;

}

.about-info-box p{

    margin:0;

    color:#6c757d;

    line-height:1.8;

}

.hero-title-wrapper{

    position:relative;

    display:inline-block;

}

.hero-glow{

    position:absolute;

    width:420px;

    height:420px;

    background:#0d6efd;

    filter:blur(120px);

    opacity:.25;

    top:-120px;

    left:-120px;

    z-index:-1;

    animation:glowMove 6s ease-in-out infinite;

}

@keyframes glowMove{

    0%{

        transform:scale(1);

    }

    50%{

        transform:scale(1.15);

        opacity:.35;

    }

    100%{

        transform:scale(1);

    }

}

/*===============================
        HERO LINES
================================*/

.hero-lines{

    position:absolute;

    inset:0;

    overflow:hidden;

    pointer-events:none;

    z-index:-1;

}

.hero-lines span{

    position:absolute;

    width:2px;

    height:180%;

    background:linear-gradient(

        transparent,

        rgba(0,184,255,.45),

        transparent

    );

    animation:moveLine 8s linear infinite;

}

.hero-lines span:nth-child(1){

    left:12%;

    animation-delay:0s;

}

.hero-lines span:nth-child(2){

    left:28%;

    animation-delay:2s;

}

.hero-lines span:nth-child(3){

    left:45%;

    animation-delay:4s;

}

.hero-lines span:nth-child(4){

    left:63%;

    animation-delay:1s;

}

.hero-lines span:nth-child(5){

    left:80%;

    animation-delay:5s;

}

.hero-lines span:nth-child(6){

    left:94%;

    animation-delay:3s;

}

@keyframes moveLine{

    from{

        transform:translateY(-100%);

    }

    to{

        transform:translateY(100%);

    }

}

/*==================================
        HERO PARTICLES
===================================*/

.hero-particles{

    position:absolute;

    inset:0;

    overflow:hidden;

    pointer-events:none;

    z-index:-1;

}

.hero-particles span{

    position:absolute;

    width:7px;

    height:7px;

    border-radius:50%;

    background:#00B8FF;

    box-shadow:0 0 20px #00B8FF;

    opacity:.5;

    animation:particleMove linear infinite;

}

.hero-particles span:nth-child(1){

    left:8%;

    animation-duration:14s;

    animation-delay:0s;

}

.hero-particles span:nth-child(2){

    left:18%;

    animation-duration:18s;

    animation-delay:4s;

}

.hero-particles span:nth-child(3){

    left:35%;

    animation-duration:16s;

    animation-delay:2s;

}

.hero-particles span:nth-child(4){

    left:52%;

    animation-duration:20s;

    animation-delay:1s;

}

.hero-particles span:nth-child(5){

    left:68%;

    animation-duration:17s;

    animation-delay:6s;

}

.hero-particles span:nth-child(6){

    left:80%;

    animation-duration:22s;

    animation-delay:3s;

}

.hero-particles span:nth-child(7){

    left:90%;

    animation-duration:19s;

    animation-delay:5s;

}

.hero-particles span:nth-child(8){

    left:96%;

    animation-duration:15s;

    animation-delay:7s;

}

@keyframes particleMove{

    from{

        transform:translateY(105vh) scale(.6);

        opacity:0;

    }

    15%{

        opacity:.6;

    }

    85%{

        opacity:.6;

    }

    to{

        transform:translateY(-20vh) scale(1.3);

        opacity:0;

    }

}

/*==========================
        STATS
===========================*/

.stats{

    padding:120px 0;
    background:#f8fbff;
    position:relative;

}

.stat-card{

    background:#fff;
    border-radius:28px;
    padding:70px 35px 40px;
    text-align:center;
    position:relative;
    overflow:hidden;

    box-shadow:0 20px 45px rgba(0,0,0,.08);

    transition:.4s;

}

.stat-card:hover{

    transform:translateY(-12px);

    box-shadow:0 35px 60px rgba(0,87,255,.18);

}

.stat-icon{

    width:90px;
    height:90px;

    background:#fff;

    border-radius:50%;

    display:flex;
    align-items:center;
    justify-content:center;

    position:absolute;

    top:-45px;
    left:50%;

    transform:translateX(-50%);

    font-size:36px;

    color:#0057ff;

    box-shadow:0 15px 40px rgba(0,87,255,.20);

}

.stat-card h2{

    font-size:72px;
    font-weight:800;
    color:#0057ff;
    margin-bottom:10px;

}

.stat-card h5{

    font-size:28px;
    font-weight:700;
    color:#081F3F;
    margin-bottom:20px;

}

.stat-card p{

    color:#6b7280;
    line-height:1.8;
    font-size:18px;

}

.stat-line{

    width:70px;
    height:4px;

    background:#0057ff;

    border-radius:30px;

    margin:0 auto 30px;

}

.stat-card::after{

    content:"";

    position:absolute;

    left:0;
    bottom:0;

    width:100%;
    height:6px;

    background:linear-gradient(90deg,#0057ff,#00b8ff);

}

/*==========================
        SERVICES
==========================*/

.services{

    position:relative;
    background:linear-gradient(180deg,#f8fbff,#ffffff);
    overflow:hidden;

}

.services::before{

    content:"";
    position:absolute;
    width:700px;
    height:700px;
    border-radius:50%;
    background:rgba(0,87,255,.04);
    top:-250px;
    left:-250px;

}

.service-card{

    position:relative;
    background:#fff;
    border-radius:25px;
    padding:45px 35px;
    text-align:center;
    overflow:hidden;
    transition:.45s;
    border:1px solid rgba(0,87,255,.08);
    box-shadow:0 15px 45px rgba(0,0,0,.05);

}

.service-card::before{

    content:"";
    position:absolute;
    top:0;
    left:0;
    width:0%;
    height:5px;
    background:#0057ff;
    transition:.5s;

}

.service-card:hover{

    transform:translateY(-12px);
    box-shadow:0 35px 70px rgba(0,87,255,.18);

}

.service-card:hover::before{

    width:100%;

}

.service-top{

    margin-bottom:20px;

}

.service-badge{

    display:inline-block;
    padding:6px 15px;
    border-radius:30px;
    background:#eef5ff;
    color:#0057ff;
    font-size:13px;
    font-weight:600;

}

.service-icon-box{

    width:95px;
    height:95px;
    margin:auto;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    background:linear-gradient(135deg,#0057ff,#00b8ff);
    color:#fff;
    margin-bottom:25px;
    transition:.4s;

}

.service-card:hover .service-icon-box{

    transform:rotate(-10deg) scale(1.12);

}

.service-icon{

    font-size:42px;

}

.service-card h4{

    font-size:34px;
    font-weight:800;
    margin-bottom:18px;

}

.service-card p{

    color:#666;
    line-height:1.8;
    min-height:120px;

}

.service-btn{

    display:inline-flex;
    align-items:center;
    gap:8px;
    padding:12px 26px;
    border-radius:50px;
    background:#0057ff;
    color:#fff;
    text-decoration:none;
    font-weight:700;
    transition:.35s;

}

.service-btn:hover{

    background:#003fb8;
    color:#fff;
    transform:scale(1.05);

}

/*==============================
        ABOUT PREMIUM
==============================*/

.about-image{

    position:relative;

}

.about-floating-card{

    position:absolute;

    bottom:25px;

    right:-20px;

    background:#ffffff;

    padding:18px 22px;

    border-radius:18px;

    display:flex;

    align-items:center;

    gap:15px;

    box-shadow:0 20px 50px rgba(0,87,255,.18);

    transition:.4s;

}

.about-floating-card:hover{

    transform:translateY(-8px);

}

.about-floating-card i{

    width:60px;

    height:60px;

    border-radius:50%;

    display:flex;

    align-items:center;

    justify-content:center;

    background:linear-gradient(135deg,#0057ff,#00b8ff);

    color:#fff;

    font-size:24px;

}

.about-floating-card h4{

    margin:0;

    font-size:28px;

    font-weight:800;

    color:#0057ff;

}

.about-floating-card span{

    font-size:14px;

    color:#666;

}

.title-line{

    width:90px;

    height:4px;

    background:linear-gradient(90deg,#0057ff,#00b8ff);

    border-radius:20px;

}

.about-info-box{

    transition:.35s;

    border-left:4px solid transparent;

}

.about-info-box:hover{

    transform:translateX(8px);

    border-left:4px solid #0057ff;

    box-shadow:0 15px 35px rgba(0,87,255,.10);

}

.project-features{

    display:flex;

    flex-direction:column;

    gap:8px;

    margin-top:18px;

}

.project-features span{

    color:#fff;

    font-size:.92rem;

    display:flex;

    align-items:center;

    gap:10px;

    opacity:.95;

}

.project-features i{

    color:#2DA8FF;

    width:18px;

}

.project-category{

    display:inline-block;

    background:#0d6efd;

    color:#fff;

    padding:8px 18px;

    border-radius:40px;

    font-size:.85rem;

    font-weight:600;

    margin-bottom:18px;

}

.project-card{

    overflow:hidden;

    border-radius:20px;

}

.project-card img{

    width:100%;

    height:320px;

    object-fit:cover;

    transition:.6s;

}

.project-card:hover img{

    transform:scale(1.08);

}

.blog-hero{

background:linear-gradient(135deg,#081F3F,#0d6efd);

padding:90px 0;

color:#fff;

position:relative;

overflow:hidden;

}

.blog-hero::before{

content:"";

position:absolute;

width:500px;

height:500px;

background:rgba(255,255,255,.05);

border-radius:50%;

right:-120px;

top:-120px;

}

.blog-logo{

height:90px;

margin-bottom:20px;

}

.blog-back{

display:inline-flex;

align-items:center;

gap:10px;

padding:12px 22px;

background:rgba(255,255,255,.15);

color:#fff;

border-radius:50px;

text-decoration:none;

font-weight:600;

transition:.3s;

}

.blog-back:hover{

background:#fff;

color:#0d6efd;

}

.blog-mini-title{

display:block;

margin-top:25px;

font-weight:700;

letter-spacing:3px;

color:#8fd0ff;

}

.blog-title{

font-size:60px;

font-weight:800;

margin:15px 0;

line-height:1.1;

}

.blog-description{

font-size:20px;

opacity:.95;

margin-bottom:35px;

}

.blog-search{

max-width:650px;

}

.blog-search .form-control{

height:65px;

border:none;

font-size:18px;

}

.blog-search .input-group-text{

background:#fff;

border:none;

font-size:22px;

padding:0 25px;

}

/*==================================
            BLOG CARDS
===================================*/

.blog-card{

background:#fff;

border-radius:25px;

overflow:hidden;

box-shadow:0 15px 45px rgba(0,0,0,.08);

transition:.4s;

height:100%;

}

.blog-card:hover{

transform:translateY(-12px);

box-shadow:0 30px 70px rgba(13,110,253,.18);

}

.blog-image{

position:relative;

overflow:hidden;

}

.blog-image img{

width:100%;

height:260px;

object-fit:cover;

transition:.5s;

}

.blog-card:hover img{

transform:scale(1.08);

}

.blog-category{

position:absolute;

top:18px;

left:18px;

background:#0d6efd;

color:#fff;

padding:8px 18px;

border-radius:30px;

font-size:13px;

font-weight:600;

}

.blog-content{

padding:28px;

}

.blog-meta{

display:flex;

justify-content:space-between;

margin-bottom:18px;

font-size:14px;

color:#777;

}

.blog-meta i{

color:#0d6efd;

margin-right:6px;

}

.blog-content h4{

font-size:26px;

font-weight:700;

margin-bottom:18px;

}

.blog-content p{

color:#666;

line-height:1.8;

margin-bottom:25px;

}

.blog-btn{

display:inline-flex;

align-items:center;

text-decoration:none;

font-weight:700;

color:#0d6efd;

transition:.3s;

}

.blog-btn:hover{

transform:translateX(6px);

}

/*=========================
        BLOG CTA
==========================*/

.blog-cta{

padding:90px 0;

background:linear-gradient(135deg,#081F3F,#0d6efd);

color:#fff;

}

.blog-cta h2{

font-size:48px;

font-weight:800;

margin:20px 0;

}

.blog-cta p{

font-size:20px;

opacity:.9;

line-height:1.8;

}

/*=========================
        FOOTER
==========================*/

.footer{

background:#081F3F;

color:#fff;

padding:90px 0 40px;

}

.footer h5{

margin-bottom:25px;

font-weight:700;

}

.footer ul{

list-style:none;

padding:0;

}

.footer li{

margin-bottom:12px;

}

.footer a{

color:#cfd8dc;

text-decoration:none;

transition:.3s;

}

.footer a:hover{

color:#2DA8FF;

}

.footer hr{

border-color:rgba(255,255,255,.1);

margin:50px 0 25px;

}

/*==================================================
            EFECTOS PREMIUM BLOG
==================================================*/

/* Fondo tecnológico del Hero */

.blog-hero{

    position:relative;

    overflow:hidden;

}

.blog-hero::after{

    content:"";

    position:absolute;

    width:900px;

    height:900px;

    background:radial-gradient(circle,
    rgba(0,184,255,.18) 0%,
    transparent 70%);

    right:-300px;

    top:-250px;

    animation:heroGlow 8s ease-in-out infinite;

    pointer-events:none;

}

/* Partículas */

.blog-hero .particle{

    position:absolute;

    width:6px;

    height:6px;

    background:#00B8FF;

    border-radius:50%;

    box-shadow:0 0 15px #00B8FF;

    animation:floatParticle 15s linear infinite;

}

/* Líneas tecnológicas */

.blog-hero::before{

    content:"";

    position:absolute;

    inset:0;

    background-image:

    linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),

    linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);

    background-size:60px 60px;

    opacity:.25;

}

/* Logo */

.blog-logo{

    transition:.4s;

}

.blog-logo:hover{

    transform:scale(1.08);

}

/* Buscador */

.blog-search .form-control{

    border-radius:50px;

    padding-left:25px;

    box-shadow:0 15px 35px rgba(0,0,0,.15);

}

.blog-search .input-group-text{

    border-radius:50px 0 0 50px;

}

/* Tarjetas */

.blog-card{

    border:1px solid rgba(0,87,255,.08);

}

.blog-card:hover{

    transform:translateY(-12px);

    box-shadow:

    0 35px 60px rgba(0,87,255,.20);

}

/* Categoría */

.blog-category{

    backdrop-filter:blur(10px);

}

/* Botón */

.blog-btn{

    position:relative;

    overflow:hidden;

}

.blog-btn::before{

    content:"";

    position:absolute;

    left:-100%;

    top:0;

    width:100%;

    height:100%;

    background:rgba(13,110,253,.10);

    transition:.45s;

}

.blog-btn:hover::before{

    left:0;

}

/* CTA */

.blog-cta{

    position:relative;

    overflow:hidden;

}

.blog-cta::before{

    content:"";

    position:absolute;

    width:700px;

    height:700px;

    background:radial-gradient(circle,
    rgba(255,255,255,.08),
    transparent);

    right:-250px;

    top:-200px;

}

/* Footer */

.footer{

    position:relative;

}

.footer::before{

    content:"";

    position:absolute;

    left:0;

    top:0;

    width:100%;

    height:4px;

    background:linear-gradient(90deg,#0057ff,#00B8FF);

}

/* Animaciones */

@keyframes heroGlow{

    0%{

        transform:scale(1);

    }

    50%{

        transform:scale(1.15);

    }

    100%{

        transform:scale(1);

    }

}

@keyframes floatParticle{

    from{

        transform:translateY(120px);

        opacity:0;

    }

    20%{

        opacity:.8;

    }

    80%{

        opacity:.8;

    }

    to{

        transform:translateY(-600px);

        opacity:0;

    }

}

.article-box{
    background:#fff;
    padding:45px;
    border-radius:20px;
    box-shadow:0 15px 40px rgba(0,0,0,.08);
}

.feature-box{
    background:#fff;
    padding:25px;
    border-radius:18px;
    box-shadow:0 10px 25px rgba(0,0,0,.08);
    height:100%;
    transition:.3s;
}

.feature-box:hover{
    transform:translateY(-8px);
}

.article-share{
    background:#fff;
    padding:35px;
    border-radius:20px;
    box-shadow:0 10px 30px rgba(0,0,0,.08);
}

.author-avatar{
    width:90px;
    height:90px;
    border-radius:50%;
    background:#0d6efd;
    color:#fff;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:35px;
    margin:auto;
}

.blog-card{
    border-radius:20px;
    overflow:hidden;
    box-shadow:0 15px 35px rgba(0,0,0,.08);
    transition:.3s;
}

.blog-card:hover{
    transform:translateY(-8px);
}

.blog-card img{
    height:240px;
    object-fit:cover;
}

.blog-content{
    padding:25px;
}

.article-index{
    background:#f8f9fa;
    padding:25px;
    border-left:5px solid #0d6efd;
    border-radius:15px;
}

.article-index ul{
    padding-left:20px;
}

.article-index li{
    margin:10px 0;
}

.article-index a{
    text-decoration:none;
}

.position-sticky{
    top:120px;
}

/*======================================
            SIDEBAR
=======================================*/

.article-sidebar{

position:sticky;

top:120px;

}

.sidebar-card{

background:#fff;

padding:30px;

border-radius:20px;

box-shadow:0 15px 40px rgba(0,0,0,.08);

margin-bottom:25px;

}

.sidebar-card h4{

font-weight:700;

margin-bottom:20px;

}

.sidebar-card ul{

padding:0;

list-style:none;

}

.sidebar-card li{

margin-bottom:15px;

}

.sidebar-card i{

color:#0d6efd;

margin-right:10px;

}

.social-share{

display:flex;

justify-content:space-between;

}

.social-share a{

width:48px;

height:48px;

border-radius:50%;

background:#0d6efd;

color:#fff;

display:flex;

align-items:center;

justify-content:center;

text-decoration:none;

transition:.3s;

}

.social-share a:hover{

transform:translateY(-5px);

}

.info-box{

background:linear-gradient(135deg,#0057ff,#00B8FF);

color:#fff;

padding:35px;

border-radius:20px;

margin:40px 0;

}

.info-box i{

font-size:34px;

margin-bottom:15px;

}

.article-index{

background:#fff;

padding:35px;

border-radius:20px;

box-shadow:0 15px 35px rgba(0,0,0,.08);

}

.article-index ul{

margin-top:20px;

padding-left:18px;

}

.article-index li{

margin-bottom:12px;

}

.article-index a{

text-decoration:none;

color:#333;

font-weight:500;

}

.article-index a:hover{

color:#0d6efd;

}

/*======================================
        DIAGRAMA
=======================================*/

.diagram-box{

background:#fff;

padding:30px;

border-radius:20px;

box-shadow:0 15px 35px rgba(0,0,0,.08);

transition:.35s;

}

.diagram-box:hover{

transform:translateY(-8px);

}

.diagram-box i{

font-size:45px;

color:#0d6efd;

margin-bottom:20px;

}

/*======================================
        TARJETAS
=======================================*/

.tech-card{

background:#fff;

padding:35px;

border-radius:22px;

box-shadow:0 15px 35px rgba(0,0,0,.08);

height:100%;

transition:.35s;

}

.tech-card:hover{

transform:translateY(-10px);

}

.tech-icon{

width:80px;

height:80px;

border-radius:20px;

background:linear-gradient(135deg,#0057ff,#00B8FF);

display:flex;

align-items:center;

justify-content:center;

margin-bottom:20px;

}

.tech-icon i{

color:#fff;

font-size:34px;

}

.wave-box{

background:#fff;

padding:40px;

border-radius:20px;

box-shadow:0 15px 40px rgba(0,0,0,.08);

}

/*==================================
        BENEFICIOS
===================================*/

.benefit-card{

background:#fff;

padding:35px;

border-radius:22px;

box-shadow:0 15px 40px rgba(0,0,0,.08);

height:100%;

transition:.35s;

}

.benefit-card:hover{

transform:translateY(-10px);

}

.benefit-icon{

width:70px;

height:70px;

border-radius:18px;

background:linear-gradient(135deg,#0057ff,#00B8FF);

display:flex;

justify-content:center;

align-items:center;

margin-bottom:20px;

}

.benefit-icon i{

color:#fff;

font-size:28px;

}

/*==================================
        TABLA
===================================*/

.compare-table{

background:#fff;

border-radius:20px;

overflow:hidden;

box-shadow:0 15px 35px rgba(0,0,0,.08);

}

.compare-table thead{

background:#0d6efd;

color:#fff;

}

/*==================================
        CASOS DE USO
===================================*/

.use-card{

background:#fff;

padding:35px;

border-radius:20px;

text-align:center;

box-shadow:0 15px 35px rgba(0,0,0,.08);

transition:.3s;

}

.use-card:hover{

transform:translateY(-8px);

}

.use-card i{

font-size:45px;

color:#0d6efd;

margin-bottom:20px;

}

/*==================================
        CTA
===================================*/

.article-cta{

margin:80px 0;

background:linear-gradient(135deg,#0057ff,#00B8FF);

padding:70px;

border-radius:30px;

text-align:center;

color:#fff;

box-shadow:0 25px 60px rgba(0,87,255,.25);

}

.article-cta h2{

font-size:42px;

font-weight:800;

margin-bottom:20px;

}

.article-cta p{

font-size:20px;

max-width:700px;

margin:auto;

margin-bottom:35px;

}

/*==================================
        AUTOR
===================================*/

.author-card{

background:#fff;

padding:40px;

border-radius:25px;

box-shadow:0 20px 50px rgba(0,0,0,.08);

}

.author-photo{

width:120px;

height:120px;

background:linear-gradient(135deg,#0057ff,#00B8FF);

border-radius:50%;

display:flex;

align-items:center;

justify-content:center;

margin:auto;

}

.author-photo i{

font-size:50px;

color:#fff;

}

/*==================================
        COMPARTIR
===================================*/

.share-section{

text-align:center;

padding:50px 0;

}

.share-buttons{

display:flex;

justify-content:center;

gap:20px;

margin-top:25px;

flex-wrap:wrap;

}

.share-buttons a{

width:60px;

height:60px;

border-radius:50%;

background:#0057ff;

display:flex;

align-items:center;

justify-content:center;

color:#fff;

font-size:22px;

transition:.3s;

text-decoration:none;

}

.share-buttons a:hover{

background:#00B8FF;

transform:translateY(-8px);

}

/*==================================
        TAGS
===================================*/

.tags{

display:flex;

flex-wrap:wrap;

gap:12px;

margin-top:20px;

}

.tags a{

padding:10px 22px;

background:#eef5ff;

color:#0057ff;

border-radius:40px;

text-decoration:none;

font-weight:600;

transition:.3s;

}

.tags a:hover{

background:#0057ff;

color:#fff;

}

/*==================================
        FAQ
===================================*/

.faq-section{

margin-top:80px;

}

.accordion-item{

border:none;

border-radius:15px;

margin-bottom:15px;

overflow:hidden;

box-shadow:0 10px 30px rgba(0,0,0,.08);

}

/*==================================
        RELACIONADOS
===================================*/

.related-card{

background:#fff;

border-radius:20px;

overflow:hidden;

box-shadow:0 15px 40px rgba(0,0,0,.08);

transition:.3s;

height:100%;

}

.related-card:hover{

transform:translateY(-10px);

}

.related-card img{

height:220px;

width:100%;

object-fit:cover;

}

.related-card h4{

font-size:22px;

margin:15px 0;

}

.related-card a{

text-decoration:none;

font-weight:700;

}

/*==================================
        NAV
===================================*/

.article-navigation{

padding:80px 0;

border-top:1px solid #eee;

margin-top:80px;

}

/*==================================
        BARRA PROGRESO
===================================*/

#reading-progress{

position:fixed;

top:0;

left:0;

width:0;

height:5px;

background:linear-gradient(90deg,#0057ff,#00B8FF);

z-index:99999;

}

/*==================================
        ESTADÍSTICAS
===================================*/

.article-stats{

background:#fff;

padding:35px 0;

box-shadow:0 10px 30px rgba(0,0,0,.05);

margin-bottom:60px;

}

.stat-item{

padding:20px;

}

.stat-item i{

font-size:42px;

color:#0057ff;

margin-bottom:15px;

}

.stat-item h5{

font-weight:700;

margin:0;

}

/*==================================================
            EFECTOS PREMIUM ARTÍCULO
==================================================*/

/* Fondo general */

.article-body{

background:#f4f8fc;

}

/* Tarjetas */

.article-card,
.tech-card,
.benefit-card,
.sidebar-card,
.related-card,
.author-card{

transition:all .35s ease;

}

.article-card:hover,
.tech-card:hover,
.benefit-card:hover,
.sidebar-card:hover,
.related-card:hover{

transform:translateY(-8px);

box-shadow:0 25px 60px rgba(0,87,255,.12);

}

/* Imágenes */

.article-image img,
.related-card img,
.hero-article-image{

transition:.5s;

}

.article-image img:hover,
.related-card img:hover{

transform:scale(1.04);

}

/* Botones */

.btn{

transition:.3s;

}

.btn:hover{

transform:translateY(-3px);

box-shadow:0 15px 35px rgba(0,87,255,.25);

}

/* Enlaces */

.article-body a{

transition:.3s;

}

.article-body a:hover{

color:#0d6efd;

}

/* Títulos */

.article-body h2{

margin-top:60px;

margin-bottom:25px;

font-weight:800;

color:#081F3F;

position:relative;

padding-bottom:15px;

}

.article-body h2::after{

content:"";

position:absolute;

left:0;

bottom:0;

width:70px;

height:4px;

background:#0d6efd;

border-radius:20px;

}

/* Scroll suave */

html{

scroll-behavior:smooth;

}

/* Selección */

::selection{

background:#0d6efd;

color:#fff;

}

/* Scroll */

::-webkit-scrollbar{

width:12px;

}

::-webkit-scrollbar-track{

background:#eef3f8;

}

::-webkit-scrollbar-thumb{

background:#0d6efd;

border-radius:30px;

}

::-webkit-scrollbar-thumb:hover{

background:#0050d5;

}

/* Hero */

.article-hero{

position:relative;

overflow:hidden;

}

.article-hero::before{

content:"";

position:absolute;

width:700px;

height:700px;

background:radial-gradient(circle,
rgba(0,184,255,.18),
transparent);

right:-250px;

top:-180px;

animation:heroGlow 7s infinite ease-in-out;

}

/* Animación */

@keyframes heroGlow{

0%{

transform:scale(1);

}

50%{

transform:scale(1.15);

}

100%{

transform:scale(1);

}

}

.tech-card,
.benefit-card,
.related-card,
.sidebar-card,
.article-card{

opacity:0;

transform:translateY(60px);

transition:.7s;

}

.tech-card.show,
.benefit-card.show,
.related-card.show,
.sidebar-card.show,
.article-card.show{

opacity:1;

transform:translateY(0);

}

/*======================================
        MENU ACTIVO
=======================================*/

.article-index ul{

list-style:none;

padding:0;

margin-top:20px;

}

.article-index li{

margin-bottom:12px;

}

.article-index a{

display:block;

padding:12px 18px;

border-radius:10px;

text-decoration:none;

color:#444;

transition:.3s;

}

.article-index a.active{

background:#0d6efd;

color:#fff;

font-weight:700;

}

.article-index a:hover{

background:#eef5ff;

color:#0d6efd;

}

/*======================================
        MARCAS
======================================*/

.brands{

    background:#fff;
    position:relative;
    overflow:hidden;

}

.brands::before{

    content:"";
    position:absolute;
    width:500px;
    height:500px;
    background:radial-gradient(rgba(13,110,253,.08),transparent 70%);
    top:-180px;
    right:-180px;
    border-radius:50%;

}

.brands-slider{

    overflow:hidden;
    position:relative;
    margin-top:50px;
    padding:20px 0;

}

.brands-track{

    display:flex;
    align-items:center;
    gap:70px;
    width:max-content;
    animation:brandsMove 35s linear infinite;

}

.brands-track:hover{

    animation-play-state:paused;

}

.brands-track img{

    height:70px;
    width:auto;
    object-fit:contain;

    opacity:.60;

    filter:grayscale(100%);

    transition:.4s;

}

.brands-track img:hover{

    opacity:1;

    filter:none;

    transform:scale(1.10);

}

@keyframes brandsMove{

    from{

        transform:translateX(0);

    }

    to{

        transform:translateX(-50%);

    }

}

/* Estadísticas */

.brand-stat{

    background:#fff;

    border-radius:18px;

    padding:30px 20px;

    box-shadow:0 10px 35px rgba(0,0,0,.08);

    transition:.35s;

    height:100%;

}

.brand-stat:hover{

    transform:translateY(-8px);

    box-shadow:0 20px 45px rgba(13,110,253,.15);

}

.brand-stat h3{

    color:#0d6efd;

    font-size:38px;

    font-weight:800;

    margin-bottom:10px;

}

.brand-stat p{

    margin:0;

    color:#6c757d;

    font-weight:500;

}

/* Botón */

.brands .btn{

    padding:15px 40px;

    border-radius:50px;

    font-weight:700;

    transition:.35s;

}

.brands .btn:hover{

    transform:translateY(-4px);

    box-shadow:0 15px 30px rgba(13,110,253,.30);

}

/*======================================
        CONTACTO PREMIUM
======================================*/

.contact{

    background:#f5f8fd;

    padding:100px 0;

}

.contact-info{

    background:linear-gradient(135deg,#0d6efd,#0a4cc5,#082f75);

    border-radius:30px;

    padding:50px;

    color:#fff;

    height:100%;

    position:relative;

    overflow:hidden;

    box-shadow:0 20px 50px rgba(13,110,253,.25);

}

/* Luces de fondo */

.contact-info::before{

    content:"";

    position:absolute;

    width:300px;

    height:300px;

    border-radius:50%;

    background:rgba(255,255,255,.08);

    top:-120px;

    right:-120px;

}

.contact-info::after{

    content:"";

    position:absolute;

    width:180px;

    height:180px;

    border-radius:50%;

    background:rgba(255,255,255,.05);

    bottom:-70px;

    left:-70px;

}

.contact-info>*{

    position:relative;

    z-index:2;

}

.contact-item{

    display:flex;

    align-items:flex-start;

    gap:18px;

    margin-bottom:25px;

}

.contact-item i{

    width:55px;

    height:55px;

    background:rgba(255,255,255,.15);

    border-radius:50%;

    display:flex;

    align-items:center;

    justify-content:center;

    font-size:20px;

}

.contact-item strong{

    display:block;

    font-size:16px;

    margin-bottom:5px;

}

.contact-extra div{

    margin-bottom:15px;

}

.contact-extra i{

    color:#8fff8f;

    margin-right:10px;

}

.social-contact{

    display:flex;

    gap:15px;

}

.social-contact a{

    width:48px;

    height:48px;

    border-radius:50%;

    background:rgba(255,255,255,.15);

    display:flex;

    align-items:center;

    justify-content:center;

    color:#fff;

    text-decoration:none;

    transition:.3s;

}

.social-contact a:hover{

    background:#fff;

    color:#0d6efd;

    transform:translateY(-5px);

}

/*======================================
        FORMULARIO
======================================*/

.contact-form{

    background:#fff;

    padding:45px;

    border-radius:30px;

    box-shadow:0 20px 60px rgba(0,0,0,.08);

}

.contact-form .form-control{

    border:none;

    background:#f4f7fc;

    height:58px;

    border-radius:15px;

    font-size:15px;

    box-shadow:none;

}

.contact-form textarea.form-control{

    height:auto;

    padding-top:18px;

}

.contact-form .form-control:focus{

    background:#fff;

    border:2px solid #0d6efd;

    box-shadow:0 0 20px rgba(13,110,253,.15);

}

.input-group-text{

    background:#0d6efd;

    color:#fff;

    border:none;

    border-radius:15px 0 0 15px;

    width:60px;

    justify-content:center;

}

/*======================================
        BOTÓN
======================================*/

.contact-form .btn{

    width:100%;

    height:60px;

    border-radius:50px;

    font-size:18px;

    font-weight:700;

    transition:.35s;

}

.contact-form .btn:hover{

    transform:translateY(-4px);

    box-shadow:0 15px 35px rgba(13,110,253,.30);

}

/*==================================================
                RESPONSIVE GENERAL
==================================================*/

/* Pantallas menores de 1200px */

@media (max-width:1200px){

.section-title{

    font-size:48px;

}

.hero h1{

    font-size:58px;

}

}


/* Tablets */

@media (max-width:991px){

section{

    padding:80px 0;

}

.section-title{

    font-size:40px;

    text-align:center;

}

.section-subtitle{

    text-align:center;

    display:block;

}

.section-text{

    text-align:center;

}

.hero{

    text-align:center;

    padding-top:120px;

}

.hero h1{

    font-size:46px;

    line-height:1.2;

}

.hero p{

    font-size:18px;

}

.hero-buttons{

    justify-content:center;

}

.hero img{

    margin-top:50px;

    max-width:80%;

}

.about-image{

    margin-bottom:40px;

}

.service-card{

    margin-bottom:25px;

}

.project-card{

    margin-bottom:30px;

}

.contact-info{

    margin-bottom:40px;

}

.footer{

    text-align:center;

}

.footer ul{

    margin-bottom:35px;

}

.footer-badges{

    justify-content:center;

}

.social-icons{

    justify-content:center;

}

.footer-bottom .row{

    row-gap:20px;

}

.footer-bottom{

    text-align:center;

}

}


/* Celulares */

@media (max-width:767px){

section{

    padding:70px 0;

}

.section-title{

    font-size:34px;

}

.hero h1{

    font-size:38px;

}

.hero p{

    font-size:17px;

}

.hero img{

    max-width:100%;

}

.btn{

    width:100%;

    margin-bottom:15px;

}

.hero-buttons{

    flex-direction:column;

}

.stats-card{

    margin-bottom:20px;

}

.service-card{

    padding:35px 25px;

}

.project-card{

    margin-bottom:30px;

}

.contact-info{

    padding:35px;

}

.contact-form{

    padding:35px 25px;

}

.footer img{

    height:80px;

}

.social-icons a{

    width:52px;

    height:52px;

}

.whatsapp{

    width:58px;

    height:58px;

    bottom:20px;

    right:20px;

}

#topBtn{

    width:50px;

    height:50px;

    bottom:90px;

    right:20px;

}

}


/* Celulares pequeños */

@media (max-width:480px){

.hero h1{

    font-size:32px;

}

.section-title{

    font-size:30px;

}

.section-text{

    font-size:16px;

}

.service-card{

    padding:30px 20px;

}

.contact-form{

    padding:25px 18px;

}

.contact-info{

    padding:25px;

}

.footer{

    padding:70px 0 30px;

}

.footer h5{

    margin-top:20px;

}

}