/* CONFIGURACIÓN ESTILO PREMIUM (BLACK & GOLD) */
:root {
    --color-primario: #050505;
    --color-acento: #d4af37; 
    --color-fondo: #0a0a0a;
    --color-texto: #ffffff;
    --color-tarjeta: #111111;
    --transition-smooth: all 0.5s cubic-bezier(0.165, 0.84, 0.44, 1);
}

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

body {
    font-family: 'Montserrat', sans-serif;
    color: var(--color-texto);
    line-height: 1.6;
    background-color: var(--color-fondo);
    scroll-behavior: smooth;
}

/* HERO SECTION */
.hero {
    background: linear-gradient(rgba(0,0,0,0.6), rgba(0,0,0,0.6)), url('../img/image.png') center/cover no-repeat;
    height: 550px;
    display: flex;
    flex-direction: column; justify-content: center; align-items: center;
    color: white; text-align: center;
    border-bottom: 1px solid var(--color-acento);
}

.hero h2 { 
    font-family: 'Playfair Display', serif;
    font-size: 3.5rem; margin-bottom: 10px; text-transform: uppercase; letter-spacing: 4px;
    animation: desplegar 1.2s ease-out;
}

.hero p {
    font-size: 1.1rem;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: var(--color-acento);
}

@media (max-width: 768px) {
    .hero h2 {
        font-size: 2.2rem;
        letter-spacing: 2px;
    }
    .hero p {
        font-size: 0.9rem;
        letter-spacing: 1px;
    }
    .hero {
        height: 400px;
    }
}

@keyframes desplegar {
    from { opacity: 0; transform: translateY(-30px); letter-spacing: 15px; }
    to { opacity: 1; transform: translateY(0); letter-spacing: 4px; }
}

/* PRODUCTOS */
.productos { padding: 90px 8%; text-align: center; background: #000; }
.productos h2 { font-family: 'Playfair Display', serif; font-size: 2.5rem; margin-bottom: 40px; }

.contenedor-productos {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 28px; margin-top: 40px;
}
@media (max-width: 600px) {
    .productos { padding: 50px 5%; }
    .productos h2 { font-size: 2rem; }
    .contenedor-productos {
        grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
        gap: 20px;
    }
    .producto { padding: 20px; }
    .producto h3 { font-size: 1.1rem; }
}
.producto {
    background: var(--color-tarjeta); padding: 25px; border-radius: 4px; border: 1px solid #1a1a1a;
    transition: var(--transition-smooth);
}
.producto:hover { 
    transform: translateY(-12px); 
    box-shadow: 0 15px 40px rgba(0,0,0,0.5);
    border-color: var(--color-acento);
}
.producto img { width: 85%; margin-bottom: 20px; transition: 0.5s ease; }
.producto h3 { font-family: 'Playfair Display', serif; font-size: 1.4rem; margin-bottom: 10px; }
.producto p { color: var(--color-acento); font-weight: 700; font-size: 1.2rem; margin-bottom: 20px; }

.agregar-carrito {
    width: 100%; padding: 14px; background: transparent; border: 1px solid var(--color-acento);
    color: var(--color-acento); font-weight: 700; text-transform: uppercase; letter-spacing: 1px; cursor: pointer; transition: 0.3s;
}
.agregar-carrito:hover { background: var(--color-acento); color: #000; }

/* SOBRE NOSOTROS (PROFESIONAL) */
.sobre-nosotros { padding: 100px 10%; background-color: var(--color-primario); }
.sobre-header { text-align: center; margin-bottom: 60px; }
.sobre-header h2 { 
    font-family: 'Playfair Display', serif; font-size: 2.8rem; color: #fff; margin-bottom: 25px; 
    position: relative; display: inline-block; padding-bottom: 10px;
}
.sobre-header h2::after { content: ''; width: 80px; height: 3px; background: var(--color-acento); position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); }
.sobre-header .intro { font-size: 1.1rem; color: #888; max-width: 800px; margin: 20px auto 0; }

.contenedor-sobre { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 30px; }

.bloque-sobre { 
    background: #0a0a0a; padding: 45px; border-radius: 4px; border: 1px solid #1a1a1a; 
    border-bottom: 4px solid var(--color-acento); 
    transition: var(--transition-smooth);
}
.bloque-sobre:hover { transform: translateY(-5px); background: #111; }
.bloque-sobre h3 { font-family: 'Playfair Display', serif; color: var(--color-acento); font-size: 1.5rem; margin-bottom: 15px; }
.bloque-sobre p { color: #777; font-size: 0.95rem; }

/* ESTILOS DEL FOOTER MEJORADO */
.footer-premium {
    background: #050505; color: #fff; padding: 80px 8% 40px; 
    border-top: 1px solid #1a1a1a;
}
.footer-container {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); 
    gap: 50px; text-align: left; max-width: 1200px; margin: 0 auto;
}
@media (max-width: 768px) {
    .footer-premium { padding: 50px 5% 30px; text-align: center; }
    .footer-container { text-align: center; gap: 30px; }
    .payment-badges { justify-content: center; }
}
.footer-col h3 { font-family: 'Playfair Display', serif; color: var(--color-acento); font-size: 1.8rem; margin-bottom: 20px; letter-spacing: 2px; }
.footer-col h4 { color: #fff; text-transform: uppercase; font-size: 0.9rem; letter-spacing: 2px; margin-bottom: 25px; border-bottom: 2px solid var(--color-acento); display: inline-block; padding-bottom: 5px; }
.footer-col p { color: #777; font-size: 0.85rem; line-height: 1.8; }
.footer-links { list-style: none; padding: 0; }
.footer-links li { margin-bottom: 12px; }
.footer-links a { color: #777; text-decoration: none; font-size: 0.85rem; transition: 0.3s; }
.footer-links a:hover { color: var(--color-acento); padding-left: 5px; }
.payment-badges { display: flex; gap: 10px; opacity: 0.6; margin-top: 20px; }
.badge { border: 1px solid #444; padding: 4px 8px; font-size: 0.6rem; border-radius: 3px; }
.footer-bottom { margin-top: 80px; padding-top: 30px; border-top: 1px solid #111; text-align: center; }
.footer-bottom p { color: #444; font-size: 0.7rem; letter-spacing: 3px; text-transform: uppercase; }
