@import url('https://fonts.googleapis.com/css2?family=Albert+Sans:wght@400;500;600;700&display=swap');

/* ── Paleta global (sistema) ─────────────────────────────────── */
:root {
    /* Principales */
    --primary-bg: #151927; /* Deep Navy */
    --primary-accent: #8E88FC; /* Lavender */
    --neutral-bg: #E9E9E9; /* Light Gray */

    /* Funcionales */
    --emphasis: #FFB76B; /* Orange */
    --success: #67FF8D; /* Green */
    --error: #FF5E61; /* Red */

    /* Texto */
    --text-on-dark: #FFFFFF;
    --text-on-light: #151927;
    --lavender-on-dark: #C3BFFF;

    /* Mapeo a variables usadas por dist/assets */
    --color-white: #FFFFFF;
    --color-black: var(--primary-bg);
    --color-grey: var(--neutral-bg);
    --color-blue: var(--primary-accent);
    --color-pink: var(--primary-accent);
    --color-orange: var(--emphasis);

    /* Usar Albert Sans como sustituto global de fuentes "Suisse*" */
    --font-suisse-intl: 'Albert Sans';
    --font-suisse-intl-mono: 'Albert Sans';
    --font-suisse-works: 'Albert Sans';
}

/* Base: contenido en claro (hero queda como está por su propio CSS) */
html, body {
    background: #FFFFFF !important;
    color: var(--text-on-light) !important;
}

/* Fuente global (todas las páginas / todo el texto) */
html,
body,
html *,
body * {
    font-family: 'Albert Sans', sans-serif !important;
}
html *::before,
html *::after,
body *::before,
body *::after {
    font-family: 'Albert Sans', sans-serif !important;
}

/* Excepción: icon-font (para que la flecha no salga como cuadrado) */
html i[class^="icon-"],
html i[class*=" icon-"],
html i.icon-arrow-right,
html i.arrow-right,
body i[class^="icon-"],
body i[class*=" icon-"],
body i.icon-arrow-right,
body i.arrow-right {
    font-family: muc !important;
}

/* Textos sobre morado (lavender) => más oscuro para mejor lectura */
.theme-pink-white,
.theme-pink-black,
.theme-pink-orange,
.theme-orange-pink {
    color: #0D0D0D !important;
}
.theme-pink-white *,
.theme-pink-black *,
.theme-pink-orange *,
.theme-orange-pink * {
    color: #0D0D0D !important;
}

/* ── Overrides para "theme-*" (dist/assets usa #000 hardcodeado) ── */
.theme-white-black {
    color: #151927 !important;
    --theme-contrast: #151927 !important;
    --theme-color: #151927 !important;
}
.theme-white-black * {
    color: #151927 !important;
}

.theme-pink-white,
.theme-pink-black,
.theme-pink-orange,
.theme-orange-pink {
    color: #0D0D0D !important;
    --theme-contrast: #0D0D0D !important;
    --theme-color: #0D0D0D !important;
}

/* Importante: el CSS global fuerza Albert Sans en *::before/*::after.
   Por eso, para que la flecha () salga bien, aseguramos muc también en pseudo-elementos */
html i.icon-arrow-right::before,
html i.arrow-right::before,
html i[class^="icon-"]::before,
html i[class*=" icon-"]::before,
body i.icon-arrow-right::before,
body i.arrow-right::before,
body i[class^="icon-"]::before,
body i[class*=" icon-"]::before,
html i.icon-arrow-right::after,
html i.arrow-right::after,
html i[class^="icon-"]::after,
html i[class*=" icon-"]::after,
body i.icon-arrow-right::after,
body i.arrow-right::after,
body i[class^="icon-"]::after,
body i[class*=" icon-"]::after {
    font-family: muc !important;
}

/* Navbar: cuando está en "scroll-up" queremos iconos/logo en negro real */
.is-scrolled.scroll-up .main-navbar.main-navbar-default {
    --navbar-color: var(--text-on-light) !important;
    --navbar-background: #FFFFFF !important;
}

/* ── Mega menu: font weight ── */
li.mega-menu-item.lvl-1.h-small,
li.mega-menu-item.lvl-1.h-small * {
    font-weight: 400 !important;
}

nav.language-switch > a > span {
    font-weight: 400 !important;
}

/* ── Menú (mega menu) y footer: usar Deep Navy (no negro puro) ── */
.mega-menu {
    background: var(--primary-bg) !important;
    color: var(--text-on-dark) !important;
}

/* Abierto: clase en body (nav-scroll-menu.js); evita depender solo de :has() en móviles viejos.
   .main-wrapper__inner tiene transform y haría que fixed quede atado a ese bloque. */
body.mega-menu-open .main-wrapper__inner {
    transform: none !important;
}
/* Cerrado: sin interacción (evita capa transparente bloqueando scroll/toques bajo el nav). */
.mega-menu:not(.is-active) {
    pointer-events: none !important;
}
.mega-menu.is-active {
    pointer-events: auto !important;
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    height: 100dvh !important;
    height: 100svh !important;
    max-height: none !important;
    box-sizing: border-box !important;
}

.footer.theme-black-white {
    background: var(--primary-bg) !important;
    color: var(--text-on-dark) !important;
}
.footer.theme-black-white .divider {
    background: rgba(255, 255, 255, 0.14) !important;
}

/* ── Home: News en navy + Albert Sans ── */
#home-news-section {
    background: var(--primary-bg) !important; /* #151927 */
    color: var(--text-on-dark) !important;    /* #FFFFFF */
    font-family: 'Albert Sans', var(--font-suisse-intl, "Suisse Int'l", "Suisse Intl", sans-serif) !important;
}
#home-news-section .section__headline,
#home-news-section .section__headline * {
    color: var(--text-on-dark) !important;
}
#home-news-section .divider__line {
    background-color: rgba(255, 255, 255, 0.2) !important;
}
#home-news-section .teaser-item,
#home-news-section .teaser-item__text,
#home-news-section .teaser-item__text * {
    color: var(--text-on-dark) !important;
    font-family: 'Albert Sans', var(--font-suisse-intl, "Suisse Int'l", "Suisse Intl", sans-serif) !important;
}
#home-news-section .teaser-item {
    border-color: rgba(255, 255, 255, 0.28) !important;
    background: transparent !important;
}
#home-news-section .teaser-item .teaser-item__text {
    border-color: rgba(255, 255, 255, 0.2) !important;
}
#home-news-section .teaser-item .h-big-v2,
#home-news-section .teaser-item h6 {
    color: var(--text-on-dark) !important;
}
/* Restaurar fuente de iconos en la flecha (evita el cuadrado "") */
#home-news-section .teaser-item i.icon-arrow-right,
#home-news-section .teaser-item i.arrow-right,
#home-news-section .teaser-item [class^="icon-"],
#home-news-section .teaser-item [class*=" icon-"] {
    font-family: muc !important;
}
@media (hover: hover) {
    #home-news-section a.teaser-item:hover {
        background: #8E88FC !important;
        border-color: #8E88FC !important;
        box-shadow: 0 14px 32px rgba(13, 13, 13, 0.28) !important;
    }
    #home-news-section a.teaser-item:hover .teaser-item__text,
    #home-news-section a.teaser-item:hover .teaser-item__text * {
        color: #FFFFFF !important;
    }
}

/* ── Hero de páginas internas (theme-black-white): fondo Navy ── */
.hero.theme-black-white,
.hero.theme-black-white .theme-background {
    background: var(--primary-bg) !important; /* #151927 */
    color: var(--text-on-dark) !important;    /* #FFFFFF */
}
.hero.theme-black-white .section__headline,
.hero.theme-black-white .section__headline *,
.hero.theme-black-white .hero__headline,
.hero.theme-black-white .hero__headline *,
.hero.theme-black-white .text-box,
.hero.theme-black-white .text-box * {
    color: var(--text-on-dark) !important;
}

/* Preloader styles */
#page-preloader {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background: var(--primary-bg) !important;
    z-index: 9999;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: opacity 0.5s ease-out;
}

.spinner {
    width: 50px;
    height: 50px;
    border: 4px solid rgba(255, 255, 255, 0.22) !important;
    border-radius: 50%;
    border-top-color: var(--primary-accent) !important;
    animation: spin 1s linear infinite !important;
}

/* Logo horizontal: mejor adaptación responsiva por ancho/alto de pantalla */
.main-navbar-brand img.brand-logo {
    width: clamp(210px, 28vw, 380px) !important;
    height: auto !important;
    max-height: clamp(42px, 7vw, 90px) !important;
    object-fit: contain !important;
}

/* ── Cards (teaser): hover más alineado a la paleta ── */
.teaser-item {
    border-color: rgba(21, 25, 39, 0.18) !important;
}
@media (hover: hover) {
    a.teaser-item:hover {
        border-color: var(--primary-accent) !important;
        box-shadow: 0 14px 36px rgba(21, 25, 39, 0.12) !important;
        transform: translateY(-2px);
    }
    a.teaser-item:hover .btn {
        background: #FFFFFF !important;
        color: var(--primary-accent) !important;
        border-color: var(--primary-accent) !important;
    }
}
@keyframes spin {
    to { transform: rotate(360deg); }
}

/* ── Mismo padding/margen del cuerpo que en Team (todas las páginas: viejas y nuevas) ── */
main .text-content.section {
    padding-top: 2.5rem;
    padding-bottom: 2.5rem;
    padding-left: 1.25rem;
    padding-right: 1.25rem;
    box-sizing: border-box;
}
@media (min-width: 768px) {
    main .text-content.section {
        padding-top: 3rem;
        padding-bottom: 3rem;
        padding-left: 2rem;
        padding-right: 2rem;
    }
}
@media (min-width: 1024px) {
    main .text-content.section {
        padding-top: 4rem;
        padding-bottom: 4rem;
        padding-left: 2.5rem;
        padding-right: 2.5rem;
    }
}
/* En páginas con wrapper .container alrededor de #dynamic-cards-container: no añadir espacio extra */
main .text-content.section .container:has(#dynamic-cards-container),
main .text-content.section .container--small:has(#dynamic-cards-container) {
    max-width: none !important;
    width: 100% !important;
    padding: 0 !important;
    box-sizing: border-box;
}
/* Espacio entre bloques dentro del dynamic builder (como en Team) */
#dynamic-cards-container > .text-content.section,
#dynamic-cards-container > .rich-text,
#dynamic-cards-container > .intro-text.section,
#dynamic-cards-container > .content-image,
#dynamic-cards-container > .image-text.section,
#dynamic-cards-container > .divider {
    margin-bottom: 2rem;
}
#dynamic-cards-container > *:last-child {
    margin-bottom: 0;
}

/* Dynamic Content Builder: título alineado con párrafo (mismo ancho centrado) */
#dynamic-cards-container .text-content.section .container,
#dynamic-cards-container .text-content.section .container--small {
    margin-left: auto !important;
    margin-right: auto !important;
}
/* Párrafo con animación (intro-text), párrafo normal (rich-text) e imágenes: centrados */
#dynamic-cards-container .intro-text .container,
#dynamic-cards-container .rich-text .container,
#dynamic-cards-container .rich-text .container--small,
#dynamic-cards-container .content-image .container,
#dynamic-cards-container .content-image .container--small {
    margin-left: auto !important;
    margin-right: auto !important;
}
/* Párrafo normal: negrita leve */
#dynamic-cards-container .rich-text .text-box p,
#dynamic-cards-container .rich-text p {
    font-weight: 500;
}

/* Hero: misma tipografía que el resto de la web (títulos de sección .h-big .text-AlbertSans) */
.hero .hero__headline,
.hero .hero__headline .text-SuisseWorks,
.hero #editable-hero-text,
.hero #editable-hero-text span {
    font-family: 'Albert Sans', sans-serif !important;
}
/* Título del hero en negrita */
.hero .hero__headline .text-AlbertSans,
.hero #editable-hero-text .text-AlbertSans {
    font-family: 'Albert Sans', sans-serif !important;
    font-weight: 700 !important;
}
.bestplace-catchline .catchline,
.bestplace-catchline #editable-hero-text,
.bestplace-catchline #editable-hero-text p {
    font-family: 'Albert Sans', sans-serif !important;
}

/* ── Partners: diseño nuevo — grid + revelado escalonado al scroll ── */
.partners.js-partners.section {
    background: #fff !important;
    color: var(--text-on-light, #111) !important;
}
/* ── Partners: diseño nuevo — grid + revelado escalonado al scroll ── */
.js-partners .partners__inner {
    width: 100%;
    overflow: visible;
}
.js-partners .partners__items {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)) !important;
    gap: 1.25rem !important;
    align-items: stretch !important;
    justify-items: center !important;
    width: 100% !important;
    max-width: 1200px !important;
    margin: 0 auto !important;
}
@media (min-width: 768px) {
    .js-partners .partners__items {
        grid-template-columns: repeat(4, 1fr) !important;
        gap: 1.5rem !important;
    }
}
@media (min-width: 1024px) {
    .js-partners .partners__items {
        grid-template-columns: repeat(5, 1fr) !important;
        gap: 1.75rem !important;
    }
}
/* Tarjeta por logo */
.js-partners .partners__item {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    min-height: 100px !important;
    padding: 0 !important;
    opacity: 0;
    transform: translateY(28px) scale(0.97);
    transition: opacity 0.6s cubic-bezier(0.22, 1, 0.36, 1),
                transform 0.6s cubic-bezier(0.22, 1, 0.36, 1);
    transition-delay: calc(var(--partners-i, 0) * 0.07s);
}
.js-partners.partners--visible .partners__item {
    opacity: 1;
    transform: translateY(0) scale(1);
}
/* Partners: movimiento leve de los logos hacia la izquierda */
@keyframes partners-drift-left {
    0%, 100% { transform: translateX(0); }
    50% { transform: translateX(-8px); }
}
/* Animación solo en la caja interior; sin transition para no pisar la keyframes */
.partners .partners__item__inner,
.js-partners .partners__item__inner {
    animation: partners-drift-left 8s ease-in-out infinite !important;
    transition: none !important; /* evita que otra regla pise la animación */
}
.partners .partners__item:nth-child(1) .partners__item__inner { animation-delay: 0s !important; }
.partners .partners__item:nth-child(2) .partners__item__inner { animation-delay: 0.4s !important; }
.partners .partners__item:nth-child(3) .partners__item__inner { animation-delay: 0.8s !important; }
.partners .partners__item:nth-child(4) .partners__item__inner { animation-delay: 1.2s !important; }
.partners .partners__item:nth-child(5) .partners__item__inner { animation-delay: 1.6s !important; }
.partners .partners__item:nth-child(6) .partners__item__inner { animation-delay: 2s !important; }
.partners .partners__item:nth-child(7) .partners__item__inner { animation-delay: 2.4s !important; }
.partners .partners__item:nth-child(8) .partners__item__inner { animation-delay: 2.8s !important; }
.partners .partners__item:nth-child(9) .partners__item__inner { animation-delay: 3.2s !important; }
.partners .partners__item:nth-child(10) .partners__item__inner { animation-delay: 3.6s !important; }
.partners .partners__item:nth-child(11) .partners__item__inner { animation-delay: 4s !important; }
.partners .partners__item:nth-child(12) .partners__item__inner { animation-delay: 4.4s !important; }
.partners .partners__item:nth-child(n+13) .partners__item__inner { animation-delay: 4.8s !important; }
/* Caja del logo (layout); will-change para que la animación no la pise el padre */
.js-partners .partners__item__inner {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    min-height: 100px !important;
    padding: 1.25rem 1.5rem !important;
    border-radius: 14px !important;
    border: 1px solid rgba(255, 255, 255, 0.06) !important;
    background: rgba(255, 255, 255, 0.03) !important;
    box-sizing: border-box !important;
    will-change: transform;
}
.js-partners .partners__item__inner img {
    max-width: 35.4rem !important;
    max-height: 80px !important;
    height: auto !important;
    object-fit: contain !important;
    display: block !important;
    filter: grayscale(0.35) brightness(1.1);
}
/* Título de la sección con pequeño delay */
.js-partners .section__headline {
    opacity: 0;
    transform: translateY(16px);
    transition: opacity 0.5s ease 0.1s, transform 0.5s ease 0.1s;
}
.js-partners.partners--visible .section__headline {
    opacity: 1;
    transform: translateY(0);
}

/* ─────────────────────────────────────────────────────────────
   Partners: marquee horizontal (bucle continuo)
   El HTML incluye dos .partners__strip idénticos (dynamic-loader.js);
   al mover -50% del ancho total, el segundo bloque sustituye al primero
   sin salto ni huecos.
   ───────────────────────────────────────────────────────────── */
@keyframes partners-scroll {
    0% { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}

/* Contenedor con recorte */
.js-partners.partners--left.partners--visible .partners__inner {
    overflow: hidden;
}

/* Track: dos tiras seguidas (sin gap entre tiras; el gap va dentro de cada tira) */
.js-partners.partners--left.partners--visible .partners__items {
    display: flex !important;
    flex-wrap: nowrap !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    width: max-content !important;
    max-width: none !important;
    gap: 0 !important;
    margin: 0 !important;
    animation: partners-scroll var(--partners-animation-speed, 30s) linear infinite !important;
    will-change: transform;
}

/* Cada tira es un flex con el mismo espaciado entre logos */
.js-partners.partners--left.partners--visible .partners__strip {
    display: flex !important;
    flex-wrap: nowrap !important;
    flex-shrink: 0 !important;
    align-items: stretch !important;
    gap: var(--partners-marquee-gap, 1.25rem) !important;
}

/* La copia solo sirve al bucle visual; no duplicar clics ni foco */
.js-partners.partners--left.partners--visible .partners__strip--clone {
    pointer-events: none !important;
}

/* Cada ítem como “slide” */
.js-partners.partners--left.partners--visible .partners__strip .partners__item {
    width: var(--partner-marquee-slide, 220px) !important;
    min-width: var(--partner-marquee-slide, 220px) !important;
    flex-shrink: 0 !important;
    padding: 0 !important;
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
}

/* Desactivar drift dentro del logo para que no compita con el marquee */
.js-partners.partners--left.partners--visible .partners__strip .partners__item__inner {
    animation: none !important;
    transition: none !important;
    padding: 0 !important;
}

@media (min-width: 768px) {
    .js-partners.partners--left.partners--visible .partners__strip .partners__item {
        width: var(--partner-marquee-slide, 250px) !important;
        min-width: var(--partner-marquee-slide, 250px) !important;
    }
}

@media (prefers-reduced-motion: reduce) {
    .js-partners.partners--left.partners--visible .partners__items {
        animation: none !important;
        transform: none !important;
    }
}

/* Footer: botón Google Maps (solo este enlace) */
.footer .google-maps-link {
    display: inline-block;
    box-sizing: border-box;
    /* Solo un poco más ancho que el texto (el padding marca el “aire”) */
    width: fit-content;
    max-width: 100%;
    font-family: Arial, Helvetica, sans-serif;
    font-weight: 700;
    border: 2px solid rgb(255, 255, 255);
    background-color: transparent;
    border-radius: 10px;
    padding: 15px 30px;
    color: #ffffff;
    text-decoration: none;
    text-align: center;
    /* Si la columna del footer es flex, no estirar el botón a todo el ancho */
    align-self: flex-start;
}
.footer .google-maps-link:hover {
    background-color: rgb(255, 255, 255);

    color: rgb(0, 0, 0);
}



/* ═══════════════════════════════════════════════════════════════
   Responsive global (móvil / tablet): todas las páginas, viejas y nuevas.
   Carga después del CSS principal; solo refuerza layout y legibilidad.
   ═══════════════════════════════════════════════════════════════ */

main.main,
#components-wrapper {
    min-width: 0;
}

@media (max-width: 767px) {
    :root {
        --container-padding: 2.2rem;
    }

    /* Contenedores: mismo patrón que el CSS principal (padding lateral + centrado) */
    main.main .container,
    main.main .container--small,
    .footer.theme-black-white > .container {
        box-sizing: border-box;
        padding-top: 0;
        padding-bottom: 0;
        padding-left: max(var(--container-padding), env(safe-area-inset-left, 0px));
        padding-right: max(var(--container-padding), env(safe-area-inset-right, 0px));
        margin-left: auto;
        margin-right: auto;
    }

    /* Evita desbordes horizontales por tipografías largas o URLs */
    .text-box,
    .text-box p,
    .section__headline h1,
    .section__headline h2,
    .hero__headline,
    .hero #editable-hero-text,
    .catchline,
    .footer-column-content,
    .footer-column-content a,
    address {
        overflow-wrap: anywhere;
        word-wrap: break-word;
    }

    /* Hero interior (páginas de contenido, plantilla new1 y similares) */
    .hero.theme-black-white {
        display: flex;
        flex-direction: column;
        align-items: stretch;
    }
    .hero .hero__content {
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
        padding-left: max(var(--container-padding), env(safe-area-inset-left, 0px));
        padding-right: max(var(--container-padding), env(safe-area-inset-right, 0px));
        padding-bottom: 1.25rem;
    }
    .hero .hero__image {
        width: 100%;
        max-width: 100%;
        min-width: 0;
    }
    .hero .hero__image .image-wrapper,
    .hero .hero__image .picture,
    .hero .hero__image img {
        max-width: 100%;
    }
    .hero .back-link {
        margin-top: 0.75rem;
        display: inline-flex;
        align-items: center;
        gap: 0.35rem;
    }

    /* Home: titular + slider */
    .bestplace-slider-component .container.bestplace-catchline {
        padding-left: max(var(--container-padding), env(safe-area-inset-left, 0px));
        padding-right: max(var(--container-padding), env(safe-area-inset-right, 0px));
        padding-bottom: 1rem;
    }
    .bestplace-logos.d-flex {
        flex-wrap: wrap;
        align-items: center;
        gap: 1rem;
        row-gap: 0.75rem;
    }
    .bestplace-logos.d-flex img {
        max-width: min(100%, 280px);
        height: auto;
    }

    /* Bloques dinámicos y secciones de texto (el aire lateral lo da .container) */
    main.main .text-content.section {
        padding-left: 0;
        padding-right: 0;
    }
    #dynamic-cards-container .intro-text.section,
    #dynamic-cards-container .rich-text {
        padding-left: 0;
        padding-right: 0;
    }
    #dynamic-cards-container .text-box,
    #dynamic-cards-container .text-box--big {
        padding-left: 0;
        padding-right: 0;
    }

    /* Intro con animación de texto: lateral igual que .container en main (regla arriba) */

    /* Imágenes de contenido y pies de foto */
    .content-image .image-wrapper,
    .content-image--small .image-wrapper {
        margin-left: auto;
        margin-right: auto;
    }
    .content-image .image-caption {
        margin-top: 0.5rem;
        padding-left: 0.25rem;
        padding-right: 0.25rem;
        line-height: 1.45;
    }

    /* Perfiles / miembros (image-text, bloques dinámicos) */
    .image-text.section .it-item__top {
        display: flex;
        flex-direction: column;
        align-items: stretch;
        gap: 1rem;
    }
    .image-text.section .it-item__image {
        max-width: 100%;
    }
    .image-text.section .it-item__content {
        padding-top: 1rem;
    }

    /* Teasers y cards de páginas enlazadas */
    .teaser .row,
    .teaser.theme-white-black .row {
        margin-left: 0;
        margin-right: 0;
    }
    

    .teaser-item .h-big-v2 {
        font-size: clamp(1.35rem, 5vw, 2rem);
        line-height: 1.15;
    }

    /* Footer: columnas y enlaces largos */
    .footer.theme-black-white .footer-content.row {
        row-gap: 1.5rem;
    }
    .footer-column {
        min-width: 0;
    }
    .footer-nav a {
        display: inline-block;
        padding: 0.2rem 0;
    }

    /* Mega menú: listas táctiles + scroll (body/html bloqueados en JS; iOS fallaba con overflow solo en .mega-menu + transform) */
    .mega-menu.is-active {
        display: flex !important;
        flex-direction: column !important;
        max-height: 100dvh !important;
        max-height: 100svh !important;
        overflow: hidden !important;
        box-sizing: border-box !important;
    }
    .mega-menu.is-active .mega-menu-content {
        flex: 1 1 auto !important;
        min-height: 0 !important;
        overflow-y: auto !important;
        -webkit-overflow-scrolling: touch !important;
        overscroll-behavior: contain !important;
        touch-action: pan-y !important;
    }
    .mega-menu-content .mega-menu-item a,
    .mega-menu-column-title {
        padding-top: 0.35rem;
        padding-bottom: 0.35rem;
    }

    /* Partners grid: 2 columnas en pantallas muy estrechas (no marquee) */
    .js-partners:not(.partners--left) .partners__items {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 0.85rem !important;
    }
    .js-partners:not(.partners--left) .partners__item__inner {
        min-height: 88px !important;
        padding: 0.85rem 0.65rem !important;
    }
}

@media (min-width: 480px) and (max-width: 767px) {
    .js-partners:not(.partners--left) .partners__items {
        grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)) !important;
    }
}

/* Contenedor del About en home: ancla el lema oculto sin afectar el flujo */
#editable-intro-text {
    position: relative;
}

/* About (home): lema duplicado solo para orden en DOM / snippets; no visible */
.home-intro-seo-lead {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    clip-path: inset(50%) !important;
    white-space: nowrap !important;
    border: 0 !important;
    pointer-events: none !important;
}

