/* ==================== PALETA ==================== */

:root{
    --primary:#00bfff;
    --primary2:#008cff;

    --dark:#020b12;
    --dark2:#071d2d;

    --text:#ffffff;
    --gray:#cfcfcf;

    --glass:rgba(255,255,255,.06);
}

/* =================== RESET ======================= */

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
    font-family:'Poppins',sans-serif;
}

html{
    scroll-behavior:smooth;
}

body{
    background:
    radial-gradient(circle at top,#0a2436 0%,#041018 40%,#000 100%);
    color:#fff;
    overflow-x:hidden;
}

/* SCROLL */

::-webkit-scrollbar{
    width:10px;
}

::-webkit-scrollbar-track{
    background:#021018;
}

::-webkit-scrollbar-thumb{
    background:linear-gradient(var(--primary),var(--primary2));
    border-radius:20px;
}

/* ============== MAIN ================= */

main{
    padding-top:110px;
}

/* ================= HEADER ================= */

header{
    width:100%;
    height:110px;

    position:fixed;
    top:0;
    left:0;

    z-index:1000;

    background:rgba(4,12,20,.55);

    -webkit-backdrop-filter:blur(18px);
    backdrop-filter:blur(18px);

    border-bottom:1px solid rgba(255,255,255,.08);

    box-shadow:
    0 10px 35px rgba(0,0,0,.35);

    transition:
    top .4s ease,
    background .4s ease;
}

/* NAVBAR */

.navbar{
    max-width:1400px;
    height:100%;
    margin:auto;

    padding:0 40px;

    display:flex;
    align-items:center;
    justify-content:space-between;
}

/* LOGO */

.logo-container{
    display:flex;
    align-items:center;
    gap:15px;
}

.logo-img{
    width:80px;
    height:80px;

    object-fit:contain;

    background:#fff;

    border-radius:18px;

    padding:6px;

    box-shadow:
    0 0 25px rgba(0,191,255,.35);

    transition:.35s ease;
}

.logo-img:hover{
    transform:scale(1.05) rotate(-2deg);
}

.logo-text h1{
    font-size:24px;
    font-weight:700;
    line-height:1.1;
}

.logo-text span{
    color:var(--primary);

    font-size:15px;
    font-weight:600;

    letter-spacing:4px;
}

/* MENU */

.menu{
    list-style:none;

    display:flex;
    align-items:center;

    gap:30px;
}

.menu li a{
    position:relative;

    color:#fff;

    text-decoration:none;

    display:flex;
    align-items:center;
    gap:8px;

    font-size:16px;
    font-weight:500;

    transition:.3s ease;
}

.menu li a i{
    color:var(--primary);
}

.menu li a:hover{
    color:var(--primary);
}

.menu li a::after{
    content:'';

    position:absolute;

    left:0;
    bottom:-8px;

    width:0%;
    height:2px;

    background:linear-gradient(to right,var(--primary),transparent);

    transition:.35s ease;
}

.menu li a:hover::after{
    width:100%;
}

/* HAMBURGER */

.hamburger{
    display:none;

    color:#fff;

    font-size:30px;

    cursor:pointer;
}

/* =====================================================
   HERO VIDEO
===================================================== */

.promo-video{
    position:relative;

    width:100%;
    height:100vh;

    overflow:hidden;

    display:flex;
    align-items:center;
    justify-content:center;

    background:#000;
}

/* VIDEO */

.promo-video video{
    position:absolute;

    top:50%;
    left:50%;

    width:100%;
    height:100%;

    object-fit:cover;

    transform:translate(-50%,-50%) scale(1.02);

    z-index:0;

    filter:
    brightness(.8)
    contrast(1.08)
    saturate(1.1);
}

/* OVERLAY */

.video-overlay{
    position:absolute;
    inset:0;

    z-index:1;

    background:
    linear-gradient(
        to bottom,
        rgba(0,0,0,.35),
        rgba(0,0,0,.55),
        rgba(0,0,0,.82)
    );
}

/* GLOW */

.video-overlay::before{
    content:'';

    position:absolute;

    width:600px;
    height:600px;

    top:50%;
    left:50%;

    transform:translate(-50%,-50%);

    background:
    radial-gradient(
        circle,
        rgba(0,191,255,.15),
        transparent 70%
    );

    filter:blur(50px);
}

/* CONTENIDO */

.video-content{
    position:relative;

    z-index:3;

    max-width:950px;

    text-align:center;

    padding:20px;
}

/* TITULO */

.video-content h2{
    font-size:72px;
    font-weight:800;

    line-height:1.05;

    margin-bottom:25px;

    letter-spacing:-2px;

    color:#fff;

    text-shadow:
    0 8px 30px rgba(0,0,0,.45),
    0 0 35px rgba(0,191,255,.25);

    animation:fadeUp 1s ease;
}

/* TEXTO */

.video-content p{
    max-width:720px;

    margin:auto auto 35px;

    font-size:22px;
    line-height:1.8;

    color:#e8f7ff;

    text-shadow:
    0 3px 15px rgba(0,0,0,.4);

    animation:fadeUp 1.2s ease;
}

/* BOTON */

.video-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;

    padding:16px 34px;

    border-radius:18px;

    text-decoration:none;

    color:#fff;

    font-size:16px;
    font-weight:600;

    background:
    linear-gradient(
        135deg,
        rgba(0,191,255,.22),
        rgba(0,140,255,.12)
    );

    border:1px solid rgba(0,191,255,.45);

    -webkit-backdrop-filter:blur(14px);
    backdrop-filter:blur(14px);

    box-shadow:
    0 0 25px rgba(0,191,255,.18);

    transition:.35s ease;

    animation:fadeUp 1.4s ease;

    position:relative;
    overflow:hidden;
}

.video-btn::before{
    content:'';

    position:absolute;

    top:0;
    left:-120%;

    width:100%;
    height:100%;

    background:
    linear-gradient(
        120deg,
        transparent,
        rgba(255,255,255,.25),
        transparent
    );

    transition:.7s ease;
}

.video-btn:hover{
    transform:
    translateY(-4px)
    scale(1.03);

    color:#fff;

    border:1px solid rgba(0,191,255,.85);

    box-shadow:
    0 0 35px rgba(0,191,255,.45);
}

.video-btn:hover::before{
    left:120%;
}

/* ANIMACION */

@keyframes fadeUp{

    from{
        opacity:0;
        transform:
        translateY(40px);
    }

    to{
        opacity:1;
        transform:
        translateY(0);
    }
}

/* =====================================================
   PRODUCTS
===================================================== */

.products{
    padding:120px 0;
}

.section-title{
    text-align:center;

    margin-bottom:60px;

    font-size:42px;
    font-weight:800;

    color:#fff;

    text-shadow:
    0 0 25px rgba(0,191,255,.18);
}

/* =====================================================
   PRODUCT CARD
===================================================== */

.product-card{
    position:relative;

    overflow:hidden;

    height:100%;

    padding:25px;

    border-radius:28px;

    background:
    linear-gradient(
        180deg,
        rgba(255,255,255,.12),
        rgba(255,255,255,.04)
    );

    border:1px solid rgba(255,255,255,.08);

    -webkit-backdrop-filter:blur(20px);
    backdrop-filter:blur(20px);

    box-shadow:
    0 15px 40px rgba(0,0,0,.45);

    transition:
    transform .4s ease,
    box-shadow .4s ease,
    border .4s ease;
}

.product-card::before{
    content:'';

    position:absolute;

    width:320px;
    height:320px;

    top:-160px;
    right:-120px;

    background:
    radial-gradient(
        circle,
        rgba(0,191,255,.28),
        transparent 70%
    );

    opacity:0;

    filter:blur(40px);

    transition:.4s ease;
}

.product-card *{
    position:relative;
    z-index:2;
}

.product-card:hover{
    transform:translateY(-12px);

    border:1px solid rgba(0,191,255,.22);

    box-shadow:
    0 0 35px rgba(0,191,255,.12),
    0 25px 60px rgba(0,0,0,.55);
}

.product-card:hover::before{
    opacity:1;
}

/* =====================================================
   CARRUSEL
===================================================== */

.product-carousel{
    position:relative;

    margin-bottom:22px;

    padding:10px;

    border-radius:24px;

    overflow:hidden;

    background:
    radial-gradient(
        circle at center,
        rgba(0,191,255,.08),
        transparent 70%
    );
}

/* IMAGEN */

.product-carousel img{
    width:100%;
    height:340px;

    object-fit:contain;

    transition:
    transform .45s ease,
    filter .45s ease;

    filter:
    drop-shadow(0 18px 40px rgba(0,191,255,.18));
}

.product-card:hover .product-carousel img{
    transform:
    scale(1.06)
    translateY(-4px);

    filter:
    drop-shadow(0 28px 50px rgba(0,191,255,.28));
}

/* FLECHAS */

.product-carousel .carousel-control-prev,
.product-carousel .carousel-control-next{
    position:absolute;

    top:50%;

    width:48px;
    height:48px;

    transform:translateY(-50%);

    border-radius:50%;

    background:rgba(0,0,0,.55);

    border:1px solid rgba(255,255,255,.12);

    -webkit-backdrop-filter:blur(12px);
    backdrop-filter:blur(12px);

    opacity:0;

    transition:.3s ease;

    z-index:20;
}

.product-carousel .carousel-control-prev{
    left:10px;
}

.product-carousel .carousel-control-next{
    right:10px;
}

.product-card:hover .carousel-control-prev,
.product-card:hover .carousel-control-next{
    opacity:1;
}

.product-carousel .carousel-control-prev:hover,
.product-carousel .carousel-control-next:hover{
    transform:
    translateY(-50%)
    scale(1.08);

    background:rgba(0,191,255,.18);

    border:1px solid rgba(0,191,255,.5);

    box-shadow:
    0 0 20px rgba(0,191,255,.4);
}

.product-carousel .carousel-control-prev-icon,
.product-carousel .carousel-control-next-icon{
    filter:
    brightness(0)
    invert(1);
}

/* =====================================================
   TEXTOS
===================================================== */

.product-card h3{
    font-size:24px;
    font-weight:700;

    margin-bottom:14px;
}

.product-desc{
    color:#d9d9d9;

    line-height:1.7;

    margin-bottom:20px;

    font-size:14px;
}

/* FEATURES */

.features{
    display:flex;
    flex-direction:column;
    gap:12px;

    margin-bottom:24px;

    text-align:left;
}

.feature-item{
    display:flex;
    align-items:center;
    gap:12px;

    padding:13px 15px;

    border-radius:15px;

    background:rgba(255,255,255,.04);

    border:1px solid rgba(255,255,255,.06);

    transition:.3s ease;
}

.feature-item:hover{
    transform:translateX(4px);

    background:rgba(0,191,255,.08);

    border:1px solid rgba(0,191,255,.22);
}

.feature-item i{
    color:var(--primary);

    min-width:18px;
}

.feature-item span{
    color:#f1f1f1;

    font-size:14px;
}

/* =====================================================
   PRECIOS
===================================================== */

.price-container{
    position:relative;

    display:flex;
    justify-content:space-between;
    align-items:center;

    margin:24px 0;

    padding:18px 20px;

    border-radius:22px;

    background:
    linear-gradient(
        145deg,
        rgba(255,255,255,.08),
        rgba(255,255,255,.03)
    );

    border:1px solid rgba(255,255,255,.08);

    overflow:hidden;

    transition:.35s ease;
}

.price-container::before{
    content:'';

    position:absolute;
    inset:0;

    background:
    linear-gradient(
        120deg,
        transparent 20%,
        rgba(255,255,255,.08) 50%,
        transparent 80%
    );

    transform:
    translateX(-120%)
    skewX(-25deg);

    animation:shine 5s linear infinite;
}

@keyframes shine{
    100%{
        transform:
        translateX(120%)
        skewX(-25deg);
    }
}

.old-price{
    display:block;

    margin-bottom:6px;

    color:#7f8c98;

    font-size:.9rem;

    text-decoration:line-through;
}

.new-price{
    font-size:30px;
    font-weight:800;

    background:
    linear-gradient(
        135deg,
        #fff,
        #6fe5ff,
        #00bfff
    );

    -webkit-background-clip:text;
    background-clip:text;

    -webkit-text-fill-color:transparent;
}

.new-price small{
    font-size:.9rem;

    -webkit-text-fill-color:#d8d8d8;
}

/* BADGE */

.discount-badge{
    padding:10px 15px;

    border-radius:16px;

    background:
    linear-gradient(
        135deg,
        rgba(255,70,120,.22),
        rgba(255,0,90,.08)
    );

    border:1px solid rgba(255,70,120,.28);

    color:#ff6b9d;

    font-size:.82rem;
    font-weight:700;
}

/* =====================================================
   BOTON
===================================================== */

.btn-detalles{
    display:inline-flex;
    align-items:center;
    justify-content:center;

    width:100%;

    padding:15px 28px;

    border-radius:18px;

    text-decoration:none;

    color:#fff;

    font-size:15px;
    font-weight:600;

    background:
    linear-gradient(
        135deg,
        rgba(0,191,255,.18),
        rgba(0,140,255,.10)
    );

    border:1px solid rgba(0,191,255,.35);

    box-shadow:
    0 0 18px rgba(0,191,255,.18);

    transition:.35s ease;

    position:relative;
    overflow:hidden;
}

.btn-detalles:hover{
    color:#fff;

    transform:translateY(-4px);

    border:1px solid rgba(0,191,255,.8);

    box-shadow:
    0 0 28px rgba(0,191,255,.4);
}

/* =====================================================
   MODAL
===================================================== */

.image-modal-content{
    background:rgba(5,10,18,.88);

    border-radius:28px;

    border:1px solid rgba(255,255,255,.08);

    -webkit-backdrop-filter:blur(24px);
    backdrop-filter:blur(24px);

    overflow:hidden;

    box-shadow:
    0 25px 80px rgba(0,0,0,.65);
}

.image-modal-content img{
    width:100%;

    max-height:85vh;

    object-fit:contain;

    padding:20px;
}

.modal-close{
    position:absolute;

    top:18px;
    right:18px;

    z-index:9999;

    width:50px;
    height:50px;

    border-radius:50%;

    background:rgba(0,0,0,.45);

    transition:.3s ease;
}

.modal-close:hover{
    transform:
    rotate(90deg)
    scale(1.08);

    background:rgba(0,191,255,.25);
}

.product-img{
    cursor:zoom-in;
}

/* =====================================================
   WHATSAPP
===================================================== */

.whatsapp-float{
    position:fixed;

    bottom:25px;
    right:25px;

    width:65px;
    height:65px;

    border-radius:50%;

    background:#25D366;
    color:#fff;

    display:flex;
    align-items:center;
    justify-content:center;

    text-decoration:none;

    font-size:34px;

    z-index:9999;

    box-shadow:
    0 10px 25px rgba(0,0,0,.3);

    animation:whatsappPulse 2s infinite;

    transition:.3s ease;
}

.whatsapp-float:hover{
    transform:scale(1.12);
}

@keyframes whatsappPulse{
    0%{
        box-shadow:0 0 0 0 rgba(37,211,102,.4);
    }

    70%{
        box-shadow:0 0 0 18px rgba(37,211,102,0);
    }

    100%{
        box-shadow:0 0 0 0 rgba(37,211,102,0);
    }
}

/* =====================================================
   FOOTER
===================================================== */

.footer{
    position:relative;

    background:
    linear-gradient(
        180deg,
        #02111c,
        #000
    );

    padding:90px 10% 25px;

    border-top:1px solid rgba(0,191,255,.15);
}

.footer::before{
    content:'';

    position:absolute;

    top:0;
    left:0;

    width:100%;
    height:2px;

    background:linear-gradient(
        to right,
        transparent,
        #00bfff,
        transparent
    );

    box-shadow:
    0 0 18px rgba(0,191,255,.8);

    pointer-events:none;
}

.footer-container{
    display:grid;

    grid-template-columns:
    repeat(auto-fit,minmax(250px,1fr));

    gap:40px;
}

.footer-box h2{
    font-size:28px;

    margin-bottom:20px;
}

.footer-box h3{
    color:var(--primary);

    margin-bottom:20px;

    display:flex;
    align-items:center;
    gap:10px;
}

.footer-box p{
    color:#ccc;

    line-height:1.8;

    margin-bottom:15px;
}

.footer-logo{
    width:100px;

    background:#fff;

    border-radius:20px;

    padding:8px;

    margin-bottom:20px;

    box-shadow:
    0 0 25px rgba(0,191,255,.4);
}

.footer-box a{
    display:flex;
    align-items:flex-start;
    gap:14px;

    color:#ccc;

    text-decoration:none;

    margin-bottom:20px;

    transition:.3s ease;
}

.footer-box a i{
    color:var(--primary);
}

.footer-box a:hover{
    color:var(--primary);

    transform:translateX(4px);
}

/* REDES */

.social-icons{
    display:flex;
    gap:15px;

    margin-top:20px;
}

.social-icons a{
    width:45px;
    height:45px;

    display:flex;
    align-items:center;
    justify-content:center;

    border-radius:50%;

    background:#111;

    color:#fff;

    border:1px solid rgba(255,255,255,.08);

    transition:.3s ease;
}

.social-icons a:hover{
    background:var(--primary);

    color:#000;

    transform:translateY(-5px);

    box-shadow:
    0 0 20px rgba(0,191,255,.5);
}

/* COPYRIGHT */

.footer-bottom{
    margin-top:50px;

    padding-top:20px;

    border-top:1px solid rgba(255,255,255,.08);

    text-align:center;
}

.footer-bottom p{
    color:#888;
}

/* =====================================================
   RESPONSIVE
===================================================== */

@media(max-width:991px){

    .video-content h2{
        font-size:56px;
    }

    .video-content p{
        font-size:19px;
    }

    .product-carousel img{
        height:260px;
    }

    .product-carousel .carousel-control-prev,
    .product-carousel .carousel-control-next{
        opacity:1;
    }
}

@media(max-width:900px){

    .navbar{
        padding:15px 20px;
    }

    .logo-img{
        width:60px;
        height:60px;
    }

    .logo-text h1{
        font-size:18px;
    }

    .logo-text span{
        font-size:12px;
        letter-spacing:2px;
    }

    .hamburger{
        display:block;
    }

    .menu{
        position:absolute;

        top:100%;
        left:0;

        width:100%;

        background:#020b12;

        flex-direction:column;

        padding:30px 0;

        gap:25px;

        display:none;

        border-top:1px solid rgba(255,255,255,.08);
    }

    .menu.active{
        display:flex;
    }
}

@media(max-width:768px){

    .promo-video{
        height:85vh;
    }

    .video-content h2{
        font-size:42px;
    }

    .video-content p{
        font-size:17px;
        line-height:1.7;
    }

    .video-btn{
        padding:14px 28px;
    }

    .section-title{
        font-size:34px;
    }

    .footer{
        padding:70px 20px 20px;
    }

    .whatsapp-float{
        width:58px;
        height:58px;

        font-size:30px;
    }
}

@media(max-width:600px){

    main{
        padding-top:95px;
    }

    header{
        height:95px;
    }

    .promo-video{
        height:78vh;
    }

    .video-content h2{
        font-size:34px;
    }

    .video-content p{
        font-size:15px;
    }

    .products{
        padding:80px 20px;
    }

    .section-title{
        font-size:28px;
    }

    .product-card{
        padding:20px;
    }

    .product-carousel img{
        height:220px;
    }
}