/**
 * Abarandiaadia Core — Header global
 *
 * Breakpoints:
 *   Desktop ≥1024px
 *   Tablet  768-1023px
 *   Mobile  <768px
 *
 * Variables expuestas:
 *   --color-seccion : color contextual (lo inyecta el shortcode inline)
 *   --aaa-i         : índice del item de menú (cascada de animación)
 *
 * Convención de clases: .aaa-header-*
 */

/* ============================================================
 * 0. FONT FACES
 * Coloca los .woff2 en /assets/fonts/ con estos nombres:
 *   inter-regular.woff2
 *   inter-semibold.woff2
 *   inter-bold.woff2
 *
 * El proyecto usa Inter para TODO (UI y display). Playfair Display
 * fue retirado el 2026-05-15: tipografía única en todo el sitio.
 * ============================================================ */

/* Inter se carga desde Google Fonts vía wp_enqueue_style en header.php.
   No declaramos @font-face local — los .woff2 nunca llegaron al server. */

/* ============================================================
 * 1. CONTENEDOR RAÍZ + CSS VARIABLES
 * ============================================================ */

.aaa-header {
    --aaa-color-marca: #2F2722;
    --aaa-color-rojo: #E20E18;
    --aaa-color-texto: #3D3B3B;
    --aaa-color-fondo: #F7F7F7;
    --aaa-color-blanco: #FFFFFF;
    --aaa-color-borde: rgba(47, 39, 34, 0.08);

    --aaa-font-ui: 'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
    /* --aaa-font-display se mantiene por compatibilidad con el código
       que aún lo referencia, pero ahora apunta a Inter (la tipografía
       única del sitio). Playfair Display retirado el 2026-05-15. */
    --aaa-font-display: var(--aaa-font-ui);

    --aaa-easing: cubic-bezier(0.22, 0.61, 0.36, 1);
    --aaa-duration: 320ms;

    --aaa-z-header: 1000;
    --aaa-z-overlay: 1100;

    position: relative;
    /* Sin margin-bottom: se vería como gap visible bajo la barra
     * sticky al hacer scroll. El espacio respira con el contenido
     * se aplica como margin-top al siguiente elemento (ver bloque 12). */
    font-family: var(--aaa-font-ui);
    color: var(--aaa-color-texto);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}

.aaa-header *,
.aaa-header *::before,
.aaa-header *::after {
    box-sizing: border-box;
}

.aaa-header-container {
    width: 100%;
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 24px;
}

.aaa-header-visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
    border: 0;
}

/* ============================================================
 * 2. TOP BAR
 * ============================================================ */

.aaa-header-topbar {
    background-color: var(--aaa-color-marca);
    color: var(--aaa-color-blanco);
    text-align: center;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.02em;
    line-height: 1.2;
}

.aaa-header-topbar-link,
.aaa-header-topbar-text {
    display: block;
    padding: 8px 16px;
    color: inherit;
    text-decoration: none;
    transition: background-color var(--aaa-duration) var(--aaa-easing),
                color var(--aaa-duration) var(--aaa-easing);
}

.aaa-header-topbar-link:hover,
.aaa-header-topbar-link:focus-visible {
    background-color: var(--aaa-color-rojo);
    color: var(--aaa-color-blanco);
    text-decoration: none;
}

@media (max-width: 767px) {
    .aaa-header-topbar {
        font-size: 12px;
    }
    .aaa-header-topbar-link,
    .aaa-header-topbar-text {
        padding: 7px 12px;
    }
}

/* ============================================================
 * 3. HEADER PRINCIPAL (sticky con logo)
 * ============================================================ */

.aaa-header-main {
    position: relative;
    background-color: var(--aaa-color-blanco);
    border-bottom: 1px solid var(--aaa-color-borde);
}

/* La clase .is-scrolled la sigue añadiendo el JS al scroll > 10px.
 * Se usa abajo (bloque 12) para aplicar sombra a la barra sticky. */

.aaa-header-main .aaa-header-container {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: 16px;
    min-height: 88px;
    padding-top: 12px;
    padding-bottom: 12px;
}

/* --- Botón hamburguesa (☰) --- */
.aaa-header-toggle {
    justify-self: start;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    padding: 0;
    margin: 0;
    background: transparent;
    border: none;
    border-radius: 4px;
    color: var(--aaa-color-marca);
    cursor: pointer;
    transition: background-color 200ms var(--aaa-easing),
                color 200ms var(--aaa-easing);
}

.aaa-header-toggle:hover,
.aaa-header-toggle:focus-visible {
    background-color: transparent;
    color: var(--aaa-color-rojo);
}

.aaa-header-toggle-bars {
    position: relative;
    display: inline-block;
    width: 22px;
    height: 16px;
}

.aaa-header-toggle-bars span {
    position: absolute;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: currentColor;
    border-radius: 2px;
    transition: transform var(--aaa-duration) var(--aaa-easing),
                opacity var(--aaa-duration) var(--aaa-easing),
                top var(--aaa-duration) var(--aaa-easing);
}

.aaa-header-toggle-bars span:nth-child(1) { top: 0; }
.aaa-header-toggle-bars span:nth-child(2) { top: 7px; }
.aaa-header-toggle-bars span:nth-child(3) { top: 14px; }

/* Estado abierto: ☰ → ✕ */
.aaa-header-toggle[aria-expanded="true"] .aaa-header-toggle-bars span:nth-child(1) {
    top: 7px;
    transform: rotate(45deg);
}
.aaa-header-toggle[aria-expanded="true"] .aaa-header-toggle-bars span:nth-child(2) {
    opacity: 0;
}
.aaa-header-toggle[aria-expanded="true"] .aaa-header-toggle-bars span:nth-child(3) {
    top: 7px;
    transform: rotate(-45deg);
}

/* --- Logo --- */
.aaa-header-logo {
    justify-self: center;
    display: inline-flex;
    align-items: center;
    text-decoration: none;
    color: inherit;
    transition: opacity 200ms var(--aaa-easing);
}

.aaa-header-logo:hover,
.aaa-header-logo:focus-visible {
    opacity: 0.78;
    text-decoration: none;
}

.aaa-header-logo img {
    display: block;
    width: auto;
    max-width: 100%;
    max-height: 44px;
}

/* --- Botón búsqueda (lupa) --- */
.aaa-header-search-btn {
    justify-self: end;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    padding: 0;
    margin: 0;
    background: transparent;
    border: none;
    border-radius: 4px;
    color: var(--aaa-color-marca);
    cursor: pointer;
    transition: background-color 200ms var(--aaa-easing),
                color 200ms var(--aaa-easing);
}

.aaa-header-search-btn:hover,
.aaa-header-search-btn:focus-visible {
    background-color: transparent;
    color: var(--aaa-color-rojo);
}

.aaa-header-search-btn svg {
    width: 22px;
    height: 22px;
    fill: currentColor;
}

/* --- Responsive del header principal --- */
@media (max-width: 1023px) {
    .aaa-header-main .aaa-header-container {
        min-height: 76px;
    }
    .aaa-header-logo img { max-height: 38px; }
}

@media (max-width: 767px) {
    .aaa-header-main .aaa-header-container {
        min-height: 64px;
        padding: 8px 16px;
        gap: 8px;
    }
    .aaa-header-logo img { max-height: 30px; }
    .aaa-header-toggle,
    .aaa-header-search-btn {
        width: 44px;
        height: 44px;
    }
    .aaa-header-search-btn svg { width: 20px; height: 20px; }
}

/* En móviles muy estrechos, reservamos algo más de espacio horizontal */
@media (max-width: 380px) {
    .aaa-header-logo img { max-height: 26px; }
}

/* ============================================================
 * 4. LÍNEA DE COLOR CONTEXTUAL
 * ============================================================ */

.aaa-header-linea-seccion {
    background-color: var(--color-seccion, var(--aaa-color-marca));
    color: var(--aaa-color-blanco);
    transition: background-color 400ms var(--aaa-easing);
}

.aaa-header-linea-seccion .aaa-header-container {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px 24px;
    min-height: 36px;
    padding-top: 8px;
    padding-bottom: 8px;
}

/* Si la línea contextual lleva subnav, queda un poco más alta */
.aaa-header-linea-seccion.has-subnav .aaa-header-container {
    min-height: 44px;
    padding-top: 10px;
    padding-bottom: 10px;
}

/* Título contextual: <h1> con apariencia de etiqueta (no de heading H1
 * de tema). Selectores con doble clase + !important para ganar a los
 * estilos globales de h1 que aplica Elementor/Hello. */
.aaa-header .aaa-header-linea-seccion h1.aaa-header-seccion-nombre,
.aaa-header h1.aaa-header-seccion-nombre {
    font-family: var(--aaa-font-ui) !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    letter-spacing: 0.16em !important;
    text-transform: uppercase !important;
    color: var(--aaa-color-blanco) !important;
    line-height: 1.2 !important;
    margin: 0 !important;
    padding: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    text-shadow: none !important;
    background: none !important;
    border: none !important;
}

/* Subnav: enlaces a contenido relacionado (pueblos cercanos, etc.) */
.aaa-header .aaa-header-subnav {
    display: flex !important;
    flex-wrap: wrap;
    gap: 4px 14px;
    margin-left: auto;
    align-items: center;
}

.aaa-header .aaa-header-linea-seccion a.aaa-header-subnav-link,
.aaa-header a.aaa-header-subnav-link {
    font-family: var(--aaa-font-ui) !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    letter-spacing: 0.06em !important;
    text-transform: none !important;
    color: rgba(255, 255, 255, 0.78) !important;
    text-decoration: none !important;
    padding: 4px 2px !important;
    border-bottom: 1px solid transparent !important;
    background: none !important;
    line-height: 1.4 !important;
    transition: color 160ms var(--aaa-easing),
                border-color 160ms var(--aaa-easing);
}
.aaa-header .aaa-header-linea-seccion a.aaa-header-subnav-link:hover,
.aaa-header .aaa-header-linea-seccion a.aaa-header-subnav-link:focus-visible,
.aaa-header a.aaa-header-subnav-link:hover,
.aaa-header a.aaa-header-subnav-link:focus-visible {
    color: #FFFFFF !important;
    border-bottom-color: rgba(255, 255, 255, 0.6) !important;
    text-decoration: none !important;
}

@media (max-width: 767px) {
    .aaa-header-linea-seccion .aaa-header-container {
        min-height: 32px;
        padding: 6px 16px;
        gap: 6px 12px;
    }
    .aaa-header-linea-seccion.has-subnav .aaa-header-container {
        min-height: auto;
        padding-top: 10px;
        padding-bottom: 10px;
    }
    .aaa-header .aaa-header-linea-seccion h1.aaa-header-seccion-nombre,
    .aaa-header h1.aaa-header-seccion-nombre {
        font-size: 12px !important;
        letter-spacing: 0.14em !important;
    }
    /* En móvil la subnav pasa a una fila propia debajo (scroll horizontal) */
    .aaa-header-linea-seccion.has-subnav {
        flex-wrap: wrap;
    }
    .aaa-header .aaa-header-subnav {
        flex-basis: 100%;
        margin-left: 0;
        overflow-x: auto;
        flex-wrap: nowrap;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        padding-bottom: 2px;
    }
    .aaa-header .aaa-header-subnav::-webkit-scrollbar { display: none; }
    .aaa-header .aaa-header-linea-seccion a.aaa-header-subnav-link,
    .aaa-header a.aaa-header-subnav-link {
        font-size: 11.5px !important;
        white-space: nowrap;
        flex-shrink: 0;
    }
}

/* ============================================================
 * 4-bis. BARRA DE SECCIONES (solo en portada)
 *
 * Cada pestaña usa `--tab-color` inline para su fondo.
 * En desktop: pestañas tocándose, centradas, sin gap.
 * En móvil:   scroll horizontal con degradado en los bordes.
 * ============================================================ */

.aaa-header-secciones-bar {
    background-color: var(--aaa-color-marca);
    padding: 10px 16px;
    position: relative;
}

.aaa-header-secciones-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;
    gap: 8px;
    width: 100%;
    /* Scroll horizontal cuando no caben todas las etiquetas */
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: none;             /* Firefox */
    -ms-overflow-style: none;          /* IE/Edge antiguo */
    scroll-snap-type: x proximity;
    -webkit-overflow-scrolling: touch;
}

.aaa-header-secciones-list::-webkit-scrollbar {
    display: none;                     /* WebKit */
}

.aaa-header-seccion-tab {
    margin: 0;
    flex: 0 0 auto;
    scroll-snap-align: start;
}

.aaa-header-seccion-tab-link {
    --tab-pad-x: 6px;
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 4px var(--tab-pad-x) 6px;
    color: var(--aaa-color-blanco);
    font-family: var(--aaa-font-ui);
    font-size: 12.5px;
    font-weight: 700;
    letter-spacing: 0.12em;
    line-height: 1.2;
    text-transform: uppercase;
    text-decoration: none;
    white-space: nowrap;
    transition: opacity 200ms var(--aaa-easing);
}

/* Subrayado animado en hover (crece desde el centro) */
.aaa-header-seccion-tab-link::after {
    content: '';
    position: absolute;
    left: var(--tab-pad-x);
    right: var(--tab-pad-x);
    bottom: 1px;
    height: 2px;
    background-color: var(--aaa-color-blanco);
    transform: scaleX(0);
    transform-origin: center;
    transition: transform 240ms var(--aaa-easing);
}

.aaa-header-seccion-tab-link:hover::after,
.aaa-header-seccion-tab-link:focus-visible::after {
    transform: scaleX(1);
}

.aaa-header-seccion-tab-link:hover,
.aaa-header-seccion-tab-link:focus-visible {
    color: var(--aaa-color-blanco);
    text-decoration: none;
}

/* Anchor activo (resaltado por IntersectionObserver del JS de la landing) */
.aaa-header-seccion-tab-link.is-active::after {
    transform: scaleX(1);
}

/* Variante CTA destacada (ej. "CONTACTAR" en la landing).
 * Aplica solo cuando el item tiene la clase .is-cta. Pastilla roja. */
.aaa-header-secciones-bar .aaa-header-seccion-tab.is-cta {
    background-color: var(--aaa-color-rojo);
    border-radius: 4px;
    margin-left: 4px;
    transition: background-color 200ms var(--aaa-easing);
}
.aaa-header-secciones-bar .aaa-header-seccion-tab.is-cta:hover,
.aaa-header-secciones-bar .aaa-header-seccion-tab.is-cta:focus-within {
    background-color: #8F2A2A;
}
.aaa-header-secciones-bar .aaa-header-seccion-tab.is-cta .aaa-header-seccion-tab-link {
    --tab-pad-x: 14px;
    padding-left: 14px;
    padding-right: 14px;
}
.aaa-header-secciones-bar .aaa-header-seccion-tab.is-cta .aaa-header-seccion-tab-link::after {
    display: none;
}

/* Override del reset de Hello para los <a> dentro */
.aaa-header-secciones-bar a.aaa-header-seccion-tab-link {
    color: var(--aaa-color-blanco);
    text-decoration: none;
}

/* --- Responsive de la barra de secciones --- */
@media (max-width: 1023px) {
    .aaa-header-secciones-bar { padding: 9px 12px; }
    .aaa-header-secciones-list { gap: 6px; }
    .aaa-header-seccion-tab-link {
        --tab-pad-x: 6px;
        font-size: 12px;
        letter-spacing: 0.1em;
    }
}

@media (max-width: 767px) {
    .aaa-header-secciones-bar { padding: 8px 12px; }
    .aaa-header-secciones-list {
        justify-content: flex-start;
        gap: 6px;
    }
    .aaa-header-seccion-tab-link {
        --tab-pad-x: 4px;
        font-size: 11.5px;
        letter-spacing: 0.08em;
    }
    /* Degradado en los bordes para sugerir scroll horizontal */
    .aaa-header-secciones-bar::before,
    .aaa-header-secciones-bar::after {
        content: '';
        position: absolute;
        top: 0;
        bottom: 0;
        width: 24px;
        pointer-events: none;
        z-index: 1;
    }
    .aaa-header-secciones-bar::before {
        left: 0;
        background: linear-gradient(to right,
            var(--aaa-color-marca) 0%,
            rgba(47, 39, 34, 0) 100%);
    }
    .aaa-header-secciones-bar::after {
        right: 0;
        background: linear-gradient(to left,
            var(--aaa-color-marca) 0%,
            rgba(47, 39, 34, 0) 100%);
    }
}

/* ============================================================
 * 5. MENÚ OVERLAY FULL-SCREEN
 * ============================================================ */

.aaa-header-menu-overlay {
    position: fixed;
    inset: 0;
    z-index: var(--aaa-z-overlay);
    background-color: var(--aaa-color-blanco);
    /* Detalle decorativo: línea sutil del color contextual en el borde */
    border-top: 4px solid var(--color-seccion, var(--aaa-color-marca));
    /* Estado cerrado */
    opacity: 0;
    visibility: hidden;
    transform: translateY(-12px);
    transition: opacity var(--aaa-duration) var(--aaa-easing),
                transform var(--aaa-duration) var(--aaa-easing),
                visibility 0s linear var(--aaa-duration);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

.aaa-header-menu-overlay.is-open {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    transition: opacity var(--aaa-duration) var(--aaa-easing),
                transform var(--aaa-duration) var(--aaa-easing),
                visibility 0s linear 0s;
}

/* Detalle decorativo: línea vertical sutil de color contextual */
.aaa-header-menu-overlay::before {
    content: '';
    position: absolute;
    top: 60px;
    left: 50%;
    width: 1px;
    height: 0;
    background-color: var(--color-seccion, var(--aaa-color-marca));
    opacity: 0.12;
    transition: height 600ms var(--aaa-easing) 200ms;
}
.aaa-header-menu-overlay.is-open::before {
    height: calc(100% - 120px);
}

.aaa-header-menu-overlay-inner {
    min-height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 96px 24px 64px;
    position: relative;
}

/* --- Botón cerrar (X) común a ambos overlays --- */
.aaa-header-overlay-close {
    position: absolute;
    top: 20px;
    right: 20px;
    width: 48px;
    height: 48px;
    padding: 0;
    background: transparent;
    border: none;
    border-radius: 50%;
    color: var(--aaa-color-marca);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    z-index: 2;
    transition: background-color 200ms var(--aaa-easing),
                color 200ms var(--aaa-easing),
                transform 200ms var(--aaa-easing);
}

.aaa-header-overlay-close:hover,
.aaa-header-overlay-close:focus-visible {
    background-color: rgba(47, 39, 34, 0.08);
    color: var(--aaa-color-rojo);
    transform: rotate(90deg);
}

.aaa-header-overlay-close--light {
    color: var(--aaa-color-blanco);
}
.aaa-header-overlay-close--light:hover,
.aaa-header-overlay-close--light:focus-visible {
    background-color: rgba(255, 255, 255, 0.12);
    color: var(--aaa-color-blanco);
}

.aaa-header-overlay-close svg {
    width: 24px;
    height: 24px;
    fill: currentColor;
}

@media (max-width: 767px) {
    .aaa-header-overlay-close {
        top: 12px;
        right: 12px;
        width: 44px;
        height: 44px;
    }
}

/* --- Navegación del overlay (3 grupos en columnas) ---
 *
 * El menú overlay agrupa los enlaces en columnas temáticas:
 * - Secciones (editoriales, autopobladas desde la taxonomía)
 * - Servicios (utilidades del medio)
 * - El medio (corporativo / agenda / hemeroteca)
 *
 * Configurable en PHP via $GLOBALS['abarandiaadia_menu_principal'].
 */
.aaa-header-menu-nav {
    width: 100%;
    max-width: 1100px;
    text-align: left;
}

.aaa-header-menu-grupos {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 56px;
    align-items: start;
    /* Reset del contextual: el wrapper .aaa-header padre setea
       --color-seccion según la página actual y eso se hereda hasta
       aquí, haciendo que el hover de items neutros (Servicios, El
       medio) tomase el color de la sección activa. Resetearlo a
       `initial` corta la herencia — el fallback del var() es el
       rojo de marca, consistente en toda página.
       Los items de sección (que setean su propio --color-seccion
       inline en el <li>) lo sobreescriben para sus descendientes
       y conservan su color identitario. */
    --color-seccion: initial;
}

.aaa-header-menu-grupo {
    min-width: 0;
}

.aaa-header-menu-grupo-titulo {
    font-family: var(--aaa-font-ui);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--aaa-color-tenue, #7A7572);
    margin: 0 0 20px 0;
    padding-bottom: 12px;
    border-bottom: 1px solid rgba(47, 39, 34, 0.12);
    line-height: 1;
}

.aaa-header-menu {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
}

.aaa-header-menu-item {
    margin: 0;
    width: 100%;
    /* Cascada: cada item entra con un retardo proporcional a --aaa-i */
    opacity: 0;
    transform: translateY(16px);
    transition: opacity 420ms var(--aaa-easing),
                transform 420ms var(--aaa-easing);
}

.aaa-header-menu-overlay.is-open .aaa-header-menu-item {
    opacity: 1;
    transform: translateY(0);
    transition-delay: calc(var(--aaa-i, 0) * 35ms + 120ms);
}

.aaa-header-menu-item a {
    display: inline-flex;
    align-items: baseline;
    gap: 8px;
    padding: 6px 0;
    font-family: var(--aaa-font-display);
    font-size: 30px;
    font-weight: 600;
    line-height: 1.15;
    letter-spacing: -0.01em;
    color: var(--aaa-color-marca);
    text-decoration: none;
    position: relative;
    transition: color 240ms var(--aaa-easing);
}

.aaa-header-menu-item a::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: 2px;
    width: 0;
    height: 2px;
    background-color: var(--color-seccion, var(--aaa-color-rojo));
    transition: width 280ms var(--aaa-easing);
}

.aaa-header-menu-item a:hover,
.aaa-header-menu-item a:focus-visible {
    color: var(--color-seccion, var(--aaa-color-rojo));
    text-decoration: none;
}

.aaa-header-menu-item a:hover::after,
.aaa-header-menu-item a:focus-visible::after {
    width: 100%;
}

.aaa-header-menu-item.is-active a {
    color: var(--color-seccion, var(--aaa-color-marca));
}
.aaa-header-menu-item.is-active a::after {
    width: 100%;
}

/* Item destacado (ej. Newsletter): tratamiento visual rojo */
.aaa-header-menu-item.is-destacado a {
    color: var(--aaa-color-rojo);
}
.aaa-header-menu-item.is-destacado a::after {
    background-color: var(--aaa-color-rojo);
}

/* Flecha de enlace externo */
.aaa-header-menu-item-externo {
    font-family: var(--aaa-font-ui);
    font-size: 0.55em;
    font-weight: 500;
    color: var(--aaa-color-tenue, #7A7572);
    line-height: 1;
    transform: translateY(-0.35em);
    transition: color 240ms var(--aaa-easing);
}
.aaa-header-menu-item a:hover .aaa-header-menu-item-externo,
.aaa-header-menu-item a:focus-visible .aaa-header-menu-item-externo {
    color: inherit;
}

/* --- Bloque de redes sociales al pie del overlay --- */
.aaa-header-menu-redes {
    margin-top: 56px;
    padding-top: 32px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
    width: 100%;
    max-width: 320px;
    position: relative;
    opacity: 0;
    transform: translateY(12px);
    transition: opacity 420ms var(--aaa-easing) 400ms,
                transform 420ms var(--aaa-easing) 400ms;
}

.aaa-header-menu-redes::before {
    content: '';
    position: absolute;
    top: 0;
    left: 50%;
    width: 64px;
    height: 1px;
    background-color: var(--color-seccion, var(--aaa-color-marca));
    opacity: 0.24;
    transform: translateX(-50%);
}

.aaa-header-menu-overlay.is-open .aaa-header-menu-redes {
    opacity: 1;
    transform: translateY(0);
}

.aaa-header-red {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    color: var(--aaa-color-marca);
    border-radius: 50%;
    text-decoration: none;
    transition: color 200ms var(--aaa-easing),
                background-color 200ms var(--aaa-easing),
                transform 200ms var(--aaa-easing);
}

.aaa-header-red:hover,
.aaa-header-red:focus-visible {
    color: var(--color-seccion, var(--aaa-color-rojo));
    background-color: rgba(47, 39, 34, 0.06);
    transform: translateY(-2px);
    text-decoration: none;
}

.aaa-header-red svg {
    width: 20px;
    height: 20px;
    fill: currentColor;
}

/* --- Responsive del menú overlay --- */

/* Tablet pequeño y desktop pequeño: reducir gap entre columnas y
   tamaño de item para que entren los 3 grupos sin estrecharse. */
@media (max-width: 1023px) {
    .aaa-header-menu-grupos {
        gap: 36px;
    }
    .aaa-header-menu-item a {
        font-size: 26px;
    }
    .aaa-header-menu-grupo-titulo {
        font-size: 0.72rem;
        margin-bottom: 16px;
    }
}

/* Móvil: los grupos se apilan en una sola columna. Items con
   touch-target generoso y separación clara entre grupos. */
@media (max-width: 767px) {
    .aaa-header-menu-overlay-inner {
        padding: 80px 24px 48px;
        justify-content: flex-start;
        padding-top: 96px;
    }

    .aaa-header-menu-nav {
        max-width: 100%;
    }

    .aaa-header-menu-grupos {
        grid-template-columns: 1fr;
        gap: 36px;
    }

    .aaa-header-menu-grupo-titulo {
        font-size: 0.7rem;
        margin-bottom: 14px;
        padding-bottom: 10px;
    }

    .aaa-header-menu {
        gap: 6px;
    }

    .aaa-header-menu-item a {
        font-size: 24px;
        padding: 8px 0;
        /* Touch target ≥44px */
        min-height: 44px;
        align-items: center;
    }

    .aaa-header-menu-redes {
        margin-top: 40px;
        padding-top: 24px;
    }
}

/* ============================================================
 * 6. BÚSQUEDA OVERLAY
 * ============================================================ */

.aaa-header-search-overlay {
    position: fixed;
    inset: 0;
    z-index: var(--aaa-z-overlay);
    background-color: rgba(47, 39, 34, 0.92);
    -webkit-backdrop-filter: blur(8px);
    backdrop-filter: blur(8px);
    /* Estado cerrado */
    opacity: 0;
    visibility: hidden;
    transform: scale(1.02);
    transition: opacity var(--aaa-duration) var(--aaa-easing),
                transform var(--aaa-duration) var(--aaa-easing),
                visibility 0s linear var(--aaa-duration);
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: 64px 24px 32px;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

.aaa-header-search-shell {
    width: 100%;
    max-width: 720px;
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.aaa-header-search-overlay.is-open {
    opacity: 1;
    visibility: visible;
    transform: scale(1);
    transition: opacity var(--aaa-duration) var(--aaa-easing),
                transform var(--aaa-duration) var(--aaa-easing),
                visibility 0s linear 0s;
}

.aaa-header-search-form {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.aaa-header-search-field {
    display: flex;
    align-items: center;
    gap: 12px;
    border-bottom: 2px solid rgba(255, 255, 255, 0.4);
    padding-bottom: 12px;
    transition: border-color 200ms var(--aaa-easing);
}

.aaa-header-search-field:focus-within {
    border-bottom-color: var(--aaa-color-blanco);
}

.aaa-header-search-input {
    flex: 1 1 auto;
    width: 100%;
    background: transparent;
    border: none;
    outline: none;
    color: var(--aaa-color-blanco);
    font-family: var(--aaa-font-display);
    font-size: 32px;
    font-weight: 600;
    line-height: 1.3;
    padding: 8px 0;
    caret-color: var(--aaa-color-blanco);
}

.aaa-header-search-input::placeholder {
    color: rgba(255, 255, 255, 0.55);
    font-style: italic;
    font-weight: 400;
}

.aaa-header-search-input::-webkit-search-cancel-button {
    display: none;
}

.aaa-header-search-submit {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    padding: 0;
    background-color: var(--aaa-color-blanco);
    color: var(--aaa-color-marca);
    border: none;
    border-radius: 50%;
    cursor: pointer;
    transition: background-color 200ms var(--aaa-easing),
                color 200ms var(--aaa-easing),
                transform 200ms var(--aaa-easing);
}

.aaa-header-search-submit:hover,
.aaa-header-search-submit:focus-visible {
    background-color: var(--aaa-color-rojo);
    color: var(--aaa-color-blanco);
    transform: scale(1.04);
}

.aaa-header-search-submit svg {
    width: 22px;
    height: 22px;
    fill: currentColor;
}

.aaa-header-search-hint {
    font-family: var(--aaa-font-ui);
    font-size: 12px;
    font-weight: 400;
    letter-spacing: 0.04em;
    color: rgba(255, 255, 255, 0.7);
    text-align: center;
    margin: 8px 0 0;
}

.aaa-header-search-hint kbd {
    display: inline-block;
    padding: 2px 6px;
    margin: 0 2px;
    background-color: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 4px;
    font-family: var(--aaa-font-ui);
    font-size: 11px;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.92);
}

@media (max-width: 767px) {
    .aaa-header-search-overlay {
        padding: 20px 16px;
        align-items: flex-start;
        padding-top: 72px;
    }
    .aaa-header-search-input {
        font-size: 22px;
    }
    .aaa-header-search-submit {
        width: 44px;
        height: 44px;
    }
    .aaa-header-search-submit svg {
        width: 18px;
        height: 18px;
    }
    .aaa-header-search-shell {
        gap: 16px;
    }
}

/* ============================================================
 * 6-bis. RESULTADOS AJAX DEL BUSCADOR
 *
 * Estados (idle | loading | empty | error | results) controlados
 * por el atributo `hidden` que pone el JS.
 * ============================================================ */

.aaa-header-search-results {
    width: 100%;
    color: var(--aaa-color-blanco);
}

/* --- Estados (idle/loading/empty/error) --- */
.aaa-header-search-state {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 24px 8px;
    text-align: center;
    font-size: 14px;
    color: rgba(255, 255, 255, 0.7);
    letter-spacing: 0.02em;
}

.aaa-header-search-state kbd {
    display: inline-block;
    padding: 1px 6px;
    background-color: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 4px;
    font-family: var(--aaa-font-ui);
    font-size: 11px;
    color: rgba(255, 255, 255, 0.92);
    margin: 0 2px;
}

.aaa-header-search-state--idle {
    font-style: italic;
}

/* Spinner: anillo CSS puro */
.aaa-header-search-spinner {
    width: 16px;
    height: 16px;
    border: 2px solid rgba(255, 255, 255, 0.25);
    border-top-color: var(--aaa-color-blanco);
    border-radius: 50%;
    animation: aaa-spin 600ms linear infinite;
}

@keyframes aaa-spin {
    to { transform: rotate(360deg); }
}

/* --- Grupos de resultados --- */
.aaa-header-search-groups {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.aaa-header-search-group {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.aaa-header-search-group-title {
    display: flex;
    align-items: baseline;
    gap: 8px;
    margin: 0 0 4px;
    padding-bottom: 6px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.18);
    font-family: var(--aaa-font-ui);
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: #FFFFFF;
}

.aaa-header-search-group-count {
    font-weight: 500;
    color: rgba(255, 255, 255, 0.55);
    letter-spacing: 0.04em;
}

/* --- Items --- */
.aaa-header-search-items {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
}

.aaa-header-search-item {
    margin: 0;
    border-radius: 6px;
    transition: background-color 160ms var(--aaa-easing);
}

.aaa-header-search-item:hover,
.aaa-header-search-item:focus-within {
    background-color: rgba(255, 255, 255, 0.06);
}

.aaa-header-search-item-link {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 10px;
    color: var(--aaa-color-blanco);
    text-decoration: none;
    border-radius: inherit;
}

.aaa-header-search-item-link:hover,
.aaa-header-search-item-link:focus-visible {
    color: var(--aaa-color-blanco);
    text-decoration: none;
}

.aaa-header-search-item-thumb {
    flex: 0 0 auto;
    width: 88px;
    aspect-ratio: 5 / 4;
    /* Fallback para navegadores antiguos sin aspect-ratio */
    height: auto;
    min-height: 70px;
    border-radius: 4px;
    overflow: hidden;
    background-color: rgba(255, 255, 255, 0.08);
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Si el navegador soporta aspect-ratio, anulamos el min-height del fallback */
@supports (aspect-ratio: 5/4) {
    .aaa-header-search-item-thumb { min-height: 0; }
}

.aaa-header-search-item-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* Fallback de thumbnail: inicial sobre color de marca/sección */
.aaa-header-search-item-thumb--fallback {
    color: var(--aaa-color-blanco);
    font-family: var(--aaa-font-display);
    font-size: 26px;
    font-weight: 700;
    line-height: 1;
}
.aaa-header-search-item-thumb--fallback span {
    display: inline-block;
    line-height: 1;
}

.aaa-header-search-item-body {
    flex: 1 1 auto;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.aaa-header-search-item-meta {
    font-family: var(--aaa-font-ui);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.65);
    line-height: 1.2;
}

.aaa-header-search-item-section {
    font-weight: 700;
    letter-spacing: 0.1em;
}

.aaa-header-search-item-title {
    font-family: var(--aaa-font-display);
    font-size: 17px;
    font-weight: 600;
    line-height: 1.3;
    color: var(--aaa-color-blanco);
    /* Truncar a 2 líneas */
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.aaa-header-search-item-excerpt {
    font-family: var(--aaa-font-ui);
    font-size: 13px;
    font-weight: 400;
    line-height: 1.4;
    color: rgba(255, 255, 255, 0.7);
    /* Truncar a 1 línea */
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.aaa-header-search-item-link mark {
    background-color: rgba(255, 255, 255, 0.18);
    color: inherit;
    padding: 0 2px;
    border-radius: 2px;
}

/* --- "Ver todas" al pie de cada grupo --- */
.aaa-header-search-group-more {
    display: inline-flex;
    align-self: flex-start;
    margin-top: 4px;
    padding: 6px 10px;
    font-family: var(--aaa-font-ui);
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.06em;
    color: rgba(255, 255, 255, 0.85);
    text-decoration: none;
    border-radius: 4px;
    transition: color 160ms var(--aaa-easing),
                background-color 160ms var(--aaa-easing);
}

.aaa-header-search-group-more:hover,
.aaa-header-search-group-more:focus-visible {
    color: var(--aaa-color-blanco);
    background-color: rgba(255, 255, 255, 0.08);
    text-decoration: none;
}

/* --- Responsive resultados --- */
@media (max-width: 767px) {
    .aaa-header-search-item-link {
        padding: 8px;
        gap: 10px;
    }
    .aaa-header-search-item-thumb {
        width: 72px;
        min-height: 58px;
    }
    .aaa-header-search-item-thumb--fallback {
        font-size: 22px;
    }
    .aaa-header-search-item-title {
        font-size: 15px;
    }
    .aaa-header-search-item-excerpt {
        font-size: 12px;
    }
    .aaa-header-search-groups {
        gap: 18px;
    }
}

/* ============================================================
 * 7. BLOQUEO DE SCROLL DEL BODY
 * Aplicada por el JS al abrir cualquier overlay.
 * ============================================================ */

body.aaa-scroll-locked {
    overflow: hidden;
    /* Compensa la scrollbar para que el contenido no salte */
    padding-right: var(--aaa-scrollbar-width, 0);
}

/* ============================================================
 * 8. FOCUS VISIBLE GLOBAL DEL HEADER
 * ============================================================ */

.aaa-header :focus-visible,
.aaa-header-menu-overlay :focus-visible,
.aaa-header-search-overlay :focus-visible {
    outline: 2px solid var(--color-seccion, var(--aaa-color-rojo));
    outline-offset: 3px;
    border-radius: 4px;
}

/* En overlay oscuro de búsqueda, focus en blanco */
.aaa-header-search-overlay :focus-visible {
    outline-color: var(--aaa-color-blanco);
}

/* ============================================================
 * 9. PREFERS-REDUCED-MOTION
 * ============================================================ */

@media (prefers-reduced-motion: reduce) {
    .aaa-header *,
    .aaa-header-menu-overlay *,
    .aaa-header-search-overlay * {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        transition-delay: 0s !important;
        scroll-behavior: auto !important;
    }

    .aaa-header-menu-item {
        opacity: 1 !important;
        transform: none !important;
    }

    .aaa-header-menu-redes {
        opacity: 1 !important;
        transform: none !important;
    }

    .aaa-header-overlay-close:hover,
    .aaa-header-overlay-close:focus-visible {
        transform: none;
    }
}

/* ============================================================
 * 10. OVERRIDES TEMA HELLO ELEMENTOR
 * Hello aplica reset a todos los button. Aseguramos que nuestros
 * controles mantengan su estilo personalizado.
 * ============================================================ */

.aaa-header button.aaa-header-toggle,
.aaa-header button.aaa-header-search-btn,
.aaa-header-menu-overlay button.aaa-header-overlay-close,
.aaa-header-search-overlay button.aaa-header-overlay-close,
.aaa-header-search-overlay button.aaa-header-search-submit {
    border: none;
    box-shadow: none;
    text-transform: none;
}

.aaa-header-search-overlay button.aaa-header-search-submit {
    background-color: var(--aaa-color-blanco);
    color: var(--aaa-color-marca);
}

/* ============================================================
 * 11. DEFENSIVOS contra Elementor Kit / Hello / temas globales
 *
 * Elementor define colores globales para <a> y <button> a través
 * de su "Kit". Esos selectores tienen especificidad de 0,1,1
 * (.elementor-kit-NN a) y ganan a nuestras reglas con clase sola.
 * Forzamos los colores críticos del header con !important para
 * blindarlos. Usamos var() para mantener la coherencia del tema.
 * ============================================================ */

/* Top bar: texto blanco siempre */
.aaa-header .aaa-header-topbar,
.aaa-header .aaa-header-topbar-link,
.aaa-header .aaa-header-topbar-text {
    color: var(--aaa-color-blanco) !important;
    text-decoration: none !important;
}
.aaa-header .aaa-header-topbar-link:hover,
.aaa-header .aaa-header-topbar-link:focus-visible {
    color: var(--aaa-color-blanco) !important;
    text-decoration: none !important;
}

/* Botones ☰ y 🔍 del header principal */
.aaa-header button.aaa-header-toggle,
.aaa-header button.aaa-header-search-btn {
    color: var(--aaa-color-marca) !important;
    background-color: transparent !important;
}
.aaa-header button.aaa-header-toggle:hover,
.aaa-header button.aaa-header-toggle:focus-visible,
.aaa-header button.aaa-header-search-btn:hover,
.aaa-header button.aaa-header-search-btn:focus-visible {
    color: var(--aaa-color-rojo) !important;
    background-color: transparent !important;
}

/* Logo: que <a> no herede color/decoración del kit */
.aaa-header a.aaa-header-logo,
.aaa-header a.aaa-header-logo:hover,
.aaa-header a.aaa-header-logo:focus-visible {
    color: inherit !important;
    text-decoration: none !important;
    background-color: transparent !important;
}

/* Línea contextual: texto blanco */
.aaa-header .aaa-header-linea-seccion,
.aaa-header .aaa-header-seccion-nombre,
.aaa-header h1.aaa-header-seccion-nombre {
    color: var(--aaa-color-blanco) !important;
}

/* Subnav del header: enlaces en blanco translúcido */
.aaa-header-linea-seccion a.aaa-header-subnav-link,
.aaa-header-linea-seccion a.aaa-header-subnav-link:hover,
.aaa-header-linea-seccion a.aaa-header-subnav-link:focus-visible {
    color: rgba(255, 255, 255, 0.78) !important;
    text-decoration: none !important;
}
.aaa-header-linea-seccion a.aaa-header-subnav-link:hover,
.aaa-header-linea-seccion a.aaa-header-subnav-link:focus-visible {
    color: #FFFFFF !important;
}

/* Pestañas de portada: enlaces siempre blancos */
.aaa-header-secciones-bar a.aaa-header-seccion-tab-link,
.aaa-header-secciones-bar a.aaa-header-seccion-tab-link:hover,
.aaa-header-secciones-bar a.aaa-header-seccion-tab-link:focus-visible {
    color: var(--aaa-color-blanco) !important;
    text-decoration: none !important;
    background-color: transparent !important;
}

/* Menú overlay: items color marca, hover color contextual */
.aaa-header-menu-overlay .aaa-header-menu-item a {
    color: var(--aaa-color-marca) !important;
    background-color: transparent !important;
    text-decoration: none !important;
}
.aaa-header-menu-overlay .aaa-header-menu-item a:hover,
.aaa-header-menu-overlay .aaa-header-menu-item a:focus-visible {
    color: var(--color-seccion, var(--aaa-color-rojo)) !important;
    text-decoration: none !important;
}
.aaa-header-menu-overlay .aaa-header-menu-item.is-active a {
    color: var(--color-seccion, var(--aaa-color-marca)) !important;
}
/* Item destacado (ej. Newsletter): rojo de marca */
.aaa-header-menu-overlay .aaa-header-menu-item.is-destacado a {
    color: var(--aaa-color-rojo) !important;
}

/* Redes sociales del overlay */
.aaa-header-menu-overlay a.aaa-header-red,
.aaa-header-menu-overlay a.aaa-header-red:hover,
.aaa-header-menu-overlay a.aaa-header-red:focus-visible {
    background-color: transparent !important;
    text-decoration: none !important;
}
.aaa-header-menu-overlay a.aaa-header-red {
    color: var(--aaa-color-marca) !important;
}
.aaa-header-menu-overlay a.aaa-header-red:hover,
.aaa-header-menu-overlay a.aaa-header-red:focus-visible {
    color: var(--color-seccion, var(--aaa-color-rojo)) !important;
    background-color: rgba(47, 39, 34, 0.06) !important;
}

/* Overlay de búsqueda: input blanco, submit blanco con texto marca */
.aaa-header-search-overlay input.aaa-header-search-input {
    color: var(--aaa-color-blanco) !important;
    background-color: transparent !important;
    border: none !important;
}
.aaa-header-search-overlay button.aaa-header-search-submit {
    color: var(--aaa-color-marca) !important;
    background-color: var(--aaa-color-blanco) !important;
}
.aaa-header-search-overlay button.aaa-header-search-submit:hover,
.aaa-header-search-overlay button.aaa-header-search-submit:focus-visible {
    color: var(--aaa-color-blanco) !important;
    background-color: var(--aaa-color-rojo) !important;
}

/* Resultados AJAX del buscador: enlaces blancos */
.aaa-header-search-overlay a.aaa-header-search-item-link,
.aaa-header-search-overlay a.aaa-header-search-item-link:hover,
.aaa-header-search-overlay a.aaa-header-search-item-link:focus-visible,
.aaa-header-search-overlay a.aaa-header-search-group-more,
.aaa-header-search-overlay a.aaa-header-search-group-more:hover,
.aaa-header-search-overlay a.aaa-header-search-group-more:focus-visible {
    color: var(--aaa-color-blanco) !important;
    text-decoration: none !important;
}

/* Resultados AJAX: textos secundarios (Elementor sobrescribe h3/p del Kit) */
.aaa-header-search-overlay .aaa-header-search-group-title {
    color: #FFFFFF !important;
}
.aaa-header-search-overlay .aaa-header-search-group-count {
    color: rgba(255, 255, 255, 0.55) !important;
}
.aaa-header-search-overlay .aaa-header-search-item-title {
    color: #FFFFFF !important;
}
.aaa-header-search-overlay .aaa-header-search-item-excerpt {
    color: rgba(255, 255, 255, 0.7) !important;
}
.aaa-header-search-overlay .aaa-header-search-item-meta {
    color: rgba(255, 255, 255, 0.65) !important;
}
.aaa-header-search-overlay .aaa-header-search-state {
    color: rgba(255, 255, 255, 0.7) !important;
}
.aaa-header-search-overlay .aaa-header-search-hint {
    color: rgba(255, 255, 255, 0.7) !important;
}
.aaa-header-search-overlay mark {
    background-color: rgba(255, 255, 255, 0.22) !important;
    color: #FFFFFF !important;
}

/* Botones de cerrar de los overlays */
.aaa-header-menu-overlay button.aaa-header-overlay-close,
.aaa-header-search-overlay button.aaa-header-overlay-close {
    background-color: transparent !important;
}
.aaa-header-menu-overlay button.aaa-header-overlay-close {
    color: var(--aaa-color-marca) !important;
}
.aaa-header-search-overlay button.aaa-header-overlay-close--light {
    color: var(--aaa-color-blanco) !important;
}

/* ============================================================
 * 12. STICKY BARRA CONTEXTUAL (técnica top negativo)
 *
 * Comportamiento deseado: solo la barra de secciones (portada) o
 * la línea contextual (resto de páginas) queda fija al scroll.
 * El top bar y el header principal se "salen" hacia arriba.
 *
 * Técnica: position:sticky NO se puede aplicar directamente a la
 * barra de secciones porque su padre (.aaa-header) solo tiene
 * la altura del header → el sticky se rompe al salir de ese
 * rango. La solución es aplicar sticky al wrapper completo
 * (.elementor-location-header) que sí vive bajo <body> y abarca
 * todo el scroll del documento, con `top` negativo igual a la
 * altura combinada de top bar + header principal. Resultado:
 * el header está sticky pero "desplazado" hacia arriba, dejando
 * visible solo la barra de secciones (parte inferior).
 *
 * Las alturas son variables CSS responsive para que se ajusten
 * en cada breakpoint sin desincronización.
 * ============================================================ */

.elementor-location-header {
    position: sticky;
    /* El offset se calcula dinámicamente: header.js mide la altura
     * real de .aaa-header-topbar + .aaa-header-main y la expone como
     * variable CSS. Garantiza encaje pixel-perfect en cualquier
     * configuración. Fallback -125px si JS falla o tarda. */
    top: var(--aaa-sticky-offset, -125px);
    z-index: var(--aaa-z-header, 1000);
    background-color: var(--aaa-color-blanco, #FFFFFF);
    transition: box-shadow 280ms cubic-bezier(0.22, 0.61, 0.36, 1);
}

/* Sombra inferior cuando el JS detecta scroll > 10px (clase .is-scrolled
 * añadida a .aaa-header-main). Refuerza visualmente que la barra de
 * secciones está flotando sobre el contenido. */
.elementor-location-header:has(.aaa-header-main.is-scrolled) {
    box-shadow: 0 2px 12px rgba(47, 39, 34, 0.12);
}

/* Espacio entre el header y el primer elemento del contenido.
 * Antes era margin-bottom del .aaa-header, pero al ser sticky se veía
 * como gap visible bajo la barra de secciones al scrollear. Ahora vive
 * en el flujo del contenido: cuando el header es sticky, este espacio
 * se desplaza con el contenido (NO con el header sticky) y por tanto
 * no aparece como gap. */
.elementor-location-header + *,
.aaa-header + * {
    margin-top: 20px;
}

/* ============================================================
 * 13. DEFENSIVOS para position: sticky
 *
 * El sticky requiere que NINGÚN wrapper padre rompa su contexto.
 * Lo rompen: overflow:hidden/auto/clip, height fija, transform,
 * filter, perspective, will-change, contain:paint en padres.
 *
 * Forzamos visible + height auto en wrappers conocidos por si
 * algún plugin/tema/configuración aplica overflow oculto.
 * ============================================================ */

/* Theme Builder de Elementor — wrappers clásicos (Section) */
.elementor-location-header,
.elementor-location-header .elementor-section,
.elementor-location-header .elementor-section-wrap,
.elementor-location-header .elementor-container,
.elementor-location-header .elementor-row,
.elementor-location-header .elementor-column,
.elementor-location-header .elementor-column-wrap,
.elementor-location-header .elementor-element-populated,
.elementor-location-header .elementor-widget-wrap,
.elementor-location-header .elementor-widget,
.elementor-location-header .elementor-widget-container,
.elementor-location-header .elementor-widget-shortcode,
.elementor-location-header .elementor-shortcode,
/* Containers de Elementor Pro nuevo (Flex/Grid) */
.elementor-location-header .e-con,
.elementor-location-header .e-con-inner,
.elementor-location-header .e-con-full,
.elementor-location-header .e-flex,
.elementor-location-header .e-grid {
    overflow: visible !important;
    height: auto !important;
}

/* Hello Elementor: el theme aplica overflow en .site-header */
.site,
.site-content,
.site-header,
.site-header > *,
header.site-header,
.elementor-page,
.page-content,
.entry-content {
    overflow: visible !important;
}

/* Asegurar que el propio header tampoco se aclipa */
.aaa-header {
    overflow: visible !important;
}
