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

:root{

    --accent:#d6a44b;

    --accent-glow:rgba(214,164,75,.45);

    --background:#050505;

    --text:#ffffff;

    --text-secondary:#bdbdbd;

}

html{
    scroll-behavior:smooth;
}

body{

background:#0f0f0f;

color:white;

font-family:'Poppins',sans-serif;

}

header{

    position:fixed;
    top:0;
    left:0;

    width:100%;

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

    padding:20px 8%;

    background:rgba(0,0,0,.65);

    backdrop-filter:blur(12px);

    z-index:1000;

    header{

    border-bottom:
    1px solid rgba(255,255,255,.08);

    box-shadow:
    0 10px 40px rgba(0,0,0,.25);

}

}

.logo img{

    width:111px;
    transition:.3s;

}

.logo img:hover{

    transform:rotate(8deg) scale(1.08);

}

nav{

    display:flex;
    gap:35px;

}

nav a{

    color:white;
    text-decoration:none;
    font-size:15px;
    transition:.3s;

}

nav a:hover{

    color:#d6a44b;

}

.hero{

    position:relative;

    height:100vh;

    display:flex;

    justify-content:center;

    align-items:center;

    text-align:center;

    padding:0 20px;

    background:
    linear-gradient(rgba(0,0,0,.65),rgba(0,0,0,.80)),
    url("../img/hero/hero.jpg");

    background-size:cover;

    background-position:center;

    background-attachment:fixed;

}

.hero h1{

    font-size:92px;

    font-weight:700;

    letter-spacing:8px;

    text-shadow:0 10px 30px rgba(0,0,0,.5);

}

.hero p{

    font-size:24px;

    color:#efefef;

    max-width:760px;

    margin:auto;

    line-height:1.8;

}

.botones{

    margin-top:45px;

}

.btn{

    display:inline-block;

    padding:16px 35px;

    background:#ffffff;

    color:#000;

    border-radius:40px;

    text-decoration:none;

    font-weight:bold;

    margin-right:15px;

}

.btn2{

    display:inline-block;

    padding:16px 35px;

    border:2px solid rgba(214,164,75);

    border-radius:40px;

    color:white;

    text-decoration:none;

}

.btn,
.btn2{

    transition:
    transform .3s,
    box-shadow .3s;

}

.btn:hover,
.btn2:hover{

    transform:translateY(-4px);

    box-shadow:
    0 15px 40px rgba(214,164,75);

}

.about{

padding:140px 8%;
text-align:center;

background:rgba(10,10,10,.45);

backdrop-filter:blur(10px);

-webkit-backdrop-filter:blur(10px);

border-top:1px solid rgba(255,255,255,.05);

border-bottom:1px solid rgba(255,255,255,.05);

}

.about h2{

font-size:60px;

margin:25px 0;

}

.about p{

max-width:900px;
margin:auto;

font-size:20px;

line-height:2;

color:#bdbdbd;

}

footer{

    margin-top:80px;

    padding:40px;

    text-align:center;

    color:#777;

    border-top:1px solid rgba(255,255,255,.08);

    margin-top:80px;

    padding:40px;

    color:#777;

    border-top:1px solid rgba(255,255,255,.08);

}

@media(max-width:900px){

nav{

display:none;

}

.hero h1{

font-size:45px;

}

.hero p{

font-size:18px;

}

.logo img{

width:99px;

}

}

.container{

    max-width:1200px;
    margin:auto;

}

.subtitulo{

    color:#d6a44b;
    letter-spacing:4px;
    font-size:14px;

}
.about,
.products,
.gallery{

    width:92%;

    margin:60px auto;

    border-radius:40px;

    background:rgba(18,18,18,.45);

    backdrop-filter:blur(18px);

    -webkit-backdrop-filter:blur(18px);

    border:1px solid rgba(255,255,255,.08);

    box-shadow:0 15px 60px rgba(0,0,0,.35);

    margin:60px auto;

width:92%;

border-radius:50px;

box-shadow:
0 20px 80px rgba(0,0,0,.35);

}
.about h2{

    font-size:50px;
    margin:15px 0;

}

.about p{

    font-size:18px;
    color:#bdbdbd;
    line-height:1.8;

}

.products{

padding:120px 8%;

background:rgba(20,20,20,.45);

backdrop-filter:blur(12px);

-webkit-backdrop-filter:blur(12px);

border-top:1px solid rgba(255,255,255,.05);

border-bottom:1px solid rgba(255,255,255,.05);

}

.products h2{

    text-align:center;
    font-size:45px;
    margin-bottom:60px;

}

.cards{

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

}

.card{

    background:rgba(25,25,25,.55);

    backdrop-filter:blur(12px);
    -webkit-backdrop-filter:blur(12px);

    border:1px solid rgba(255,255,255,.08);

    border-radius:50px;

    overflow:hidden;

    padding:50px 35px;

    min-height:320px;

    display:flex;

    flex-direction:column;

    justify-content:center;

    align-items:center;

    text-align:center;

    transition:.4s;

    cursor:pointer;

}

.card:hover{

    transform:translateY(-10px);

    border-color:#d6a44b;

}

.card h3{

    margin:20px 0;

    font-size:28px;

}

.card p{

    color:#bdbdbd;

}

.card{

cursor:pointer;

}

.card:hover{

background:#222;

box-shadow:0 20px 50px rgba(255, 153, 0, 0.12);

}

/*=========================
GALERÍA
=========================*/

.gallery{

padding:120px 8%;

background:rgba(5,5,5,.35);

backdrop-filter:blur(10px);

-webkit-backdrop-filter:blur(10px);

}

.gallery h2{
    color:#fff;
    font-size:48px;
    margin-bottom:15px;
}

.gallery-text{
    color:#a5a5a5;
    max-width:700px;
    margin:auto;
    margin-bottom:60px;
    line-height:1.8;
}

.gallery-grid{

    display:grid;

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

    gap:25px;

}

.gallery-grid img{

    width:100%;

    height:320px;

    object-fit:cover;

    border-radius:20px;

    transition:.45s;

    cursor:pointer;

}

.gallery-grid img:hover{

    transform:scale(1.05);

    box-shadow:0 25px 60px rgba(214, 173, 102, 0.791);

}

.gallery-grid img{

    overflow:hidden;

}

.gallery-grid img:hover{

    transform:scale(1.08);

}

/*=========================
LOADER
=========================*/

#loader{

    position:fixed;

    inset:0;

    background:#050505;

    display:flex;

    flex-direction:column;

    justify-content:center;

    align-items:center;

    z-index:99999;

    transition:opacity .8s ease, visibility .8s ease;

}

#loader img{

    width:120px;

    margin-bottom:25px;

    animation:logoPulse 1.8s infinite;

}

#loader h2{

    font-size:34px;

    letter-spacing:6px;

    margin-bottom:10px;

}

#loader p{

    color:#8f8f8f;

    letter-spacing:2px;

}

#loader.hidden{

    opacity:0;

    visibility:hidden;

}

@keyframes logoPulse{

    0%{

        transform:scale(.95);
        opacity:.7;

    }

    50%{

        transform:scale(1.08);
        opacity:1;

    }

    100%{

        transform:scale(.95);
        opacity:.7;

    }

}

/*=========================
WHATSAPP PREMIUM
=========================*/

.whatsapp{

    position:fixed;

    right:30px;

    bottom:30px;

    width:72px;

    height:72px;

    border-radius:50%;

    background:#050505;

    display:flex;

    justify-content:center;

    align-items:center;

    text-decoration:none;

    z-index:9999;

    box-shadow:
        0 0 20px rgba(214, 173, 102, 0.791),
        0 0 50px rgba(172, 122, 23, 0.35);

    animation:whatsappGlow 2s infinite ease-in-out;

    transition:.3s;

}

.whatsapp span{

    color:white;

    font-size:34px;

    font-weight:bold;

}

.whatsapp:hover{

    transform:scale(1.12);

    box-shadow:
        0 0 30px rgba(37,211,102,.9),
        0 0 70px rgba(37,211,102,.6);

}

.whatsapp i{

    color:white;

    font-size:38px;

}

@keyframes whatsappGlow{

    0%{

        box-shadow:
            0 0 15px rgba(37,211,102,.4),
            0 0 35px rgba(37,211,102,.2);

    }

    50%{

        box-shadow:
            0 0 30px rgba(37,211,102,.8),
            0 0 60px rgba(37,211,102,.4);

    }

    100%{

        box-shadow:
            0 0 15px rgba(37,211,102,.4),
            0 0 35px rgba(37,211,102,.2);

    }

}

@keyframes pulse{

    0%{
        transform:scale(1);
    }

    50%{
        transform:scale(1.1);
    }

    100%{
        transform:scale(1);
    }

}

/*=========================
BRANDS
=========================*/

.brands{

    width:92%;

    margin:60px auto;

    padding:100px 6%;

    background:rgba(15,15,15,.45);

    backdrop-filter:blur(15px);

    -webkit-backdrop-filter:blur(15px);

    border-radius:50px;

    border:1px solid rgba(255,255,255,.08);

    box-shadow:0 20px 80px rgba(0,0,0,.3);

}

.brands h2{

    text-align:center;

    font-size:50px;

    margin-bottom:20px;

}

.brands-text{

    text-align:center;

    color:#bdbdbd;

    max-width:700px;

    margin:auto;

    margin-bottom:80px;

}

.brand-category{

    margin-bottom:80px;

}

.brand-category h3{

    color:#d6a44b;

    font-size:28px;

    margin-bottom:35px;

    text-align:center;

    letter-spacing:3px;

}

.brands-grid{

    display:grid;

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

    gap:30px;

    align-items:center;

}

.brands-grid img{

    height:80px;

    width:auto;

    max-width:180px;

    object-fit:contain;

    margin:auto;

    display:block;

    transition:.35s;

}

.brands-grid img:hover{

    transform:scale(1.1);

}

.brands-grid img:hover{

    transform:scale(1.08);

}

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

.contact{

    width:92%;
    margin:120px auto 60px auto;

    padding:100px 8%;

    background:rgba(15,15,15,.45);

    backdrop-filter:blur(15px);

    border-radius:50px;

}

.contact h2{

    text-align:center;

    font-size:50px;

    margin-bottom:60px;

}

.contact-grid{

    display:grid;

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

    gap:30px;

}

.contact-card{

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

    border:1px solid rgba(255,255,255,.08);

    border-radius:30px;

    padding:28px;
    
    min-height:180px;

    transition:.3s;

    .contact-card{

    transition:.35s ease;

}

.contact-card:hover{

    transform:translateY(-8px);

    box-shadow:
        0 20px 50px rgba(0, 0, 0, 0.12);

}

}

.contact-card:hover{

    transform:translateY(-8px);

    border-color:#d6a44b;

}

.contact-card h3{

    margin-bottom:20px;

    color:#d6a44b;

}

.contact-card p{

    color:#d0d0d0;

    line-height:1.8;

}

.map-button{

    display:flex;

    justify-content:center;

    margin-top:50px;

    background:#d6a44b;

    color:#000;

    padding:18px 45px;

    border-radius:50px;

    text-decoration:none;

    font-weight:700;

    transition:.3s;

    box-shadow:
        0 0 20px rgba(214,164,75,.45);

}

.map-button a:hover{

    transform:translateY(-4px);

    box-shadow:
        0 15px 40px rgba(43, 30, 3, 0.4);

}

