/* ========================================
   NAVEGACIÓN PRINCIPAL
======================================== */
.duque-nav {
    display: flex;
    align-items: center;
}
.duque-menu {
    list-style: none;
    display: flex;
    gap: 24px;
    margin: 0;
    padding: 0;
    align-items: center;
}
.duque-menu > li { position: relative; }
.duque-menu > li > a {
    text-decoration: none;
    text-transform: uppercase;
    font-weight: 600;
    font-size: 12px;
    letter-spacing: 0.1em;
    color: #000;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 8px 0;
    transition: color 0.2s;
    font-family: 'Poppins', sans-serif;
}
.duque-menu > li > a:hover { color: #555; }
.nav-ofertas { color: #FF4500 !important; }

/* Mostrar todos - oculto en desktop */
.mostrar-todos { display: none; }

/* ========================================
   DROPDOWN VERTICAL
======================================== */
.dropdown-panel {
    display: none !important;
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    background: #fff;
    border: 1px solid #eaeaea;
    border-top: 2px solid #000;
    padding: 12px 0;
    min-width: 210px;
    z-index: 2000;
    box-shadow: 0 8px 24px rgba(0,0,0,0.08);
}
.has-dropdown:hover > .dropdown-panel {
    display: block !important;
}
.dropdown-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
}
.dropdown-list > li {
    position: relative;
    display: block;
    width: 100%;
}
.dropdown-list > li > a {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 20px;
    font-size: 13px;
    color: #333;
    text-decoration: none;
    font-family: 'Poppins', sans-serif;
    font-weight: 400;
    transition: background 0.15s, color 0.15s;
    white-space: nowrap;
}
.dropdown-list > li > a:hover {
    background: #f9f9f9;
    color: #000;
    font-weight: 600;
}
.dropdown-list > li > a svg {
    opacity: 0.4;
    flex-shrink: 0;
}
.dropdown-list > li:hover > a svg { opacity: 1; }

/* ========================================
   SUB-PANEL
======================================== */
.sub-panel {
    display: none !important;
    position: absolute;
    left: 100%;
    top: 0;
    background: #fff;
    border: 1px solid #eaeaea;
    border-left: 2px solid #000;
    padding: 8px 0;
    min-width: 160px;
    z-index: 2001;
    box-shadow: 4px 4px 16px rgba(0,0,0,0.06);
    list-style: none;
    margin: 0;
}
.has-sub:hover > .sub-panel {
    display: block !important;
}
.sub-panel li { display: block; }
.sub-panel li a {
    display: block;
    padding: 8px 20px;
    font-size: 13px;
    color: #333;
    text-decoration: none;
    font-family: 'Poppins', sans-serif;
    font-weight: 400;
    transition: background 0.15s, color 0.15s;
    white-space: nowrap;
}
.sub-panel li a:hover {
    background: #f9f9f9;
    color: #000;
    font-weight: 600;
}

/* ========================================
   MOBILE
======================================== */
@media (max-width: 768px) {
    /* Hamburguesa - quitar azul */
    .duque-menu-toggle {
        display: inline-flex;
        -webkit-tap-highlight-color: transparent;
        outline: none !important;
    }
    .duque-menu-toggle:focus,
    .duque-menu-toggle:active,
    .duque-menu-toggle:focus-visible {
        outline: none !important;
        box-shadow: none !important;
        background: transparent !important;
        color: #000 !important;
        -webkit-tap-highlight-color: transparent !important;
    }
    .duque-menu-toggle svg {
        color: #000 !important;
        stroke: #000 !important;
    }

    /* Nav */
    .duque-nav {
        display: none;
        position: absolute;
        top: 100%;
        left: 0;
        right: 0;
        background: #fff;
        border-bottom: 1px solid #eaeaea;
        padding: 0;
        z-index: 1500;
        box-shadow: 0 8px 16px rgba(0,0,0,0.06);
    }
    .duque-nav.open { display: block; }
    .duque-menu {
        flex-direction: column;
        gap: 0;
        align-items: stretch;
    }
    .duque-menu > li > a {
        padding: 14px 20px;
        display: flex;
        border-bottom: 1px solid #f5f5f5;
    }

    /* Dropdown: toggle con click, no hover */
    .has-dropdown:hover > .dropdown-panel {
        display: none !important;
    }
    .has-dropdown.active > .dropdown-panel {
        display: block !important;
    }
    .dropdown-panel {
        position: static !important;
        transform: none !important;
        border: none !important;
        border-top: 1px solid #f0f0f0 !important;
        box-shadow: none !important;
        padding: 0 !important;
        min-width: auto !important;
        background: #fafafa !important;
    }

    /* Mostrar "Mostrar todos" en mobile */
    .mostrar-todos {
        display: block !important;
    }
    .mostrar-todos a {
        font-weight: 600 !important;
        color: #000 !important;
        border-bottom: 1px solid #eee !important;
    }

    .dropdown-list > li > a {
        padding: 12px 32px;
    }

    /* Sub-panel mobile */
    .has-sub:hover > .sub-panel {
        display: none !important;
    }
    .has-sub.active > .sub-panel {
        display: block !important;
    }
    .sub-panel {
        position: static !important;
        border: none !important;
        border-top: 1px solid #eee !important;
        box-shadow: none !important;
        padding: 0 !important;
        min-width: auto !important;
        background: #f5f5f5 !important;
    }
    .sub-panel li a {
        padding: 10px 48px;
        font-size: 12px;
    }

    /* Quitar todo vestigio de azul en links */
    a, button, a:focus, a:active, button:focus, button:active {
        -webkit-tap-highlight-color: transparent !important;
    }
}

/* SCROLL EN MENÚ MOBILE */
@media (max-width: 768px) {
    .duque-nav.open {
        max-height: calc(100vh - 60px) !important;
        overflow-y: auto !important;
        -webkit-overflow-scrolling: touch !important;
    }
}

/* Mostrar todos en sub-panels mobile */
@media (max-width: 768px) {
    .sub-panel .mostrar-todos {
        display: block !important;
    }
    .sub-panel .mostrar-todos a {
        font-weight: 600 !important;
        color: #000 !important;
        border-bottom: 1px solid #ddd !important;
    }
    
    /* Sub-panel toggle con clase active */
    .has-sub > .sub-panel {
        display: none !important;
    }
    .has-sub.active > .sub-panel {
        display: block !important;
    }
    
    /* Flecha rota cuando está activo */
    .has-dropdown.active > a svg,
    .has-sub.active > a svg {
        transform: rotate(90deg);
    }
}
