/* =========================================
   1. RESET & BASIC SETUP
   ========================================= */
* {
    box-sizing: border-box;
}

button,
a,
input[type="button"],
input[type="submit"],
.btn,
.swiper-button-next,
.swiper-button-prev,
.performance-toggle-mobile-button,
.gallery-nav,
.search-icon-mobile,
.hamburger,
.float-button,
.toggle-description-button,
.mobile-back-btn,
.mobile-filter-toggle-btn,
.close-filters-btn {
    -webkit-tap-highlight-color: transparent;
    outline: none;
}

html {
    height: 100%;
    font-family: Arial, sans-serif;
    margin: 0;
    line-height: 0;
    padding: 0;
    overflow-x: hidden;
    overflow-y: auto;
    scroll-behavior: smooth;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;

    /* Scrollbar Firefox */
    scrollbar-width: thin;
    scrollbar-color: #f19a31 transparent;
}

/* Scrollbar premium — webkit (Chrome, Edge, Safari) */
::-webkit-scrollbar {
    width: 5px;
    height: 5px;
}

::-webkit-scrollbar-track {
    background: #f1f5f9;
    border-radius: 100px;
}

::-webkit-scrollbar-thumb {
    background: linear-gradient(180deg, #f19a31 0%, #d97706 100%);
    border-radius: 100px;
}

::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(180deg, #fbbf24 0%, #f19a31 100%);
}

::-webkit-scrollbar-button {
    display: none;
    height: 0;
    width: 0;
}



body {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    background-color: #f8f9fa;

    /* EFECTO GRANULADO SVG INLINE ELIMINADO POR RENDIMIENTO */

    margin: 0;
    padding: 0;
    letter-spacing: 0.01em;
}

body.no-click {
    pointer-events: none;
}

a:-webkit-any-link {
    cursor: pointer;
    text-decoration: none;
}



/* =========================================
   2. UTILITIES & ANIMATIONS
   ========================================= */


/* Animation Classes */
.no-animations *:not(.swiper-container *):not(.swiper-wrapper *):not(.swiper-slide *):not(.swiper-button-next *):not(.swiper-button-prev *):not(.swiper-pagination *):not(.swiper-pagination-bullet *):not(.allow-animation):not(.fullscreen-img *):not(.fullscreen-img):not(.floating-search-results *):not(.floating-search-results):not(.floating-search-results.active *):not(.floating-search-results.active):not(.hamburger *):not(.hamburger):not(.compare-bar *):not(.compare-bar) {
    animation: none !important;
    transition: none !important;
    transform: none !important;
}

.no-animations .producto-item,
.no-animations .categoria-item {
    will-change: auto !important;

}

/* =========================================
   FIX: TARJETAS EN MODO LIGERO (Cambio Instantáneo)
   ========================================= */
.no-animations .categoria-item {
    perspective: none !important;
}

.no-animations .categoria-item-inner {
    transition: transform 0.6s cubic-bezier(0.4, 0.2, 0.2, 1) !important;
}

.no-animations .categoria-item-front,
.no-animations .categoria-item-back {
    transition: none !important;
    transform: none !important;
    backface-visibility: visible !important;
}

/* Estado normal: Muestra frente, oculta atrás */
.no-animations .categoria-item-front {
    opacity: 1 !important;
    visibility: visible !important;
    z-index: 2;
}

.no-animations .categoria-item-back {
    opacity: 0 !important;
    visibility: hidden !important;
    z-index: 1;
}

/* Estado activo (Hover / Toque): Oculta frente, muestra atrás */
.no-animations .categoria-item.is-flipped .categoria-item-front {
    opacity: 0 !important;
    visibility: hidden !important;
    z-index: 1;
}

.no-animations .categoria-item.is-flipped .categoria-item-back {
    opacity: 1 !important;
    visibility: visible !important;
    z-index: 2;
}


.no-animations .producto-item:hover,
.no-animations .categoria-item:hover {
    transform: none !important;
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.1), 0 6px 6px rgba(0, 0, 0, 0.15) !important;
}

/* FIX: Menú móvil en Modo Ligero
   Los items de #nav-menu arrancan con opacity:0 y se revelan via animación navItemFadeIn.
   Con no-animations la animación se cancela pero opacity:0 queda — items invisibles.
   Solución: forzar visibilidad cuando el menú está activo en modo ligero. */
.no-animations #nav-menu > li.nav-item {
    opacity: 1 !important;
    transform: translateX(0) !important;
}

@keyframes rotateMenuIn {
    0% {
        opacity: 0;
        transform: translateY(10px);
    }

    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes rotateMenuOut {
    0% {
        opacity: 1;
        transform: translateY(0);
    }

    100% {
        opacity: 0;
        transform: translateY(10px);
    }
}

@keyframes logoBounce {
    0% {
        transform: translateY(-50px);
        opacity: 0;
    }

    60% {
        transform: translateY(10px);
        opacity: 1;
    }

    100% {
        transform: translateY(0);
        opacity: 1;
    }
}

@keyframes logoPulse {
    0% {
        transform: scale(1);
    }

    50% {
        transform: scale(1.05);
    }

    100% {
        transform: scale(1);
    }
}

@keyframes slideIn {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes fadeIn {
    from {
        opacity: 0.8;
    }

    to {
        opacity: 1;
    }
}

@keyframes pulse {
    0% {
        box-shadow: 0 0 0 0 rgba(0, 0, 0, 0.5);
    }

    70% {
        box-shadow: 0 0 0 8px rgba(0, 0, 0, 0);
    }

    100% {
        box-shadow: 0 0 0 0 rgba(0, 0, 0, 0);
    }
}

@keyframes slideInLeft {
    from {
        transform: translateX(-100%);
        opacity: 0.6;
    }

    to {
        transform: translateX(0);
        opacity: 1;
    }
}

@keyframes slideOutLeft {
    from {
        transform: translateX(0);
        opacity: 1;
    }

    to {
        transform: translateX(-100%);
        opacity: 0;
    }
}

@keyframes reveal {
    from {
        opacity: 0;
        clip-path: inset(0 100% 0 0);
    }

    to {
        opacity: 1;
        clip-path: inset(0 0 0 0);
    }
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}


/* =========================================
   3. LAYOUT & GLOBAL COMPONENTS
   ========================================= */
main {
    flex: 1 0 auto;
    line-height: 1.6;
}

/* Headers */
.header {
    background: linear-gradient(90deg, rgba(250, 248, 246, 0.8) 0%, rgba(255, 255, 255, 0.8) 90%);
    padding: 8px 0;
    color: #fff;
    /* or white per overrides */
    position: sticky;
    top: 0;
    z-index: 9990;
    display: flex;
    align-items: center;
    will-change: box-shadow;
    transition: box-shadow 0.3s ease-in-out;
    border-top: 3px solid #f19a31;
    box-shadow: 0px 2px 8px -2px rgba(0, 0, 0, 0.2);
    line-height: 1.6;
}

/* backdrop-filter en pseudo-elemento para que .header NO sea containing block
   de position:fixed. Si el filtro está en el elemento padre sticky, los hijos
   position:fixed usan su posición de layout (no la visual sticky) como origen,
   lo que hace que el menú móvil quede oculto por encima del viewport al scrollear. */
.header::before {
    content: '';
    position: absolute;
    inset: 0;
    backdrop-filter: blur(15px);
    -webkit-backdrop-filter: blur(15px);
    z-index: -1;
    pointer-events: none;
}

#page-home .header {
    box-shadow: inset 0 -8px 2px -6px rgba(0, 0, 0, 0.08), inset 0 -10px 18px -7px rgba(0, 0, 0, 0.1), inset 0 -4px 10px -3px rgba(0, 0, 0, 0.06), inset 0 -1px 0 rgba(255, 255, 255, 0.3);
}

.header.scrolled {
    box-shadow: 0px 2px 8px -2px rgba(0, 0, 0, 0.2);
}

/* Logo */
.logo {
    max-width: 100%;
    width: clamp(320px, 75vw, 340px);
    height: clamp(40px, 30vw, 42px);
    cursor: pointer;
    transition: transform 0.3s ease;
    margin-left: 2rem;
    aspect-ratio: 16/9;
}

.logo:hover {
    transform: scale(1.05);
}

.logo:active {
    transform: scale(0.95);
    transition: all 0.2s ease;
}

/* Navigation */
.header nav {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 90%;
    gap: 10px;
}

.nav-text {
    color: #ffffff;
}

.nav-left {
    display: flex;
    align-items: center;
    justify-items: center;
    margin-top: 8px;
}

#nav-menu {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    gap: 1.5rem;
    opacity: 100%;
}

#nav-menu li {
    position: relative;
    padding-left: 5px;
    padding-right: 5px;
    border: 0px;
}

#nav-menu li:hover {
    background-color: transparent;
}

#nav-menu>li>a,
#nav-menu li div {
    color: black;
    text-decoration: none;
    font-size: 14px;
    font-weight: 600;
    /* div uses 500 */
    display: block;
    padding: 0.75rem 0;
    /* div uses block only, override logic handled by specific rules */
    transition: all 0.2s ease;
    cursor: pointer;
    position: relative;
    border-radius: 0px;
    /* div 4px */
    background-color: transparent;
    text-align: center;
}

#nav-menu li div {
    font-weight: 500;
    border-radius: 4px;
    padding: 0;
}

/* Reset specific props for div */

#nav-menu>li>a::after,
#nav-menu>li>div::after {
    content: "";
    position: absolute;
    width: 0;
    height: 2px;
    background-color: #f19a31;
    bottom: 10px;
    left: 50%;
    transform: translateX(-50%);
    transition: width 0.3s ease;
}

#nav-menu>li>a:hover,
#nav-menu li div:hover {
    color: #f19a31;
}

#nav-menu li div:hover {
    transform: scale(1.05);
}

#nav-menu>li>a:hover::after,
#nav-menu>li>div:hover::after {
    width: 100%;
}

#nav-menu>li>a.active-tap {
    transform: scale(0.95);
    transition: all 0.1s ease;
}

/* Dropdowns */
.dropdown {
    position: relative;
}

.dropdown-menu {
    list-style: none;
    margin: 2px;
    position: absolute;
    top: 95%;
    left: -15px;
    width: 100%;
    border-radius: 0.25rem;
    border: 1px solid rgba(0, 0, 0, .15);
    box-shadow: 1px 4px 9px rgba(0, 0, 0, 0.4);
    min-width: 300px;
    /* or 250px conflict */
    opacity: 0;
    visibility: hidden;
    z-index: 999;
    display: none;
    transform: rotateX(-90deg);
    grid-template-columns: 1fr;
    gap: 0;
    overflow-x: hidden;
    overflow-y: hidden;
    transform-origin: top center;
    backface-visibility: hidden;
    perspective: 1000px;
    pointer-events: none;
    padding: 0.5rem 0;
    margin: .125rem 0 0;
    background-clip: padding-box;
}

.dropdown-menu.show {
    opacity: 1;
    visibility: visible;
    animation: rotateMenuIn 0.3s ease forwards;
    pointer-events: auto;
}

.dropdown-menu.hide {
    animation: rotateMenuOut 0.2s ease forwards;
    pointer-events: none;
}

.dropdown-menu.active {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    display: grid;
    pointer-events: auto;
    border-bottom: 2px solid #ff8c00;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
    max-height: 50vh;
    overflow-y: auto;
}

.dropdown-menu.show.dropdown-border-active {
    border: 0.5px solid #99969275;
}

.dropdown-menu li {
    margin: 0;
}

.dropdown-menu li a,
.dropdown-menu li div {
    color: black;
    text-decoration: none;
    font-size: 15px;
    font-weight: 500;
    display: block;
    text-align: left;
    touch-action: manipulation;
}

.dropdown-menu li div {
    padding: 0.5rem 1rem;
    font-size: 14px;
    border-radius: 10px;
}

.dropdown-menu li a::after,
.dropdown-menu li div::after {
    display: none;
}

.dropdown-menu li div:hover {
    background-color: #f19a31;
    color: white;
    transform: none;
}

.dropdown-menu li a:hover {
    border-radius: 2px;
    transition: all 0.4s ease;
}

/* Mobile Menu & Search Overlay */
#mobile-menu-overlay,
#search-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: 8000;
    display: none;
    opacity: 0;
    transition: opacity 0.3s ease-in-out;
    -webkit-tap-highlight-color: transparent;
    contain: strict;
    pointer-events: none;
}

#search-overlay {
    top: var(--header-height, 70px);
    height: calc(100% - var(--header-height, 70px));
    background-color: rgba(0, 0, 0, 0.6);
    z-index: 9000;
}

#mobile-menu-overlay.active,
#search-overlay.active {
    display: block;
    opacity: 1;
}

.hamburger {
    display: none;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0.5rem;
    width: 30px;
    height: 40px;
    z-index: 1001;
}

.hamburger span {
    display: block;
    width: 20px;
    height: 2px;
    background-color: black;
    margin: 4px auto;
    transition: all 0.2s ease;
}

.hamburger.open span:first-child {
    transform: rotate(45deg) translate(4px, 3px);
}

.hamburger.open span:nth-child(2) {
    opacity: 0;
}

.hamburger.open span:nth-child(3) {
    transform: rotate(-45deg) translate(5px, -5px);
}

/* Search Components */
.search-icon-mobile {
    display: block;
    /* Visible por defecto en escritorio */
    background: 0 0;
    border: none;
    color: #000;
    font-size: 18px;
    cursor: pointer;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    transition: background-color 0.3s;
}

.search-icon-mobile:hover {
    background-color: #f19a31;
    transform: scale3d(1.1, 1.1, 1);
    transition: all 0.2s ease;
}

.search-icon-mobile:active {
    transform: scale(0.95);
    transition: all 0.2s ease;
}

/* =========================================
   BUSCADOR FLOTANTE (Premium B2B)
   ========================================= */

/* Contenedor principal */
.class_floating-search-container {
    display: none;
    position: fixed;
    top: 75px;
    /* Un poco más abajo para respirar respecto al header */
    right: 5%;
    /* Alineado con el margen de la web */
    z-index: 9999;
    padding: 10px;
    width: 25%;
    /* Un poco más ancho para que los resultados se lean bien */
    min-width: 320px;
    /* Evita que se rompa en pantallas medianas */
    transform: translateY(-15px);
    opacity: 0;
    transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.4s ease;
}

.class_floating-search-container.active {
    transform: translateY(0);
    opacity: 1;
}

/* La caja donde el usuario escribe */
.floating-search-box {
    position: relative;
    width: 100%;
    background-color: #ffffff;
    border-radius: 12px;
    border: 1px solid #e2e8f0;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
    /* Sombra elegante */
    transition: all 0.3s ease;
}

/* Efecto Glow cuando el usuario hace clic para escribir */
.floating-search-box:focus-within {
    border-color: #f19a31;
    box-shadow: 0 10px 30px rgba(241, 154, 49, 0.15);
}

.floating-search-box input {
    width: 100%;
    height: 48px;
    /* Más alto y cómodo */
    padding: 0 45px 0 20px;
    font-size: 1.05rem;
    border: none;
    /* Quitamos el borde interno */
    border-radius: 12px;
    outline: none;
    background-color: transparent;
    color: #1e293b;
    font-weight: 500;
}

.floating-search-box input::placeholder {
    color: #94a3b8;
    font-weight: 400;
}

/* Botón de Cerrar (X) */
.floating-search-close {
    position: absolute;
    top: 50%;
    right: 5px;
    transform: translateY(-50%);
    background: none;
    border: none;
    color: #94a3b8;
    font-size: 20px;
    cursor: pointer;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
}

.floating-search-close:hover {
    color: #f19a31;
    transform: translateY(-50%) rotate(90deg) scale(1.1);
    /* Gira sutilmente */
}

/* Contenedor de los resultados */
.floating-search-results {
    width: 100%;
    margin-top: 12px;
    background-color: #ffffff;
    border-radius: 12px;
    border: 1px solid #e2e8f0;
    box-shadow: 0 15px 40px rgba(0, 0, 0, 0.1);
    max-height: 60vh;
    overflow-y: auto;
    overflow-x: hidden;
    position: absolute;
    display: none;
    z-index: 1002;
    padding: 10px;
    /* Padding interno para que los ítems no toquen el borde */
    /* Estilo del scrollbar */
    scrollbar-width: thin;
    scrollbar-color: #cbd5e1 transparent;
}

.floating-search-results::-webkit-scrollbar {
    width: 6px;
}

.floating-search-results::-webkit-scrollbar-thumb {
    background-color: #cbd5e1;
    border-radius: 10px;
}

.floating-search-results.active {
    display: block;
    animation: fadeInUp 0.3s ease forwards;
}

/* Cada ítem de resultado (Producto) */
.floating-search-result-item {
    display: flex;
    align-items: center;
    padding: 12px 15px;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.25s ease;
    text-decoration: none;
    background-color: transparent;
    border: 1px solid transparent;
    margin-bottom: 4px;
}

.floating-search-result-item:last-child {
    margin-bottom: 0;
}

.floating-search-result-item:hover {
    background-color: #f8fafc;
    border-color: #e2e8f0;
}

/* La imagen en miniatura */
.floating-product-img {
    width: 45px;
    height: 45px;
    border-radius: 6px;
    object-fit: contain;
    background-color: #ffffff;
    border: 1px solid #f1f5f9;
    padding: 2px;
    margin-right: 15px;
    flex-shrink: 0;
}

/* Contenedor de los textos */
.product-text-container {
    display: flex;
    flex-direction: column;
    justify-content: center;
    flex-grow: 1;
}

.floating-search-result-item .product-name {
    font-weight: 600;
    color: #1e293b !important;
    font-size: 0.95rem;
    line-height: 1.3;
    transition: color 0.2s ease;
}

.floating-search-result-item:hover .product-name {
    color: #f19a31;
}

.floating-search-result-item .product-category {
    font-size: 0.72rem;
    color: #64748b;
    margin-top: 4px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    font-weight: 500;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
}

.floating-search-result-item .product-main-category {
    color: #64748b;
    transition: color 0.2s ease;
}

/* La barra diagonal separadora (/) */
.floating-search-result-item .product-category-separator {
    color: #cbd5e1;
    /* Gris clarito para que no quite protagonismo */
    margin: 0 5px;
    font-weight: 300;
}

/* La subcategoría destacada (Naranja corporativo) */
.floating-search-result-item .product-subcategory {
    color: #f19a31;
    font-weight: 700;
    transition: color 0.2s ease;
}

/* Efecto Hover: Oscurece la principal y resalta la subcategoría */
.floating-search-result-item:hover .product-main-category {
    color: #475569;
}

.floating-search-result-item:hover .product-subcategory {
    color: #d98220;
    /* Naranja más oscuro */
}

.floating-no-results {
    padding: 30px 20px;
    text-align: center;
    color: #64748b;
    font-size: 0.95rem;
    font-weight: 500;
}

/* =========================================
   BUSCADOR FLOTANTE (SOLO ESCRITORIO - Premium B2B)
   ========================================= */
@media (min-width: 1051px) {

    /* Contenedor principal */
    .class_floating-search-container {
        display: none;
        position: fixed;
        top: 75px;
        right: 5%;
        z-index: 9999;
        padding: 10px;
        width: 25%;
        min-width: 320px;
        transform: translateY(-15px);
        opacity: 0;
        transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.4s ease;
    }

    .class_floating-search-container.active {
        transform: translateY(0);
        opacity: 1;
    }

    /* La caja donde el usuario escribe */
    .floating-search-box {
        position: relative;
        width: 100%;
        background-color: #ffffff;
        border-radius: 12px;
        border: 1px solid #e2e8f0;
        box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
        transition: all 0.3s ease;
    }

    .floating-search-box:focus-within {
        border-color: #f19a31;
        box-shadow: 0 10px 30px rgba(241, 154, 49, 0.15);
    }

    .floating-search-box input {
        width: 100%;
        height: 48px;
        padding: 0 45px 0 20px;
        font-size: 1.05rem;
        border: none;
        border-radius: 12px;
        outline: none;
        background-color: transparent;
        color: #1e293b;
        font-weight: 500;
    }

    .floating-search-box input::placeholder {
        color: #94a3b8;
        font-weight: 400;
    }

    /* Botón de Cerrar (X) */
    .floating-search-close {
        position: absolute;
        top: 50% !important;
        right: 5px !important;
        transform: translateY(-50%) !important;
        background: none;
        border: none;
        color: #94a3b8;
        font-size: 20px;
        cursor: pointer;
        width: 40px;
        height: 40px;
        display: flex;
        align-items: center;
        justify-content: center;
        transition: all 0.3s ease;
    }

    .floating-search-close:hover {
        color: #f19a31;
        transform: translateY(-50%) rotate(90deg) scale(1.1);
    }

    /* Contenedor de los resultados */
    .floating-search-results {
        width: 100%;
        margin-top: 12px;
        background-color: #ffffff;
        border-radius: 12px;
        border: 1px solid #e2e8f0;
        box-shadow: 0 15px 40px rgba(0, 0, 0, 0.1);
        max-height: 60vh;
        overflow-y: auto;
        overflow-x: hidden;
        position: absolute;
        left: 0;
        /* Reset del 48% antiguo */
        display: none;
        z-index: 1002;
        padding: 10px;
        scrollbar-width: thin;
        scrollbar-color: #cbd5e1 transparent;
    }

    .floating-search-results::-webkit-scrollbar {
        width: 6px;
    }

    .floating-search-results::-webkit-scrollbar-thumb {
        background-color: #cbd5e1;
        border-radius: 10px;
    }

    .floating-search-results.active {
        display: block;
        animation: fadeInUp 0.3s ease forwards;
    }

    /* Efecto de desplazamiento lateral en PC */
    .floating-search-result-item:hover {
        transform: translateX(4px);
    }
}

@media (min-width: 1051px) {

    /* Forzamos al input a respetar el 100% real de su contenedor */
    #floating-search-container .floating-search-box {
        width: 100% !important;
        right: auto !important;
        margin: 0 !important;
        border-radius: 12px !important;
    }

    /* Anclamos los resultados matemáticamente a los bordes del input */
    #floating-search-container .floating-search-results {
        position: absolute !important;
        left: 10px !important;
        /* Compensa el padding izquierdo del padre */
        right: 10px !important;
        /* Compensa el padding derecho del padre */
        width: auto !important;
        /* Se ajusta exactamente al ancho del input */
        transform: none !important;
        /* Anula los desplazamientos viejos que lo rompían */
        border-radius: 12px !important;
        margin-top: 8px !important;
        /* Separación limpia debajo de la caja */
    }
}


/* Slogan */
.slogan {
    background: linear-gradient(90deg, #f19a31 0%, #e67a00 100%);
    color: #ffffff;
    text-align: center;
    padding: 0.8rem 1rem;
    font-size: 0.85rem;
    font-family: 'Poppins', Arial, sans-serif;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 2px;
    /* Letras más separadas y limpias */
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
    position: relative;
    width: 100%;
    z-index: 1001;
    border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}

.slogan p {
    margin: 0;
    position: relative;
    text-shadow: none;
    /* Quitamos el text-shadow para un look corporativo limpio */
    animation: reveal 2s ease-out;
}

/* Breadcrumbs */
.breadcrumb-wrapper-ext {
    box-sizing: border-box;
    max-width: 100%;
    width: 100%;
    margin: 20px auto;
}

.breadcrumb-content-int {
    background-color: #fff;
    padding: 1rem 1.5rem;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-left: 8rem;
    padding-right: 4rem;
}

.breadcrumb-actual-links {
    color: #555;
    align-items: center;
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: 5px;
}

.breadcrumb-actual-links a {
    color: #f19a31;
    text-decoration: none;
    transition: color 0.2s ease;
    font-size: 1em;
}

.breadcrumb-actual-links a:hover {
    color: #d98220;
    text-decoration: underline;
}

.breadcrumb-actual-links .breadcrumb-separator {
    margin: 0;
    padding: 0 0.2em;
    color: #777;
}

.breadcrumb-actual-links .breadcrumb-current {
    color: #333;
    font-weight: 700;
    font-size: 1em;
}

/* =========================================
   BOTÓN "VOLVER" (Escritorio)
   ========================================= */
#breadcrumb-back-button {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    /* Espacio entre flecha y texto */
    padding: 8px 18px;
    background-color: #ffffff;
    color: #475569;
    /* Gris oscuro elegante */
    font-size: 0.9rem;
    font-weight: 600;
    text-decoration: none;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    cursor: pointer;
}

/* El ícono de la flecha */
#breadcrumb-back-button i {
    color: #f19a31;
    font-size: 0.85rem;
    transition: transform 0.3s ease;
    /* Prepara la animación */
}

/* Micro-interacciones al pasar el mouse */
#breadcrumb-back-button:hover {
    color: #f19a31;
    border-color: #f19a31;
    background-color: #fffaf5;
    /* Tintado naranja ultra suave */
    box-shadow: 0 4px 12px rgba(241, 154, 49, 0.1);
    /* Glow naranja */
    transform: translateY(-1px);
}

/* ¡Magia! La flecha se desliza hacia atrás al hacer hover */
#breadcrumb-back-button:hover i {
    transform: translateX(-4px);
}

#breadcrumb-back-button:active {
    transform: scale(0.97);
}

/* Containers */
#home-page .container,
#page-nuevos-productos .container,
#page-category .container,
#page-subcategory .container,
#page-product .container {
    margin: 0 auto;
    padding: 0 0;
    max-width: 100vw;
}

#contact-page .container {
    margin: 0 auto;
    padding: 0 1rem;
    padding-bottom: 1rem;
    max-width: 100vw;
}


/* Products & Categories Global */
:where(h1) {
    margin-block: 0.67em;
    font-size: 1.5em;
}

#categorias {
    padding: 0.8rem 0.2rem;
    text-align: center;
    margin-bottom: 55px;
}

#productos {
    padding: 0;
    text-align: center;
    background-color: transparent;
    margin-bottom: 30px;
}

/* =========================================
   ESTILO PREMIUM: TÍTULO DE CATEGORÍA (Ej: Alarmas)
   ========================================= */
#productos #productos-titulo {
    font-size: 2.0rem;
    color: #1e293b;
    /* Gris/Azul oscuro muy corporativo */
    font-weight: 800;
    margin-top: 0;
    margin-bottom: 1.5rem;
    text-align: center;
    letter-spacing: -0.5px;
    position: relative;
    display: inline-block;
    width: 100%;
    word-break: break-word !important;
}

/* Línea naranja corporativa debajo del título */
#productos #productos-titulo::after {
    content: '';
    display: block;
    width: 60px;
    height: 4px;
    background-color: #f19a31;
    border-radius: 2px;
    margin: 15px auto 0 auto;
}

/* Pantallas 1366px (laptops HD) */
@media (max-width: 1366px) {
    #productos #productos-titulo {
        font-size: 1.8rem;
    }
}

/* Ajuste proporcional para pantallas móviles */
@media (max-width: 768px) {
    #productos #productos-titulo {
        font-size: 1.5rem;
        margin-bottom: 1.2rem;
    }

    #productos #productos-titulo::after {
        width: 45px;
        height: 3px;
        margin-top: 10px;
    }
}


#productos-nuevos-titulo {
    font-size: 1.8rem;
    /* Tamaño equilibrado */
    color: #1a1a1a;
    font-weight: 700;
    margin: 0;
    letter-spacing: -0.5px;
    line-height: 1;
}

.seccion-header-titulos {
    text-align: center;
    margin-bottom: 3.5rem;
    padding: 0 1rem;

}

#categorias-titulo {
    font-size: 2.5rem;
    /* Más grande e imponente */
    color: #1a1a1a;
    /* Casi negro, más elegante que el azul */
    font-weight: 800;
    margin-bottom: 0.8rem;
    text-transform: none;
    /* Quitamos las mayúsculas para un look más moderno/tech */
    letter-spacing: -0.5px;
    /* Apretar ligeramente las letras da un toque premium */
    position: relative;
    display: inline-block;
}

#categorias-titulo::after {
    content: '';
    display: block;
    width: 50px;
    height: 4px;
    background-color: #f19a31;
    border-radius: 2px;
    margin: 15px auto 0 auto;
}

.categorias-subtitulo {
    font-size: 1.1rem;
    color: #666;
    max-width: 1050px;
    margin: 0 auto;
    font-weight: 400;
    line-height: 1.6;
}

.categorias-subtitulo strong {
    color: #2c3e50;
    /* Un gris/azul muy oscuro y elegante */
    font-weight: 600;
    /* Un semi-bold para que no se vea tosco */
}

@media(max-width: 768px) {
    #categorias-titulo {
        font-size: 1.8rem;
    }

    .categorias-subtitulo {
        font-size: 0.95rem;
    }
}

.categoria-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
    gap: 45px;
    margin-top: 20px;
    margin-left: 30px;
    margin-right: 30px;
    padding: 0 1rem;
}

.producto-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 350px));
    justify-content: center;
    gap: 30px;
    max-width: 100%;
    margin: 0 auto;
    padding: 0;
}

/* Item Styles */
.categoria-item,
.producto-item {
    border: 1px solid #ddd;
    padding: 1.2rem;
    border-radius: 10px;
    transition: all .3s ease;
    background-color: white;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.1), 0 6px 6px rgba(0, 0, 0, 0.15);
    backface-visibility: hidden;
    will-change: transform, box-shadow;
    transform: translateZ(0);
}

.categoria-item {
    background-color: transparent !important;
    perspective: 1000px;
    /* Activa el espacio 3D */
    border: none !important;
    padding: 0 !important;
    min-height: 480px !important;
    box-shadow: none !important;
    cursor: pointer;
    outline: none;
    /* Quita el borde azul al hacer focus/click */
}

.categoria-item-inner {
    position: relative;
    width: 100%;
    height: 100%;
    text-align: center;
    transition: transform 0.6s cubic-bezier(0.4, 0.2, 0.2, 1);
    transform-style: preserve-3d;
    border-radius: 10px;
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.1), 0 6px 6px rgba(0, 0, 0, 0.15);
}

.categoria-item.is-flipped .categoria-item-inner {
    transform: rotateY(180deg);
    box-shadow: 0 15px 30px rgba(0, 0, 0, 0.2), 0 10px 10px rgba(0, 0, 0, 0.15);
}

/* Estilos comunes para Frente y Dorso */
.categoria-item-front,
.categoria-item-back {
    position: absolute;
    width: 100%;
    height: 100%;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    /* Oculta la cara que no mira a la cámara */
    border-radius: 10px;
    background-color: white;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 1.8rem;
    border: 1px solid #ddd;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.03);
    /* Sombra base suave */

}

.categoria-item:hover .categoria-item-inner {
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.08), 0 1px 3px rgba(0, 0, 0, 0.02);
}

/* Estilos específicos del Dorso */
.categoria-item-back {
    transform: rotateY(180deg);
    background: linear-gradient(145deg, #ffffff, #fdf8f2);
    /* Ligero tono cálido de fondo */
    border: 2px solid #f19a31;
    justify-content: flex-start !important;
    padding: 2.5rem 1.5rem 1.5rem 1.5rem !important;

}

.categoria-item-back .categoria-descripcion {
    font-size: 0.9rem;
    line-height: 1.4;
    margin: 0 0 15px 0;
}




/* =========================================
   MEJORA H2 Y SUBTÍTULO (FRENTE DE TARJETA)
   ========================================= */

/* 1. H2 Frontal más elegante (Premium) */
.categoria-item-front h2 {
    font-size: 1.5rem;
    color: #2c3e50;
    /* Azul oscuro corporativo, más elegante que el negro puro */
    letter-spacing: -0.3px;
    /* Letras levemente más juntas */
    line-height: 1.2;
}

/* Controlamos el strong para que no sea un negrita tosco */
.categoria-item-front h2 strong {
    font-weight: 700;
    word-break: break-word !important;
}

.categoria-item-back h3 {
    word-break: break-word !important;
}


/* 3. Margen de seguridad en la tarjeta para evitar colisiones */
.categoria-item-front {
    /* Mantenemos tu padding actual arriba y a los lados, pero forzamos un espacio vacío abajo */
    padding-bottom: 70px !important;
}

/* Aseguramos que la imagen ocupe el espacio restante y no se aplaste */
.categoria-enlace-imagen {
    height: 240px;
    /* Levemente más chica para que el texto respire mejor */
    margin-bottom: auto;
    /* Empuja el texto hacia abajo de forma prolija */
    margin-top: 10px;
}

.categoria-enlace-texto {
    color: inherit;
    /* Hereda el color oscuro original del h2 */
    text-decoration: none;
    /* Quita el subrayado */
    transition: color 0.3s ease;
}

.categoria-enlace-texto:hover {
    color: #f19a31;
    /* Se vuelve naranja al pasar el mouse */
}



/* Títulos dentro de la tarjeta */
.categoria-item-back h2 {
    font-size: 1.4rem;
    margin: 0.75rem 0 0.5rem 0;
    color: #333;
    transition: color 0.3s ease;
}

.categoria-item:hover .categoria-item-front h2 {
    color: #f19a31;
}


.categoria-item-back h2 strong {
    font-weight: 560;
    /* Puedes cambiar a 400 si lo quieres totalmente normal */
    letter-spacing: -0.5px;
}

.categoria-descripcion {
    font-size: 0.95rem;
    color: #555;
    line-height: 1.5;
    /* Un interlineado más natural */
    margin: 0.5rem 0 1rem 0;
    /* Ajustamos los márgenes */
    text-align: center;
    /* Aseguramos que sea centrado, NUNCA justify */
    font-weight: 400;
    width: 100%;
    /* Toma todo el ancho disponible */
    padding: 0 15px;
    /* Evita que toque los bordes */

    /* Reseteo agresivo de rotura de palabras y justificación */
    text-justify: auto;
    word-spacing: normal;
    /* Fuerza el espaciado normal entre palabras */
    letter-spacing: normal;
    white-space: normal;
    word-break: break-word;
    overflow-wrap: break-word;
    -webkit-hyphens: none;
    hyphens: none;
}

.categoria-item-back .btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    /* Espacio entre texto e icono */
}

.categoria-item-back .btn::after {
    content: '\f061';
    /* Código FontAwesome para flecha derecha */
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: 0.85em;
    transition: transform 0.3s ease;
}

.categoria-item-back .btn:hover::after {
    transform: translateX(4px);
    /* La flecha se mueve al pasar el mouse */
}


.producto-item {
    width: 100%;
    max-width: 380px;
    margin: 0 auto;
    min-height: 380px;
}

.categoria-item:hover,
.producto-item:hover {
    transform: translateY(-5px) translateZ(0);
    box-shadow: 0px 12px 28px rgba(0, 0, 0, 0.25), 0px 8px 10px rgba(0, 0, 0, 0.22);
    transition: transform 0.3s ease-out, box-shadow 0.3s ease-out;
    transition-delay: 0.1s;
}

.categoria-item:hover {
    box-shadow: 0 10px 78px -24px rgba(0, 0, 0, 0.99);
}

.producto-item h2 {
    font-size: 1.25rem;
    margin: 0.5rem 0;
    color: #333;
    font-weight: 600;
    word-break: break-word;
    overflow-wrap: break-word;
}

.categoria-item h2 {
    font-size: 1.4rem;
    margin-bottom: 1.2rem;
    color: #333;
    font-weight: 600;
}

.categoria-enlace-imagen {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 240px;
    /* Fija altura para unificar */
}

.categoria-imagen {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    aspect-ratio: 1/1;
    transition: transform 0.3s ease-in-out;

}

/* =========================================
   MODIFICACIÓN: FRONT-TAGLINE (TARJETAS)
   ========================================= */
.front-tagline.rotator-wrapper {
    display: block;
    height: 45px;
    margin-top: 1.5rem;
    /* <--- AUMENTADO (Empuja la etiqueta hacia abajo) */
    margin-bottom: 2rem;
    pointer-events: none;
}

.front-tagline .rotator-item {
    /* Diseño de Píldora */
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: max-content;
    max-width: 100%;
    background-color: rgba(255, 255, 255, 0.9);
    border: 1px solid rgba(241, 154, 49, 0.15);
    padding: 6px 12px;
    border-radius: 20px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05);

    /* Tipografía idéntica al .flip-indicator-text */
    font-size: 0.65rem;
    color: #555;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    font-weight: 600;

    /* NUEVO: Permite que el texto baje a la siguiente línea si es muy largo */
    white-space: normal;
    /* Antes estaba en nowrap */
    text-align: center;
    /* Centra el texto si cae en 2 líneas */
    line-height: 1.3;
    /* Le da un poco de respiro entre las líneas */

    transform-origin: center center;
    word-break: break-word !important;
}

.front-tagline .rotator-item::before {
    content: '';
    display: inline-block;
    flex-shrink: 0;
    /* Evita que el punto se aplaste si el texto es muy largo */
    width: 6px;
    height: 6px;
    margin-right: 6px;
    /* Mismo 'gap' que tiene el icono de abajo */
    border-radius: 50%;
    background-color: #f19a31;
    box-shadow: 0 0 6px rgba(241, 154, 49, 0.4);
}

@media (max-width: 480px) {
    .front-tagline .rotator-item {
        font-size: 0.6rem;
        padding: 5px 10px;
        max-width: 95%;
    }
}

/* =========================================
   UX/UI: INDICADOR ANIMADO DE "TOCAR" (Sin Cápsula)
   ========================================= */

/* Contenedor del indicador (Flotando transparente) */
.flip-indicator-container {
    position: absolute;
    bottom: 25px;
    /* Separación desde el borde inferior */
    left: 50%;
    /* Lo empuja a la mitad exacta de la tarjeta */
    transform: translateX(-50%);
    /* Lo corrige para que el centro del elemento sea el centro de la tarjeta */
    /* Tiene transform y z-index propios, así que se le escapa al
       backface-visibility de la cara frontal: sin esto, "Toca para ver
       detalles" se ve espejado en el dorso de la tarjeta. */
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    /* Asegura que el contenido interno se centre */
    gap: 8px;
    /* Separación entre el dedo y el texto */
    background: transparent;
    border: none;
    padding: 0;
    box-shadow: none;
    z-index: 10;
    width: max-content;
    /* Evita que el contenedor ocupe el 100% y arruine el centrado del texto */
    transition: transform 0.3s ease;
    pointer-events: auto;
    cursor: pointer;
}


@media (max-width: 768px) {
    .flip-indicator-container {

        left: 50%;
        margin: 0 auto;
        width: max-content;
        bottom: 20px;
    }
}

/* El contenedor del ícono (Para posicionar el anillo pulsante) */
.flip-indicator-icon {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #f19a31;
    /* Naranja de tu marca */
    font-size: 0.95rem;
    /* Apenas más grande para compensar la falta de fondo */
    animation: tapAnimation 2s infinite ease-in-out;
    transition: color 0.3s ease;
}

/* El texto "Toca para detalles" */
.flip-indicator-text {
    font-size: 0.65rem;
    font-weight: 700;
    /* Más negrita para que lea bien sobre el blanco puro */
    color: #888;
    /* Gris medio, no compite con el título */
    text-transform: uppercase;
    letter-spacing: 0.5px;
    white-space: nowrap;
    transition: color 0.3s ease;
}

/* Comportamiento al pasar el mouse (Hover sin cápsula) */
.flip-indicator-container:hover {
    background: transparent;
    border: none;
    box-shadow: none;
    transform: translateX(-50%) translateY(-3px);
    /* Mantiene el centrado en X, pero lo sube en Y */
}

.flip-indicator-container:hover .flip-indicator-icon {
    color: #d98220;
    /* Naranja un poco más oscuro/fuerte */
}

.flip-indicator-container:hover .flip-indicator-text {
    color: #f19a31;
    /* El texto se pinta de naranja al pasar el ratón */
}

.flip-indicator-container:hover .pulse-ring {
    background-color: rgba(241, 154, 49, 0.4);
    /* El anillo pulsante se mantiene naranja */
}

/* =========================================
   ELIMINAR HIGHLIGHT DE TAP EN MÓVILES
   ========================================= */

.categoria-item {
    -webkit-tap-highlight-color: transparent;
    -webkit-touch-callout: none;
    outline: none;
}

.categoria-item a,
.categoria-item .btn,
.categoria-item-front,
.categoria-item-back,
.categoria-item-inner {
    -webkit-tap-highlight-color: transparent;
    outline: none;
}

/* =========================================
   ESTILO PREMIUM: BADGES (ETIQUETAS)
   ========================================= */
.categoria-badges {
    position: relative;
    height: 120px;
    width: 100%;
    margin: 0 0 20px 0;
    display: flex;
    justify-content: center;
    align-items: center;
}

.categoria-badge {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, 15px);
    /* Posición inicial: Abajo y oculto */
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.4s ease, transform 0.4s ease, visibility 0.4s;

    /* Diseño premium de la píldora */
    background-color: #fff9f2;
    color: #d97706;
    border: 1px solid rgba(241, 154, 49, 0.3);
    padding: 6px 18px;
    border-radius: 25px;
    font-size: 0.8rem;
    font-weight: 600;
    white-space: nowrap;
    /* Evita que el texto se parta en 2 líneas */
    display: flex;
    align-items: center;
    gap: 8px;
    box-shadow: 0 4px 10px rgba(241, 154, 49, 0.1);
}

.categoria-badge i {
    font-size: 0.9rem;
    color: #f19a31;
}

.categoria-badge.rotator-active {
    opacity: 1;
    visibility: visible;
    transform: translate(-50%, -50%);
    /* Sube al centro perfecto */
}

.categoria-badge.rotator-exit {
    opacity: 0;
    visibility: hidden;
    transform: translate(-50%, -35px);
    /* Desaparece por arriba */
}

/* Micro-interacción: Si el usuario pasa el ratón por el badge (en PC) */
.categoria-badge:hover {
    background-color: #f19a31;
    /* Fondo Naranja */
    color: #ffffff;
    /* Letra blanca */
    border-color: #f19a31;
    /* AQUÍ ESTÁ LA CORRECCIÓN: Mantenemos el -50% en X, y lo subimos un poquito en Y */
    transform: translate(-50%, calc(-50% - 3px));
    box-shadow: 0 4px 10px rgba(241, 154, 49, 0.3);
}

/* Y para asegurar que el icono también se vea bien al pasar el mouse */
.categoria-badge:hover i {
    color: #ffffff;
}

.categoria-item:focus .categoria-item-inner,
.categoria-item.is-flipped .categoria-item-inner {
    box-shadow: 0 15px 30px rgba(0, 0, 0, 0.15), 0 0 0 4px rgba(241, 154, 49, 0.1);
    /* Ese último valor es el glow naranja */
}




.categoria-item:hover .categoria-imagen {
    transform: scale(1.05);
}

.product-image-container {
    width: 100%;
    height: 220px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1rem;
    overflow: hidden;
}

.producto-grid .producto-item img {
    max-width: 100%;
    max-height: 100%;
    height: auto;
    width: auto;
    object-fit: contain;
    border-radius: 5px;
    transition: transform 0.4s ease-in-out;
    padding-left: 0.5rem;
    padding-right: 0.5rem;
}

.product-image-container:hover img {
    transform: scale(1.1);
}

.categoria-item p,
.producto-grid .producto-item p {
    font-size: 0.9rem;
    color: #555;
    line-height: 1.5;
    min-height: 10px;
    margin: 0 0 1rem 0;
    flex-grow: 1;
    text-align: center;
    word-break: break-word;
    overflow-wrap: break-word;
    overflow: hidden;
}

.categoria-item p {
    margin-bottom: 10px;
    text-align: justify;
}


.categoria-item-front {
    /* Mantenemos tus estilos y agregamos esto: */
    border-top: 4px solid #f19a31;
    /* O el naranja #f19a31 */
}

.categoria-item-front .categoria-badges {
    margin: 10px 0 0 0;
    /* Lo separamos un poco del título */
    height: 40px;
    /* Un poco más compacto para que la imagen no se achique */
}

/* Opcional: Que el borde cambie de color al girar */
.categoria-item-back {
    border-top: 4px solid #f19a31;
}

.btn {
    display: inline-block;
    padding: 10px 25px;
    background-color: #2c3e50;
    color: white;
    text-decoration: none;
    border-radius: 8px;
    font-size: 0.9rem;
    font-weight: 500;
    transition: all 0.3s ease;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
    width: auto;
    min-width: 150px;
    text-align: center;
    margin-top: auto;
    opacity: 1;
}

.categoria-item .btn {
    padding: 10px 20px;
    border-radius: 10px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.3), 0 1px 3px rgba(0, 0, 0, 0.2);
    width: 80%;
    opacity: 95%;
}

.btn:hover {
    background-color: #f19a31;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
    transform: translateY(-2px);
}

.categoria-item .btn:hover {
    background-color: #e67a00;
}

.btn.active-tap,
.categoria-item a.active-tap {
    transform: scale(0.95);
    transition: all 0.1s ease;
}

.no-products-message {
    display: none;
    grid-column: 1 / -1;
    text-align: center;
    padding: 3rem 1rem;
    color: #555;
    font-size: 1.1rem;
}

/* =========================================
   UX: DORSO DE TARJETA (Scroll y Botón Cerrar)
   ========================================= */

/* Botón de cerrar (X) inyectado por JS */
.btn-close-card {
    position: absolute;
    top: 12px;
    right: 15px;
    background: rgba(241, 154, 49, 0.1);
    color: #f19a31;
    border: none;
    border-radius: 50%;
    width: 32px;
    height: 32px;
    font-size: 1.1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.3s ease;
    z-index: 10;
}

.btn-close-card:hover {
    background: #f19a31;
    color: white;
    transform: scale(1.1);
}

/* Scroll para la descripción en el dorso */
.categoria-item-back .categoria-descripcion {
    max-height: 180px;
    /* Altura máxima antes de hacer scroll */
    overflow-y: auto;
    padding-right: 10px;
    /* Separación del texto con la barra de scroll */

    /* Forzamos a que elimine la restricción de 3 líneas en móviles */
    display: block !important;
    -webkit-line-clamp: unset !important;
    line-clamp: unset !important;

    /* Aseguramos que los eventos táctiles y de mouse funcionen aquí */
    pointer-events: auto;
}

/* Estilo del scrollbar personalizado y elegante */
.categoria-item-back .categoria-descripcion::-webkit-scrollbar {
    width: 6px;
}

.categoria-item-back .categoria-descripcion::-webkit-scrollbar-track {
    background: #f8fafc;
    border-radius: 4px;
}

.categoria-item-back .categoria-descripcion::-webkit-scrollbar-thumb {
    background: #cbd5e1;
    border-radius: 4px;
}

.categoria-item-back .categoria-descripcion::-webkit-scrollbar-thumb:hover {
    background: #f19a31;
}

/* Ajustes para pantallas pequeñas */
@media (max-width: 768px) {
    .categoria-item-back {
        padding-top: 1.5rem !important;
        /* Más espacio para que el título no pise la X */
    }

    .categoria-item-back .categoria-descripcion {
        max-height: 150px;
        /* Un poco más corto en móviles */
    }
}

s
/* =========================================
   SECCIÓN DE AUTORIDAD (NIVEL PREMIUM B2B)
   ========================================= */

/* 1. El Fondo: Pasamos de un gris plano a un gradiente radial sutil */
.seo-authority-section {
    padding: 6rem 1rem;
    margin-top: 4rem;
    margin-bottom: 3.5rem;
    margin-left: 30px;
    margin-right: 30px;
    position: relative;
    overflow: hidden;
}

/* Patrón sutil de puntos de fondo (Opcional, da un toque técnico) */
.seo-authority-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-image: radial-gradient(#d1d5db 1px, transparent 1px);
    background-size: 24px 24px;
    opacity: 0.3;
    z-index: 0;
}

#home-page .container-seo-section {
    margin: 0 auto;
    padding: 0 1rem;
    max-width: 100vw;
    margin-left: 30px;
    margin-right: 30px;

}

@media (max-width: 768px) {
    #home-page .container-seo-section {

        margin: 0 auto;
        padding: 0 1rem;
        max-width: 100vw;
        margin-left: 0px;
        margin-right: 0px;


    }


}



/* 2. La Tarjeta: Profundidad y elegancia */
.seo-authority-card {
    max-width: 100%;
    background: #ffffff;
    border-radius: 20px;
    box-shadow: 0 10px 10px rgba(0, 0, 0, 0.2);
    border: none;
    padding: 5rem 6rem;
    position: relative;
    z-index: 1;
    overflow: hidden;
    transform: translateY(0);
    transition: transform 0.4s ease, box-shadow 0.4s ease;
}

/* Efecto de levitación al pasar el mouse (Aporta mucha calidad) */
.seo-authority-card:hover {
    transform: translateY(-5px);
    box-shadow:
        0 10px 30px rgba(0, 0, 0, 0.12),
        0 4px 15px rgba(0, 0, 0, 0.05)
}

/* NUEVO ACENTO PREMIUM: Línea superior degradada en lugar de lateral */
.seo-authority-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 5px;
    background: linear-gradient(90deg, #f19a31 0%, #ffc107 50%, #f19a31 100%);
}

/* GLOW INTERNO: Un resplandor naranja muy suave en la esquina inferior derecha */
.seo-authority-card::after {
    content: '';
    position: absolute;
    bottom: -20%;
    right: -10%;
    width: 500px;
    height: 500px;
    background: radial-gradient(circle, rgba(241, 154, 49, 0.06) 0%, transparent 70%);
    border-radius: 50%;
    pointer-events: none;
    /* Para que no interfiera con los clics */
    z-index: -1;
}

/* 3. Etiqueta (Label) más moderna */
.seo-authority-label {
    display: inline-flex;
    align-items: center;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 2.5px;
    color: #f19a31;
    font-weight: 700;
    margin-bottom: 1.5rem;
    padding: 6px 14px;
    background-color: rgba(241, 154, 49, 0.1);
    border-radius: 30px;
    /* Forma de píldora */
}

/* 4. Título con contraste extremo */
.seo-authority-card h2 {
    font-size: 2.6rem;
    /* Aún más grande */
    color: #1a202c;
    /* Gris casi negro, muy profundo */
    margin-top: 0;
    margin-bottom: 2.5rem;
    line-height: 1.15;
    letter-spacing: -1px;
    font-weight: 300;
}

.seo-authority-card h2 strong {
    font-weight: 900;
    color: #111827;
    display: block;
    /* Obligamos a que "Seguridad Integral" baje de línea */
    margin-top: 5px;
}

/* 5. Mejora de la tipografía del texto (Las dos columnas) */
.seo-authority-text {
    font-size: 1.1rem;
    /* Letra un poco más grande */
    color: #4b5563;
    /* Gris medio/oscuro, fácil de leer */
    line-height: 1.85;
    column-count: 2;
    column-gap: 5rem;
    /* Más separación entre columnas */
    text-align: left;
    /* Alineación izquierda suele ser más moderna que el justificado */
}

.seo-authority-text p {
    margin-top: 0;
    margin-bottom: 1.5rem;
}

/* Enlaces (Cerraduras, Control de acceso) sutiles y corporativos */
.seo-authority-text a {
    color: #2c3e50;
    font-weight: 600;
    text-decoration: none;
    border-bottom: 2px solid rgba(241, 154, 49, 0.4);
    /* Línea naranja suave debajo */
    transition: all 0.3s ease;
}

.seo-authority-text a:hover {
    color: #f19a31;
    border-bottom-color: #f19a31;
    background-color: rgba(241, 154, 49, 0.05);
    /* Leve resaltado al pasar el mouse */
}

/* =========================================
   ADAPTACIONES RESPONSIVE (MÓVILES)
   ========================================= */
@media(max-width: 1050px) {
    .seo-authority-card {
        padding: 4rem 4rem;
    }

    .seo-authority-text {
        column-gap: 3rem;
    }
}

@media(max-width: 800px) {
    .seo-authority-section {
        padding: 4rem 0;
    }

    .seo-authority-card {
        padding: 3rem 2.5rem;

    }

    .seo-authority-card::after {
        border-radius: 0;
        width: 4px;
    }

    .seo-authority-card h2 {
        font-size: 2rem;
    }

    .seo-authority-text {
        column-count: 1;
    }

    /* Pasa a 1 columna */
}

@media(max-width: 500px) {
    .seo-authority-card {
        padding: 2.5rem 1.5rem;
    }

    .seo-authority-card h2 {
        font-size: 1.7rem;
    }

    .seo-authority-text {
        font-size: 1rem;
    }
}

/* =========================================
   BOTÓN EXPLORAR (HERO CTA) - FLECHAS VERTICALES
   ========================================= */
.hero-cta-container {
    margin-top: 3.5rem;
    /* Un poco más de aire arriba para que las flechas verticales respiren */
    display: flex;
    justify-content: center;
    position: relative;
    z-index: 10;
}

.hero-explore-btn {
    display: inline-flex;
    flex-direction: column;
    /* Apila el texto y las flechas verticalmente */
    align-items: center;
    /* Centra todo */
    gap: 8px;
    /* Separación entre "Explorar" y las flechas */
    color: #f19a31;
    /* Naranja de tu marca */
    text-decoration: none;
    font-size: 0.95rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 2px;
    transition: all 0.3s ease;
}

/* Efecto Hover: Brilla y baja un poquito */
.hero-explore-btn:hover {
    color: #ffc107;
    /* Amarillo brillante */
    transform: translateY(3px);
}

.hero-explore-btn:active {
    transform: translateY(6px);
    /* Efecto de "hundimiento" al hacer clic */
}

/* Contenedor de las flechas en Columna */
.hero-explore-arrows {
    display: flex;
    flex-direction: column;
    /* Apila las 3 flechas una debajo de la otra */
    align-items: center;
    gap: -1px;
    /* Las acerca un poco pero no tanto (antes -4px) */
    margin-top: 5px;
}

/* Animación de Cascada Vertical Removida */
.hero-explore-arrows i {
    font-size: 1.2rem;
    /* Tamaño de las flechas */
    line-height: 0.8;
    /* Deja un poco más de altura visible para separarlas */
    opacity: 0.7;
    /* Estado estático visible */
}

/* Ajustes para móviles */
@media (max-width: 768px) {
    .hero-cta-container {
        margin-top: 20vh;
    }

    .hero-explore-btn {
        font-size: 0.85rem;
    }

    .hero-explore-arrows i {
        font-size: 1rem;
    }
}

/* Nuevos Productos Section */
#productos-nuevos {
    padding: 5rem 1rem;
    margin: 0 auto;
    text-align: center;
    background-color: #f8f9fa;
    overflow: hidden;
    position: relative;
    width: 100%;

}

.titulo-con-enlace {
    display: flex;
    justify-content: space-between;
    /* Separa título de botón a los extremos */
    align-items: center;
    /* Centra verticalmente */
    margin: 0 auto 2rem auto;
    padding: 0 10px 15px 10px;
    /* Ajusta con los bordes del slider */
    width: 100%;
    /* Ocupa todo el contenedor gris */
    max-width: 100%;
    /* Elimina restricciones previas */
    border-bottom: 2px solid #e2e8f0;
    /* Línea de base elegante */
    box-sizing: border-box;
}


.ver-mas-link {
    position: relative;
    /* Anula tu absolute antiguo */
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.9rem;
    font-weight: 600;
    color: #d98220;
    text-decoration: none;
    background-color: rgba(241, 154, 49, 0.1);
    /* Fondo transparente naranja */
    padding: 8px 20px;
    border-radius: 30px;
    /* Forma de píldora */
    transition: all 0.3s ease;
    white-space: nowrap;
    margin: 0 !important;
    /* Evita márgenes heredados */
    transform: none !important;
    /* Anula transforms antiguos */
}

.ver-mas-link:hover {
    background-color: #f19a31 !important;
    color: #ffffff !important;
    text-decoration: none;
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 12px rgba(241, 154, 49, 0.3);
}

@media (max-width: 768px) {
    .titulo-con-enlace {
        flex-direction: row;
        /* Mantener en una línea si es posible */
        align-items: center;
        margin-bottom: 1.5rem;
    }

    #productos-nuevos-titulo {
        font-size: 1.4rem;
    }

    .ver-mas-link {
        padding: 6px 16px;
        font-size: 0.85rem;
    }
}

.productos-nuevos-slider-container {
    padding: 0 1rem;
    position: relative;
}

.productos-nuevos-swiper {
    width: 100%;
    padding-top: 10px;
    padding-bottom: 50px;
}

.productos-nuevos-swiper .swiper-slide {
    display: flex;
    justify-content: center;
    align-items: stretch;
    height: auto;
    box-sizing: border-box;
}

.productos-nuevos-swiper .producto-item {
    width: 100%;
    max-width: 350px;
    min-height: 350px;
}

.productos-nuevos-swiper .producto-item img {
    max-width: 80%;
    max-height: 200px;
    object-fit: contain;
    aspect-ratio: 1/1;
    margin: 0 auto 1rem auto;
}

.productos-nuevos-swiper .producto-item h3,
.productos-nuevos-swiper .producto-item p {
    word-break: break-word;
    overflow-wrap: break-word;
    overflow: hidden;
}

.productos-nuevos-swiper .producto-item .btn {
    padding: 10px 20px;
    border-radius: 10px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.3);
    width: 90%;
    opacity: 95%;
}

.productos-nuevos-swiper .producto-item .btn:hover {
    background-color: #e67a00;
}

.productos-nuevos-swiper .swiper-button-next,
.productos-nuevos-swiper .swiper-button-prev {
    color: #f19a31;
    background-color: rgba(255, 255, 255, 0.7);
    border-radius: 50%;
    width: 50px;
    height: 50px;
    top: calc(50% - 25px);
    margin-top: 0;
    transform: translateY(-50%);
    padding: 0.5rem;
    border: 1px solid #ddd;
    /* --- AGREGA ESTA LÍNEA --- */
    --swiper-navigation-size: 0;
    /* Esto oculta la flecha gigante por defecto de Swiper */
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
}

.productos-nuevos-swiper .swiper-button-next svg,
.productos-nuevos-swiper .swiper-button-prev svg {
    display: none !important;
}

.productos-nuevos-swiper .swiper-button-next::after,
.productos-nuevos-swiper .swiper-button-prev::after {
    font-family: 'Font Awesome 5 Free' !important;
    font-weight: 900 !important;
    font-size: 25px;
    display: block !important;
}

.productos-nuevos-swiper .swiper-button-next:hover,
.productos-nuevos-swiper .swiper-button-prev:hover {
    background-color: #f19a31;
    color: #ffffff;
    opacity: 1;
    transform: translateY(-50%) scale(1.1);
    box-shadow: 0 0 10px rgba(241, 154, 49, 0.6);
    transition: all 0.3s ease;
}

.productos-nuevos-swiper .swiper-button-next::after {
    content: '\f054' !important;
}

.productos-nuevos-swiper .swiper-button-prev::after {
    content: '\f053' !important;
}

.productos-nuevos-swiper .swiper-pagination {
    bottom: 0px !important;
}

.productos-nuevos-swiper .swiper-pagination-bullet {
    background-color: #f19a31;
    opacity: 0.5;
    width: 14px;
    height: 14px;
    margin: 0 6px !important;
}

.productos-nuevos-swiper .swiper-pagination-bullet-active {
    opacity: 1;
    background-color: #e07b00;
}

.productos-nuevos-slider {
    -ms-overflow-style: none;
    scrollbar-width: none;
}

.productos-nuevos-slider::-webkit-scrollbar {
    display: none;
}

/* Image Fullscreen */
.fullscreen-img {
    position: fixed !important;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) scale(1);
    max-width: 90vw;
    max-height: 90vh;
    z-index: 99999;
    cursor: zoom-out;
    background-color: white;
    padding: 8px 15px;
    border-radius: 2px;
    box-shadow: 0 0 20px rgba(0, 0, 0, 0.5);
    object-fit: contain;
}

.image-backdrop {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: 99998;
    cursor: pointer;
}

.floating-product-img {
    transition: transform 0.3s ease;
    cursor: zoom-in;
    width: clamp(50px, 25vw, 100px);
    height: auto;
    border-radius: 4px;
    object-fit: contain;
    aspect-ratio: 1 / 1;
}

.fullscreen-wrapper {
    position: fixed !important;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 99999;
    background-color: white;
    padding: 10px;
    border-radius: 4px;
    box-shadow: 0 0 25px rgba(0, 0, 0, 0.6);
    display: inline-block;
}

.fullscreen-wrapper img.fullscreen-img {
    position: static !important;
    transform: none !important;
    box-shadow: none !important;
    background-color: transparent !important;
    padding: 0 !important;
    margin: 0 !important;
    max-width: 90vw;
    max-height: 85vh;
}

/* Botón sutil y transparente */
.btn-cerrar-popup {
    position: absolute;
    top: -30px;
    /* Lo subimos un poco más para que flote sobre la imagen */
    right: -10px;
    width: 30px;
    height: 30px;
    background-color: transparent;
    /* Fondo transparente */
    color: #ffffff;
    /* X blanca inicial (se verá bien contra el fondo oscuro del overlay) */
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 300;
    /* Más fino */
    font-family: Arial, sans-serif;
    font-size: 30px;
    /* X más grande */
    cursor: pointer;
    z-index: 100000;
    transition: all 0.2s ease;
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.5);
    /* Sombra al texto para que se lea siempre */
}

/* Si el fondo es blanco (el wrapper tiene padding), cambiamos a oscuro */
.fullscreen-wrapper .btn-cerrar-popup {
    top: 5px;
    right: 5px;
    color: #555;
    /* Gris oscuro para contrastar con el fondo blanco del wrapper */
    text-shadow: none;
}

.btn-cerrar-popup:hover {
    color: #f19a31;
    /* Naranja al pasar el mouse */
    transform: scale(1.2);
}

.btn-cerrar-popup::before {
    content: "×";
    margin-top: -4px;
}

body.body-no-scroll {
    overflow: hidden;
    /* position:fixed + top se aplican via JS para evitar el salto de scroll */
}

/* Compensación de altura del header cuando el menú móvil abre.
   El header pasa de sticky a fixed (sale del flujo). El body es
   `display: flex; flex-direction: column`; su padding-top empuja
   TODOS los flex items en flujo (slogan en home, breadcrumb en
   categoría/producto, main en general) la misma cantidad — match
   exacto con la altura del header. La variable la setea main.js
   dentro de openMobileMenu() en cada apertura, ANTES de body-no-scroll. */
@media (max-width: 1050px) {
    body.body-no-scroll {
        padding-top: var(--header-height-mobile, 74px);
    }
}

/* CRÍTICO: overflow:hidden en <html>/<body> ROMPE position:sticky del header.
   Cuando el menú móvil abre (body-no-scroll activa), el header pierde sticky
   y vuelve a su posición natural (top del documento), quedando fuera del
   viewport si el usuario scrolleó. Forzamos position:fixed para mantenerlo
   visible sin importar el scroll. */
body.body-no-scroll .header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    width: 100%;
}

/* Float Buttons */
.float-buttons,
.float-buttonsleft {
    position: fixed;
    z-index: 100;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.float-buttons {
    bottom: 25px;
    right: -22px;
    align-items: flex-end;
}

.float-buttonsleft {
    bottom: 90px;
    left: 20px;
    gap: 15px;
}

.float-button,
.float-button2 {
    width: 80px;
    height: 50px;
    border-radius: 40px;
    text-align: center;
    font-size: 28px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.3);
    display: flex;
    align-items: center;
    justify-content: left;
    text-decoration: none;
    transition: all 0.3s ease;
    color: #fff;
    opacity: 70%;
    position: relative;
    padding: 0px 15px;
    -webkit-tap-highlight-color: transparent;
}

.float-button {
    opacity: 1 !important;
    background-clip: padding-box;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
    border: 2px solid transparent;
    position: relative; /* ancla el ::before tooltip al botón */
}

.float-button:hover {
    transform: scale(1.1);
    box-shadow: 0 6px 15px rgba(0, 0, 0, 0.5);
    opacity: 1;
}

.float-button:active {
    transform: scale(0.98);
    transition: all 0.1s ease;
}

.float-button.hovered {
    background-color: #f19a31 !important;
}

.whatsapp-float {
    background-color: #25d366;
    font-size: 29px;
}

.whatsapp-float:hover {
    background-color: #20ba5a;
}

.email-float {
    background-color: #ff4500;
}

.email-float:hover {
    background-color: #e63e00;
}

.phone-float {
    background-color: #007bff;
}

.phone-float:hover {
    background-color: #0056b3;
}

.map-float {
    background-color: #005e00;
}

.map-float:hover {
    background-color: #168a16ea;
}

.btnup-float {
    background-color: #ff9a03;
}

.btnup-float:hover {
    background-color: #f34d00ea;
}

.float-button:not(.contact-main-float):not(.btnup-float)::before {
    content: attr(title);
    position: absolute;
    right: 90px;
    top: 50%;
    background-color: inherit;
    color: white;
    padding: 15px 20px;
    border-radius: 15px;
    font-size: 14px;
    white-space: nowrap;
    opacity: 0;
    transform: translateY(-50%) translateX(20px);
    transition: all 0.3s ease;
    pointer-events: none;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
}

.float-button:not(.contact-main-float):not(.btnup-float):hover::before,
.float-button.show-tooltip:not(.contact-main-float):not(.btnup-float)::before {
    opacity: 1;
    transform: translateY(-50%) translateX(0);
}

#btnUp {
    height: 0 !important;
    min-height: 0 !important;
    margin-top: 0 !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    opacity: 0;
    visibility: hidden;
    overflow: hidden;
    pointer-events: none;
    border: none;
    display: flex !important;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

#btnUp.show {
    height: 50px !important;
    opacity: 0.7;
    visibility: visible;
    pointer-events: auto;
    padding: 0 15px !important;
}

#btnUp.show:hover {
    opacity: 1;
    transform: scale(1.1);
}

/* Performance Toggle (Desktop) */
.performance-toggle-mobile {
    position: fixed;
    bottom: 90px;
    left: -22px;
    z-index: 7000;
    display: none;
    align-items: center;
}

.performance-toggle-mobile-button {
    width: 60px;
    height: 45px;
    background-color: #333333d5;
    color: white;
    border-radius: 40px;
    display: flex;
    align-items: center;
    justify-content: right;
    font-size: 25px;
    cursor: pointer;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
    transition: background-color 0.3s ease, transform 0.3s ease, box-shadow 0.3s ease;
    border: 1px solid rgba(255, 255, 255, 0.1);
    outline: none;
    position: relative;
    padding: 0 15px;
    -webkit-tap-highlight-color: transparent;
}

.performance-toggle-mobile-button:hover {
    transform: scale(1.1);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.5);
}

.performance-toggle-mobile-button.active-mode {
    background-color: #f19a31;
}

.performance-toggle-mobile-button.active-tap {
    transform: scale(0.92);
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);
}

.performance-toggle-mobile-button i {
    transition: transform 0.4s ease-out;
}

.performance-toggle-mobile-button.active-mode i {
    transform: rotate(180deg);
}

.performance-toggle-mobile-tooltip {
    position: absolute;
    left: calc(100% + 10px);
    top: 50%;
    transform: translateY(-50%) translateX(-10px);
    background-color: rgba(51, 51, 51, 0.9);
    color: white;
    padding: 6px 12px;
    border-radius: 5px;
    font-size: 12px;
    white-space: nowrap;
    opacity: 0;
    transition: opacity 0.3s ease 0.1s, transform 0.3s ease 0.1s;
    pointer-events: none;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.15);
}

.performance-toggle-mobile-button.show-tooltip .performance-toggle-mobile-tooltip {
    opacity: 1;
    transform: translateY(-50%) translateX(0);
    transition-delay: 0s;
    padding: 6px 12px;
}



#pagina-nosotros .contact-page-container {
    padding: 2rem 1rem;
    max-width: 100%;
    padding-top: 0px;
}

@media (max-width: 768px) {
    #pagina-nosotros .contact-page-container {
        padding: 2rem 1rem;
        max-width: 100%;
        padding-top: 0px;
    }

}

/* Contact Page Specifics */
.contact-page-container {
    padding: 2rem 1rem;
    max-width: 90%;
    padding-top: 0px;
}

.contact-page-container h1 {
    text-align: center;
    margin-bottom: 2rem;
    margin-top: 1.5rem;
    font-size: 2rem;
    font-weight: 700;
    color: #333;
}

.contact-layout-container {
    display: flex;
    gap: 2rem;
    align-items: stretch;
}

.contact-details {
    background-color: #fff;
    padding: 2rem;
    border-radius: 10px;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
    width: 100%;
    flex: 1;
    max-width: 500px;
    min-width: 200px;
    display: flex;
    flex-direction: column;
}

.contact-details h2 {
    margin-top: 0;
    margin-bottom: 1.5rem;
    color: #333;
    border-bottom: 2px solid #f19a31;
    padding-bottom: 0.5rem;
}

.contact-details ul {
    list-style: none;
    padding: 0;
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
}

.contact-details li {
    display: flex;
    align-items: flex-start;
    font-size: 1rem;
    background-color: #f9f9f9;
    border: 1px solid #eee;
    border-left: 4px solid #f19a31;
    padding: 1.25rem;
    border-radius: 8px;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.contact-details li:hover {
    transform: translateY(-5px);
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.08);
}

.contact-details li i {
    font-size: 1.5rem;
    color: #f19a31;
    margin-right: 15px;
    margin-top: 2px;
    width: 25px;
    text-align: center;
}

.contact-details li a {
    color: #333;
    text-decoration: none;
    transition: color 0.3s ease;
}

.contact-details li a:hover {
    color: #f19a31;
    text-decoration: underline;
}

.location-section {
    background-color: #fff;
    padding: 2rem;
    border-radius: 10px;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
    text-align: center;
    margin-top: 0;
    flex: 1.5;
    min-width: 200px;
    display: flex;
    flex-direction: column;
}

.location-section h2 {
    margin-top: 0;
    margin-bottom: 1.5rem;
    color: #333;
}

.map-responsive {
    margin-bottom: 2rem;
    flex-shrink: 0;
}

.map-responsive iframe {
    border-radius: 10px;
    border: 0;
    width: 100%;
}

.transport-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1.5rem;
    text-align: left;
    padding-top: 1.5rem;
}

.transport-item {
    background-color: #ffffff;
    border: 1px solid #eee;
    border-radius: 8px;
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 0.5rem;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.transport-item:hover {
    transform: translateY(-5px);
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.08);
}

.transport-item i {
    font-size: 2rem;
    color: #f19a31;
    margin-bottom: 0.5rem;
}

.transport-item h3 {
    margin: 0 0 0.5rem 0;
    font-size: 1.2rem;
    color: #333;
}

.transport-item p {
    margin: 0;
    line-height: 1.5;
    color: #555;
    font-size: 0.95rem;
    flex-grow: 1;
}


/* =========================================
   BARRA DE CONTACTO UNIFICADA (CLEAN PREMIUM)
   ========================================= */
.contact-info-section {
    background-color: transparent;
    padding: 1.5rem 1rem 0 1rem;
    margin-top: -10px;
    position: relative;
    z-index: 10;

}

.contact-info-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    /* Hace que ocupe el 95% del ancho de la pantalla */
    background: #ffffff;
    border-radius: 16px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.06), 0 1px 3px rgba(0, 0, 0, 0.02);
    border: 1px solid rgba(0, 0, 0, 0.04);
    overflow: hidden;
}

/* Items individuales (Cada tercio de la barra) */
.contact-info-item-wsp,
.contact-info-item-dir,
.contact-info-item-tel {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem 1rem;
    flex: 1;
    text-decoration: none;
    color: inherit;
    background-color: transparent;
    transition: background-color 0.3s ease;
    position: relative;
    cursor: pointer;
}

/* Líneas separadoras elegantes usando pseudo-elementos */
.contact-info-item-wsp::after,
.contact-info-item-dir::after {
    content: '';
    position: absolute;
    right: 0;
    top: 20%;
    height: 60%;
    width: 1px;
    background-color: #eaeaea;
}

/* Hover: Fondo sutil gris claro para indicar que es clickeable */
.contact-info-item-wsp:hover,
.contact-info-item-dir:hover,
.contact-info-item-tel:hover {
    background-color: #f8fafc;
    border-radius: 16px;
}

/* Iconos Cuadrados Premium (Estilo Apple/Moderno) */
.contact-info-icon-wsp,
.contact-info-icon-dir,
.contact-info-icon-tel {
    width: 45px;
    height: 45px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-right: 15px;
    background: linear-gradient(135deg, #f19a31 0%, #ffc107 100%);
    box-shadow: 0 4px 10px rgba(241, 154, 49, 0.25);
    flex-shrink: 0;
    transition: transform 0.3s ease;
}

.contact-info-icon-wsp i,
.contact-info-icon-dir i,
.contact-info-icon-tel i {
    font-size: 20px;
    color: #fff;
    margin: 0;
}

/* Al pasar el mouse, el icono crece sutilmente */
.contact-info-item-wsp:hover .contact-info-icon-wsp,
.contact-info-item-dir:hover .contact-info-icon-dir,
.contact-info-item-tel:hover .contact-info-icon-tel {
    transform: scale(1.1);
}

/* Textos de la barra */
.contact-info-text-wsp,
.contact-info-text-dir,
.contact-info-text-tel {
    text-align: left;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.contact-info-label-wsp,
.contact-info-label-dir,
.contact-info-label-tel {
    font-size: 0.85rem;
    color: #64748b;
    /* Gris corporativo */
    margin-bottom: 2px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.contact-info-value-wsp,
.contact-info-value-dir,
.contact-info-value-tel {
    font-size: 1.1rem;
    font-weight: 700;
    color: #1e293b;
    /* Casi negro */
}

/* Adaptación para Móviles */
@media (max-width: 900px) {
    .contact-info-container {
        flex-direction: column;
    }

    .contact-info-item-wsp::after,
    .contact-info-item-dir::after {
        width: 80%;
        height: 1px;
        right: 10%;
        top: auto;
        bottom: 0;
    }

    .contact-info-item-wsp,
    .contact-info-item-dir,
    .contact-info-item-tel {
        width: 100%;
        justify-content: center;
        padding: 1.2rem;
    }
}

/* =========================================
   ESTILOS: HERO B2B (PROPUESTA DE VALOR)
   ========================================= */

/* 1. Contenedor Exterior (Actúa igual que .contact-info-section) */
.b2b-hero-intro {
    background-color: transparent;
    padding: 1rem 1rem 0 1rem;
    margin-bottom: 2rem;
    position: relative;
    z-index: 10;
    width: 100%;
    box-sizing: border-box;

    /* NUEVO: Lo convertimos en un contenedor Flex que ocupa toda la pantalla */
    display: flex;
    flex-direction: column;
    /* 100vh menos la altura del header (aprox 80px) y el margin-bottom (32px) */
    min-height: calc(100dvh - 250px);
}

/* 2. La Caja Oscura (Actúa igual que .contact-info-container) */
.b2b-hero-container {
    width: 100%;
    margin: 0 auto;
    background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);
    border-radius: 16px;
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.2), inset 0 1px 0 rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.05);
    padding: 1.5rem 1.5rem;
    position: relative;
    overflow: hidden;
    color: white;
    text-align: center;
    box-sizing: border-box;
    min-height: 420px;
    /* NUEVO: Obliga a la caja oscura a estirarse y centrar su contenido verticalmente */
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

/* Efecto visual de fondo movido a la caja oscura */
.b2b-hero-container::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: radial-gradient(circle at 50% -20%, rgba(241, 154, 49, 0.15), transparent 60%),
        radial-gradient(rgba(255, 255, 255, 0.03) 1px, transparent 1px);
    background-size: 100% 100%, 24px 24px;
    z-index: 0;
}

/* 3. Contenedor del texto (evita que el texto toque los bordes en monitores anchos) */
.b2b-hero-content {
    position: relative;
    z-index: 1;
    max-width: 1200px;
    margin: 0 auto;
}

/* Etiqueta superior más moderna */
.b2b-badge {
    background: rgba(241, 154, 49, 0.1);
    color: #f19a31;
    padding: 8px 20px;
    border-radius: 30px;
    font-size: 0.85rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 2px;
    display: inline-block;
    margin-bottom: 2rem;
    border: 1px solid rgba(241, 154, 49, 0.3);
    box-shadow: 0 4px 15px rgba(241, 154, 49, 0.1);
}

/* Título principal con mayor jerarquía */
.b2b-hero-content h2 {
    font-size: clamp(1.8rem, 4vw, 2.8rem);
    margin-top: 0;
    margin-bottom: 1.5rem;
    font-weight: 300;
    line-height: 1.2;
    letter-spacing: -0.5px;
    color: #ffffff;
}

/* El texto principal resalta en un degradado Naranja/Dorado Premium */
.b2b-hero-content h2 strong {
    font-weight: 800;
    background: linear-gradient(90deg, #f19a31, #ffc107);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    display: inline-block;
}

.b2b-hero-content h1 {
    font-size: clamp(3.2rem, 5vw, 4.5rem);
    margin-top: 0;
    margin-bottom: 2.5rem;
    font-weight: 300;
    line-height: 1.2;
    letter-spacing: -0.5px;
    color: #ffffff;
}

.b2b-hero-content h1 strong {
    font-weight: 800;
    background: linear-gradient(90deg, #f19a31, #ffc107);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    display: inline-block;
}

/* Párrafo más legible */
.b2b-hero-content p {
    font-size: 1.15rem;
    color: #94a3b8;
    line-height: 1.7;
    max-width: 800px;
    margin-left: auto;
    margin-right: auto;
    font-weight: 400;
}

@media (max-width: 1366px) {
    .b2b-hero-intro {
        min-height: calc(100dvh - 250px);
        padding: 1rem 1rem 0 1rem;
        margin-bottom: 1.5rem;
    }

    .b2b-hero-container {
        padding: 1.5rem;
    }

    .b2b-badge {
        margin-bottom: 1.2rem;
        padding: 6px 16px;
        font-size: 0.8rem;
    }

    .b2b-hero-content h1,
    .b2b-hero-content h2 {
        font-size: clamp(2.8rem, 5.5vw, 4.5rem);
        margin-bottom: 2rem;
    }

    .b2b-hero-content p {
        font-size: 1.05rem;
        line-height: 1.5;
        max-width: 700px;
    }

    .b2b-features.rotator-wrapper {
        margin-top: 1.5rem;
        height: 70px;
    }

    .b2b-features .rotator-item {
        padding: 10px 18px;
        font-size: 0.85rem;
    }

    .hero-cta-container {
        margin-top: 3rem;
    }
}


/* Adaptación para móviles */
@media (max-width: 768px) {
    .b2b-hero-intro {
        padding: 1rem 1rem 0 1rem;
        /* Ajustamos el cálculo porque el header es más chico en tablet */
        min-height: calc(100dvh - 95px);
    }

    .b2b-hero-container {
        padding: 2rem 1.5rem;
    }
}

@media (max-width: 480px) {
    .b2b-hero-intro {
        padding: 1rem 1rem 0 1rem;
        margin-bottom: 1.5rem;
        /* Antes: calc(100dvh - 115px). El offset de 115px fallaba en anchos <400px
           donde el slogan o el header crecían levemente y la card quedaba "corta".
           svh = small viewport height: respeta la altura visible cuando el chrome
           del browser (URL bar) está visible, valor estable en mobile portrait. */
        min-height: 100svh;
    }

    .b2b-hero-container {
        padding: 1.5rem 1rem 1rem 1rem;
    }

    .b2b-hero-content h1 {
        line-height: 1.15;
        margin-bottom: 2.5rem;
    }

    .b2b-hero-content p {
        font-size: 0.85rem;
        line-height: 1.45;
        margin-bottom: 1rem;
        padding: 0 5px;
    }

    .b2b-features.rotator-wrapper {
        height: 60px;
        margin-top: 0.5rem;
    }

    .b2b-features .rotator-item {
        padding: 8px 12px;
        font-size: 0.75rem;
    }

    .hero-cta-container {
        margin-top: 10vh;
        padding-bottom: 0.5rem;
    }

    .hero-explore-btn {
        font-size: 0.65rem;
        letter-spacing: 1.5px;
    }

    .hero-explore-arrows i {
        font-size: 1rem;
        line-height: 0.5;
    }
}

/* Móviles portrait angostos (≤480px) con altura corta (≤750px):
   S8/S9 (360×740), iPhone 6/7/8 (375×667), iPhone 6/7/8+ (414×736), Moto G4 (360×640).
   Sin este bloque, los queries max-height sin restricción de ancho reducían el h1
   a 24px (1.5rem), haciéndolo excesivamente pequeño. */
@media (max-width: 480px) and (max-height: 750px) {
    .b2b-hero-content h1,
    .b2b-hero-content h2 {
        font-size: clamp(1.9rem, 7vw, 2.5rem);
        margin-bottom: 1.1rem;
    }
    .b2b-hero-content p {
        font-size: 0.9rem;
        line-height: 1.5;
        margin-bottom: 0.75rem;
    }
    .b2b-features.rotator-wrapper {
        margin-top: 0.8rem;
        height: 58px;
    }
    .hero-cta-container {
        margin-top: 1.75rem;
    }
}

/* =========================================
   SISTEMA DE ROTACIÓN GENÉRICO DE TEXTOS
   ========================================= */
.rotator-wrapper {
    position: relative;
    width: 100%;
}

.rotator-item {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, 15px);
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.5s ease, transform 0.5s cubic-bezier(0.4, 0, 0.2, 1), visibility 0.5s;
    width: 100%;
    will-change: transform, opacity;
}

.rotator-item.is-active {
    opacity: 1;
    visibility: visible;
    transform: translate(-50%, -50%);
}

.rotator-item.is-exiting {
    opacity: 0;
    visibility: hidden;
    transform: translate(-50%, -35px);
}

/* Protección para el "Modo Ligero" (no-animations) */
.no-animations .rotator-item {
    transition: none !important;
    transform: translate(-50%, -50%) !important;
}



/* =========================================
   MODIFICACIÓN: B2B-FEATURES (HERO OSCURO)
   ========================================= */
.b2b-features.rotator-wrapper {
    display: block;
    height: 90px;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    margin-top: 2.5rem;
    padding-top: 1.1rem; /* espacio entre la línea divisoria y la píldora */
    contain: strict;
    will-change: contents;
}

.b2b-features .rotator-item {
    width: max-content;
    max-width: 95%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    font-size: 0.95rem;
    font-weight: 500;
    color: #e2e8f0;
    background: rgba(255, 255, 255, 0.05);
    padding: 12px 24px;
    border-radius: 8px;
    border: 1px solid rgba(255, 255, 255, 0.1);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
}

.b2b-features .rotator-item i {
    color: #f19a31;
    font-size: 1.2rem;
}

@media (max-width: 768px) {
    .b2b-features.rotator-wrapper {
        height: 80px;
        margin-top: 1.5rem;
    }

    .b2b-features .rotator-item {
        font-size: 0.85rem;
        padding: 10px 16px;
        white-space: normal;
        text-align: center;
    }
}

/* Product Details Page */
.products-page-container {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 30px;
    max-width: 90%;
    margin: 0 auto 30px auto;
    padding: 0 1rem;
}

.products-page-container-single-column {
    display: grid;
    grid-template-columns: auto;
    gap: 30px;
    max-width: 90%;
    margin: 0 auto 30px auto;
    padding: 0 1rem;
}

.filters-header {
    display: flex;
    justify-content: right;
    align-items: center;
    margin-bottom: 1rem;
}

.filters-header h3 {
    margin: 0;
    font-size: 1.25rem;
    color: #333;
}

.close-filters-btn {
    display: none;
    background: none;
    border: none;
    font-size: 2rem;
    cursor: pointer;
    color: #555;
    line-height: 1;
}

.close-filters-btn:hover {
    color: #000;
}

/* NOSOTROS HERO & LAYOUT */
#pagina-nosotros .contact-page-container {
    max-width: 100%;
    padding: 0 1rem;
    margin: 0 auto;
    width: 100%;
    overflow: hidden;
}

.nosotros-premium-title {
    font-family: 'Arial', sans-serif;
    letter-spacing: -0.5px;
}

.nosotros-hero {
    position: relative;
    text-align: center;
    padding: 5rem 2rem;
    background: linear-gradient(135deg, #1e293b 0%, #0f172a 100%);
    border-radius: 16px;
    margin-bottom: 0;
    margin-top: 1rem;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
    overflow: hidden;
    color: white;
    border-bottom: 5px solid #f19a31;
    width: 100%;
    display: block;
}

.nosotros-hero::before {
    content: '';
    position: absolute;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background: radial-gradient(circle, rgba(241, 154, 49, 0.08) 0%, transparent 60%);
    z-index: 1;
    pointer-events: none;
}

.nosotros-hero-content {
    position: relative;
    z-index: 2;
    width: 100%;
}

.nosotros-hero h1 {
    font-size: clamp(2.2rem, 5vw, 3.5rem);
    color: #ffffff;
    margin-top: 0;
    margin-bottom: 1.5rem;
    font-weight: 700;
    line-height: 1.2;
}

.nosotros-hero h1 span {
    color: #f19a31;
}

.nosotros-hero p {
    font-size: 1.2rem;
    color: #cbd5e1;
    max-width: 850px;
    margin: 0 auto;
    line-height: 1.8;
    font-weight: 300;
}

@media (max-width: 768px) {
    .nosotros-hero p {
        font-size: 1rem;
        color: #cbd5e1;
        max-width: 850px;
        margin: 0 auto;
        line-height: 1.8;
        font-weight: 300;

        text-align: justify;
        text-justify: inter-word;
        hyphens: auto;
        -webkit-hyphens: auto;
        -ms-hyphens: auto;
        overflow-wrap: break-word;
    }

}

.nosotros-stats-banner {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 4rem;
    background-color: #ffffff;
    padding: 2.5rem 2rem;
    border-radius: 8px;
    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.06);
    max-width: 1000px;
    margin: -3rem auto 4rem auto;
    position: relative;
    z-index: 10;
    border: 1px solid #f1f5f9;
    width: 100%;
}

.nosotros-stat-item {
    text-align: center;
    flex: 1 1 auto;
}

.nosotros-stat-number {
    display: block;
    font-size: 2.8rem;
    font-weight: 700;
    color: #f19a31;
    line-height: 1;
    margin-bottom: 0.5rem;
}

.nosotros-stat-label {
    display: block;
    font-size: 0.95rem;
    color: #64748b;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
}


/* --- Layout Dos Columnas --- */
.nosotros-two-col {
    display: grid;
    grid-template-columns: 1.2fr 0.8fr;
    gap: 4rem;
    margin: 0 auto 5rem auto;
    align-items: center;
    max-width: 1200px;
    width: 100%;
}

@media (max-width: 768px) {
    .nosotros-two-col {
        grid-template-columns: 1fr;
        gap: 2rem;
    }
}

.nosotros-text-content h2 {
    font-size: 2.2rem;
    color: #1e293b;
    margin-top: 0;
    margin-bottom: 1.5rem;
    position: relative;
    padding-bottom: 1rem;
    line-height: 1.3;
}

.nosotros-text-content h2::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    width: 60px;
    height: 3px;
    background-color: #f19a31;
}

.nosotros-text-content p {
    font-size: 1.05rem;
    color: #475569;
    line-height: 1.8;
    margin-top: 0;
    margin-bottom: 1.5rem;
    text-align: justify;
}

.nosotros-text-content strong {
    color: #1e293b;
}

.nosotros-highlight-box {
    background: #f8fafc;
    padding: 2.5rem;
    border-radius: 12px;
    border-left: 5px solid #f19a31;
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.03);
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.nosotros-highlight-box h3 {
    color: #0f172a;
    font-size: 1.4rem;
    margin-top: 0;
    margin-bottom: 1.2rem;
    line-height: 1.3;
}

.nosotros-highlight-box ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.nosotros-highlight-box li {
    position: relative;
    padding-left: 28px;
    margin-bottom: 1rem;
    color: #475569;
    font-size: 1rem;
    line-height: 1.5;
}

.nosotros-highlight-box li i {
    position: absolute;
    left: 0;
    top: 4px;
    color: #f19a31;
    font-size: 1.1rem;
    width: auto;
}

.nosotros-highlight-box p {
    margin-top: 1rem;
    margin-bottom: 0;
    font-size: 0.95rem;
    color: #475569;
    line-height: 1.6;
}

/* --- Grid de Valores --- */
.nosotros-section-title {
    text-align: center;
    font-size: 2.2rem;
    color: #1e293b;
    margin-top: 0;
    margin-bottom: 3rem;
    font-weight: 700;
}

.nosotros-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
    margin: 0 auto 5rem auto;
    max-width: 1200px;
    width: 100%;
}

@media (max-width: 768px) {
    .nosotros-grid {
        grid-template-columns: 1fr;
        gap: 2rem;
    }
}

.nosotros-card {
    background: #ffffff;
    padding: 3rem 2rem;
    border-radius: 12px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.02), 0 10px 20px rgba(0, 0, 0, 0.04);
    transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1), box-shadow 0.4s ease;
    text-align: left;
    border: 1px solid #f1f5f9;
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.nosotros-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 4px;
    background: #f19a31;
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.4s ease;
}

.nosotros-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.08);
}

.nosotros-card:hover::before {
    transform: scaleX(1);
}

.nosotros-card i {
    font-size: 2.5rem;
    color: #f19a31;
    margin-bottom: 1.5rem;
    background: #fff8f0;
    width: 70px;
    height: 70px;
    border-radius: 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.nosotros-card h3 {
    font-size: 1.4rem;
    color: #1e293b;
    margin-top: 0;
    margin-bottom: 1rem;
    font-weight: 700;
    line-height: 1.3;
}

.nosotros-card p {
    color: #64748b;
    line-height: 1.7;
    margin: 0;
    font-size: 1rem;
}

/* --- CTA Final Premium --- */
.nosotros-cta {
    text-align: center;
    padding: 5rem 2rem;
    background: linear-gradient(to right, #2c3e50, #1a252f);
    color: white;
    border-radius: 16px;
    margin: 0 auto 3rem auto;
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.2);
    max-width: 1200px;
    width: 100%;
    display: block;
}

.nosotros-cta h2 {
    color: white;
    margin-top: 0;
    margin-bottom: 1.5rem;
    font-size: 2.2rem;
    font-weight: 700;
    line-height: 1.2;
}

.nosotros-cta p {
    font-size: 1.15rem;
    margin-top: 0;
    margin-bottom: 2.5rem;
    color: #cbd5e1;
    max-width: 700px;
    margin-left: auto;
    margin-right: auto;
    line-height: 1.7;
}

.nosotros-cta .cta-buttons {
    display: flex;
    gap: 20px;
    justify-content: center;
    flex-wrap: wrap;
}

.nosotros-cta .btn {
    padding: 14px 30px;
    font-size: 1.05rem;
    border-radius: 8px;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    transition: all 0.3s ease;
    background-color: #f19a31;
    color: white;
    border: 2px solid transparent;
    cursor: pointer;
}

.nosotros-cta .btn:hover {
    background-color: #d98220;
    transform: translateY(-2px);
}

.nosotros-cta .btn-outline {
    background-color: transparent;
    border: 2px solid #f19a31;
    color: #f19a31;
}

.nosotros-cta .btn-outline:hover {
    background-color: #f19a31;
    color: white;
    box-shadow: 0 8px 20px rgba(241, 154, 49, 0.3);
}

/* --- Media Queries Secciones Nosotros --- */
@media (max-width: 992px) {
    .nosotros-two-col {
        grid-template-columns: 1fr;
        gap: 2.5rem;
    }

    .nosotros-stats-banner {
        gap: 2rem;
        padding: 2rem 1rem;
    }

    .nosotros-stat-item {
        flex: 1 1 40%;
    }

    .nosotros-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .nosotros-hero {
        padding: 3rem 1rem 4rem 1rem;
    }

    .nosotros-stats-banner {
        margin-top: -4rem;
    }

    .nosotros-stat-number {
        font-size: 2.2rem;
    }

    .nosotros-cta {
        padding: 3.5rem 1.5rem;
    }

    .nosotros-text-content h2 {
        font-size: 1.8rem;
    }

    .nosotros-section-title {
        font-size: 1.8rem;
    }

    .nosotros-grid {
        grid-template-columns: 1fr;
        gap: 1.5rem;
    }

    .nosotros-highlight-box {
        padding: 2rem 1.5rem;
    }
}



/* =========================================
   DISEÑO PREMIUM: SIDEBAR Y FILTROS 
   ========================================= */

/* -----------------------------------------
   1. BASE Y MODO ESCRITORIO (PC)
   ----------------------------------------- */
.product-filters-sidebar {
    background-color: #ffffff;
    padding: 1.8rem;
    border-radius: 12px;
    border: 1px solid #e2e8f0;
    box-shadow: 0 10px 30px -10px rgba(0, 0, 0, 0.08);
    /* ESCRITORIO: fluye con su contenido, sin max-height ni scroll interno.
       El usuario scrollea la página normalmente. */
    display: flex;
    flex-direction: column;
    transition: left 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}

/* =========================================
   SCROLLBAR PREMIUM (Global para Sidebar)
   ========================================= */
.product-filters-sidebar {
    /* Firefox — scrollbar premium */
    scrollbar-width: thin;
    scrollbar-color: rgba(241, 154, 49, 0.5) transparent;
}

/* Chrome / Edge / Safari — scrollbar premium */
.product-filters-sidebar::-webkit-scrollbar {
    width: 5px;
}

/* Sin botones de flecha y ocultando la flecha del track */
.product-filters-sidebar::-webkit-scrollbar-button {
    display: none !important;
    height: 0 !important;
    width: 0 !important;
    opacity: 0 !important;
}

/* Ocultar botones de flecha específicos (arriba y abajo) */
.product-filters-sidebar::-webkit-scrollbar-button:start:decrement,
.product-filters-sidebar::-webkit-scrollbar-button:end:increment {
    display: none !important;
    height: 0 !important;
    width: 0 !important;
}

/* Track invisible */
.product-filters-sidebar::-webkit-scrollbar-track {
    background: transparent;
}

/* Thumb premium: gradiente naranja con borde interior flotante */
.product-filters-sidebar::-webkit-scrollbar-thumb {
    background: linear-gradient(180deg, #fbd38d 0%, #f19a31 100%);
    border-radius: 100px;
    border: 1.5px solid transparent;
    background-clip: padding-box;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.25);
    min-height: 40px;
}

.product-filters-sidebar::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(180deg, #f19a31 0%, #d47a18 100%);
    background-clip: padding-box;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.3), 0 0 6px rgba(241, 154, 49, 0.4);
}

/* Títulos y Menú */
.filter-group {
    display: flex;
    flex-direction: column;
    /* Sin overflow:hidden ni flex-grow:1 - las categorías se muestran completas */
    overflow: visible;
    flex-grow: 0;
    flex-shrink: 0;
    margin-bottom: 0;
}

.filter-group h4,
.filter-group-header h4 {
    flex-shrink: 0;
    font-size: 0.95rem !important;
    font-weight: 800 !important;
}

.sidebar-menu {
    list-style: none;
    padding: 0;
    margin: 0;
    /* Sin scroll interno: el sidebar padre maneja todo el scroll */
    overflow: visible;
    max-height: none;
    scrollbar-width: thin;
    scrollbar-color: #cbd5e1 transparent;
    padding-right: 5px;
}

.sidebar-menu::-webkit-scrollbar {
    width: 5px;
}

.sidebar-menu::-webkit-scrollbar-thumb {
    background-color: #cbd5e1;
    border-radius: 5px;
}

.sidebar-menu::-webkit-scrollbar-thumb:hover {
    background-color: #94a3b8;
}

.sidebar-menu>li {
    margin-bottom: 5px;
    border-bottom: 1px solid #f8fafc;
}

.sidebar-menu>li:last-child {
    border-bottom: none;
}

.filter-item-wrapper {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-radius: 6px;
    transition: all 0.2s ease;
}

.filter-item-wrapper>a {
    flex-grow: 1;
    padding: 10px 8px;
    font-size: 0.95rem;
    color: #334155;
    font-weight: 600;
    text-decoration: none;
    transition: color 0.2s ease, background-color 0.2s ease;
    border-radius: 6px;
}

.filter-item-wrapper:hover {
    background-color: #f8fafc;
}

.filter-item-wrapper>a:hover {
    color: #f19a31;
}

.submenu-toggle {
    background: transparent;
    border: none;
    color: #94a3b8;
    padding: 10px 12px;
    cursor: pointer;
    font-size: 0.85rem;
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1), color 0.2s ease;
}


.has-submenu.open .submenu-toggle {
    transform: rotate(180deg);
    color: #f19a31;
}

.submenu {
    list-style: none;
    padding-left: 0;
    margin-left: 12px;
    border-left: 2px solid #e2e8f0;
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    visibility: hidden;
    transition: max-height 0.4s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.3s ease, margin 0.3s;
}

.has-submenu.open .submenu {
    opacity: 1;
    visibility: visible;
    margin-top: 4px;
    margin-bottom: 10px;
}

.submenu li {
    margin: 2px 0;
}

.submenu a {
    display: block;
    padding: 8px 15px 8px 20px;
    font-size: 0.85rem;
    color: #64748b;
    text-decoration: none;
    transition: all 0.2s ease;
    border-radius: 0 6px 6px 0;
    position: relative;
}

.submenu a::before {
    content: '';
    position: absolute;
    left: -2px;
    top: 0;
    bottom: 0;
    width: 2px;
    background-color: transparent;
    transition: background-color 0.2s;
}

.submenu a:hover {
    color: #f19a31;
    background-color: #f8fafc;
}

.submenu a:hover::before {
    background-color: #f19a31;
}

.filter-item-wrapper a.active {
    color: #f19a31;
    background-color: #fffaf5;
}

.submenu a.active {
    color: #d97706;
    background-color: #fffaf5;
    font-weight: 600;
}

.submenu a.active::before {
    background-color: #f19a31;
}

.submenu a.ver-todos-link {
    font-weight: 700;
    color: #2c3e50;
    padding-bottom: 10px;
    padding-top: 10px;
    margin-top: -4px;
}

/* Quitamos la barra lateral gris estándar para que "Ver Todos" sea diferente a los demás ítems */
.submenu a.ver-todos-link::before {
    display: none;
}

.submenu a.ver-todos-link:hover {
    background-color: transparent;
    padding-left: 24px;
    /* Pequeño desplazamiento al hacer hover */
}

.filter-buttons {
    flex-shrink: 0;
    /* Mantiene el botón "Ver Todos" fijo abajo */
    margin-top: 1rem;
    border-top: 1px solid #f1f5f9;
    padding-top: 1.5rem;
    display: flex;
    flex-direction: column;
}

.btn-clear-filters {
    display: block;
    width: 100%;
    padding: 12px;
    background-color: #f8fafc;
    color: #475569;
    border: 1px solid #000000;
    border-radius: 8px;
    font-size: 0.95rem;
    font-weight: 600;
    cursor: pointer;
    text-align: center;
    text-decoration: none;
    transition: all 0.2s ease;
}

.btn-clear-filters:hover {
    background-color: #2c3e50;
    border-color: #2c3e50;
    transform: translateY(-2px);
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
    color: #fff8f0;
}

/* -----------------------------------------
   2. VERSIÓN MÓVIL (Menú Off-Canvas)
   ----------------------------------------- */
@media (max-width: 1050px) {

    /* Mostrar el botón que abre el panel lateral en móviles */
    .mobile-filter-toggle-btn {
        display: block !important;
        width: calc(100% - 2rem);
        margin: 0 auto 1.5rem auto;
        padding: 12px;
        background-color: #2c3e50;
        color: white;
        border: none;
        border-radius: 8px;
        font-size: 1rem;
        font-weight: 600;
        cursor: pointer;
        text-align: center;
        box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
    }

    /* Convertir el sidebar en un menú lateral escondido */
    .product-filters-sidebar {
        display: flex !important;
        flex-direction: column !important;
        position: fixed !important;
        top: 0 !important;
        left: -100% !important;
        width: 85% !important;
        max-width: 320px !important;
        /* MÓVIL: siempre 100dvh sin importar la cantidad de items */
        height: 100dvh !important;
        min-height: unset !important;
        max-height: 100dvh !important;
        z-index: 9998 !important;
        /* El sidebar scrollea internamente si hay muchos filtros */
        overflow-y: auto !important;
        overflow-x: hidden !important;
        background-color: #ffffff !important;
        box-shadow: 5px 0 25px rgba(0, 0, 0, 0.3) !important;
        border-radius: 0 15px 15px 0 !important;
        padding: 0 1.5rem 1.5rem 1.5rem !important;
        border: none !important;
    }

    /* Activar entrada del sidebar cuando se pulsa el botón */
    .product-filters-sidebar.filters-sidebar-mobile-active {
        left: 0 !important;
    }

    /* Mostrar botón "Cerrar" en el móvil */
    .filters-header {
        display: flex !important;
        justify-content: flex-end !important;
        width: 100%;
        margin-top: 25px;
        margin-bottom: 10px;
        flex-shrink: 0;
        /* Fijo arriba */
    }

    .close-filters-btn {
        display: block !important;
        font-size: 2.2rem;
        color: #334155;
        background: none;
        border: none;
        padding: 0;
        margin-top: -10px;
        margin-right: -5px;
    }

    .close-filters-btn:hover {
        color: #f19a31;
    }

    .filter-group {
        display: flex;
        flex-direction: column;
        flex: none;
        flex-shrink: 0;
        /* Las categorías se muestran completas y empujan los demás filtros hacia abajo */
        overflow: visible;
    }

    /* En móvil el sidebar-menu NO scrollea internamente */
    .sidebar-menu {
        flex: none;
        max-height: none !important;
        overflow: visible !important;
        padding-bottom: 0;
    }

    .filter-buttons {
        margin-top: auto;
        padding-bottom: env(safe-area-inset-bottom, 20px);
    }

    .filter-item-wrapper>a {
        padding: 12px 8px;
        font-size: 1rem;
    }

    .submenu-toggle {
        padding: 12px 15px;
        font-size: 1rem;
    }

    .submenu a {
        padding: 10px 15px 10px 20px;
        font-size: 0.95rem;
    }
}

/* =========================================
   SCROLLBAR SIEMPRE VISIBLE (NARANJA SUTIL)
   ========================================= */

/* 1. Scrollbar para Escritorio */
.sidebar-menu {
    /* Firefox */
    scrollbar-width: thin;
    scrollbar-color: #f7c186 #f8fafc;
    /* Thumb naranja sutil, Track gris ultra claro */
}

/* Chrome, Edge, Safari */
.sidebar-menu::-webkit-scrollbar {
    width: 6px;
    -webkit-appearance: none;
    /* Fuerza a que no se oculte por el sistema operativo */
}

.sidebar-menu::-webkit-scrollbar-track {
    background-color: #f8fafc;
    /* Un fondo gris clarito permanente para el carril */
    border-radius: 10px;
}

.sidebar-menu::-webkit-scrollbar-thumb {
    background-color: #f7c186;
    /* Naranja sutil */
    border-radius: 10px;
}

.sidebar-menu::-webkit-scrollbar-thumb:hover {
    background-color: #f19a31;
    /* Naranja fuerte al interactuar */
}

/* 2. Scrollbar para Móvil (Se aplica al panel completo) */
@media (max-width: 1050px) {
    .product-filters-sidebar {
        /* Firefox — scrollbar premium */
        scrollbar-width: thin;
        scrollbar-color: rgba(241, 154, 49, 0.5) transparent;
    }

    /* Chrome / Edge / Safari — scrollbar premium */
    .product-filters-sidebar::-webkit-scrollbar {
        width: 5px;
    }

    /* Sin botones de flecha */
    .product-filters-sidebar::-webkit-scrollbar-button {
        display: none;
        height: 0;
        width: 0;
    }

    /* Track invisible */
    .product-filters-sidebar::-webkit-scrollbar-track {
        background: transparent;
    }

    /* Thumb premium: gradiente naranja con borde interior flotante */
    .product-filters-sidebar::-webkit-scrollbar-thumb {
        background: linear-gradient(180deg, #fbd38d 0%, #f19a31 100%);
        border-radius: 100px;
        border: 1.5px solid transparent;
        background-clip: padding-box;
        box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.25);
        min-height: 40px;
    }

    .product-filters-sidebar::-webkit-scrollbar-thumb:hover {
        background: linear-gradient(180deg, #f19a31 0%, #d47a18 100%);
        background-clip: padding-box;
        box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.3), 0 0 6px rgba(241, 154, 49, 0.4);
    }
}



/* =========================================
   DESCRIPCIÓN DE CATEGORÍA (Lectura Premium)
   ========================================= */
.category-description-wrapper {
    text-align: center;
    max-width: 1000px;
    margin: 1.5rem auto 3rem auto;
    border-bottom: none;
    padding-bottom: 0;
    box-shadow: none;
}

.category-description {
    font-size: 1.15rem;
    color: #475569;
    line-height: 1.8;
    margin: 0 auto;
    max-width: 800px;
    padding: 0 1rem;
    letter-spacing: -0.2px;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s ease-out, padding 0.4s ease-out;
    word-break: break-word !important;
}

.category-description.expanded {
    max-height: 2000px;
    padding-top: 1.5rem;
    padding-bottom: 1.5rem;
}

/* Efecto "Highlighter" B2B para las etiquetas strong */
.category-description strong {
    color: #1e293b;
    /* Casi negro, para máximo contraste */
    font-weight: 700;
    /* Crea un subrayado grueso naranja translúcido por detrás del texto */
    background: linear-gradient(120deg, rgba(241, 154, 49, 0.25) 0%, rgba(241, 154, 49, 0.15) 100%);
    background-repeat: no-repeat;
    background-size: 100% 35%;
    background-position: 0 90%;
    padding: 0 2px;
    border-radius: 2px;
    transition: background-size 0.3s ease;
}

/* Micro-interacción: al pasar el mouse sobre el texto, el resaltado crece */
.category-description:hover strong {
    background-size: 100% 50%;
}

@media (max-width: 768px) {
    .category-description {
        font-size: 1rem;
        line-height: 1.6;
        text-align: left;
        /* En móviles es más fácil leer alineado a la izquierda */
    }
}

.toggle-description-button {
    display: inline-block;
    margin-top: 1rem;
    padding: 8px 25px;
    font-size: 0.9rem;
    font-weight: 600;
    color: #fff;
    background-color: #2c3e50;
    border: none;

    .category-description-wrapper>.accordion-wrapper {
        display: none;
        opacity: 0;
        transition: opacity 0.5s ease;
        max-height: 0;
        overflow: hidden;
        visibility: hidden;
        margin-top: 0;
        transition: all 0.5s ease-in-out;
    }

    .category-description-wrapper>.accordion-wrapper.expanded {
        display: block;
        opacity: 1;
        animation: fadeIn 0.5s ease forwards;
        max-height: none;
        visibility: visible;
        margin-top: 20px;
    }

    border-radius: 8px;
    cursor: pointer;
    transition: background-color 0.2s ease;
    -webkit-tap-highlight-color: transparent;
}

.mobile-filter-toggle-btn {
    display: none;
}

#filter-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: 9997;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease-in-out, visibility 0.3s;
}

#filter-overlay.active {
    opacity: 1;
    visibility: visible;
}

/* Accordion */

.accordion-wrapper {
    max-width: 1000px;
    margin: 30px auto 20px;
    text-align: left;
    background: #ffffff;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.03);
    overflow: hidden;
}

.accordion-item {
    border-bottom: 1px solid #e2e8f0;
    position: relative;
    transition: background-color 0.3s ease;
}

.accordion-item:last-child {
    border-bottom: none;
}

.accordion-header {
    width: 100%;
    padding: 20px 25px;
    background: transparent;
    border: none;
    text-align: left;
    font-size: 1.05rem;
    font-weight: 600;
    color: #1e293b;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition: all 0.3s ease;
    position: relative;
}

/* Barra lateral indicadora */
.accordion-header::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 4px;
    background-color: #f19a31;
    transform: scaleY(0);
    transform-origin: center;
    transition: transform 0.3s ease;
}

.accordion-header:hover {
    background-color: #f8fafc;
    color: #f19a31;
}

.accordion-header.active {
    background-color: #fffaf5;
    color: #f19a31;
}

.accordion-header.active::before {
    transform: scaleY(1);
}

.accordion-header i {
    font-size: 0.9em;
    color: #94a3b8;
    transition: transform 0.3s ease, color 0.3s ease;
}

.accordion-header.active i {
    transform: rotate(180deg);
    color: #f19a31;
}

.accordion-content {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s ease-out;
    padding: 0 25px;
    background-color: #fffaf5;
    /* Sutil fondo para el texto abierto */
}

.accordion-content p {
    font-size: 0.95rem;
    color: #475569;
    margin: 0 0 20px 0;
    line-height: 1.7;
}

.accordion-header .accordion-inner-title {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 600;
    color: inherit;
    text-align: left;
    line-height: 1.4;
    padding-right: 15px;

    /* NUEVO: Solución Responsive para texto largo */
    flex: 1 1 auto;
    /* Toma el espacio disponible */
    white-space: normal;
    /* Fuerza al texto a saltar de línea */
    word-break: break-word;
    /* Evita que palabras largas rompan el diseño */
}

/* Proteger la flechita para que el texto largo no la aplaste */
.accordion-header i {
    flex-shrink: 0;
    margin-left: auto;
    /* Empuja la flecha siempre a la derecha */
}

/* 2. Subtítulos internos (H4) */
.accordion-content h4 {
    color: #1e293b;
    font-size: 1.15rem;
    font-weight: 700;
    margin-top: 1.8rem;
    margin-bottom: 1rem;
    padding-left: 12px;
    border-left: 4px solid #f19a31;
    line-height: 1.2;
}

/* 3. Listas elegantes (con checkmarks naranjas) */
.accordion-content ul {
    list-style: none;
    padding-left: 0;
    margin: 0 0 1.5rem 0;
}

.accordion-content li {
    position: relative;
    padding-left: 32px;
    margin-bottom: 12px;
    color: #475569;
    font-size: 0.95rem;
    line-height: 1.6;
}

.accordion-content li::before {
    content: '\f058';
    /* Icono Check */
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    position: absolute;
    left: 0;
    top: 2px;
    color: #f19a31;
    font-size: 1.1rem;
}

/* 4. Tabla Premium Responsive */
.table-responsive-wrapper {
    width: 100%;
    overflow-x: auto;
    /* Permite scroll horizontal en celulares */
    -webkit-overflow-scrolling: touch;
    /* Scroll suave en iOS */
    margin-top: 1.5rem;
    margin-bottom: 2rem;
    border-radius: 12px;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.03);
    border: 1px solid #e2e8f0;
}

.accordion-content table {
    width: 100%;
    border-collapse: collapse;
    min-width: 600px;
    /* Al forzar esto, aparece la barra de scroll abajo en móviles, sin romper la web */
    background-color: #ffffff;
}

.accordion-content th,
.accordion-content td {
    padding: 14px 20px;
    text-align: left;
    font-size: 0.95rem;
    color: #475569;
    border-bottom: 1px solid #e2e8f0;
}

.accordion-content th {
    background-color: #f8fafc;
    font-weight: 700;
    color: #1e293b;
    text-transform: uppercase;
    font-size: 0.85rem;
    letter-spacing: 0.5px;
    border-bottom: 2px solid #cbd5e1;
}

.accordion-content tr:last-child td {
    border-bottom: none;
}

.accordion-content tbody tr {
    transition: background-color 0.2s ease;
}

.accordion-content tbody tr:hover {
    background-color: #fffaf5;
}

.accordion-content td strong {
    color: #1e293b;
}


/* =========================================
   ADAPTACIÓN EXTREMA PARA MÓVILES (Hasta 320px)
   ========================================= */
@media (max-width: 768px) {

    /* Convierte la tabla del acordeón en "tarjetas" apiladas para móviles */
    .accordion-content table,
    .accordion-content tbody,
    .accordion-content tr,
    .accordion-content th,
    .accordion-content td {
        display: block;
        width: 100%;
        min-width: 0 !important;
        /* Anula los 600px fijos */
    }

    .accordion-content th {
        background-color: transparent;
        border-bottom: none;
        padding: 15px 15px 4px 15px;
        /* Ajuste visual del título */
    }

    .accordion-content td {
        padding: 0 15px 15px 15px;
        /* Ajuste visual del valor */
        border-bottom: 2px solid #e2e8f0;
    }

    .accordion-content tr:last-child td {
        border-bottom: none;
    }

    .accordion-content tr:hover td,
    .accordion-content tr:hover th {
        background-color: transparent;
    }
}

@media (max-width: 768px) {

    /* Reducimos el padding exagerado de escritorio (25px) */
    .accordion-header {
        padding: 15px 15px;
    }

    .accordion-header .accordion-inner-title {
        font-size: 0.95rem;
    }

    .accordion-content h4 {
        font-size: 1.05rem;
    }
}

@media (max-width: 480px) {
    .accordion-header {
        padding: 12px 12px;
    }

    .accordion-header .accordion-inner-title {
        font-size: 0.9rem;
        line-height: 1.3;
        padding-right: 10px;
    }

    .accordion-content {
        padding: 0 15px;
        /* Menos espacio en blanco a los lados del texto */
    }

    .accordion-content li {
        font-size: 0.9rem;
    }
}

@media (max-width: 360px) {

    /* Pantallas ultra chicas (ej: iPhone SE - 320px) */
    .accordion-header {
        padding: 10px 8px;
        /* Optimizamos el espacio horizontal al máximo */
    }

    .accordion-header .accordion-inner-title {
        font-size: 0.85rem;
    }

    .accordion-content {
        padding: 0 10px;
    }

    .accordion-content p {
        font-size: 0.85rem;
    }
}

/* =========================================
   ACORDEÓN INTERNO (PREGUNTAS FRECUENTES - FAQs)
   ========================================= */

/* Contenedor del acordeón interno: le quitamos el borde externo y la sombra grande */
.accordion-inner-wrapper {
    margin: 1.5rem 0 2rem 0;
    /* Separación del texto superior e inferior */
    box-shadow: none;
    border: none;
    background: transparent;
}

/* Cada "Pregunta" es una caja separada (estilo burbuja) */
.accordion-inner-item {
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    /* Bordes redondeados en cada pregunta */
    margin-bottom: 12px;
    /* Separación entre preguntas */
    background-color: #ffffff;
    overflow: hidden;
    transition: all 0.3s ease;
}

/* Quitamos el borde inferior del último ítem que viene por defecto */
.accordion-inner-item:last-child {
    border-bottom: 1px solid #e2e8f0;
}

/* Efecto hover suave sobre toda la caja de la pregunta */
.accordion-inner-item:hover {
    border-color: #cbd5e1;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.02);
}

/* Cabecera de la Pregunta (El Botón) */
.accordion-inner-header {
    padding: 16px 20px;
    background-color: transparent;
    /* Fondo blanco inicial */
}

/* La barra naranja lateral la hacemos más finita en las FAQs */
.accordion-inner-header::before {
    width: 3px;
    border-radius: 4px 0 0 4px;
}

/* El texto de la Pregunta */
.faq-question {
    margin: 0;
    font-size: 0.95rem;
    /* Levemente más chico que un H3 */
    font-weight: 600;
    color: #334155;
    /* Gris intermedio */
    line-height: 1.4;
    padding-right: 15px;
    /* Espacio para el ícono */
    flex: 1 1 auto;
    white-space: normal;
    word-break: break-word;
}

/* El ícono de "+" o "-" */
.accordion-inner-header i {
    font-size: 0.85rem;
    color: #94a3b8;
    transition: transform 0.3s ease, color 0.3s ease;
    background-color: #f1f5f9;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    /* Lo metemos en un circulito para que luzca moderno */
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

/* Estado ACTIVO (Pregunta Abierta) */
.accordion-inner-header.active {
    background-color: #f8fafc;
    /* Gris ultra claro, no naranja, para no saturar */
}

.accordion-inner-header.active .faq-question {
    color: #f19a31;
    /* El texto se vuelve naranja */
}

.accordion-inner-header.active i {
    color: #ffffff;
    background-color: #f19a31;
    /* El circulito se pinta de naranja */
    transform: rotate(45deg);
    /* El '+' se convierte en una 'x' */
}

/* El contenido de la Respuesta */
.accordion-inner-content {
    background-color: #ffffff;
    /* Fondo blanco limpio para leer fácil */
    padding: 0 20px 20px 20px;
    /* Padding bottom para que respire */
    border-top: 1px dashed #e2e8f0;
    /* Línea punteada sutil separando pregunta de respuesta */
}

.accordion-inner-content p {
    font-size: 0.95rem;
    color: #475569;
    line-height: 1.6;
    margin: 15px 0 0 0;
    /* Margen superior para separarse de la línea punteada */
}

.accordion-inner-content strong {
    color: #1e293b;
    font-weight: 600;
}

/* RESPONSIVE MÓVIL (Hasta 320px) */
@media (max-width: 768px) {
    .accordion-inner-header {
        padding: 14px 15px;
    }

    .faq-question {
        font-size: 0.9rem;
    }

    .accordion-inner-content {
        padding: 0 15px 15px 15px;
    }
}

@media (max-width: 480px) {
    .accordion-inner-header {
        padding: 12px 12px;
    }

    .faq-question {
        font-size: 0.85rem;
    }

    .accordion-inner-header i {
        width: 24px;
        height: 24px;
        font-size: 0.75rem;
    }
}

/* =========================================
   PRODUCT INNER DETAILS (PREMIUM UI/UX)
   ========================================= */

.product-detail-section {
    display: flex;
    flex-direction: column;
    gap: 30px;
    background-color: transparent;
    align-items: center;
    justify-content: center;
    padding-top: 0;
    padding-bottom: 1rem;
    padding-left: 0.5rem;
    padding-right: 0.5rem;
}

.product-main-content-flex-container {
    display: flex;
    flex-direction: row;
    gap: 30px;
    align-items: stretch;
    width: 95%;
    max-width: 100%;
    margin: 0 auto;
    justify-content: center;
}

/* Cajas principales con sombra Premium */
.product-image-gallery,
.product-info-column,
.product-tabs-container {
    background-color: #ffffff;
    padding: 2.5rem;
    border-radius: 16px;
    box-shadow: 0 10px 30px -5px rgba(0, 0, 0, 0.06), 0 4px 10px -3px rgba(0, 0, 0, 0.03);
    border: 1px solid rgba(226, 232, 240, 0.8);
}

.product-image-gallery {
    flex: 45%;
    max-width: 45%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    position: relative;
}

.product-info-column {
    flex: 55%;
    max-width: 55%;
    display: flex;
    flex-direction: column;
    justify-content: space-evenly;
}

/* Galería de Imágenes */
#main-product-image {
    width: 100%;
    min-height: 250px;
    max-width: 450px;
    height: auto;
    aspect-ratio: 1/1;
    object-fit: contain;
    border-radius: 12px;
    cursor: zoom-in;
    margin-bottom: 20px;
    transition: transform 0.3s ease;
    mix-blend-mode: multiply;
    /* Elimina fondos blancos si la imagen los tiene */
}

#main-product-image:hover {
    transform: scale(1.03);
}

.thumbnail-slider {
    display: flex;
    gap: 12px;
    overflow-x: auto;
    padding: 10px 5px;
    width: 100%;
    max-width: 450px;
    cursor: grab;
    user-select: none;
    scrollbar-width: none;
}

.thumbnail-slider::-webkit-scrollbar {
    display: none;
}

.thumbnail-slider.grabbing {
    cursor: grabbing;
}

.thumbnail-image {
    width: 75px;
    height: 75px;
    object-fit: contain;
    padding: 5px;
    border: 2px solid #e2e8f0;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.2s ease;
    flex-shrink: 0;
    background-color: #fff;
}

.thumbnail-image:hover,
.thumbnail-image.active {
    border-color: #f19a31;
    box-shadow: 0 4px 10px rgba(241, 154, 49, 0.15);
}

/* Tipografía y Jerarquía del Producto */
.product-title {
    font-size: 2.2rem;
    color: #0f172a;
    margin: 0 0 0.5em 0;
    margin-left: 0.5rem;
    font-weight: 800;
    letter-spacing: -0.5px;
    line-height: 1.2;
    word-break: break-word;
    overflow-wrap: break-word;
}

/* Modelo como "Píldora" Tech */
.product-model {
    display: inline-block;
    max-width: 100%;
    font-size: 0.95rem;
    color: #d97706;
    font-weight: 700;
    background-color: rgba(241, 154, 49, 0.1);
    padding: 4px 14px;
    border-radius: 20px;
    margin: 0 0 1.5rem 0;
    letter-spacing: 1px;
    border: 1px solid rgba(241, 154, 49, 0.2);
    word-break: break-word;
    overflow-wrap: break-word;
}

/* Descripción Alineada a la izquierda para escaneo rápido */
.product-short-description {
    font-size: 1.05rem;
    color: #475569;
    line-height: 1.7;
    margin-bottom: 1.5rem;
    text-align: left;
}

/* Caja de Metadatos */
.product-meta {
    background-color: #f8fafc;
    padding: 1.2rem;
    border-radius: 12px;
    border: 1px solid #e2e8f0;
    margin-bottom: 1.5rem;
    font-size: 0.95rem;
}

.product-meta span {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    margin-bottom: 0.5em;
    color: #64748b;
}

.product-meta span:last-child {
    margin-bottom: 0;
}

.product-meta strong {
    color: #1e293b;
    min-width: 85px;
    font-weight: 600;
}

.product-category a {
    color: #f19a31;
    font-weight: 600;
    text-decoration: none;
    transition: color 0.2s;
}

.product-category a:hover {
    color: #d97706;
}

.product-certifications {
    display: flex;
    gap: 10px;
    margin-bottom: 1.5rem;
    align-items: center;
}

.product-certifications img {
    height: 28px;
    filter: grayscale(100%);
    opacity: 0.7;
    transition: all 0.3s;
}

.product-certifications img:hover {
    filter: grayscale(0%);
    opacity: 1;
}

/* Botones de Acción Premium */
.product-actions-container {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-top: auto;
    padding-top: 1.5rem;
    border-top: 1px solid #e2e8f0;
}

.product-share-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 14px 20px;
    color: white !important;
    text-decoration: none;
    border-radius: 10px;
    font-size: 1rem;
    font-weight: 600;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    width: 100%;
    max-width: 100%;
}

.product-share-button i {
    font-size: 1.2rem;
}

.product-share-email {
    background-color: #f19a31;
    box-shadow: 0 4px 15px rgba(241, 154, 49, 0.25);
}

.product-share-email:hover {
    background-color: #d97706;
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(241, 154, 49, 0.35);
}

.product-share-whatsapp {
    background-color: #25D366;
    box-shadow: 0 4px 15px rgba(37, 211, 102, 0.25);
}

.product-share-whatsapp:hover {
    background-color: #1ebc59;
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(37, 211, 102, 0.35);
}

.product-share-generic {
    background-color: #ffffff;
    color: #475569 !important;
    border: 1px solid #cbd5e1;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.02);
}

.product-share-generic:hover {
    background-color: #121212;
    border-color: rgb(148, 163, 184);
    transform: translateY(-2px);
    color: rgb(255 255 255) !important;
}

.product-share-generic.copied {
    background-color: #10b981;
    color: white !important;
    border-color: #10b981;
}

/* =========================================
   Pestañas Inferiores (TABS)
   ========================================= */
.product-tabs-container {
    max-width: 100%;
    margin: 0 auto;
    width: 95%;
    min-height: 300px;
}

.tab-buttons {
    display: flex;
    gap: 15px;
    border-bottom: 2px solid #e2e8f0;
    margin-bottom: 25px;
    padding-bottom: 0;
}

.tab-button {
    padding: 12px 20px;
    cursor: pointer;
    background-color: transparent;
    border: none;
    font-size: 1.05rem;
    font-weight: 600;
    color: #64748b;
    position: relative;
    top: 2px;
    transition: all 0.3s ease;
}

.tab-button:hover {
    color: #f19a31;
}

.tab-button.active {
    color: #f19a31;
}

.tab-button.active::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 100%;
    height: 3px;
    background-color: #f19a31;
    border-radius: 3px 3px 0 0;
}

.tab-panel {
    display: none;
    color: #475569;
    animation: fadeIn 0.4s ease forwards;
    contain: layout;
}

.tab-panel.active {
    display: block;
    contain: none;
}

.tab-panel h3 {
    font-size: 1.4rem;
    color: #0f172a;
    margin-top: 0;
    margin-bottom: 1.5rem;
    display: flex;
    align-items: center;
    gap: 10px;
}

.tab-panel h3::before {
    content: '';
    display: block;
    width: 4px;
    height: 22px;
    background-color: #f19a31;
    border-radius: 2px;
}

.tab-panel p {
    line-height: 1.7;
    margin-bottom: 1rem;
}

.tab-panel ul {
    padding-left: 20px;
    line-height: 1.7;
}

.tab-panel li {
    margin-bottom: 0.5rem;
}

.tab-panel li a {
    color: #f19a31;
    font-weight: 600;
    text-decoration: none;
}

.tab-panel li a:hover {
    text-decoration: underline;
}

/* Diseño de Tabla Premium */
.tab-panel table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    margin-top: 1.5rem;
    border-radius: 12px;
    border: 1px solid #e2e8f0;
    overflow: hidden;
}

.tab-panel th,
.tab-panel td {
    padding: 15px 20px;
    text-align: left;
    border-bottom: 1px solid #e2e8f0;
    font-size: 0.95rem;
}

.tab-panel tr:last-child th,
.tab-panel tr:last-child td {
    border-bottom: none;
}

.tab-panel th {
    background-color: #f8fafc;
    font-weight: 700;
    color: #1e293b;
    width: 35%;
    border-right: 1px solid #e2e8f0;
}

.tab-panel tr:hover td,
.tab-panel tr:hover th {
    background-color: #f8fafc;
}

.gallery-nav {
    position: absolute;
    top: 50%;
    background-color: rgba(0, 0, 0, 0.5);
    color: white;
    border: none;
    padding: 10px;
    font-size: 22px;
    cursor: pointer;
    z-index: 10;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background-color 0.2s ease;
}

.gallery-nav:hover {
    background-color: rgba(0, 0, 0, 0.8);
}

.gallery-prev {
    left: 10px;
}

.gallery-next {
    right: 10px;
}

.mobile-back-btn {
    display: none;
    width: calc(100% - 2rem);
    margin: 0 auto 0.8rem auto;
    padding: 10px;
    background-color: #2c3e50;
    color: white;
    border: none;
    border-radius: 8px;
    font-size: 1rem;
    font-weight: 500;
    cursor: pointer;
    text-align: center;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.15);
    transition: background-color 0.2s;
}

.mobile-back-btn:hover {
    background-color: #3f5872;
}

.mobile-back-btn i {
    margin-right: 8px;
}

/* Footer */
footer {
    background-color: #1a1a1a;
    color: #fff;
    padding: 100px 0;
    position: relative;
    font-family: Arial, sans-serif;
    box-shadow: 0 -2px 15px rgba(0, 0, 0, 0.3);
    display: flex;
    flex-direction: column;
    align-items: center;
    line-height: normal;
}

.footer-container {
    line-height: 1.6;
    max-width: 1400px;
    margin: auto auto;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 50px;
    padding: 0 30px;
}

.footer-section .footer-about-text {
    color: #b3b3b3;
    font-size: 100%;
    line-height: 140%;
    letter-spacing: normal;
    margin: 0;
}

.footer-section .footer-about-text strong {
    font-weight: 500;
    color: inherit;
}

.footer-subsection {
    margin-bottom: 40px;
}

.footer-section h3 {
    color: #fff;
    font-size: 120%;
    margin-bottom: 20px;
    position: relative;
    padding-bottom: 10px;
}

.footer-section h3::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 50px;
    height: 2px;
    background-color: #ff4500;
}

.footer-section a {
    color: #b3b3b3;
    margin-bottom: 10px;
    display: block;
    text-decoration: none;
    transition: all 0.3s ease;
    line-height: 1.2;
    margin: 6px 0;
    font-size: 100%;
}

.footer-section a:hover {
    color: #ff4500;
    transform: scale3d(1.02, 1.02, 1);
}

.footer-section a.active-tap {
    transform: scale(0.98);
    transition: all 0.1s ease;
}

.social-icons {
    display: flex;
    gap: 15px;
    margin-top: 20px;
    flex-wrap: wrap;
}

.social-icons a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    background-color: #333;
    border-radius: 50%;
    color: #fff;
    transition: all 0.3s ease;
    position: relative;
    text-decoration: none;
}

.social-icons a i {
    z-index: 1;
}

.social-icons a:hover {
    background-color: #ff4500;
    color: #fff;
    transform: scale3d(1.1, 1.1, 2);
    box-shadow: 1px 1px 15px #ff4500;
}

.social-icons a:after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0.25;
    border-radius: 50%;
    z-index: 0;
    transition: opacity 0.3s ease;
}

.social-icons a.active-tap {
    transform: scale(0.98);
    transition: all 0.1s ease;
}

.contact-info {
    display: flex;
    align-items: center;
    margin-bottom: 15px;
    font-size: 100%;
}

.contact-info i {
    margin-right: 10px;
    color: #ff4500;
    font-size: 1.2rem;
}

.contact-info .fab.fa-whatsapp {
    font-size: 1.3rem;
}

.footer-bottom {
    background-color: #0d0d0d;
    padding: auto;
    text-align: center;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    box-shadow: 0 -5px 15px rgba(0, 0, 0, 0.3);
    border-top: 1px solid #000000;
}

.footer-bottom p {
    color: #ffffff;
    font-size: 90%;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.5em;
    padding: 0 10px;
}

.footer-bottom p a {
    color: #ffffff;
    text-decoration: none;
    transition: color 0.3s ease;
    font-weight: 700;
}

.footer-bottom p a:hover {
    color: #ff4500;
}

.footer-developer::before {
    content: "|";
    margin-right: 0.5em;
    color: #b3b3b3;
}

.social_footer {
    padding-top: 30px;
    text-align: center;
    display: block;
    margin-top: 19px;
    gap: 20px;
    padding: 0 30px;
    font-size: 100%;
}

.social_footer a:hover {
    background-color: #ff4500;
    color: #fff;
    transform: scale3d(1.1, 1.1, 2);
    box-shadow: 1px 1px 15px #ff4500;
}

.map-wrapper {
    min-height: 290px;
    background-color: #e9e9e9;
    border-radius: 10px;
    width: 95%;
    margin: 0 auto;
    display: flex;
    justify-content: center;
    align-items: center;
}

.map-wrapper iframe {
    width: 100%;
}

/* 404 Page */
.error-page-container {
    text-align: center;
    padding: 4rem 1rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: calc(100vh - 400px);
}

.error-page-container h1 {
    font-size: 6rem;
    font-weight: 700;
    color: #f19a31;
    margin: 0;
    line-height: 1;
}

.error-page-container h2 {
    font-size: 1.8rem;
    margin-top: 0.5rem;
    color: #333;
}

.error-page-container p {
    max-width: 500px;
    margin-top: 1rem;
    margin-bottom: 2rem;
    font-size: 1.1rem;
    color: #555;
}

.error-page-container .btn {
    width: auto;
    padding: 12px 25px;
    font-size: 1rem;
}



/* =========================================
   4. MEDIA QUERIES (DESKTOP FIRST STRATEGY)
   ========================================= */

/* --- A. Min-Width Overrides (Large screens or Specific Desktop behaviors) --- */
@media (min-width: 1200px) {
    .floating-product-img {
        width: clamp(50px, 25vw, 100px);
    }

    .fullscreen-img {
        max-width: 30%;
        max-height: 30%;
        transform: translate(-50%, -50%) scale(2);
    }
}

@media (min-width: 1051px) {
    #nav-menu>li:not(:last-child)::after {
        content: "";
        position: absolute;
        right: -0.75rem;
        top: 50%;
        transform: translateY(-50%);
        height: 20px;
        width: 1px;
        background-color: #484848;
    }

    .float-button.phone-float,
    .float-button.email-float,
    .float-button.whatsapp-float {
        display: flex !important;
        opacity: 0.7;
        transform: none;
    }

    .float-button.phone-float {
        display: none !important;
    }

    .contact-main-float {
        display: none !important;
    }

    .float-buttons.contact-active .phone-float,
    .float-buttons.contact-active .email-float,
    .float-buttons.contact-active .whatsapp-float,
    .float-buttons.contact-active .wishlist-float,
    .float-buttons.contact-active .recently-float {
        opacity: 0.7;
        transform: none;
    }

    .performance-toggle-mobile {
        display: flex !important;
    }

    .performance-toggle {
        display: none !important;
    }

    /* Desktop Dropdown Styles */
    .dropdown-menu {
        padding: 12px;
        gap: 0;
        background-color: #f8f9fa;
        margin: 0;
        overflow-x: hidden;
        overflow-y: auto;
        max-height: calc(100vh - 85px);
        scrollbar-width: thin;
        scrollbar-color: #f19a31 #e0e0e0;
        box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15);
        border-radius: 8px;
        border: 1px solid rgba(0, 0, 0, 0.05);
        margin-top: 15px;
    }

    .dropdown-menu::before {
        content: '';
        position: absolute;
        top: -20px;
        left: 0;
        width: 100%;
        height: 20px;
        background: transparent;
    }

    .dropdown-menu li a,
    .dropdown-menu li div {
        font-size: 14px;
        font-weight: 500;
        padding: 0.6rem 1rem;
        text-align: left;
        border-radius: 4px;
        color: #2c3e50;
        border-bottom: 1px solid #f0f0f0;
        display: block;
        text-decoration: none;
        transition: all 0.2s ease;
    }

    .dropdown-menu li:last-child a,
    .dropdown-menu li:last-child div {
        border-bottom: none;
    }

    .dropdown-menu li a:hover,
    .dropdown-menu li div:hover {
        color: #f19a31;
        background-color: #fff9f2;
    }

    .dropdown-menu li a::after,
    .dropdown-menu li div::after {
        display: none !important;
    }

    #nav-menu>li>a#productos-toggle.productos-link-active {
        color: #f19a31;
    }

    #nav-menu>li>a#productos-toggle.productos-link-active::after {
        width: 100%;
    }

    .breadcrumb-actual-links {

        display: flex;
        flex-wrap: wrap;
        justify-content: flex-start;
    }
}

@media (min-width: 931px) and (max-width: 1366px) {
    .producto-grid .producto-item {
        min-height: 280px;
    }

    .product-image-container {
        height: 140px;
    }

    .categoria-item {
        min-height: 480px !important;
        padding: 1.2rem;
    }

    .categoria-enlace-imagen {
        height: 240px;
        width: 100%;
    }

    .categoria-imagen {
        max-height: 100%;
    }

    .categoria-item h2 {
        font-size: 1.4rem;
        margin-bottom: 0.8rem;
    }

    .breadcrumb-content-int {
        background-color: #fff;
        padding: 1rem 1.5rem;
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
        justify-content: space-between;
        align-items: center;
        padding-left: 6.2rem;
        padding-right: 4rem;
    }

    .breadcrumb-actual-links {
        color: #555;
        align-items: center;
        flex-wrap: wrap;
        justify-content: flex-start;
    }

    .breadcrumb-actual-links a {
        color: #f19a31;
        text-decoration: none;
        transition: color 0.2s ease;
        font-size: 1em;
    }

    .breadcrumb-actual-links .breadcrumb-current {
        color: #333;
        font-weight: 700;
        font-size: 1em;
    }
}

@media (hover: hover) {
    .toggle-description-button:hover {
        background-color: #f19a31;
    }

    .toggle-description-button:active {
        background-color: #e07b00;
        transform: scale(0.98);
    }
}

/* --- B. Max-Width Waterfall (Descending Order) --- */

@media (max-width: 1700px) {
    .top-float {
        animation: pulse 2s infinite;
        animation-delay: 0.9s;
        bottom: 5%;
        right: 6%;
    }
}

@media (max-width: 1600px) {
    .top-float {
        animation: pulse 2s infinite;
        animation-delay: 0.9s;
        bottom: 5%;
        right: 6%;
    }

    .breadcrumb-content-int {
        padding-left: 7rem;
        padding-right: 4rem;
    }
}

@media (max-width: 1400px) {
    .top-float {
        animation: pulse 2s infinite;
        animation-delay: 0.9s;
        bottom: 5%;
        right: 5%;
    }

    .breadcrumb-content-int {
        padding-left: 6.7rem;
        padding-right: 4rem;
    }
}

@media (max-width: 1200px) {
    .logo {
        max-width: 100%;
        width: clamp(320px, 75vw, 340px);
        height: clamp(40px, 30vw, 42px);
        aspect-ratio: 16/9;
    }

    .slogan {
        padding: 0.7rem 0.2rem;
        font-size: 95%;
    }

    .top-float {
        animation: pulse 2s infinite;
        animation-delay: 0.9s;
        bottom: 5%;
        right: 6%;
    }

    .class_floating-search-container {
        display: none;
        position: fixed;
        top: 64px;
        right: 4.2%;
        z-index: 9999;
        padding: 10px 10px;
        box-sizing: border-box;
        transform: translateY(-10%);
        opacity: 0;
        transition: transform 0.3s ease, opacity 0.3s ease;
        width: 20%;
    }

    .class_floating-search-container.active {
        transform: translateY(0);
        opacity: 1;
    }

    .floating-search-box {
        position: relative;
        width: 120%;
        max-width: 1200px;
        background-color: #ffffff;
        border-radius: 10px;
        border: 1px solid #918989d8;
        padding: 0;
        box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
        right: 4.2%;
    }

    .floating-search-results {
        position: absolute;
        width: 130%;
        left: 48%;
        transform: translateX(-50%);
        z-index: 1002;
    }
}



/* --- THE BIG BREAKPOINT: TABLET/MOBILE --- */
@media (max-width: 1050px) {

    /* Global Changes */
    .performance-toggle {
        display: none !important;
    }

    .performance-toggle-mobile {
        display: flex !important;
    }

    .logo {
        max-width: 100%;
        width: clamp(320px, 75vw, 340px);
        height: clamp(40px, 30vw, 42px);
        aspect-ratio: 16 / 9;
    }

    /* Header & Nav */
    .header {
        padding: 0.5rem 1rem;
    }

    .header nav {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: 0.3rem 0.5rem;
        position: relative;
        width: 100%;
        height: 58px;
    }

    .nav-left {
        margin-top: 10px;
    }

    .nav-right {
        display: flex;
        align-items: center;
        gap: 0;
    }

    .hamburger {
        display: block;
    }

    .search-icon-mobile {
        display: none;
    }

    /* Mobile Search behavior */
    body>.class_floating-search-container.active,
    #search-overlay.active {
        display: none !important;
    }

    #nav-menu.search-mode-active .class_floating-search-container {
        display: block !important;
        position: relative !important;
        width: 100%;
        max-width: 100%;
        min-width: 0;
        /* ESTA LÍNEA PERMITE QUE SE ACHIQUE CORRECTAMENTE */
        top: 0;
        left: 0;
        right: 0;
        background-color: transparent;
        padding: 10px 10px 15px 10px;
        box-shadow: none;
        transform: none;
        opacity: 1;
        z-index: 5;
        order: -1;
        border-top: 1px solid #e0e0e0;
        border-bottom: 1px solid #e0e0e0;
    }

    #nav-menu.search-mode-active {
        display: flex;
        flex-direction: column;
    }

    #nav-menu>a.logo-in-mobile-nav {
        display: block;
        padding: 10px 0px 10px 0px;
        order: -2;
        width: 100%;
        margin-left: 25px;
        margin-top: 10px;
        border-bottom: none;
    }

    #nav-menu>a.logo-in-mobile-nav .logo {
        width: clamp(260px, 45vw, 300px);
        margin-left: 0;
        aspect-ratio: 16/9;
        display: inline-block;
    }

    #nav-menu .floating-search-box {
        width: 95%;
        margin: 0 auto;
        background-color: #ffffff;
        border: 1px solid #ccc;
        box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
        right: auto;
    }

    #nav-menu .floating-search-box input {
        height: 38px;
        font-size: 0.9rem;
        padding: 0 35px 0 12px;
        /* Da más espacio al texto en pantallas chicas */
    }

    #nav-menu .floating-search-results {
        position: absolute !important;
        left: 50% !important;
        transform: translateX(-50%) !important;
        width: 100% !important;
        max-width: none !important;
        background-color: #f5f5f5;
        border-radius: 0px;
        box-shadow: 0 2px 5px rgba(0, 0, 0, 0.15);
        max-height: 70vh !important;
        z-index: 15 !important;
        display: none;
        scrollbar-width: thin;
        scrollbar-color: #ff8c00 #444;
        height: 60vh;
    }



    #nav-menu .floating-search-results.active {
        display: block;
    }

    .floating-search-results.active {
        height: 50vh;
    }

    /* Mobile Nav Menu (Off-canvas) */
    #nav-menu {
        position: fixed;
        top: 0;
        left: -100%;
        height: 100vh;
        width: 80%;
        max-width: 100vw;
        background-color: #f5f5f5;
        transition: left 0.3s ease;
        z-index: 9999;
        box-shadow: 12px 0 15px -5px rgba(0, 0, 0, 0.25);
        border-top-right-radius: 10px;
        animation: slideOutLeft 0.4s forwards;
        overflow-y: auto;
        overflow-x: hidden;
        gap: 0;
        margin-top: 0;
        display: flex;
        flex-direction: column;
    }

    #nav-menu.menu-collapsing {
        left: 0;
        transition: left 0.3s ease;
    }

    #nav-menu.active {
        left: -1px;
        animation: slideInLeft 0.4s forwards;
        z-index: 9999;
        padding-top: 0;
    }

    #nav-menu>li {
        transition: opacity 0.2s ease;
        width: 100%;
        padding: 0;
        left: -5px;
    }

    #nav-menu>div.class_floating-search-container,
    #nav-menu>li:last-of-type {
        border-bottom: none;
    }

    #nav-menu li a,
    #nav-menu li div {
        padding: 1.2rem 1.5rem;
        font-size: 15px;
        color: #333;
        text-align: right;
        width: 101%;
        text-decoration: none;
        display: block;
        transition: background-color 0.2s ease, color 0.2s ease;
        border-bottom: 1px solid #e0e0e0;
    }

    #nav-menu li a:hover,
    #nav-menu li div:hover {
        background-color: #f19a31;
        color: white;
        width: 102%;
    }

    #nav-menu>li>a::after,
    #nav-menu>li>div::after {
        content: "";
        position: absolute;
        width: 0;
        height: 2px;
        bottom: 0;
        left: 0%;
        transform: translateX(-50%);
        transition: width 0.3s ease;
        background-color: transparent;
    }

    #nav-menu>li>a.active-tap {
        background-color: #f19a31 !important;
        color: #fff !important;
        transform: scale(0.98);
        transition: all 0.1s ease;
    }



    /* Mobile Dropdown */
    .dropdown-menu {
        position: static;
        background-color: #f8f9fa;
        min-width: 102%;
        padding: 0px;
        margin: 0px;
        display: none;
        max-height: 35vh !important;
        overflow-y: auto !important;
        -webkit-overflow-scrolling: touch !important;
        touch-action: pan-y !important;
        box-shadow: inset 0 2px 5px rgba(0, 0, 0, 0.2);
        scrollbar-width: thin;
        scrollbar-color: #ff8c00 #444;
        grid-template-columns: 1fr;
        transform: none;
        opacity: 1;
        visibility: visible;
        animation: slideOut 0.3s ease forwards;
    }

    .dropdown-menu.active {
        display: grid !important;
        padding: 0px 10px;
        margin: 0px;
        animation: slideIn 0.3s ease forwards;
        background-color: #e7e5e6;
        justify-items: right;

    }

    .dropdown-menu li div,
    .dropdown-menu li a {
        padding: 0.75rem 2rem;
        font-size: 15px;
        color: #333;
        will-change: transform, background-color;
    }

    .dropdown-menu li:last-child a,
    .dropdown-menu li:last-child div {
        border-bottom: none;
    }

    .dropdown-menu li a.active-tap,
    .dropdown-menu li a:hover,
    .dropdown-menu li div:hover {
        background-color: #f19a31 !important;
        color: #fff !important;
        transform: scale(0.98);
        transition: all 0.1s ease;
        border-top-right-radius: 0;
        border-bottom-right-radius: 0;
    }

    .dropdown-menu::-webkit-scrollbar {
        width: 8px;
    }

    .dropdown-menu::-webkit-scrollbar-track {
        background: #444;
        border-radius: 4px;
    }

    .dropdown-menu::-webkit-scrollbar-thumb {
        background: #ff8c00;
        border-radius: 4px;
    }

    .dropdown-menu::-webkit-scrollbar-thumb:hover {
        background: #e07b00;
    }

    .dropdown.active .arrow {
        transform: rotate(180deg);
        transition: transform 0.3s ease;
    }

    /* UI Elements */
    .slogan {
        padding: 0.8rem 0.2rem;
        font-size: 90%;
    }

    .footer-container {
        grid-template-columns: repeat(2, 1fr);
    }

    .top-float {
        animation: pulse 2s infinite;
        animation-delay: 0.9s;
        bottom: 1%;
        right: 8%;
    }

    .float-buttonsleft {
        bottom: 70px;
    }

    .float-button {
        opacity: 0.8;
    }

    .floating-product-img {
        transition: transform 0.3s ease;
        cursor: zoom-in;
        height: auto;
        border-radius: 4px;
        object-fit: contain;
        aspect-ratio: 1 / 1;
        width: clamp(50px, 10vw, 100px);
    }

    .fullscreen-img {
        max-width: 40%;
        max-height: 30%;
        transform: translate(-50%, -50%) scale(2);
    }

    /* Float Buttons */
    .float-buttons,
    .float-buttonsleft {
        position: fixed;
        z-index: 100;
        display: flex;
        flex-direction: column;
        gap: 10px;
    }

    .float-buttons {
        bottom: 25px;
        right: -22px;
        align-items: flex-end;
    }

    .float-buttonsleft {
        bottom: 90px;
        left: 20px;
        gap: 15px;
    }

    .float-button,
    .float-button2 {
        width: 80px;
        height: 50px;
        border-radius: 40px;
        text-align: center;
        font-size: 28px;
        box-shadow: 0 4px 10px rgba(0, 0, 0, 0.3);
        display: flex;
        align-items: center;
        justify-content: left;
        text-decoration: none;
        transition: all 0.3s ease;
        color: #fff;
        opacity: 70%;
        position: relative;
        padding: 0px 15px;
        -webkit-tap-highlight-color: transparent;
    }

    .float-button {
        opacity: 1 !important;
        background-clip: padding-box;
        box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
        border: 2px solid transparent;
    }

    .float-button:hover {
        transform: scale(1.1);
        box-shadow: 0 6px 15px rgba(0, 0, 0, 0.5);
        opacity: 1;
    }

    .float-button:active {
        transform: scale(0.98);
        transition: all 0.1s ease;
    }

    .float-button.hovered {
        background-color: #f19a31 !important;
    }

    .whatsapp-float {
        background-color: #25d366;
        font-size: 29px;
    }

    .whatsapp-float:hover {
        background-color: #20ba5a;
    }

    .email-float {
        background-color: #ff4500;
    }

    .email-float:hover {
        background-color: #e63e00;
    }

    .phone-float {
        background-color: #007bff;
    }

    .phone-float:hover {
        background-color: #0056b3;
    }

    /* Float Buttons Logic */
    .contact-main-float {
        display: flex !important;
        background-color: #555;
        order: 4;
    }

    .contact-main-float .fa-comments {
        display: inline-block;
    }

    .contact-main-float .fa-times {
        display: none;
    }

    .contact-main-float.active .fa-comments {
        display: none;
    }

    .contact-main-float.active .fa-times {
        display: inline-block;
    }

    .contact-main-float.active {
        background-color: #c0392b;
    }

    .float-buttons .phone-float,
    .float-buttons .email-float,
    .float-buttons .whatsapp-float,
    .float-buttons .wishlist-float,
    .float-buttons .recently-float {
        display: none;
        opacity: 0;
        transform: translateY(15px) scale(0.9);
        transition: opacity 0.2s ease-out, transform 0.2s ease-out;
        margin-bottom: 0;
    }

    .float-buttons.contact-active .phone-float,
    .float-buttons.contact-active .email-float,
    .float-buttons.contact-active .whatsapp-float,
    .float-buttons.contact-active .wishlist-float,
    .float-buttons.contact-active .recently-float {
        display: flex !important;
        opacity: 0.8;
        transform: translateY(0) scale(1);
    }

    .float-buttons.contact-active .phone-float {
        transition-delay: 0s;
        order: 1;
    }

    .float-buttons.contact-active .email-float {
        transition-delay: 0.07s;
        order: 2;
    }

    .float-buttons.contact-active .whatsapp-float {
        transition-delay: 0.14s;
        order: 3;
    }

    .float-buttons.contact-active .wishlist-float {
        transition-delay: 0.21s;
        order: 4;
    }

    .float-buttons.contact-active .recently-float {
        transition-delay: 0.28s;
        order: 5;
    }

    .float-button.btnup-float {
        order: 5;
        display: flex !important;
    }

    .btnup-float:active {
        background-color: #e06500;
        transform: scale(0.95);
        box-shadow: 0 2px 5px rgba(0, 0, 0, 0.3);
        transition: all 0.1s ease;
    }

    .touch-device .categoria-item:hover {
        transform: none;
        box-shadow: 0 10px 20px rgba(0, 0, 0, 0.19), 0 6px 6px rgba(0, 0, 0, 0.23);
    }

    .touch-device .categoria-item:hover .categoria-imagen {
        transform: none;
    }

    .touch-device .btn:hover {
        background-color: #2c3e50;
        box-shadow: 0 4px 6px rgba(0, 0, 0, 0.3), 0 1px 3px rgba(0, 0, 0, 0.2);
    }

    /* Breadcrumbs */
    .breadcrumb-wrapper-ext {
        width: 100%;
        margin-top: 15px;
        margin-bottom: 15px;
        padding: 0 1rem;
    }

    .breadcrumb-content-int {
        padding: 0.4rem 0.8rem;
        border-radius: 8px;
    }

    .breadcrumb-actual-links {
        font-size: 0.9em;
        color: #555;
        align-items: center;
        flex-wrap: wrap;
        justify-content: flex-start;
    }

    .breadcrumb-actual-links a {
        color: #f19a31;
        text-decoration: none;
        transition: color 0.2s ease;
        font-size: 1em;
    }

    .breadcrumb-actual-links a:hover {
        color: #d98220;
        text-decoration: underline;
    }

    .breadcrumb-actual-links .breadcrumb-separator {
        margin: 0;
        padding: 0 0.2em;
        color: #777;
    }

    .breadcrumb-actual-links .breadcrumb-current {
        color: #333;
        font-weight: 700;
        font-size: 1em;
    }

    /* Products Grid */
    #productos {
        padding: 0.8rem 1rem;
    }

    .producto-grid {
        grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
        gap: 20px;
        padding: 0;
    }

    .producto-grid .producto-item {
        min-height: 320px;
        padding: 1rem;
    }

    .producto-grid .producto-item img {
        max-height: auto;
    }

    .producto-grid .producto-item h2 {
        font-size: 1.1em;
    }

    .producto-grid .producto-item p {
        font-size: 0.85em;
        min-height: 10px;
    }

    .producto-grid .producto-item .btn {
        padding: 8px 20px;
        font-size: 0.85rem;
    }

    .productos-nuevos-swiper .swiper-button-next,
    .productos-nuevos-swiper .swiper-button-prev {
        display: block;
        padding: 5px 5px;
    }

    .gallery-nav {
        display: none;
    }

    /* Product Page Sidebar & Filters */
    .products-page-container {
        grid-template-columns: 1fr;
        padding: 0;
    }

    .product-filters-sidebar {
        position: fixed;
        top: 0;
        left: -100%;
        width: 85%;
        max-width: 320px;
        height: 100%;
        z-index: 9998;
        overflow-y: auto;
        box-shadow: 5px 0 15px rgba(0, 0, 0, 0.2);
        border-radius: 0;
        border-top-right-radius: 10px;
    }

    .product-filters-sidebar.filters-sidebar-mobile-active {
        left: 0;
    }

    .close-filters-btn {
        display: block;
    }

    .mobile-filter-toggle-btn {
        display: block;
        width: calc(100% - 2rem);
        margin: 0 auto 1.5rem auto;
        padding: 10px;
        background-color: #2c3e50;
        color: white;
        border: none;
        border-radius: 8px;
        font-size: 1rem;
        font-weight: 500;
        cursor: pointer;
        text-align: center;
        box-shadow: 0 2px 5px rgba(0, 0, 0, 0.15);
    }

    .mobile-back-btn {
        display: none;
    }

    .categoria-item {
        min-height: 480px !important;
    }

    .categoria-item-front,
    .categoria-item-back {
        padding: 1rem;
    }

    /* Product Details */
    .product-detail-section {
        flex-direction: column;
        align-items: center;
    }

    .product-main-content-flex-container {
        flex-direction: column;
        gap: 20px;
    }

    .product-image-gallery,
    .product-info-column,
    .product-tabs-container {
        max-width: 100%;
        flex: 100%;
        padding: 1.5rem;
    }

    .product-quicknav-column {
        display: none;
    }

    .product-tabs-container {
        flex-basis: auto;
        width: 100%;
        max-width: 100%;
        padding: 0.5em 1em;
    }

    #main-product-image {
        width: 80%;
        max-width: 100%;
        min-height: 250px;
        height: 300px;
        aspect-ratio: 1 / 1;
    }

    .product-title {
        font-size: 1.8rem;
    }

    /* Tabla Responsive para móviles (Pone el Título arriba del Dato) */
    .tab-panel table,
    .tab-panel tbody,
    .tab-panel tr,
    .tab-panel th,
    .tab-panel td {
        display: block;
        width: 100%;
    }

    .tab-panel th {
        border-right: none;
        border-bottom: none;
        padding: 12px 15px 4px 15px;
        background-color: transparent;
    }

    .tab-panel td {
        padding: 0 15px 12px 15px;
        border-bottom: 1px solid #e2e8f0;
    }

    .tab-panel tr:hover td,
    .tab-panel tr:hover th {
        background-color: transparent;
    }



    .tab-buttons {
        flex-wrap: wrap;
    }

    .tab-button {
        padding: 10px 15px;
        font-size: 0.9em;
    }

    .product-actions-container {
        align-items: center;
        justify-content: center;
    }

    .product-share-button {
        min-width: 0;
        width: 100%;
        max-width: 320px;
    }

    /* Contact Info Grid */
    .contact-info-section {
        display: none;
        background-color: #fff;
        box-shadow: 0 -5px 15px rgba(0, 0, 0, 0.3);
    }

    .contact-info-text,
    .contact-info-label,
    .contact-info-label a,
    .contact-info-value {
        display: none;
    }
}

@media (max-width: 930px) {
    .slogan {
        padding: 0.6rem 0.2rem;
        font-size: 90%;
        font-weight: 600;
        height: auto;
    }

    .top-float {
        background-color: #ff7300;
        animation: pulse 2s infinite;
        animation-delay: 0.9s;
        bottom: 1%;
        right: 10%;
    }

    .footer-container {
        grid-template-columns: repeat(2, 1fr);
    }

    .categoria-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
        margin-left: 30px;
        margin-right: 30px;
        padding: 0 1rem;
        gap: 25px;
    }
}

@media (max-width: 900px) {
    .slogan {
        padding: 0.6rem 0.2rem;
        font-size: 90%;
        font-weight: 600;
        height: auto;
    }

    .top-float {
        animation: pulse 2s infinite;
        animation-delay: 0.9s;
        bottom: 1%;
        right: 10%;
    }

    .whatsapp-float,
    .email-float,
    .phone-float {
        animation: none;
    }

    .contact-layout-container {
        flex-direction: column;
        align-items: stretch;
    }

    .contact-details {
        max-width: none;
    }

    .titulo-con-enlace {
        flex-direction: row !important;
        /* Evita que se apilen en columna */
        justify-content: space-between !important;
        padding: 0 5px 12px 5px !important;
        margin-bottom: 1.5rem !important;
    }

    #productos-nuevos-titulo {
        font-size: 1.4rem !important;
        margin-bottom: 0 !important;
    }

    .ver-mas-link {
        font-size: 0.85rem !important;
        padding: 6px 16px !important;
        background-color: rgba(241, 154, 49, 0.1) !important;
        color: #d98220 !important;
        width: auto !important;
        /* Anula el botón gigante azul que tenías en móvil */
        box-shadow: none !important;
    }
}

@media (max-width: 800px) {
    .performance-toggle.hide-mobile {
        display: none;
    }

    .slogan {
        padding: 0.6rem 0.2rem;
        font-size: 85%;
    }

    .top-float {
        animation: pulse 2s infinite;
        animation-delay: 0.9s;
        bottom: 3%;
        right: 15%;
    }

    .logo-entrance {
        animation: logoBounce 1s ease-out forwards;
    }

    .logo:hover {
        transform: scale(1.05);
    }

    #breadcrumb-back-button,
    .breadcrumb-back-separator-desktop {
        display: none;
    }

    .mobile-back-btn {
        display: block;
        width: calc(100% - 2rem);
        margin: 0 auto 0.5rem auto;
        padding: 10px;
        font-size: 1rem;
        font-weight: 500;
    }


}

@media (max-width: 800px) {
    .tab-panel .accordion-wrapper {
        display: block !important;
        opacity: 1 !important;
        visibility: visible !important;
        max-height: none !important;
        margin-top: 20px !important;
    }
}

@media (max-width: 768px) {

    /* 1. Darle la altura necesaria para que entre Título + Texto + Badges + Botón */
    .categoria-item {
        min-height: 480px !important;
    }

    /* 2. Configurar la cara trasera para que respete los espacios */
    .categoria-item-back {
        padding: 1rem;
        justify-content: center;
        gap: 12px;
        /* Forzamos una separación estricta de 12px entre cada bloque */
    }

    /* 3. Ahorrar espacio en el título trasero */
    .categoria-item-back h2 {
        margin: 0;
        font-size: 1.15rem;
    }

    /* 4. Ajustar el texto de descripción */
    .categoria-descripcion {
        font-size: 0.85rem;
        line-height: 1.4;
        margin: 0;
        padding: 0 5px;
        /* El truco de cortar en 3 líneas sigue activo para móviles */
        display: -webkit-box;
        -webkit-line-clamp: 3;
        line-clamp: 3;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }

    /* 5. Achicar los badges para que entren en pantallas de 320px */
    .categoria-badges {
        margin: 0;
        gap: 6px;
        /* Menos espacio entre pildoritas */
        padding: 0;
    }

    .categoria-badge {
        font-size: 0.65rem;
        /* Letra más chica */
        padding: 4px 10px;
        /* Píldora más ajustada */
        letter-spacing: 0.2px;
    }

    /* 6. Ajustar el botón para que sea consistente */
    .categoria-item-back .btn {
        margin-top: auto;
        /* Empuja el botón hacia abajo si sobra espacio */
        padding: 8px 20px;
        font-size: 0.8rem;
    }

    .categoria-item-back .btn {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 8px;
        /* Espacio entre texto e icono */
    }
}

@media (max-width: 700px) {
    .top-float {
        animation: pulse 2s infinite;
        animation-delay: 0.9s;
        bottom: 3%;
        right: 15%;
    }

    .productos-nuevos-slider-container {
        padding: 0 0.5rem;
    }

    .productos-nuevos-swiper .swiper-button-next,
    .productos-nuevos-swiper .swiper-button-prev {
        width: 30px;
        height: 30px;
        padding: 3px;
    }

    .productos-nuevos-swiper .swiper-button-next::after,
    .productos-nuevos-swiper .swiper-button-prev::after {
        font-size: 16px;
    }

    .productos-nuevos-swiper {
        padding-bottom: 40px;
    }

    .mobile-back-btn {
        display: block;
        width: calc(100% - 2rem);
        margin: 0 auto 0.8rem auto;
        padding: 10px;
        font-size: 0.9rem;
        font-weight: 500;
    }

    .mobile-filter-toggle-btn {
        width: calc(100% - 2rem);
        margin: 0 auto 1.5rem auto;
        padding: 10px;
        background-color: #2c3e50;
        color: white;
        border: none;
        border-radius: 8px;
        font-size: 0.9rem;
        font-weight: 500;
        cursor: pointer;
        text-align: center;
        box-shadow: 0 2px 5px rgba(0, 0, 0, 0.15);
        transition: background-color 0.2s;
    }

    .mobile-filter-toggle-btn:hover {
        background-color: #3f5872;
    }

    .mobile-filter-toggle-btn i {
        margin-right: 8px;
    }

    .toggle-description-button {
        font-size: 0.9rem;
        font-weight: 500;
    }
}

@media (max-width: 600px) {
    .slogan {
        padding: 0.6rem 0.2rem;
        font-size: 85%;
    }

    .top-float {
        animation: pulse 2s infinite;
        animation-delay: 0.9s;
        bottom: 5%;
        right: 15%;
    }

    .producto-grid {
        grid-template-columns: 1fr;
        padding: 0;
    }

    #productos {
        padding: 0.8rem;
    }

    .breadcrumb-wrapper-ext {
        padding: 0 1rem;
    }

    .mobile-back-btn {
        width: calc(100% - 2rem);
        margin: 0 auto 0.8rem auto;
        padding: 10px;
        font-size: 0.8rem;
        font-weight: 500;
    }

    .mobile-filter-toggle-btn {
        width: calc(100% - 2rem);
        margin: 0 auto 1.5rem auto;
        padding: 10px;
        background-color: #2c3e50;
        color: white;
        border: none;
        border-radius: 8px;
        font-size: 0.8rem;
        font-weight: 500;
        cursor: pointer;
        text-align: center;
        box-shadow: 0 2px 5px rgba(0, 0, 0, 0.15);
        transition: background-color 0.2s;
    }

    .toggle-description-button {
        font-size: 0.8rem;
        font-weight: 500;
    }
}

@media (max-width: 550px) {
    .logo {
        width: clamp(280px, 50vw, 240px);
        margin-left: 0px;
        height: clamp(38px, 30vw, 35px);
        aspect-ratio: 16 / 9;
    }

    .top-float {
        animation: pulse 2s infinite;
        animation-delay: 0.9s;
        bottom: 5%;
        right: 15%;
    }

    .header nav {
        height: 50px !important;
    }

    .float-button,
    .float-button2 {
        width: 70px;
        height: 50px;
        font-size: 25px;
        padding: 0px 15px;
    }

    .float-button.whatsapp-float {
        font-size: 26px;
    }

    .productos-nuevos-swiper .producto-item:hover {
        transform: translateY(-5px) translateZ(0);
        box-shadow: 0px 10px 78px -24px rgba(0, 0, 0, 0.99);
        transition: all 0.4s ease;
    }

    .breadcrumb-wrapper-ext {
        width: 100%;
        padding: 0 1rem;
    }

    .breadcrumb-actual-links .breadcrumb-separator {
        margin: 0;
        padding: 0 0.1em;
    }

    .breadcrumb-content-int {
        background-color: #fff;
        padding: 0.5rem 1rem;
        border-radius: 8px;
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);

        justify-content: space-between;
        align-items: center;
    }

    .breadcrumb-actual-links {
        font-size: 0.9em;
        color: #555;
        align-items: center;
        flex-wrap: wrap;
        justify-content: flex-start;
    }

    .breadcrumb-actual-links a {
        color: #f19a31;
        text-decoration: none;
        transition: color 0.2s ease;
        font-size: 1em;
    }

    .breadcrumb-actual-links a:hover {
        color: #d98220;
        text-decoration: underline;
    }

    .breadcrumb-actual-links .breadcrumb-separator {
        margin: 0;
        padding: 0 0.2em;
        color: #777;
    }

    .breadcrumb-actual-links .breadcrumb-current {
        color: #333;
        font-weight: 700;
        font-size: 1em;
    }

    .slogan {
        padding: 0.6rem 0.2rem;
        font-size: 75%;
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 1px;
        width: 100%;
        height: auto;
    }

    .dropdown-menu {
        padding: 0;
        margin: 2px;
    }

    .footer-container {
        grid-template-columns: repeat(1, 1fr);
    }

    .footer {
        padding: 70px;
        font-size: 0.8rem;
        border-top: 2px solid #000000;
    }

    .footer-bottom p {
        flex-direction: column;
        gap: 10px;
        padding-bottom: 15px;
        padding-top: 15px;
    }

    .footer-developer::before {
        display: none;
    }

    .productos-nuevos-slider-container {
        padding: 0 10px;
    }

    .productos-nuevos-swiper .producto-item {
        max-width: 70%;
    }

    .mobile-back-btn {
        width: calc(100% - 2rem);
        margin: 0 auto 0.8rem auto;
        padding: 10px;
        font-size: 0.8rem;
        font-weight: 500;
    }

    #btnUp.show {
        height: 50px !important;
        padding: 0 15px !important;
    }

    .tab-buttons {
        display: flex;
        flex-direction: column;
        border-bottom: 2px solid #ddd;
        padding-bottom: 1rem;
        margin-bottom: 2rem;
        justify-content: space-around;
        gap: 15px;
        flex-wrap: wrap;
    }

    .tab-button.active {
        color: #f19a31;
        letter-spacing: 0.012em;
        font-size: 1.0em;
        font-weight: 700;
    }

    .tab-button.active::after {
        width: 50%;
        transform: translateX(50%);
    }

    #main-product-image {
        width: 70%;
        max-width: 100%;
        height: auto;
    }

    .product-share-button {
        min-width: 0;
        width: 100%;
        max-width: 100%;
    }

    #categorias-titulo {
        font-size: 1.5rem;
        margin-bottom: 2rem;
    }

    .categoria-item:hover {
        transform: translateY(-5px) translateZ(0);
        box-shadow: 0 10px 78px -24px rgba(0, 0, 0, 0.99);
        transition: all 0.4s ease;
    }

    .categoria-imagen {
        max-width: 90%;
        max-height: 250px;
    }

    .categoria-grid {
        padding: 0.5rem;
    }

    .categoria-item {
        min-height: 480px !important;
    }

    .categoria-item-front h2,
    .categoria-item-back h2 {
        font-size: 1.1rem;
    }

    .categoria-descripcion {
        font-size: 0.85rem;
        margin: 5px 0 15px 0;
    }

    .categoria-enlace-imagen {
        height: 240px;
    }

    .categoria-item h2 {
        font-size: 1.4rem;
    }

    .btn {
        padding: 8px 14px;
        font-size: 0.8rem;
    }
}

@media (max-width: 480px) {
    .header nav {
        display: flex;
        align-items: center;
        justify-content: space-between;
        margin: 0px;
        padding: 0.3rem 0.2rem;
    }

    .nav-right {
        display: flex;
        align-items: center;
        gap: 0px;
    }

    .nav-left {
        display: flex;
        align-items: center;
        justify-items: center;
        margin-top: 8px;
    }

    .logo {
        width: clamp(280px, 50vw, 240px);
        margin-left: 0px;
        height: clamp(38px, 30vw, 35px);
        aspect-ratio: 16 / 9;
    }

    .hamburger {
        border: none;
        cursor: pointer;
        padding: 0.5rem;
        width: 30px;
        height: 40px;
        z-index: 1001;
    }

    .hamburger span {
        display: block;
        width: 20px;
        height: 2px;
        background-color: black;
        margin: 4px auto;
        transition: all 0.2s ease;
    }

    .slogan {
        opacity: 95%;
        text-align: center;
        padding: 0.5rem 0.2rem;
        font-size: 70%;
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 1px;
        width: 100%;
        height: auto;
    }

    .dropdown-menu {
        padding: 0;
        margin: 2px;
    }



    .float-button,
    .float-button2 {
        width: 65px;
        height: 45px;
        font-size: 24px;
        padding: 0px 12px;
    }

    .float-button.whatsapp-float {
        font-size: 25px;
    }

    .performance-toggle-mobile {
        position: fixed;
        bottom: 90px;
        left: -22px;
        z-index: 7000;
        align-items: center;
    }

    .performance-toggle-mobile-button {
        width: 60px;
        height: 45px;
        background-color: #333333d5;
        color: white;
        border-radius: 40px;
        display: flex;
        align-items: center;
        justify-content: right;
        font-size: 25px;
        cursor: pointer;
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
        transition: background-color 0.3s ease, transform 0.3s ease, box-shadow 0.3s ease;
        border: 1px solid rgba(255, 255, 255, 0.1);
        outline: none;
        position: relative;
        padding: 0 15px;
        -webkit-tap-highlight-color: transparent;
    }

    .float-buttonsleft {
        bottom: 70px;
    }

    .footer-container {
        grid-template-columns: repeat(1, 1fr);
    }

    .footer-bottom {
        background-color: #0d0d0d;
        position: absolute;
        text-align: center;
        font-size: 10px;
        padding: 0px;
        bottom: 0;
        left: 0;
        width: 100%;
        display: grid;
        justify-content: center;
        box-shadow: 0 -5px 15px rgba(0, 0, 0, 0.3);
    }

    .contact-info-icon {
        background-color: #ff8c00;
        width: 35px;
        height: 35px;
        border-radius: 50%;
        display: flex;
        align-items: center;
        justify-content: center;
        margin-bottom: 5px;
        box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
    }

    .contact-info-icon i {
        font-size: 18px;
        color: white;
    }

    .footer-bottom p {
        margin: 0;
        color: #b3b3b3;
        font-size: 95%;
    }

    .breadcrumb-wrapper-ext {
        width: 100%;
        max-width: 100%;
        margin-top: 10px;
        margin-bottom: 10px;
        padding: 0 1rem;
    }

    .breadcrumb-content-int {
        padding: 0.5rem 1rem;
    }

    .breadcrumb-actual-links {
        font-size: 0.8em;
    }

    .breadcrumb-actual-links a {
        font-size: 1em;
    }

    .breadcrumb-actual-links .breadcrumb-current {
        font-size: 1em;
    }

    .productos-nuevos-swiper .producto-item {
        max-width: 80%;
    }

    #productos-nuevos-titulo {
        font-size: 1.2rem !important;
    }

    .ver-mas-link {
        font-size: 0.8rem !important;
        padding: 6px 12px !important;
    }

    .gallery-nav {
        position: absolute;
        top: 50%;
        background-color: rgba(0, 0, 0, 0.5);
        color: white;
        border: none;
        padding: 8px;
        font-size: 18px;
        cursor: pointer;
        z-index: 10;
        border-radius: 50%;
        width: 30px;
        height: 30px;
        display: flex;
        align-items: center;
        justify-content: center;
        transition: background-color 0.2s ease;
    }

    .gallery-nav:hover {
        background-color: rgba(0, 0, 0, 0.8);
    }

    .gallery-prev {
        left: 10px;
    }

    .gallery-next {
        right: 10px;
    }

    .floating-product-img {
        width: clamp(55px, 8vw, 80px);
    }

    .fullscreen-img {
        transform: translate(-50%, -50%) scale(2);
    }

    #btnUp.show {
        height: 45px !important;

        padding: 0 12px !important;
    }

    .product-title {
        font-size: 1.4em;
    }

    .thumbnail-image {
        width: 60px;
        height: 60px;
    }

    .product-share-button {
        font-size: 0.9em;
        padding: 8px 12px;
    }

    .product-share-button i {
        font-size: 1.2em;
    }

    .contact-page-container h1 {
        font-size: 1.5rem;
    }
}

@media (max-width: 410px) {
    .contact-info-icon i {
        font-size: 18px;
        color: white;
    }

    .logo {
        width: clamp(280px, 50vw, 240px);
        margin-left: 0px;
        height: clamp(36px, 30vw, 38px);
        aspect-ratio: 16 / 9;
    }

    #nav-menu>a.logo-in-mobile-nav .logo {
        width: clamp(240px, 45vw, 260px);
        margin-left: 0;
        aspect-ratio: 16/9;
        display: inline-block;
    }

    .hero-cta-container {
        margin-top: 5vh;
        padding-bottom: 0.5rem;
    }
}

@media (max-width: 390px) {
    .logo {
        width: clamp(240px, 50vw, 240px);
        margin-left: 0px;
        height: clamp(36px, 30vw, 38px);
        aspect-ratio: 16 / 9;
    }

    .hero-cta-container {
        margin-top: 10vh;
        padding-bottom: 0.5rem;
    }

    .breadcrumb-actual-links {
        font-size: 0.8em;
        color: #555;
        align-items: center;
        flex-wrap: wrap;
        justify-content: flex-start;
    }

    .breadcrumb-content-int {
        padding: 0.4rem 0.8rem;
    }

    .breadcrumb-actual-links a {
        color: #f19a31;
        text-decoration: none;
        transition: color 0.2s ease;
        font-size: 1em;
    }

    .breadcrumb-actual-links a:hover {
        color: #d98220;
        text-decoration: underline;
    }

    .breadcrumb-actual-links .breadcrumb-separator {
        margin: 0;
        padding: 0 0.2em;
        color: #777;
    }

    .breadcrumb-actual-links .breadcrumb-current {
        color: #333;
        font-weight: 700;
        font-size: 1em;
    }

    .contact-details li {
        display: flex;
        align-items: flex-start;
        font-size: 0.85rem;
        background-color: #f9f9f9;
        border: 1px solid #eee;
        border-left: 4px solid #f19a31;
        padding: 1rem;
        border-radius: 8px;
        transition: transform 0.3s ease, box-shadow 0.3s ease;
    }
}

@media (max-width: 375px) {
    .slogan {
        padding: 0.5rem 0.1rem;
        font-size: 60%;
        letter-spacing: 0.75px;
    }

    .logo {
        width: clamp(240px, 50vw, 240px);
        margin-left: 0px;
        height: clamp(36px, 30vw, 38px);
        aspect-ratio: 16 / 9;
    }

    #nav-menu>a.logo-in-mobile-nav .logo {
        width: clamp(220px, 45vw, 240px);
        margin-left: -10px;
        aspect-ratio: 16/9;
        display: inline-block;
    }

    .hero-cta-container {
        margin-top: 5vh;
        padding-bottom: 0.5rem;
    }
}

@media (max-width: 360px) {
    .categoria-item {
        min-height: 480px !important;
    }

    .categoria-badge {
        font-size: 0.6rem;
        padding: 3px 8px;
    }

    .hero-cta-container {
        margin-top: 10vh;
        padding-bottom: 0.5rem;
    }

    .hero-cta-container {
        margin-top: 5vh;
        padding-bottom: 0.5rem;
    }
}



@media (max-width: 325px) {
    .logo {
        width: clamp(240px, 50vw, 240px);
        margin-left: 0px;
        height: clamp(34px, 30vw, 36px);
        aspect-ratio: 16 / 9;
    }

    #nav-menu>a.logo-in-mobile-nav .logo {
        width: clamp(200px, 45vw, 200px);
        margin-left: -10px;
        aspect-ratio: 16/9;
        display: inline-block;
    }

    .header nav {
        display: flex;
        align-items: center;
        justify-content: space-between;
        margin: 0px;
        padding: 0.3rem 0.2rem;
    }

    .nav-right {
        display: flex;
        align-items: center;
        gap: 0px;
    }

    .nav-left {
        display: flex;
        align-items: center;
        justify-items: center;
        margin-top: 8px;
    }

    .hero-cta-container {
        margin-top: 5vh;
        padding-bottom: 0.5rem;
    }

    .hamburger {
        border: none;
        cursor: pointer;
        padding: 0.5rem;
        width: 30px;
        height: 40px;
        z-index: 1001;
    }

    .hamburger span {
        display: block;
        width: 20px;
        height: 2px;
        background-color: black;
        margin: 4px auto;
        transition: all 0.2s ease;
    }

    .performance-toggle-mobile {
        position: fixed;
        bottom: 90px;
        left: -30px;
        z-index: 7000;
        align-items: center;
    }

    .breadcrumb-content-int {
        padding: 0.4rem 0.8rem;
    }

    .breadcrumb-actual-links {
        font-size: 0.8em;
        color: #555;
        align-items: center;
        flex-wrap: wrap;
        justify-content: flex-start;
    }

    .breadcrumb-actual-links a {
        color: #f19a31;
        text-decoration: none;
        transition: color 0.2s ease;
        font-size: 1em;
    }

    .breadcrumb-actual-links a:hover {
        color: #d98220;
        text-decoration: underline;
    }

    .breadcrumb-actual-links .breadcrumb-separator {
        margin: 0;
        padding: 0 0.2em;
        color: #777;
    }

    .breadcrumb-actual-links .breadcrumb-current {
        color: #333;
        font-weight: 700;
        font-size: 1em;
    }

    .contact-details li {
        display: flex;
        align-items: flex-start;
        font-size: 0.85rem;
        background-color: #f9f9f9;
        border: 1px solid #eee;
        border-left: 4px solid #f19a31;
        padding: 1rem;
        border-radius: 8px;
        transition: transform 0.3s ease, box-shadow 0.3s ease;
    }

    .performance-toggle-mobile-button {
        width: 60px;
        height: 45px;
        background-color: #333333d5;
        color: white;
        border-radius: 40px;
        display: flex;
        align-items: center;
        justify-content: right;
        font-size: 20px;
        cursor: pointer;
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
        transition: background-color 0.3s ease, transform 0.3s ease, box-shadow 0.3s ease;
        border: 1px solid rgba(255, 255, 255, 0.1);
        outline: none;
        position: relative;
        padding: 0 10px;
    }

    .float-buttons {
        position: fixed;
        bottom: 12px;
        right: -30px;
        display: flex;
        flex-direction: column;
        align-items: flex-end;
        gap: 10px;
        z-index: 100;
    }

    .float-buttonsleft {
        position: fixed;
        bottom: 90px;
        left: 20px;
        display: flex;
        flex-direction: column;
        gap: 15px;
        z-index: 100;
    }

    .float-button,
    .float-button2 {
        width: 65px;
        height: 40px;
        font-size: 18px;
        padding: 0 10px;
    }

    .float-button.whatsapp-float {
        font-size: 20px;
    }

    .footer-container {
        grid-template-columns: repeat(1, 1fr);
    }

    .footer-bottom p {
        margin: 0;
        color: #b3b3b3;
        font-size: 90%;
    }

    .producto-grid {
        grid-template-columns: 1fr;
    }

    #btnUp.show {
        height: 40px !important;
        padding: 0 10px !important;
    }

    .product-title {
        font-size: 1.4em;
    }

    .product-short-description {
        font-size: 0.9em;
    }

    .tab-button {
        padding: 8px 10px;
        font-size: 0.85em;
    }

    .thumbnail-image {
        width: 60px;
        height: 60px;
    }

    .slogan {
        padding: 0.5rem 0.1rem;
        font-size: 60%;
        letter-spacing: 0.75px;
    }

    #categorias {
        padding: 2rem 0.2rem;
        text-align: center;
    }

    .categoria-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
        padding: 0 0.5rem;
        margin-top: 20px;
        margin-left: 30px;
        margin-right: 30px;
        gap: 25px;
    }

    .categoria-item {
        border: 1px solid #ddd;
        padding: 0.9rem;
        border-radius: 10px;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        align-items: center;
        min-height: 480px !important;
    }

    .categoria-imagen {
        max-width: 90%;
    }

    .categoria-item h2 {
        font-size: 1.2rem;
    }

    .categoria-item p {
        margin: 0 0 10px 0;
        flex-grow: 1;
    }
}

/* Browser Specifics */
@-moz-document url-prefix() {
    .dropdown-menu.show {
        display: grid !important;
        animation: rotateMenuIn 0.4s ease forwards !important;
        pointer-events: auto !important;
    }

    .dropdown-menu.hide {
        animation: rotateMenuOut 0.4s ease forwards !important;
        pointer-events: none !important;
    }
}

body.no-animations:not(#_) .rotator-item,
body.no-animations:not(#_) .rotator-item.is-active,
body.no-animations:not(#_) .categoria-badge,
body.no-animations:not(#_) .categoria-badge.rotator-active,
html.no-animations:not(#_) .rotator-item,
html.no-animations:not(#_) .rotator-item.is-active,
html.no-animations:not(#_) .categoria-badge,
html.no-animations:not(#_) .categoria-badge.rotator-active {
    transform: translate(-50%, -50%) !important;
}

body.no-animations:not(#_) .flip-indicator-container,
html.no-animations:not(#_) .flip-indicator-container {
    transform: translateX(-50%) !important;
}

/* =========================================
   FIX: BOTON X DEL BUSCADOR EN MODO LIGERO
   ========================================= */
body.no-animations:not(#_) .floating-search-box .floating-search-close,
html.no-animations:not(#_) .floating-search-box .floating-search-close,
body.no-animations:not(#_) .floating-search-box .floating-search-close:hover,
html.no-animations:not(#_) .floating-search-box .floating-search-close:hover {
    transform: translateY(-50%) !important;
}

/* =========================================
   FIX: CENTRADO DE FOTO ZOOM EN MODO LIGERO
   ========================================= */
body.no-animations:not(#_) .fullscreen-wrapper,
html.no-animations:not(#_) .fullscreen-wrapper {
    transform: translate(-50%, -50%) !important;
}

/* En caso de que la imagen se abra sin el borde blanco */
body.no-animations:not(#_) img.fullscreen-img:not(.fullscreen-wrapper img),
html.no-animations:not(#_) img.fullscreen-img:not(.fullscreen-wrapper img) {
    transform: translate(-50%, -50%) !important;
}

/* =========================================
   COOKIE CONSENT BANNER (PREMIUM)
   ========================================= */
.cookie-banner {
    position: fixed;
    z-index: 999999;
    /* Por encima de todo, incluidos los botones flotantes */
    background-color: #ffffff;
    border: 1px solid #e2e8f0;
    box-shadow: 0 15px 40px rgba(0, 0, 0, 0.15);
    transition: transform 0.6s cubic-bezier(0.165, 0.84, 0.44, 1), opacity 0.5s ease;
    opacity: 0;
    visibility: hidden;
    display: flex;
    flex-direction: column;
    gap: 15px;

    /* Posición Escritorio: Inferior Izquierda */
    bottom: 30px;
    left: 30px;
    width: 380px;
    max-width: calc(100vw - 60px);
    border-radius: 16px;
    padding: 22px;
    transform: translateY(50px) scale(0.95);
    pointer-events: none;
    /* No bloquea clics mientras está oculto */
}

.cookie-banner.show {
    opacity: 1;
    visibility: visible;
    transform: translateY(0) scale(1);
    pointer-events: auto;
    /* Se vuelve interactivo */
}

.cookie-content {
    display: flex;
    align-items: flex-start;
    gap: 15px;
}

.cookie-icon {
    font-size: 1.8rem;
    color: #f19a31;
    /* Naranja corporativo */
    flex-shrink: 0;
    margin-top: 2px;
}

.cookie-text h4 {
    margin: 0 0 6px 0;
    font-size: 1.05rem;
    color: #1e293b;
    font-weight: 800;
    letter-spacing: -0.3px;
}

.cookie-text p {
    margin: 0;
    font-size: 0.85rem;
    color: #475569;
    line-height: 1.3;
    margin-top: 1rem;
}

.cookie-actions {
    display: flex;
    gap: 10px;
    width: 100%;
}

.btn-cookie {
    flex: 1;
    padding: 10px 15px;
    font-size: 0.9rem;
    font-weight: 700;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.2s ease;
    text-align: center;
    border: none;
    outline: none;
}

.btn-cookie-reject {
    background-color: transparent;
    color: #64748b;
    border: 1px solid #cbd5e1;
}

.btn-cookie-reject:hover {
    background-color: #f8fafc;
    color: #1e293b;
    border-color: #94a3b8;
}

.btn-cookie-accept {
    background-color: #f19a31;
    color: #ffffff;
    border: 1px solid #f19a31;
    box-shadow: 0 4px 10px rgba(241, 154, 49, 0.2);
}

.btn-cookie-accept:hover {
    background-color: #d97706;
    border-color: #d97706;
    transform: translateY(-2px);
    box-shadow: 0 6px 15px rgba(241, 154, 49, 0.35);
}

/* =========================================
   COOKIE BANNER: RESPONSIVE MÓVIL (<= 768px)
   ========================================= */
@media (max-width: 768px) {
    .cookie-banner {
        bottom: 0;
        left: 0;
        width: 100%;
        /* Ocupa todo el ancho */
        max-width: 100%;
        border-radius: 20px 20px 0 0;
        /* Bordes redondeados solo arriba */
        border-bottom: none;
        border-left: none;
        border-right: none;
        padding: 20px 20px 25px 20px;
        /* Padding inferior extra para iOS (Safe Area) */
        transform: translateY(100%);
        /* Escondido debajo de la pantalla */
        box-shadow: 0 -5px 20px rgba(0, 0, 0, 0.1);
    }

    .cookie-banner.show {
        transform: translateY(0);
        /* Sube desde abajo */
    }
}

/* Para pantallas súper pequeñas (<= 360px) */
@media (max-width: 360px) {
    .cookie-actions {
        flex-direction: column;
        /* Apila los botones si la pantalla es muy estrecha */
    }

    .btn-cookie {
        width: 100%;
    }
}


/* =========================================
   SIDEBAR FILTER MENU
   ========================================= */
.sidebar-menu {
    list-style: none;
    padding: 0;
    margin: 0;
}

.sidebar-menu li {
    margin-bottom: 2px;
}

.filter-item-wrapper {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0;
}

.filter-item-wrapper a {
    flex: 1;
    padding: 0.5rem 0.75rem;
    color: #444;
    text-decoration: none;
    font-size: 0.9rem;
    border-radius: 6px;
    transition: background 0.2s, color 0.2s;
}

.filter-item-wrapper a:hover,
.filter-item-wrapper a.active {
    color: #f19a31;
    font-weight: 600;
}

.submenu-toggle {
    background: none;
    border: none;
    cursor: pointer;
    padding: 0.5rem 0.625rem;
    color: #777;
    font-size: 0.7rem;
    transition: transform 0.3s ease, color 0.2s;
    border-radius: 6px;
    flex-shrink: 0;
}


.has-submenu.open .submenu-toggle,
.has-submenu.open .submenu-toggle i {
    transform: rotate(180deg);
    color: #f19a31;
}



.submenu {
    list-style: none;
    padding: 0;
    margin: 0 0 0 0.75rem;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.35s ease;
}

.submenu li a {
    display: block;
    padding: 0.375rem 0.75rem;
    color: #666;
    text-decoration: none;
    font-size: 0.85rem;
    border-radius: 6px;
    transition: all 0.2s;
}

.submenu li a:hover,
.submenu li a.active {
    color: #f19a31;
    background: rgba(241, 154, 49, 0.06);
}

.submenu li a.ver-todos-link {
    font-weight: 600;
}

.filter-buttons {
    margin-top: 1rem;
    padding-top: 0.75rem;
    border-top: 1px solid #eee;
}

.btn-clear-filters {
    display: block;
    padding: 0.5rem 1rem;
    background: #f19a31;

    border-radius: 6px;
    font-size: 0.85rem;
    font-weight: 600;
    transition: all 0.2s ease;
}




/* =========================================
   CATEGORY ACCORDIONS (Tabs)
   ========================================= */
.accordion-wrapper {
    max-width: 1000px;
    margin: 30px auto 20px;
    background: #ffffff;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.03);
    overflow: hidden;
    display: block;
}

.accordion-item {
    border-bottom: 1px solid #e2e8f0;
    position: relative;
}

.accordion-header {
    width: 100%;
    padding: 20px 25px;
    background: transparent;
    border: none;
    text-align: left;
    font-size: 1.05rem;
    font-weight: 600;
    color: #1e293b;
    display: flex;
    justify-content: space-between;
    align-items: center;
    cursor: pointer;
}

.accordion-header i {
    transition: transform 0.3s ease;
    color: #475569;
}

.accordion-header.active i {
    transform: rotate(180deg);
    color: #f19a31;
}

.accordion-inner-title {
    font-size: 1.05rem;
    margin: 0;
    font-weight: 600;
    color: #1e293b;
    transition: color 0.2s ease;
}

.accordion-header:hover .accordion-inner-title {
    color: #f19a31;
}

.accordion-header.active .accordion-inner-title {
    color: #f19a31;
}

.accordion-content {
    max-height: 0;
    overflow: hidden;
    padding: 0 25px;
    background-color: #fffaf5;
    transition: max-height 0.4s ease-in-out, padding 0.4s ease-in-out;
}

.accordion-header.active+.accordion-content {
    padding: 15px 25px 25px 25px;
    min-height: 50px;
}

/* Descripción Categoría & Botón Mostrar Detalles (Móvil) */


/* Category Accordion Tabs */
.accordion-wrapper {
    max-width: 1000px;
    margin: 30px auto 20px;
    background: #ffffff;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.03);
    overflow: hidden;
    display: block;
}

.accordion-item {
    border-bottom: 1px solid #e2e8f0;
    position: relative;
}

.accordion-header {
    width: 100%;
    padding: 20px 25px;
    background: transparent;
    border: none;
    text-align: left;
    font-size: 1.05rem;
    font-weight: 600;
    color: #1e293b;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.accordion-content {
    max-height: 0;
    overflow: hidden;
    padding: 0 25px;
    background-color: #fffaf5;
}

.category-description-wrapper {
    text-align: center;
    max-width: 1000px;
    margin: 1.5rem auto 3rem auto;
    padding-bottom: 2rem;
    border-bottom: 1px solid #e2e8f0;
}

.category-description {
    font-size: 1.15rem;
    color: #475569;
    line-height: 1.75;
    margin: 0 auto;
    max-width: 800px;
    padding: 0 1rem;
    text-align: justify;
    hyphens: auto;
    -webkit-hyphens: auto;
    -ms-hyphens: auto;
}

.toggle-description-button {
    display: none;
    margin-top: 1rem;
    padding: 8px 25px;
    font-size: 0.9rem;
    font-weight: 600;
    color: #fff;
    background-color: #2c3e50;
    border: none;
    border-radius: 8px;
}

/* ==========================================
   PRODUCT DETAIL PAGE
   ========================================== */
.product-detail-section {
    display: flex;
    flex-direction: column;
    gap: 20px;
    background-color: #f8f9fa;
    align-items: center;
    justify-content: center;
    padding-top: 0;
    padding-bottom: 1rem;
    padding-left: 0.5rem;
    padding-right: 0.5rem;
}

.product-main-content-flex-container {
    display: flex;
    flex-direction: row;
    gap: 20px;
    align-items: stretch;
    width: 95%;
    margin-left: auto;
    margin-right: auto;
    justify-content: center;
    max-width: 100%;
}

.product-image-gallery,
.product-info-column,
.product-tabs-container {
    background-color: #ffffff;
    padding: 1.5rem;
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
    max-width: 100%;
    width: 95%;
}

.product-image-gallery {
    flex: 50%;
    max-width: 50%;
    display: flex;
    flex-direction: column;
    align-items: center;
    overflow: hidden;
    position: relative;
    justify-content: flex-end;
}

.product-info-column {
    flex: 50%;
    max-width: 50%;
}

#main-product-image {
    width: 80%;
    max-width: 450px;
    min-height: 250px;
    height: auto;
    aspect-ratio: 1/1;
    object-fit: contain;
    border-radius: 8px;
    margin-bottom: 10px;
    display: block;
}

.thumbnail-slider {
    display: flex;
    gap: 10px;
    overflow-x: auto;
    padding: 10px 0;
    max-width: 100%;
    scrollbar-width: none;
}

.thumbnail-image {
    width: 80px;
    height: 80px;
    object-fit: cover;
    border: 2px solid #ddd;
    border-radius: 4px;
    flex-shrink: 0;
    cursor: pointer;
}

.thumbnail-image.active {
    border-color: #f19a31;
}

.gallery-nav {
    display: none;
}

.product-title {
    font-size: 1.5em;
    color: #333;
    margin-top: 0;
    margin-bottom: 0.5em;
}

.product-model {
    font-size: 1.3em;
    color: #555;
    margin-top: 0.1em;
    margin-bottom: 0.6em;
    font-weight: 600;
}

.product-short-description {
    font-size: 1em;
    color: #555;
    line-height: 1.6;
    margin-bottom: 0.8em;
    text-align: justify;
}

.product-meta {
    margin-bottom: 1em;
    font-size: 0.9em;
    color: #666;
}

.product-meta span {
    display: block;
    margin-bottom: 0.3em;
}

.product-meta strong {
    color: #444;
}

.product-certifications {
    margin-bottom: 1.5em;
    display: flex;
    gap: 8px;
}

.product-certifications img {
    height: 30px;
    vertical-align: middle;
}

.product-actions-container {
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 1.0em;
}

.product-share-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 10px 15px;
    color: white !important;
    text-decoration: none;
    border-radius: 5px;
    font-weight: 500;
    text-align: center;
    min-width: 220px;
    box-sizing: border-box;
    width: auto;
    max-width: 320px;
    cursor: pointer;
    border: none;
    font-size: 1em;
    transition: opacity 0.2s ease, transform 0.15s ease;
}

.product-share-button:hover {
    opacity: 0.9;
    transform: translateY(-1px);
}

.product-share-email {
    background-color: #f19a31;
}

.product-share-whatsapp {
    background-color: #25D366;
}

.product-share-generic {
    background-color: #555;
}

/* PRODUCT TABS */
.product-tabs-container {
    width: 100%;
    align-self: center;
}

.tab-buttons {
    display: flex;
    border-bottom: 1px solid #ddd;
    margin-bottom: 20px;
}

.tab-button {
    padding: 12px 20px;
    background-color: transparent;
    border: none;
    font-size: 1em;
    font-weight: 600;
    color: #555;
    position: relative;
    cursor: pointer;
}

.tab-button.active {
    color: #f19a31;
    font-weight: 700;
    font-size: 1.1em;
}

.tab-button.active::after {
    content: '';
    position: absolute;
    bottom: -1px;
    left: 0;
    width: 100%;
    height: 3px;
    background-color: #f19a31;
}

.tab-panel {
    display: none;
    padding: 15px 0;
    line-height: 1.7;
    color: #444;
    text-align: justify;
}

.tab-panel.active {
    display: block;
}

.tab-panel h3 {
    margin-top: 0;
    font-size: 1.3em;
    color: #333;
}

.tab-panel table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 1em;
}

.tab-panel th,
.tab-panel td {
    border: 1px solid #ddd;
    padding: 8px 12px;
    text-align: left;
}

/* PRODUCT DETAIL RESPONSIVE */
@media (max-width: 1050px) {
    .product-detail-section {
        flex-direction: column;
        align-items: center;
    }

    .product-main-content-flex-container {
        flex-direction: column;
        align-items: center;
        justify-content: center;
        max-width: 100%;
        width: 100%;
        margin-top: 10px;
    }

    .product-image-gallery,
    .product-info-column {
        flex-basis: auto;
        width: 100%;
        max-width: 100%;
        padding: 0.5em 1em;
    }

    .product-tabs-container {
        flex-basis: auto;
        width: 100%;
        max-width: 100%;
        padding: 0.5em 1em;
    }

    #main-product-image {
        width: 80%;
        max-width: 100%;
        height: 300px;
        aspect-ratio: 1 / 1;
    }

    .product-title {
        font-size: 1.4em;
    }

    .tab-buttons {
        flex-wrap: wrap;
    }

    .tab-button {
        padding: 10px 15px;
        font-size: 0.9em;
    }

    .product-actions-container {
        align-items: center;
        justify-content: center;
    }

    .product-share-button {
        min-width: 0;
        width: 100%;
        max-width: 320px;
    }
}

@media (max-width: 550px) {
    .tab-buttons {
        flex-direction: column;
        border-bottom: 2px solid #ddd;
        padding-bottom: 1rem;
        margin-bottom: 2rem;
        justify-content: space-around;
        gap: 15px;
    }

    .tab-button.active {
        font-size: 1.0em;
    }

    .tab-button.active::after {
        width: 50%;
        transform: translateX(50%);
    }

    #main-product-image {
        width: 70%;
        height: auto;
    }

    .product-share-button {
        max-width: 100%;
    }
}

@media (max-width: 480px) {
    .tab-panel h3 {
        font-size: 1.2em;
    }

    .tab-panel table {
        font-size: 12px;
    }

    .thumbnail-image {
        width: 60px;
        height: 60px;
    }

    .product-share-button {
        font-size: 0.9em;
        padding: 8px 12px;
    }
}

/* 404 ERROR PAGE */
.error-page-container {
    text-align: center;
    padding: 4rem 1rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: calc(100vh - 400px);
}

.error-page-container h1 {
    font-size: 6rem;
    font-weight: 700;
    color: #f19a31;
    margin: 0;
    line-height: 1;
}

.error-page-container h2 {
    font-size: 1.8rem;
    margin-top: 0.5rem;
    color: #333;
}

.error-page-container p {
    max-width: 500px;
    margin-top: 1rem;
    margin-bottom: 2rem;
    font-size: 1.1rem;
    color: #555;
}

.error-page-container .btn {
    width: auto;
    padding: 12px 25px;
    font-size: 1rem;
}

/* ==========================================================================
   Soditec Developer Modal Styles
   ========================================================================== */
.soditec-modal-overlay {
    display: none;
    position: fixed;
    z-index: 10000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.7);
    backdrop-filter: blur(5px);
    justify-content: center;
    align-items: center;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.soditec-modal-overlay.active {
    display: flex;
    opacity: 1;
}

.soditec-modal-content {
    background: linear-gradient(145deg, #1e1e1e, #121212);
    border: 1px solid #333;
    border-radius: 12px;
    width: 90%;
    max-width: 450px;
    position: relative;
    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.5);
    transform: translateY(20px);
    transition: transform 0.3s ease;
    overflow: hidden;
    font-family: 'Inter', sans-serif;
}

.soditec-modal-overlay.active .soditec-modal-content {
    transform: translateY(0);
}

.soditec-modal-close {
    position: absolute;
    top: 20px;
    right: 15px;
    color: #888;
    font-size: 28px;
    font-weight: bold;
    cursor: pointer;
    transition: color 0.2s ease;
    z-index: 10;
}

.soditec-modal-close:hover {
    color: #f19a31;
}

.soditec-modal-header {
    padding: 30px 20px 20px;
    text-align: center;
    border-bottom: 1px solid #2a2a2a;
    background: rgba(255, 255, 255, 0.02);
}

.soditec-header-icon {
    font-size: 36px;
    color: #f19a31;
    margin-bottom: 15px;
}

.soditec-modal-title {
    color: #fff;
    font-size: 1.4rem;
    margin: 0 0 5px 0;
    font-weight: 600;
}

.soditec-highlight {
    color: #f19a31;
}

.soditec-modal-subtitle {
    color: #aaa;
    font-size: 0.9rem;
    margin: 0;
}

.soditec-modal-body {
    padding: 25px 30px;
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.soditec-contact-card {
    display: flex;
    align-items: center;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid #333;
    border-radius: 8px;
    padding: 15px;
    text-decoration: none;
    transition: all 0.3s ease;
}

.soditec-contact-card:hover {
    background: rgba(241, 154, 49, 0.1);
    border-color: #f19a31;
    transform: translateY(-2px);
}

.soditec-icon-container {
    width: 45px;
    height: 45px;
    border-radius: 50%;
    background: rgba(241, 154, 49, 0.15);
    display: flex;
    justify-content: center;
    align-items: center;
    margin-right: 15px;
}

.soditec-icon {
    color: #f19a31;
    font-size: 20px;
}

.soditec-contact-details {
    display: flex;
    flex-direction: column;
}

.soditec-contact-label {
    color: #888;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 3px;
}

.soditec-contact-value {
    color: #fff;
    font-size: 1rem;
    font-weight: 500;
}

.soditec-contact-card:hover .soditec-contact-value {
    color: #f19a31;
}

.soditec-modal-footer {
    padding: 15px;
    text-align: center;
    background: #111;
    border-top: 1px solid #2a2a2a;
}

.soditec-modal-footer p {
    color: #666;
    font-size: 0.8rem;
    margin: 0;
}

/* Soditec Modal Responsive Styles */
@media (max-width: 480px) {
    .soditec-modal-content {
        width: 95%;
        margin: 0 auto;
    }

    .soditec-modal-header {
        padding: 20px 15px 15px;
    }

    .soditec-header-icon {
        font-size: 28px;
        margin-bottom: 10px;
    }

    .soditec-modal-title {
        font-size: 1.2rem;
    }

    .soditec-modal-body {
        padding: 15px 20px;
        gap: 12px;
    }

    .soditec-contact-card {
        padding: 12px;
    }

    .soditec-icon-container {
        width: 38px;
        height: 38px;
        margin-right: 12px;
    }

    .soditec-icon {
        font-size: 16px;
    }

    .soditec-contact-value {
        font-size: 0.95rem;
    }
}

@media (max-width: 350px) {
    .soditec-modal-body {
        padding: 12px 15px;
        gap: 10px;
    }

    .soditec-contact-card {
        padding: 10px;
    }

    .soditec-icon-container {
        width: 32px;
        height: 32px;
        margin-right: 10px;
    }

    .soditec-icon {
        font-size: 14px;
    }

    .soditec-contact-label {
        font-size: 0.7rem;
    }

    .soditec-contact-value {
        font-size: 0.85rem;
        word-break: break-word;
        /* Prevents long emails from overlapping */
    }

    .soditec-modal-footer {
        padding: 10px;
    }

    .soditec-modal-footer p {
        font-size: 0.75rem;
    }
}


.arrow {
    display: inline-block;
    width: 1em;
    /* reserva el espacio aunque la fuente no cargó */
    height: 1em;
    vertical-align: middle;
    margin-left: 4px;
}

/* Evitar que el nav se mueva mientras cargan los íconos */
@media (min-width: 1051px) {
    #nav-menu li a {
        display: flex;
        align-items: center;
        gap: 4px;
        white-space: normal;
    }
}

@media (max-width: 1050px) {
    #nav-menu li a {
        display: flex;
        gap: 4px;
        white-space: normal;
        justify-content: flex-start;
        align-items: center;
        flex-direction: row;
    }
}

@media (max-width: 325px) {
    .categoria-item.is-flipped {
        min-height: 480px !important;
    }

    .categoria-item-back {
        gap: 0px !important;
    }
}

.fa,
.fab,
.fad,
.fal,
.far,
.fas {
    line-height: 1;
}
/* ── Autocomplete: agrupación por tipo (categorías / subcategorías / productos) ── */
.floating-search-group-title {
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: #999;
    padding: 10px 15px 6px 15px;
    border-top: 1px solid rgba(0,0,0,.05);
    background: rgba(0,0,0,.02);
}
.floating-search-group-title:first-child {
    border-top: none;
}
.floating-search-cat-icon {
    width: 38px;
    height: 38px;
    min-width: 38px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(241,154,49,0.12);
    color: #f19a31;
    border-radius: 8px;
    font-size: 16px;
    margin-right: 10px;
}
.floating-search-cat .product-name {
    font-weight: 600;
}

/* ═══════════════════════════════════════════════════════════════════════
   MOBILE MENU PREMIUM
   Look elevado: gradiente sutil, accent bar naranja, ítems con icono e
   indicador lateral, animaciones suaves, footer de contacto. Solo activo
   ≤1050px (tablet/mobile). NO toca lógica JS ni rompe la búsqueda interna.
   Cumple guías UX: touch ≥44px, transición 200ms, transform/opacity.
   ═══════════════════════════════════════════════════════════════════════ */
@media (max-width: 1050px) {

    /* ─── Off-canvas container ────────────────────────────────────────── */
    #nav-menu {
        background: linear-gradient(180deg, #ffffff 0%, #fafafa 100%);
        box-shadow: 8px 0 32px -8px rgba(15, 23, 42, 0.18),
                    2px 0 0 rgba(241, 154, 49, 0.08);
        border-top-right-radius: 14px;
        border-bottom-right-radius: 14px;
        /* Top accent bar de marca */
        border-top: 3px solid #f19a31;
        padding: 0;
    }

    /* Subtle inner glow al borde derecho del panel */
    #nav-menu::after {
        content: '';
        position: absolute;
        inset: 0 0 0 auto;
        width: 1px;
        background: linear-gradient(180deg,
            rgba(241, 154, 49, 0.35) 0%,
            rgba(241, 154, 49, 0)  20%,
            rgba(241, 154, 49, 0)  80%,
            rgba(241, 154, 49, 0.35) 100%);
        pointer-events: none;
    }

    /* ─── Buscador integrado: tarjeta elevada al top ──────────────────── */
    #nav-menu.search-mode-active .class_floating-search-container {
        background: linear-gradient(180deg, #fff8ef 0%, #ffffff 100%);
        border-top: none;
        border-bottom: 1px solid rgba(241, 154, 49, 0.18);
        padding: 14px 14px 16px;
    }
    #nav-menu .floating-search-box {
        background: #ffffff;
        border: 1px solid rgba(241, 154, 49, 0.35);
        border-radius: 10px;
        box-shadow: 0 2px 8px rgba(15, 23, 42, 0.06),
                    inset 0 0 0 1px rgba(255, 255, 255, 0.5);
        transition: border-color 200ms ease, box-shadow 200ms ease;
    }
    #nav-menu .floating-search-box:focus-within {
        border-color: #f19a31;
        box-shadow: 0 0 0 3px rgba(241, 154, 49, 0.18),
                    0 4px 12px rgba(241, 154, 49, 0.12);
    }
    #nav-menu .floating-search-box input {
        color: #1e293b;
    }
    #nav-menu .floating-search-box input::placeholder {
        color: #94a3b8;
    }

    /* ─── Items del menú: icono + texto + chevron, alineación elegante ─ */
    #nav-menu > li.nav-item {
        position: relative;
        width: 100%;
        left: 0;
        opacity: 0;
        transform: translateX(-8px);
        animation: navItemFadeIn 320ms ease forwards;
    }
    /* Stagger animation: cada item entra desplazado en el tiempo */
    #nav-menu.active > li.nav-item:nth-of-type(1) { animation-delay:  60ms; }
    #nav-menu.active > li.nav-item:nth-of-type(2) { animation-delay: 100ms; }
    #nav-menu.active > li.nav-item:nth-of-type(3) { animation-delay: 140ms; }
    #nav-menu.active > li.nav-item:nth-of-type(4) { animation-delay: 180ms; }
    #nav-menu.active > li.nav-item:nth-of-type(5) { animation-delay: 220ms; }
    #nav-menu.active > li.nav-item:nth-of-type(6) { animation-delay: 260ms; }

    @keyframes navItemFadeIn {
        from { opacity: 0; transform: translateX(-8px); }
        to   { opacity: 1; transform: translateX(0); }
    }

    /* Reset: el width: 101% / 102% del CSS original distorsiona */
    #nav-menu li a,
    #nav-menu li > div {
        position: relative;
        width: 100%;
        padding: 14px 18px 14px 56px; /* min 44px de alto + space para icono */
        min-height: 52px;
        display: flex;
        align-items: center;
        text-align: left;
        font-size: 14.5px;
        font-weight: 600;
        letter-spacing: 0.06em;
        color: #1e293b;
        border-bottom: 1px solid rgba(15, 23, 42, 0.06);
        transition: background-color 200ms ease, color 200ms ease, padding-left 200ms ease;
    }

    /* Indicator bar naranja a la izquierda (oculto por default) */
    #nav-menu li a::before,
    #nav-menu li > div::before {
        content: '';
        position: absolute;
        left: 0;
        top: 8px;
        bottom: 8px;
        width: 3px;
        background: #f19a31;
        border-radius: 0 3px 3px 0;
        transform: scaleY(0);
        transform-origin: center;
        transition: transform 200ms ease;
    }

    /* Iconos FontAwesome por tipo de item — usados como pseudo-elemento */
    #nav-menu .nav-item > a::after,
    #nav-menu .nav-item > div::after {
        font-family: "Font Awesome 5 Free", "FontAwesome";
        font-weight: 900;
        position: absolute;
        left: 22px;
        top: 50%;
        transform: translateY(-50%);
        font-size: 15px;
        color: #f19a31;
        opacity: 0.7;
        transition: opacity 200ms ease, transform 200ms ease;
        width: 18px;
        text-align: center;
    }
    #nav-menu .nav-item--home    > a::after { content: "\f015"; } /* home */
    #nav-menu .nav-item--about   > a::after { content: "\f1ad"; } /* building */
    #nav-menu .nav-item--products > a::after { content: "\f466"; } /* box */
    #nav-menu .nav-item--news    > a::after { content: "\f1ea"; } /* newspaper */
    #nav-menu .nav-item--contact > a::after { content: "\f0e0"; } /* envelope */

    /* Hover/tap state — premium con barra lateral. Sin alterar padding ni
       transform del icono para evitar shifts visuales. */
    #nav-menu li a:hover,
    #nav-menu li a:focus-visible,
    #nav-menu li > div:hover {
        background: linear-gradient(90deg,
            rgba(241, 154, 49, 0.10) 0%,
            rgba(241, 154, 49, 0.04) 80%,
            transparent 100%);
        color: #c2680a;
        width: 100%;          /* anula el 102% del CSS original */
        outline: none;
    }
    #nav-menu li a:hover::before,
    #nav-menu li a:focus-visible::before,
    #nav-menu li > div:hover::before {
        transform: scaleY(1);
    }
    /* Icono solo cambia opacity al hover — sin scale ni movimiento */
    #nav-menu li a:hover::after,
    #nav-menu li > div:hover::after {
        opacity: 1;
    }

    #nav-menu > li > a.active-tap {
        background: linear-gradient(90deg, #f19a31 0%, #ff8a00 100%) !important;
        color: #fff !important;
        transform: scale(0.985);
    }
    #nav-menu > li > a.active-tap::before { background: #fff; transform: scaleY(1); }
    #nav-menu > li > a.active-tap::after { color: #fff; opacity: 1; }

    /* Chevron del dropdown PRODUCTOS — pill premium con background sutil */
    #nav-menu .dropdown > a .arrow {
        margin-left: auto;
        flex-shrink: 0;
        width: 28px;
        height: 28px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        font-size: 12px;
        color: #f19a31;
        background: rgba(241, 154, 49, 0.10);
        border: 1px solid rgba(241, 154, 49, 0.22);
        border-radius: 50%;
        transition: transform 280ms cubic-bezier(0.4, 0, 0.2, 1),
                    background 200ms ease,
                    border-color 200ms ease,
                    color 200ms ease;
    }
    #nav-menu .dropdown > a:hover .arrow {
        background: rgba(241, 154, 49, 0.18);
        border-color: rgba(241, 154, 49, 0.4);
    }
    #nav-menu .dropdown.active > a .arrow {
        transform: rotate(180deg);
        background: #f19a31;
        border-color: #f19a31;
        color: #fff;
        box-shadow: 0 2px 8px rgba(241, 154, 49, 0.35);
    }

    /* ─── Dropdown menu (categorías de productos) ─────────────────────── */
    #nav-menu .dropdown-menu {
        background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
        border-left: 3px solid rgba(241, 154, 49, 0.4);
        margin-left: 0;
        padding: 4px 0;
        /* Los items del dropdown no tienen íconos → stretch ocupa todo el ancho */
        justify-items: stretch;
        min-width: 100%;
    }
    #nav-menu .dropdown-menu li {
        width: 100%;
    }
    #nav-menu .dropdown-menu li a {
        /* Sin padding-left de 56px: no hay íconos en los sub-items */
        padding: 10px 14px 10px 14px;
        min-height: 44px;
        font-size: 13px;
        font-weight: 500;
        letter-spacing: 0.04em;
        color: #475569;
        border-bottom: 1px solid rgba(15, 23, 42, 0.04);
        width: 100%;
        box-sizing: border-box;
        white-space: normal;
        word-break: break-word;
        overflow-wrap: break-word;
    }
    #nav-menu .dropdown-menu li a::after { display: none; } /* sin icono en sub-items */
    #nav-menu .dropdown-menu li a:hover {
        background: rgba(241, 154, 49, 0.08);
        color: #c2680a;
        padding-left: 18px; /* indent sutil en hover, sin cambiar altura ni causar shift */
    }

    /* ─── Logo dentro del menú móvil (cuando se mueve al body) ────────── */
    #nav-menu > a.logo-in-mobile-nav {
        padding: 16px 18px;
        margin: 0;
        background: linear-gradient(180deg, #ffffff 0%, #fafafa 100%);
        border-bottom: 1px solid rgba(15, 23, 42, 0.08);
    }

    /* ─── Respeta prefers-reduced-motion ──────────────────────────────── */
    @media (prefers-reduced-motion: reduce) {
        #nav-menu > li.nav-item {
            opacity: 1;
            transform: none;
            animation: none;
        }
        #nav-menu li a,
        #nav-menu li > div {
            transition: background-color 1ms, color 1ms;
        }
    }
}

/* ─── Mobile menu overlay con backdrop blur premium ──────────────────── */
@media (max-width: 1050px) {
    #mobile-menu-overlay,
    .mobile-menu-overlay {
        backdrop-filter: blur(4px) saturate(0.85);
        -webkit-backdrop-filter: blur(4px) saturate(0.85);
        background: rgba(15, 23, 42, 0.5);
    }
}

/* ═══════════════════════════════════════════════════════════════════════
   ALTURA REDUCIDA — viewport vertical chico (laptops 1366×768, 1440×760,
   2560×760, ventanas reducidas, monitores ultrawide, split-screen, etc.).
   Aplica SIN importar el ancho. Empieza a partir de altura ≤770px para
   captar laptops modernas con barra de tareas visible (~745-768 útiles).
   Reduce paddings, alturas de hero y tipografía para que el contenido
   crítico entre en pantalla sin overlap entre secciones.
   ═══════════════════════════════════════════════════════════════════════ */
@media (max-height: 770px) and (min-width: 481px) {

    /* ─── Header más compacto ─────────────────────────────────────────── */
    /* Reduce el padding vertical SIN tocar el horizontal — sin esto, el
       nav quedaba pegado a los bordes en mobile portrait (caso reportado). */
    .header { padding: 4px 1rem; }
    .header nav { height: 50px; }

    /* ─── Slogan más fino ─────────────────────────────────────────────── */
    .slogan {
        padding: 0.5rem 0.8rem;
        font-size: 0.78rem;
        letter-spacing: 1px;
    }

    /* ─── Hero del home: menos alto, menos padding, h1 con clamp más
       agresivo para evitar overlap con la siguiente sección en altura chica. */
    .b2b-hero-intro {
        /* -230px (no -130px): descuenta header compacto + slogan + tarjeta de
           contacto para que la caja entre completa en 768px y el contenido
           centrado quede a la vista, sin hueco muerto arriba. */
        min-height: calc(100dvh - 230px);
        padding: 0.5rem 1rem 0;
        margin-bottom: 1.1rem;
    }
    .b2b-hero-container {
        min-height: 300px;
        padding: 2rem 1.5rem;
    }
    .b2b-hero-content h1 {
        /* Sube de 35px a ~51px: el título llena la caja (hace wrap a 2 líneas
           como en 1920px) en vez de quedar chico flotando en el centro. */
        font-size: clamp(2.4rem, 3.8vw, 3.2rem);
        margin-bottom: 1.25rem;
        line-height: 1.15;
    }
    .b2b-hero-content h2 {
        font-size: clamp(1rem, 1.8vw, 1.3rem);
        margin-bottom: 0.6rem;
    }
    .b2b-hero-content p {
        font-size: 1.05rem;
        max-width: 640px;
        line-height: 1.55;
    }
    .b2b-features.rotator-wrapper {
        height: 70px;
        margin-top: 1.6rem;
        padding-top: 1.6rem; /* separa la píldora de la línea divisoria */
    }
    .hero-cta-container { margin-top: 2rem; }

    /* ─── Categorías grid: gap más chico, márgenes reducidos ─────────── */
    .categoria-grid {
        gap: 25px;
        margin-top: 10px;
    }
    #categorias-titulo { font-size: 1.5rem; margin-bottom: 0.5rem; }
    .categorias-subtitulo { font-size: 0.88rem; margin-bottom: 1rem; }

    /* ─── Sidebar filtros (categoría): más alto disponible ───────────── */
    .product-filters-sidebar {
        max-height: calc(100vh - 70px);
        top: 80px;
        padding: 1.2rem;
    }

    /* ─── Footer más compacto ─────────────────────────────────────────── */
    .footer {
        padding-top: 1.5rem;
        padding-bottom: 1rem;
    }

    /* ─── Floating buttons más cerca del borde ───────────────────────── */
    .float-buttons { bottom: 15px; }

    /* ─── Modales (wishlist, quote-cart, lightbox): respetar altura ──── */
    .wishlist-panel,
    .quote-cart-panel { box-shadow: -4px 0 16px rgba(0,0,0,0.15); }
    .wishlist-header,
    .quote-cart-header { padding: 12px 18px; }
    .wishlist-footer,
    .quote-cart-footer { padding: 12px 18px; }
}

/* Refinamiento intermedio para alturas 700-740px — laptops con barra de tareas */
@media (max-height: 700px) and (min-width: 481px) {
    .b2b-hero-intro {
        min-height: calc(100dvh - 130px);
        margin-bottom: 1rem;
        padding: 0.4rem 1rem 0;
    }
    .b2b-hero-container {
        min-height: 280px;
        padding: 1rem 1.3rem;
    }
    .b2b-hero-content h1 {
        font-size: clamp(1.5rem, 3.6vw, 2.3rem);
        margin-bottom: 0.65rem;
    }
    .b2b-hero-content h2 {
        font-size: clamp(0.8rem, 1.6vw, 0.98rem);
        margin-bottom: 0.4rem;
    }
    .b2b-hero-content p { font-size: 0.86rem; }
    .b2b-features.rotator-wrapper { height: 48px; margin-top: 0.85rem; }
    .hero-cta-container { margin-top: 1.15rem; }

    .categoria-grid { gap: 18px; margin-top: 8px; }
    #categorias-titulo { font-size: 1.35rem; margin-bottom: 0.4rem; }
    .categorias-subtitulo { font-size: 0.84rem; margin-bottom: 0.8rem; }

    .header nav { height: 48px; }
    .slogan { padding: 0.45rem 0.7rem; font-size: 0.75rem; }

    /* Sidebar filtros más útil */
    .product-filters-sidebar {
        max-height: calc(100dvh - 60px);
        top: 70px;
        padding: 1rem 1.1rem;
    }
}

/* Refinamiento extra para alturas MUY chicas (<640px) — modo "minimal" */
@media (max-height: 640px) and (min-width: 481px) {
    .b2b-hero-intro {
        min-height: auto;
        margin-bottom: 1rem;
    }
    .b2b-hero-container { min-height: 240px; padding: 0.9rem 1.1rem; }
    .b2b-hero-content h1 { font-size: clamp(1.3rem, 3.2vw, 1.85rem); margin-bottom: 0.55rem; }
    .b2b-features.rotator-wrapper { height: 42px; margin-top: 0.7rem; }
    .hero-cta-container { margin-top: 0.9rem; }
    .slogan { padding: 0.4rem 0.6rem; font-size: 0.72rem; }
    .header nav { height: 44px; }
}

/* Modo ultra-compacto para alturas <600px (split-screen, ventanas mitad) */
@media (max-height: 600px) and (min-width: 481px) {
    .header { padding: 2px 1rem; }
    .header nav { height: 40px; }
    .slogan { padding: 0.3rem 0.5rem; font-size: 0.68rem; letter-spacing: 0.5px; }

    .b2b-hero-intro {
        min-height: auto;
        padding: 0.3rem 0.8rem 0;
        margin-bottom: 0.75rem;
    }
    .b2b-hero-container { min-height: 200px; padding: 0.75rem 1rem; }
    .b2b-hero-content h1 {
        font-size: clamp(1.15rem, 2.8vw, 1.65rem);
        margin-bottom: 0.45rem;
    }
    .b2b-hero-content h2 {
        font-size: clamp(0.72rem, 1.4vw, 0.88rem);
        margin-bottom: 0.3rem;
    }
    .b2b-hero-content p { font-size: 0.78rem; }
    .b2b-features.rotator-wrapper { height: 36px; margin-top: 0.5rem; }
    .hero-cta-container { margin-top: 0.7rem; }
    .footer { padding-top: 1rem; padding-bottom: 0.7rem; }
    .float-buttons { bottom: 10px; }
}

/* ═══════════════════════════════════════════════════════════════════════
   ALTURA-DESKTOP-CORTO: altura ≤ 760px en CUALQUIER ancho.
   Cubre 1366×768, 1440×760, 1920×720, 2560×760 (laptops 14"-15" y 4K),
   monitores ultrawide, split-screen vertical. Aquí el hero fluye con su
   contenido (sin min-height forzado por viewport) para evitar overlap
   con la siguiente sección, y la tipografía se comprime más fuerte.
   ═══════════════════════════════════════════════════════════════════════ */
@media (max-height: 760px) and (min-width: 481px) {
    /* Hero: fluye con su contenido — sin min-height, evita overlap (solo pantallas anchas/landscape) */
    .b2b-hero-intro {
        min-height: auto !important;
        padding: 0.3rem 1rem 0 !important;
        margin-bottom: 0.7rem !important;
    }
    .b2b-hero-container {
        min-height: 200px !important;
        padding: 0.7rem 1.1rem !important;
    }
    /* H1 reducido al máximo — prioriza el rotator hero__highlight visible */
    .b2b-hero-content h1 {
        font-size: clamp(1rem, 1.6vw, 1.3rem) !important;
        margin: 0 0 0.35rem !important;
        line-height: 1.1 !important;
        letter-spacing: 0 !important;
        font-weight: 500 !important;
    }
    .b2b-hero-content h1 strong { font-weight: 700; }
    .b2b-hero-content h2 {
        font-size: clamp(0.78rem, 1.2vw, 0.92rem) !important;
        margin: 0 0 0.25rem !important;
    }
    .b2b-hero-content p {
        font-size: 0.78rem !important;
        max-width: 540px;
        line-height: 1.4 !important;
        margin: 0 auto 0.4rem !important;
    }
    /* Rotator: altura garantizada para que SIEMPRE sea visible */
    .b2b-features.rotator-wrapper {
        height: 48px !important;
        margin-top: 0.5rem !important;
        border-top: none !important;
        padding-top: 0 !important;
    }
    .b2b-features .rotator-item {
        font-size: 0.82rem !important;
        padding: 6px 14px !important;
    }
    .hero-cta-container { margin-top: 0.6rem !important; }
    .b2b-badge {
        margin-bottom: 0.5rem !important;
        padding: 4px 12px !important;
        font-size: 0.7rem !important;
    }

    /* Categorías más compactas */
    .categoria-grid {
        grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
        gap: 22px;
        margin-top: 12px;
        margin-left: 20px;
        margin-right: 20px;
    }
    #categorias-titulo { font-size: 1.45rem; margin-bottom: 0.55rem; }
    .categorias-subtitulo { font-size: 0.88rem; margin-bottom: 1rem; }

    .product-filters-sidebar {
        max-height: calc(100dvh - 80px);
        top: 80px;
    }

    .footer { padding-top: 1.3rem; padding-bottom: 0.85rem; }
}

/* ── Productos Destacados (home slider) ── */
#productos-destacados {
    padding: 5rem 1rem;
    margin: 0 auto;
    text-align: center;
    background-color: transparent;
    overflow: hidden;
    position: relative;
    width: 100%;
}
#productos-destacados-titulo {
    font-size: 2.2rem;
    font-weight: 800;
    color: #1e293b;
    margin-bottom: 1.5rem;
}
/* ── Productos Destacados Swiper — mismo estilo que Nuevos Productos ── */
.productos-destacados-swiper {
    width: 100%;
    padding-top: 10px;
    padding-bottom: 50px;
}
.productos-destacados-swiper .swiper-slide {
    display: flex;
    justify-content: center;
    align-items: stretch;
    height: auto;
    box-sizing: border-box;
}
.productos-destacados-swiper .producto-item {
    width: 100%;
    max-width: 350px;
    min-height: 350px;
}
.productos-destacados-swiper .producto-item img {
    max-width: 80%;
    max-height: 200px;
    object-fit: contain;
    aspect-ratio: 1/1;
    margin: 0 auto 1rem auto;
}
.productos-destacados-swiper .producto-item h3 {
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    word-break: break-word;
}
.productos-destacados-swiper .producto-item p {
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    word-break: break-word;
    overflow-wrap: break-word;
}
.productos-destacados-swiper .producto-item .btn {
    padding: 10px 20px;
    border-radius: 10px;
    box-shadow: 0 4px 6px rgba(0,0,0,0.3);
    width: 90%;
    opacity: 95%;
    background-color: #2c3e50;
    color: #fff;
}
.productos-destacados-swiper .producto-item .btn:hover {
    background-color: #e67a00;
}
/* Flechas — mismo estilo que Nuevos Productos (tamaño reducido) */
.productos-destacados-swiper .swiper-button-next,
.productos-destacados-swiper .swiper-button-prev {
    color: #f19a31;
    background-color: rgba(255,255,255,0.7);
    border-radius: 50%;
    width: 38px;
    height: 38px;
    top: 50%;
    margin-top: 0;
    transform: translateY(-50%);
    padding: 0.35rem;
    border: 1px solid #ddd;
    --swiper-navigation-size: 0;
    box-shadow: 0 2px 6px rgba(0,0,0,0.2);
}
.productos-destacados-swiper .swiper-button-next svg,
.productos-destacados-swiper .swiper-button-prev svg { display: none !important; }
.productos-destacados-swiper .swiper-button-next::after,
.productos-destacados-swiper .swiper-button-prev::after {
    font-family: 'Font Awesome 5 Free' !important;
    font-weight: 900 !important;
    font-size: 17px;
    display: block !important;
}
.productos-destacados-swiper .swiper-button-next::after { content: '\f054' !important; }
.productos-destacados-swiper .swiper-button-prev::after { content: '\f053' !important; }
.productos-destacados-swiper .swiper-button-next:hover,
.productos-destacados-swiper .swiper-button-prev:hover {
    background-color: #f19a31;
    color: #fff;
    opacity: 1;
    transform: translateY(-50%) scale(1.1);
    box-shadow: 0 0 10px rgba(241,154,49,0.6);
    transition: all 0.3s ease;
}
/* Bullets — mismo estilo que Nuevos Productos */
.productos-destacados-swiper .swiper-pagination { bottom: 0px !important; }
.productos-destacados-swiper .swiper-pagination-bullet {
    background-color: #f19a31;
    opacity: 0.5;
    width: 14px;
    height: 14px;
    margin: 0 6px !important;
}
.productos-destacados-swiper .swiper-pagination-bullet-active {
    opacity: 1;
    background-color: #e07b00;
}
@media (max-width: 600px) {
    #productos-destacados { padding: 3rem 1rem; }
    #productos-destacados-titulo { font-size: 1.6rem; }
}

/* ── Fixes generales ────────────────────────────────────────── */

/* Botón "Vistos recientemente" — color visible + posición relativa para el badge */
.recently-float {
    background-color: #0891b2;
    position: relative;  /* ancla .recently-count (position:absolute) al botón, igual que .wishlist-float */
}
.recently-float:hover {
    background-color: #0e7490;
}

/* Hero: en móviles angostos y cortos, descontar header+slogan (~140px) de la
   altura para que la caja oscura ENTRE en el viewport. Si dejamos 100svh la caja
   queda más alta que el área visible (porque arriba hay header+slogan), se empuja
   hacia abajo y el contenido centrado queda bajo con un hueco muerto arriba. */
@media (max-height: 760px) and (min-width: 481px) {
    .b2b-hero-intro { min-height: auto !important; }
}
@media (max-height: 760px) and (max-width: 480px) {
    .b2b-hero-intro { min-height: calc(100svh - 140px) !important; }
}

/* CTA Home — sección entre SEO authority y Nuevos Productos */
.home-cta-section {
    background: linear-gradient(135deg, #0f172a 0%, #1e293b 60%, #0f172a 100%);
    padding: 4.5rem 2rem;
    text-align: center;
    position: relative;
    box-shadow: 0 -16px 32px -6px rgba(0,0,0,.18), 0 16px 32px -6px rgba(0,0,0,.18);
}
.home-cta-section h2 {
    color: #f1f5f9;
    font-size: 2.2rem;
    font-weight: 800;
    margin: 0 0 1rem;
    line-height: 1.25;
    letter-spacing: -.4px;
}
.home-cta-section p {
    color: #94a3b8;
    font-size: 1.05rem;
    line-height: 1.7;
    max-width: 660px;
    margin: 0 auto 2.25rem;
}
.home-cta-section .cta-buttons {
    display: flex;
    gap: 1rem;
    justify-content: center;
    flex-wrap: wrap;
}
.home-cta-section .btn {
    padding: 13px 28px;
    font-size: 1rem;
    font-weight: 600;
    background: #f19a31;
    color: #fff;
    border: 2px solid transparent;
    border-radius: 10px;
    text-decoration: none;
    transition: background .2s, transform .2s;
    min-width: 0;
}
.home-cta-section .btn:hover { background: #d98220; transform: translateY(-2px); }
.home-cta-section .btn-outline {
    background: transparent;
    border: 2px solid #f19a31;
    color: #f19a31;
}
.home-cta-section .btn-outline:hover {
    background: #f19a31;
    color: #fff;
}
@media (max-width: 480px) {
    .home-cta-section { padding: 3rem 1.25rem; }
    .home-cta-section h2 { font-size: 1.6rem; }
}

/* ── Swiper anti-parpadeo: oculta hasta que Swiper inicializa ──────────── */
.productos-destacados-swiper:not(.swiper-initialized),
.productos-nuevos-swiper:not(.swiper-initialized) {
    opacity: 0;
}
.productos-destacados-swiper,
.productos-nuevos-swiper {
    transition: opacity 0.35s ease;
}

/* ── Slogan: adaptar a 360px para que entre en una línea ─────────────── */
@media (max-width: 360px) {
    .slogan {
        font-size: 72%;
        letter-spacing: 0;
        padding: 0.5rem 0.3rem;
    }
}

/* ── Hero rotator: reducir más en 320px ─────────────────────────────── */
@media (max-width: 325px) {
    .b2b-features.rotator-wrapper {
        height: 50px;
        margin-top: 0.2rem;
    }
    .b2b-features .rotator-item {
        padding: 5px 8px;
        font-size: 0.65rem;
    }
}

/* ── Menú móvil: wrap y tamaño correcto en 360px / 320px ─────────────── */
/* IMPORTANTE: padding-left se mantiene en 50px para que los íconos FA     */
/* absolutamente posicionados (left: 22px) no se superpongan al texto.     */
@media (max-width: 360px) {
    #nav-menu li a,
    #nav-menu li div {
        font-size: 13px;
        padding: 0.9rem 1rem 0.9rem 50px;
        white-space: normal;
        word-break: break-word;
    }
    .dropdown-menu li a,
    .dropdown-menu li div {
        font-size: 12px;
        padding: 0.55rem 0.7rem;
        white-space: normal;
        word-break: break-word;
        overflow-wrap: break-word;
    }
}

/* ── productos-toggle: chevron estable al abrir submenu ──────────────── */
/* El ícono FA izquierdo (::after, position:absolute) tiene will-change     */
/* para que el scale(0.985) en active-tap no genere un stacking context     */
/* nuevo que desplace visualmente el ícono del texto "PRODUCTOS".           */
@media (max-width: 1050px) {
    #nav-menu li a::after,
    #nav-menu li div::after {
        will-change: opacity;  /* capa propia — evita recomposición al transformar padre */
    }
    #nav-menu .dropdown > a .arrow {
        flex-shrink: 0;
        position: relative;
        z-index: 2;  /* sobre el ::after para que nunca quede debajo */
    }
    /* Cuando el submenu abre, el chevron rota sobre su propio centro sin desplazar layout */
    #nav-menu .dropdown.active > a .arrow {
        transform-origin: center center;
    }
}

/* ── Slogan 320px: override final — después del bloque max-width:360px ── */
/* El bloque 360px está más arriba en el archivo y gana en cascade sobre    */
/* el viejo bloque 325px. Este override restaura el tamaño correcto.        */
@media (max-width: 325px) {
    .slogan {
        font-size: 55%;
        letter-spacing: 0;
        padding: 0.4rem 0.2rem;
    }
}

/* ── Hero b2b-content: mejorar espacio vertical en 360px y 320px ─────── */
/* En Moto G (420–460px) los márgenes del rotator wrapper se ven premium.  */
/* A 360px / 320px la compresión reduce demasiado el gap sobre el divisor   */
/* (border-top del rotator-wrapper) y el contenido queda aplastado.         */
/* Estos overrides restauran un margin-top digno + ajustan padding interno  */
/* del contenedor para que el h1, el párrafo y el rotator respiren.         */
@media (max-width: 360px) {
    .b2b-hero-container {
        padding: 0.65rem 1rem 1.1rem;
    }
    .b2b-hero-content h1 {
        font-size: clamp(1.7rem, 6.5vw, 2.1rem);
        margin-bottom: 0.9rem;
        line-height: 1.18;
    }
    .b2b-hero-content h2 {
        font-size: 0.85rem;
        margin-bottom: 0.6rem;
    }
    .b2b-hero-content p {
        font-size: 0.9rem;
        line-height: 1.55;
        margin-bottom: 0.7rem;
    }
    .b2b-features.rotator-wrapper {
        margin-top: 1.4rem;
        height: 56px;
        padding-top: 1.5rem; /* separa la píldora de la línea divisoria */
    }
    .hero-cta-container {
        margin-top: 1.4rem;
    }
}

@media (max-width: 325px) {
    .b2b-hero-container {
        padding: 0.5rem 0.85rem 1rem;
    }
    .b2b-hero-content h1 {
        font-size: clamp(1.5rem, 6vw, 1.9rem);
        margin-bottom: 0.8rem;
        line-height: 1.2;
    }
    .b2b-hero-content h2 {
        font-size: 0.8rem;
        margin-bottom: 0.55rem;
    }
    .b2b-hero-content p {
        font-size: 0.85rem;
        line-height: 1.5;
        margin-bottom: 0.6rem;
    }
    .b2b-features.rotator-wrapper {
        margin-top: 1.2rem;
        height: 54px;
        padding-top: 1.4rem; /* separa la píldora de la línea divisoria */
    }
    .b2b-features .rotator-item {
        font-size: 0.65rem;
        padding: 5px 8px;
    }
    .hero-cta-container {
        margin-top: 1.2rem;
    }
}
