/* =========================================================
   PALETA / VARIABLES
========================================================= */

:root{
    --primary:#00bfff;
    --primary2:#008cff;
    --dark:#020b12;
    --dark2:#071d2d;
    --text:#fff;
    --gray:#cfcfcf;
    --verde:#08c995;
    --glass:rgba(255,255,255,.06);

    --shadow-blue:
        0 0 25px rgba(0,191,255,.25);

    --shadow-card:
        0 10px 35px rgba(0,0,0,.35);

    --transition:.3s ease;
}

/* =========================================================
   RESET
========================================================= */

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

html{
    scroll-behavior:smooth;
}

body{
    font-family:'Poppins',sans-serif;
    color:var(--text);
    overflow-x:hidden;

    background:
    linear-gradient(
        135deg,
        #03131f 0%,
        #071d2d 30%,
        #041018 60%,
        #000 100%
    );
}

img{
    max-width:100%;
    display:block;
}

a{
    text-decoration:none;
}

ul{
    list-style:none;
}

main{
    padding-top:140px;
}

/* =========================================================
   HEADER
========================================================= */

header{
    position:fixed;
    top:0;
    left:0;
    width:100%;
    height:110px;
    z-index:1000;

    background:rgba(255,255,255,.08);

    backdrop-filter:blur(18px);
    -webkit-backdrop-filter:blur(18px);

    border-bottom:1px solid rgba(0,191,255,.15);

    box-shadow:
    0 8px 30px rgba(0,0,0,.25);

    transition:top .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;

    padding:6px;

    background:#fff;

    border-radius:18px;

    box-shadow:
    0 0 25px rgba(0,191,255,.5);

    transition:var(--transition);
}

.logo-img:hover{
    transform:scale(1.05);
}

.logo-text h1{
    font-size:24px;
    font-weight:700;
    line-height:1;
    letter-spacing:1px;
}

.logo-text span{
    color:var(--primary);

    font-size:16px;
    font-weight:600;
    letter-spacing:4px;
}

/* MENU */

.menu{
    display:flex;
    align-items:center;
    gap:30px;
}

.menu li a{
    position:relative;

    display:flex;
    align-items:center;
    gap:8px;

    color:#fff;

    font-size:17px;
    font-weight:500;

    transition:var(--transition);
}

.menu li a i{
    color:var(--primary);
    font-size:16px;
}

.menu li a:hover{
    color:var(--primary);
}

.menu li a::after{
    content:'';

    position:absolute;
    left:0;
    bottom:-6px;

    width:0;
    height:2px;

    background:var(--primary);

    transition:var(--transition);
}

.menu li a:hover::after{
    width:100%;
}

/* HAMBURGER */

.hamburger{
    display:none;

    position:relative;
    z-index:2000;

    color:#fff;

    font-size:30px;

    cursor:pointer;
}

/* =========================================================
   HERO
========================================================= */

.hero{
    position:relative;
    overflow:hidden;

    padding:100px 20px;

    background:
    linear-gradient(
        135deg,
        rgba(0,191,255,.12),
        rgba(0,140,255,.08)
    );

    border-top:
    1px solid rgba(0,191,255,.15);

    border-bottom:
    1px solid rgba(0,191,255,.15);
}

.hero h2{
    font-size:52px;
    font-weight:800;

    margin-bottom:20px;
}

.hero p{
    color:#cfd9df;

    font-size:18px;

    margin-bottom:30px;
}

/* =========================================================
   PRICE CARD
========================================================= */

.price{
    font-size:38px;
    font-weight:700;
    color:var(--verde);
}

.price-card{
    position:relative;
    overflow:hidden;

    margin-bottom:25px;
    padding:28px;

    border-radius:24px;

    background:
    linear-gradient(
        135deg,
        rgba(255,255,255,.08),
        rgba(0,191,255,.08)
    );

    border:
    1px solid rgba(0,191,255,.25);

    backdrop-filter:blur(16px);
    -webkit-backdrop-filter:blur(16px);

    box-shadow:
    var(--shadow-card),
    0 0 25px rgba(0,191,255,.08);
}

.price-card::before{
    content:'';

    position:absolute;
    top:-80px;
    right:-80px;

    width:180px;
    height:180px;

    background:
    radial-gradient(
        circle,
        rgba(0,191,255,.28),
        transparent 70%
    );
}

/* TOP */

.price-top{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:15px;

    margin-bottom:12px;
}

.old-price{
    color:#9fb3c8;

    font-size:15px;

    text-decoration:line-through;

    opacity:.8;
}

/* BADGE */

.discount-badge{
    display:flex;
    align-items:center;
    gap:8px;

    padding:8px 14px;

    border-radius:50px;

    background:
    linear-gradient(
        135deg,
        #ff3d6e,
        #ff1744
    );

    color:#fff;

    font-size:13px;
    font-weight:700;
    letter-spacing:.5px;

    box-shadow:
    0 0 20px rgba(255,23,68,.35);
}

/* PRECIO */

.price-main{
    font-size:52px;
    font-weight:800;
    line-height:1;

    text-shadow:
    0 0 18px rgba(0,191,255,.35);
}

.price-main span{
    margin-left:6px;

    color:var(--primary);

    font-size:18px;
    font-weight:600;
}

.price-note{
    margin-top:14px;

    color:#b8c7d1;

    font-size:14px;
    letter-spacing:.4px;
}

/* =========================================================
   BUTTONS
========================================================= */

.btn-premium,
.btn-detalles{
    position:relative;
    overflow:hidden;

    display:inline-flex;
    align-items:center;
    justify-content:center;

    font-weight:600;

    transition:var(--transition);
}

/* BTN PREMIUM */

.btn-premium{
    padding:16px 38px;

    border:none;
    border-radius:40px;

    background:
    linear-gradient(
        135deg,
        var(--primary),
        var(--primary2)
    );

    color:#fff;

    box-shadow:
    0 0 20px rgba(0,191,255,.35);
}

.btn-premium:hover{
    transform:translateY(-3px);

    box-shadow:
    0 0 30px rgba(0,191,255,.6);
}

/* BTN DETALLES */

.btn-detalles{
    margin-top:18px;
    padding:14px 28px;

    border-radius:16px;

    font-size:15px;

    color:#fff;

    background:
    linear-gradient(
        135deg,
        rgba(0,191,255,.18),
        rgba(0,140,255,.12)
    );

    border:
    1px solid rgba(0,191,255,.35);

    backdrop-filter:blur(12px);
    -webkit-backdrop-filter:blur(12px);

    box-shadow:
    0 0 18px rgba(0,191,255,.18),
    inset 0 0 12px rgba(255,255,255,.04);
}

.btn-detalles::before{
    content:'';

    position:absolute;
    top:0;
    left:-120%;

    width:100%;
    height:100%;

    background:
    linear-gradient(
        120deg,
        transparent,
        rgba(255,255,255,.22),
        transparent
    );

    transition:.6s ease;
}

.btn-detalles:hover{
    transform:
    translateY(-4px)
    scale(1.03);

    background:
    linear-gradient(
        135deg,
        rgba(0,191,255,.32),
        rgba(0,140,255,.22)
    );

    border:
    1px solid rgba(0,191,255,.75);

    box-shadow:
    0 0 24px rgba(0,191,255,.45),
    0 0 55px rgba(0,191,255,.20);
}

.btn-detalles:hover::before{
    left:120%;
}

/* =========================================================
   CAROUSEL / GALLERY
========================================================= */

.carousel img{
    border-radius:16px;
    cursor:zoom-in;
}

/* MODAL */

.image-modal{
    position:fixed;
    inset:0;

    z-index:99999;

    display:flex;
    align-items:center;
    justify-content:center;

    padding:20px;

    background:rgba(0,0,0,.92);

    opacity:0;
    visibility:hidden;

    transition:var(--transition);
}

.image-modal.active{
    opacity:1;
    visibility:visible;
}

.modal-img{
    max-width:90%;
    max-height:90%;

    border-radius:20px;

    box-shadow:
    0 0 40px rgba(0,191,255,.35);

    transform:scale(.8);

    transition:var(--transition);
}

.image-modal.active .modal-img{
    transform:scale(1);
}

.close-modal{
    position:absolute;
    top:30px;
    right:40px;

    color:#fff;

    font-size:50px;

    cursor:pointer;

    transition:var(--transition);
}

.close-modal:hover{
    color:var(--primary);

    transform:scale(1.1);
}

/* FLECHAS */

.carousel-control-prev,
.carousel-control-next{
    top:50%;

    width:55px;
    height:55px;

    transform:translateY(-50%);

    border-radius:50%;

    background:
    rgba(0,191,255,.12);

    border:
    1px solid rgba(0,191,255,.35);

    backdrop-filter:blur(10px);

    transition:var(--transition);
}

.carousel-control-prev:hover,
.carousel-control-next:hover{
    background:
    rgba(0,191,255,.25);

    box-shadow:
    0 0 25px rgba(0,191,255,.45);

    transform:
    translateY(-50%)
    scale(1.08);
}

.carousel-control-prev-icon,
.carousel-control-next-icon{
    width:22px;
    height:22px;

    filter:
    brightness(0)
    saturate(100%)
    invert(61%)
    sepia(96%)
    saturate(2237%)
    hue-rotate(165deg)
    brightness(101%)
    contrast(101%);
}

/* =========================================================
   FEATURES
========================================================= */

.feature{
    min-height:220px;

    padding:30px;

    text-align:center;

    border-radius:18px;

    background:
    rgba(255,255,255,.05);

    border:
    1px solid rgba(0,191,255,.15);

    backdrop-filter:blur(12px);
    -webkit-backdrop-filter:blur(12px);

    box-shadow:
    0 10px 30px rgba(0,0,0,.35);

    transition:.35s ease;
}

.feature:hover{
    transform:translateY(-8px);

    border-color:
    rgba(0,191,255,.45);

    box-shadow:
    0 0 25px rgba(0,191,255,.25),
    0 15px 40px rgba(0,0,0,.45);
}

.feature i{
    margin-bottom:15px;

    color:var(--primary);

    font-size:40px;

    text-shadow:
    0 0 20px rgba(0,191,255,.5);
}

.feature h5{
    color:#fff;
}

.feature p{
    color:var(--gray);
}

/* =========================================================
   COLOR OPTIONS
========================================================= */

.color-option{
    width:28px;
    height:28px;

    border:2px solid #ddd;
    border-radius:50%;

    cursor:pointer;

    transition:var(--transition);
}

.color-option:hover,
.color-option.active{
    border-color:var(--verde);

    transform:scale(1.1);
}

/* =========================================================
   TABLE
========================================================= */

.table-premium{
    overflow:hidden;

    border-radius:20px;

    background:
    rgba(255,255,255,.05);

    border:
    1px solid rgba(0,191,255,.15);

    backdrop-filter:blur(14px);
    -webkit-backdrop-filter:blur(14px);

    box-shadow:
    var(--shadow-card);
}

.table{
    --bs-table-bg:transparent;

    margin-bottom:0;

    color:#fff;
}

.table th,
.table td{
    background:transparent !important;

    border-color:
    rgba(255,255,255,.08);
}

.table th{
    color:var(--primary);
    font-weight:600;
}

.table td{
    color:#e5e5e5;
}

.text-muted{
    color:#b8c7d1 !important;
}

/* =========================================================
   WHATSAPP
========================================================= */

.whatsapp-float{
    position:fixed;
    right:25px;
    bottom:25px;

    z-index:9999;

    width:65px;
    height:65px;

    display:flex;
    align-items:center;
    justify-content:center;

    border-radius:50%;

    background:#25D366;

    color:#fff;

    font-size:36px;
    line-height:1;

    box-shadow:
    0 6px 20px rgba(0,0,0,.25);

    transition:var(--transition);

    animation:whatsappPulse 2s infinite;

    -webkit-tap-highlight-color:transparent;
}

.whatsapp-float:hover{
    background:#1ebe5d;

    transform:scale(1.15);
}

@keyframes whatsappPulse{
    0%{
        box-shadow:0 0 0 0 rgba(37,211,102,.3);
    }

    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;
    z-index:1;

    padding:90px 10% 25px;

    background:
    linear-gradient(
        180deg,
        #02111c,
        #000
    );

    border-top:
    1px solid rgba(0,191,255,.15);
}

.footer::before{
    content:'';

    position:absolute;
    top:0;
    left:0;

    width:100%;
    height:3px;

    background:var(--primary);

    box-shadow:
    0 0 20px var(--primary);
}

/* GRID */

.footer-container{
    display:grid;

    grid-template-columns:
    repeat(auto-fit,minmax(250px,1fr));

    gap:40px;
}

/* BOX */

.footer-box h2{
    margin-bottom:20px;

    font-size:28px;
}

.footer-box h3{
    display:flex;
    align-items:center;
    gap:10px;

    margin-bottom:20px;

    color:var(--primary);

    font-size:22px;
}

.footer-box p{
    margin-bottom:15px;

    color:#ccc;

    font-size:15px;
    line-height:1.8;
}

/* LOGO */

.footer-logo{
    width:100px;

    padding:8px;
    margin-bottom:20px;

    background:#fff;

    border-radius:20px;

    box-shadow:
    0 0 25px rgba(0,191,255,.5);
}

/* LINKS */

.footer-box a{
    display:flex;
    align-items:flex-start;
    gap:14px;

    margin-bottom:22px;
    padding-bottom:12px;

    color:#ccc;

    font-size:15px;
    line-height:1.6;

    word-break:break-word;

    border-bottom:
    1px solid rgba(255,255,255,.06);

    transition:var(--transition);
}

.footer-box a i{
    min-width:12px;
    margin-top:2px;

    color:var(--primary);

    font-size:18px;
}

.footer-box a:hover{
    color:var(--primary);

    transform:translateX(4px);

    border-color:
    rgba(0,191,255,.25);
}

/* 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;

    font-size:18px;

    border:
    1px solid rgba(255,255,255,.1);

    transition:var(--transition);
}

.social-icons a:hover{
    background:var(--primary);

    color:#000;

    transform:translateY(-5px);

    box-shadow:
    0 0 20px var(--primary);
}

/* COPYRIGHT */

.footer-bottom{
    margin-top:50px;
    padding-top:20px;

    text-align:center;

    border-top:
    1px solid rgba(255,255,255,.1);
}

.footer-bottom p{
    color:#888;
    font-size:14px;
}

/* =========================================================
   RESPONSIVE
========================================================= */

@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%;

        display:none;
        flex-direction:column;
        gap:25px;

        padding:30px 0;

        background:#000;

        border-top:
        1px solid rgba(255,255,255,.1);
    }

    .menu.active{
        display:flex;
    }

    .promo-content h2{
        font-size:45px;
    }
}

@media(max-width:768px){

    .hero{
        padding:80px 20px;
    }

    .hero h2{
        font-size:36px;
    }

    .hero p{
        font-size:16px;
    }

    .price-main{
        font-size:42px;
    }

    .price-top{
        flex-direction:column;
        align-items:flex-start;
    }

    .footer{
        padding:60px 20px 20px;
    }

    .footer-container{
        gap:50px;
    }

    .whatsapp-float{
        right:20px;
        bottom:20px;

        width:55px;
        height:55px;

        font-size:30px;
    }
}

@media(max-width:600px){

    .promo-content h2{
        font-size:35px;
    }

    .promo-content p{
        font-size:16px;
    }
}