:root{--primary:#8b0000;--primary-glow:#b8860b;--bg:#f9f9f9;--card-bg:#fff;--shadow:0 8px 24px rgba(0,0,0,.1);--radius:14px;--text:#333;--footer-bg:#2d0000;--footer-bottom-bg:#1a0000; --nav-height: 70px;}
*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:'Poppins',sans-serif;background:var(--bg);color:var(--text); padding-top: 40px;}

/* Utilidades */
.hidden{display:none !important}

/* Contact Bar */
.contact-bar{background:linear-gradient(90deg,var(--primary),#600000);color:#fff;display:flex;justify-content:space-between;align-items:center;padding:8px 20px;font-size:.9rem;position:fixed;top:0;left:0;right:0;z-index:1001;box-shadow:0 4px 15px rgba(0,0,0,.2); height: 40px;}
.contact-bar a{color:#fff;text-decoration:none;margin-right:12px;transition:color .2s ease; display: inline-flex; align-items: center; gap: 5px;}
.contact-bar a:hover{color:var(--primary-glow)}.social-icons{display:flex;gap:10px}.social-icons a{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--primary-glow);color:#fff;transition:all .3s ease}.social-icons a:hover{background:gold;color:#000;transform:scale(1.1)}

/* Nav */
nav{background:#fff;border-bottom:1px solid #eee;position:sticky;top:40px;z-index:1000;height:var(--nav-height);box-shadow:0 5px 15px rgba(0,0,0,0);transition:box-shadow .3s ease-in-out}
nav.scrolled{box-shadow:0 8px 20px rgba(0,0,0,.1)}.nav-inner{max-width:1200px;margin:0 auto;height:100%;display:flex;align-items:center;justify-content:space-between;padding:0 20px}.brand{display:flex;align-items:center;gap:10px;text-decoration:none}.logo img{height:48px}.company-title{color:var(--primary);font-weight:700;font-size:1.1rem}.nav-links{list-style:none;display:flex;gap:10px}.nav-links a{text-decoration:none;color:var(--primary);font-weight:600;padding:10px 15px;transition:all .3s ease;border-radius:8px}.nav-links a:hover,.nav-links a.active{background-color:var(--primary);color:#fff;transform:translateY(-2px)}

/* Menú Hamburguesa y Menú Móvil */
.menu-toggle, .mobile-nav { display: none; }
.menu-toggle{flex-direction:column;gap:5px;width:30px;height:30px;background:0 0;border:none;cursor:pointer;z-index:1100}
.menu-toggle span{width:100%;height:3px;background-color:var(--primary);border-radius:2px;transition:all .3s ease}
.menu-toggle.active span:nth-child(1){transform:translateY(8px) rotate(45deg)} .menu-toggle.active span:nth-child(2){opacity:0} .menu-toggle.active span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* Hero Slider */
.hero-slider{height:80vh;width:100%;margin-top:0}.header-image{position:relative;width:100%;height:100%}.header-image img{width:100%;height:100%;object-fit:cover;filter:brightness(.6)}.hero-overlay{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.6);padding:20px}.hero-overlay h1{font-size:2.8rem;font-weight:700;margin-bottom:20px}.hero-overlay h2{font-size:1.6rem;color:#fff;text-shadow:none;background-color:rgba(0,0,0,.4);padding:10px 20px;border-radius:10px;display:inline-block;min-height:50px}.swiper-button-next,.swiper-button-prev{color:var(--primary-glow)}.swiper-pagination-bullet-active{background:var(--primary-glow)}

/* Sections */
main section{padding:50px 20px;scroll-margin-top:120px;max-width:1200px;margin:0 auto}
h2{color:var(--primary);margin-bottom:20px;font-size:2rem;text-align:center}

/* Nosotros */
.section-box{background:var(--card-bg);padding:40px;border-radius:var(--radius);box-shadow:0 10px 35px rgba(0,0,0,.12)}.tags-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-top:30px}.tag-card{background:var(--card-bg);border-radius:var(--radius);padding:25px;text-align:center;box-shadow:0 4px 10px rgba(0,0,0,.05);border:1px solid #eee;transition:transform .3s ease,box-shadow .3s ease}.tag-card:hover{transform:translateY(-8px);box-shadow:var(--shadow)}.tag-card .icon{font-size:2.5rem;color:var(--primary);margin-bottom:10px}.presencia{margin-top:40px;font-weight:600;color:var(--text);background:#f5f5f5;padding:20px;border-radius:var(--radius);text-align:center}

/* Categorías (Grid Principal) */
.categorias-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }

.categoria-card {
    position: relative; aspect-ratio: 1/1; width: 90%; justify-self: center; cursor: pointer;
    background: #fff; border: 4px solid #FFD700; border-radius: 35px; padding: 8px;
    box-shadow: 0 10px 20px rgba(0,0,0,0.3); overflow: hidden; transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.categoria-card img { width: 100%; height: 100%; object-fit: cover; border-radius: 25px; display: block; transition: transform 0.3s ease; }
.categoria-card-title {
    position: absolute; bottom: 8px; left: 8px; right: 8px;
    background: linear-gradient(to top, #222 0%, rgba(50,50,50,0.8) 50%, transparent 100%);
    color: #FFD700; padding: 30px 10px 15px; text-align: center; font-weight: 800; font-size: 1.4rem;
    border-radius: 0 0 25px 25px; opacity: 1; transform: none;
}
.categoria-card:hover { transform: translateY(-5px); box-shadow: 0 15px 30px rgba(0,0,0,0.4); border-color: #ffea00; }
.categoria-card:hover img { transform: scale(1.05); }

/* === BANNER DE CATEGORÍA (30% IMAGEN - 70% ROJO) === */
.category-hero {
    width: 100%; height: 220px; display: flex; border-radius: var(--radius); margin-bottom: 40px;
    overflow: hidden; box-shadow: var(--shadow); background-color: var(--primary); animation: fadeIn 0.5s ease;
}
.hero-img-side { width: 30%; height: 100%; position: relative; background-color: #fff; }

/* CORRECCIÓN IMAGEN GALLOS: Alineación TOP */
.hero-img-side img {
    width: 100%; 
    height: 100%;
    object-fit: cover;
    object-position: center center; /* CAMBIO: Centrado absoluto para que se vean bien todos */
    display: block;
}

.hero-text-side {
    width: 70%; display: flex; align-items: center; justify-content: center; padding: 20px;
    background: linear-gradient(90deg, var(--primary) 0%, #600000 100%);
}
.hero-text-side h1 {
    color: #fff; font-size: 3.5rem; font-weight: 800; text-transform: uppercase;
    letter-spacing: 2px; text-align: center; margin: 0; line-height: 1; text-shadow: 0 4px 10px rgba(0,0,0,0.2);
}
@keyframes fadeIn { from { opacity: 0; transform: translateY(-20px); } to { opacity: 1; transform: translateY(0); } }

/* Productos Grid */
.productos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;align-items:stretch;}

.producto-card {
    background: #fff; border-radius: 14px; border: 3px solid #d4b36c;
    box-shadow: var(--shadow); overflow: hidden; transition: transform .3s ease, box-shadow .3s ease;
    display: flex; flex-direction: column; height: 100%; justify-content: space-between;
}
.producto-card:hover{transform:translateY(-10px);box-shadow:0 12px 30px rgba(0,0,0,.15)}
.producto-card img{width:100%;height:220px;object-fit:contain;padding:10px;background:#fff;transition:transform .3s ease}
.producto-card:hover img{transform:scale(1.03);opacity:0.9}

.producto-info{padding:15px;text-align:center;display:flex;flex-direction:column;flex-grow:1}
.producto-info h3 {
    color: var(--primary); font-size: 1.1rem; font-weight: bold; margin-bottom: 15px;
    display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical;
    overflow: hidden; text-overflow: ellipsis;
}

.producto-card .btn {
    margin-top: auto; align-self: center;
    background-color: #FFD700 !important; color: #000 !important; font-weight: 700;
    box-shadow: 0 4px 10px rgba(0,0,0,0.2); border: 2px solid #e6c200;
    text-transform: uppercase; font-size: 0.9rem; padding: 12px 25px;
    border-radius: 50px; text-decoration: none; transition: all .3s ease;
}
.producto-card .btn:hover { background-color: #ffea00 !important; transform: scale(1.05); box-shadow: 0 6px 15px rgba(255, 215, 0, 0.4); }

/* Botón Volver (Pastilla) */
#volver-categorias.btn {
    display: block; margin: 40px auto 0; width: fit-content;
    border-radius: 50px !important; padding: 12px 35px; border: none !important;
    background-color: #b8860b !important; color: #fff !important;
    font-size: 1.2rem; font-weight: 700; box-shadow: 0 4px 10px rgba(0,0,0,0.1); transition: all 0.3s ease;
}
#volver-categorias.btn:hover {
    background-color: #FFD700 !important; color: #000 !important;
    transform: translateY(-3px); box-shadow: 0 6px 15px rgba(0,0,0,0.2); cursor: pointer;
}

/* Footer */
.footer{background:var(--footer-bg);color:#ddd;padding:60px 20px}.footer-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:50px;align-items:start}.footer h3{color:#fff;margin-bottom:20px;font-size:1.5rem}.footer-info a{display:flex;align-items:center;color:#ddd;text-decoration:none;margin-bottom:15px;transition:color .3s ease}.footer-info a:hover{color:var(--primary-glow)}.footer-info i{width:30px;text-align:center;margin-right:10px}.contact-form-container input,.contact-form-container textarea{width:100%;padding:12px;margin-bottom:12px;border:1px solid #555;border-radius:8px;background:#444;color:#fff;font-family:'Poppins',sans-serif}.contact-form-container button{background:var(--primary-glow);border:none;padding:12px;width:100%;color:#fff;font-weight:600;cursor:pointer;border-radius:8px;transition:all .3s ease}.contact-form-container button:hover{background:gold;color:#000}.footer-socials{margin-top:20px;padding-top:20px;border-top:1px solid rgba(255,255,255,.1);display:flex;gap:15px}.footer-socials a{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:var(--primary-glow);color:#fff;text-decoration:none;transition:all .3s ease}.footer-socials a:hover{background:gold;color:#000;transform:translateY(-3px)}.map-section{width:100%;height:450px}.map-section iframe{width:100%;height:100%;border:0}.footer-bottom{background:var(--footer-bottom-bg);text-align:center;padding:20px;font-size:.9rem;color:#aaa;margin-top:0}.btn-top{position:fixed;bottom:30px;right:30px;background:var(--primary-glow);color:#fff;width:50px;height:50px;border-radius:50%;border:none;cursor:pointer;box-shadow:var(--shadow);display:none;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;transition:all .3s ease;z-index:1100}.btn-top:hover{background:gold;color:#000;transform:translateY(-5px) scale(1.05)}

/* Detalle Producto */
.product-detail-container{max-width:1100px;margin:40px auto;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;padding-bottom:30px}.product-detail-header{padding:20px 30px;border-bottom:1px solid #eee}
.nav-buttons-container{display:flex;justify-content:space-between;flex-wrap:wrap;gap:15px;align-items:center}
.back-button{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:8px;background-color:#f5f5f5;color:var(--primary);font-weight:600;transition:all .3s ease;border:1px solid #ddd;text-decoration:none}.back-button:hover{background-color:var(--primary);color:#fff;border-color:var(--primary);transform:translateY(-2px)}.back-button.secondary{border-left:4px solid var(--primary-glow)}

.product-content-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:40px;padding:40px}
.product-image-section{display:flex;justify-content:center;align-items:flex-start;padding:10px;cursor:pointer}
.product-image-section img{width:100%;max-width:350px;height:auto;object-fit:contain;border-radius:15px;border:1px solid #eee;box-shadow:0 10px 25px rgba(0,0,0,0.2);transition:all .4s cubic-bezier(0.175,0.885,0.32,1.275)}
.product-image-section img:hover{transform:scale(1.05) translateY(-10px);box-shadow:0 20px 40px rgba(0,0,0,0.3);border-color:var(--primary-glow)}
.product-info-section h1{color:var(--primary);font-size:2.2rem;margin-bottom:25px;padding-bottom:15px;border-bottom:3px solid var(--primary-glow)}.detail-grid .detail-item{padding:15px 0;border-bottom:1px solid #eee}.detail-key{display:block;font-weight:700;color:#333;margin-bottom:5px}.detail-value{color:#555;line-height:1.6}.analisis-list{list-style:none;padding:0}.analisis-list li{display:flex;justify-content:space-between;padding:4px 0;border-bottom:1px dashed #eee}

/* Modal */
.modal { display: none; position: fixed; z-index: 2000; padding-top: 50px; left: 0; top: 0; width: 100%; height: 100%; overflow: auto; background-color: rgba(0,0,0,0.9); backdrop-filter: blur(5px); align-items: center; justify-content: center; flex-direction: column; }
.modal-content { margin: auto; display: block; width: 80%; max-width: 600px; max-height: 70vh; object-fit: contain; border-radius: 10px; box-shadow: 0 0 20px rgba(255, 215, 0, 0.2); animation-name: zoom; animation-duration: 0.4s; }
@keyframes zoom { from {transform:scale(0)} to {transform:scale(1)} }
.close { position: absolute; top: 20px; right: 35px; color: #f1f1f1; font-size: 40px; font-weight: bold; transition: 0.3s; cursor: pointer; z-index: 2001; }
.close:hover { color: var(--primary-glow); }
#caption { margin: 20px auto; display: block; width: 80%; max-width: 700px; text-align: center; color: #fff; font-size: 1.5rem; font-weight: 600; font-family: 'Poppins', sans-serif; text-shadow: 0 2px 4px rgba(0,0,0,0.8); }

/* === ZONA RESPONSIVE (MÓVIL) === */
@media (max-width: 900px) {
    /* 1. Ajuste de Grid General */
    .categorias-grid { grid-template-columns: repeat(2, 1fr); gap: 15px; }
    
    /* 2. Barra de Contacto y Navegación */
    .contact-bar { height: auto; flex-direction: column; padding: 5px 10px; position: relative; }
    body { padding-top: 0; }
    nav { top: 0; }
    .nav-links { display: none; }
    .menu-toggle { display: flex; }
    
    /* Menú Móvil */
    .mobile-nav { 
        display: flex; flex-direction: column; position: fixed; 
        top: 70px; left: 0; right: 0; background: #fff; padding: 20px; 
        box-shadow: 0 10px 20px rgba(0, 0, 0, .1); 
        transform: translateY(-150%); transition: transform .4s ease-in-out; 
        z-index: 998; 
    }
    .mobile-nav.active { transform: translateY(0); }
    .mobile-nav a { 
        color: var(--primary); text-decoration: none; font-size: 1.2rem; 
        padding: 15px 20px; border-bottom: 1px solid #eee; display: block; 
    }
    
    /* 3. Slider Principal (Inicio) */
    .hero-slider { height: 50vh; } /* Un poco más pequeño en móvil */
    .hero-overlay h1 { font-size: 1.8rem; padding: 0 10px; }
    
    /* 4. BANNER DE CATEGORÍA (Encabezado) - AJUSTADO */
    .category-hero { 
        height: 200px; /* Altura cómoda para móvil */
        margin-bottom: 30px;
    }
    .category-hero h1 { 
        font-size: 2rem; /* Texto más legible */
        padding: 0 15px; /* Margen lateral para que no toque bordes */
    }

    /* 5. DETALLE DE PRODUCTO - AJUSTADO */
    .product-content-grid { 
        grid-template-columns: 1fr; /* Una sola columna */
        padding: 20px; 
        gap: 20px;
    }
    
    /* Botones de navegación (Volver) */
    .nav-buttons-container { 
        flex-direction: column; 
        align-items: stretch; 
        gap: 10px;
    }
    .back-button { 
        justify-content: center; 
        width: 100%;
    }

    /* IMAGEN DEL PRODUCTO EN MÓVIL (CORRECCIÓN) */
    .product-image-section {
        margin-bottom: 10px;
    }
    .product-image-section img {
        max-width: 80%; /* Que no ocupe toda la pantalla, se ve más elegante */
        max-height: 300px; /* Limite de altura */
    }

    /* Título del producto en móvil */
    .product-info-section h1 {
        font-size: 1.8rem; /* Un poco más pequeño */
        text-align: center;
    }
}

@media (max-width: 600px) {
    .categorias-grid { grid-template-columns: 1fr; } /* 1 columna en cels pequeños */
    .hero-overlay h1 { font-size: 1.5rem; }
    .category-hero h1 { font-size: 1.6rem; }
}

/* === NUEVOS ESTILOS PARA MISIÓN, VISIÓN Y VALORES === */

/* Lista de Valores a 2 columnas */
.values-list {
    list-style: none;
    padding: 0;
    margin-top: 10px;
    display: grid;
    grid-template-columns: 1fr 1fr; /* Dos columnas */
    gap: 8px;
    text-align: left;
}

.values-list li {
    font-size: 0.9rem;
    color: #555;
    padding-left: 5px;
    border-left: 2px solid var(--primary-glow); /* Pequeña línea dorada */
}

/* Botón Leer Más */
.btn-read-more {
    background: none;
    border: none;
    color: var(--primary);
    font-weight: 700;
    cursor: pointer;
    text-decoration: underline;
    margin-top: 10px;
    font-size: 0.9rem;
    padding: 5px;
    transition: color 0.3s;
}

.btn-read-more:hover {
    color: var(--primary-glow);
}

/* Animación simple para el texto */
.more-text {
    display: inline;
}

.more-text.hidden {
    display: none;
}