/**
 * Mobile Responsive Fixes
 * Corrige problemas de overflow en móviles para WhatsApp y selector de idioma
 */

/* ========================================
   General Mobile Fixes
   ======================================== */
@media screen and (max-width: 768px) {
    /* Prevenir overflow horizontal global */
    html, body {
        overflow-x: hidden !important;
        max-width: 100vw !important;
    }
    
    /* Container principal */
    .site-content,
    #site-content,
    .wrapper,
    .container {
        overflow-x: hidden !important;
        max-width: 100% !important;
    }
}

/* ========================================
   WhatsApp Button Fixes
   ======================================== */
@media screen and (max-width: 768px) {
    /* Botón flotante de WhatsApp */
    .whatsapp-button,
    .wa-button,
    .wa-chat-button,
    .whatsapp-floating,
    .text_us_whatsapp {
        position: fixed !important;
        right: 10px !important;
        bottom: 70px !important;
        left: auto !important;
        z-index: 9999 !important;
        max-width: 60px !important;
        width: 60px !important;
        height: 60px !important;
    }
    
    /* Container de WhatsApp */
    .text_us_whatsapp {
        margin: 0 !important;
        padding: 0 !important;
        max-width: calc(100vw - 40px) !important;
        width: auto !important;
    }
    
    .text_us_whatsapp_body {
        max-width: calc(100vw - 40px) !important;
        padding: 15px !important;
        margin: 0 10px !important;
    }
    
    .text_us_whatsapp .desc {
        max-width: 100% !important;
        font-size: 14px !important;
    }
    
    .text_us_whatsapp .mv-btn {
        max-width: 100% !important;
        width: 100% !important;
        font-size: 13px !important;
        padding: 10px 15px !important;
    }
    
    /* WhatsApp widget/popup */
    .whatsapp-widget,
    .wa-widget,
    .wa-chat-box {
        max-width: calc(100vw - 20px) !important;
        width: calc(100vw - 20px) !important;
        right: 10px !important;
        left: 10px !important;
        bottom: 80px !important;
    }
}

@media screen and (max-width: 480px) {
    .whatsapp-button,
    .wa-button,
    .wa-chat-button,
    .whatsapp-floating {
        width: 50px !important;
        height: 50px !important;
        right: 10px !important;
        bottom: 60px !important;
    }
    
    .whatsapp-button img,
    .wa-button img {
        width: 30px !important;
        height: 30px !important;
    }
}

/* ========================================
   Language Switcher Fixes
   ======================================== */
@media screen and (max-width: 768px) {
    /* TranslatePress Language Switcher */
    .trp-language-switcher,
    .trp-ls-shortcode-language {
        position: relative !important;
        max-width: 100% !important;
        overflow: visible !important;
    }
    
    /* Keep floater language switcher as fixed positioned */
    #trp-floater-ls {
        /* position: fixed is handled by TranslatePress CSS */
        max-width: 100% !important;
        overflow: visible !important;
    }
    
    /* Dropdown del selector de idioma */
    .trp-ls-shortcode-dropdown,
    .trp-language-switcher-dropdown,
    .trp-floater-ls-lang-list {
        position: absolute !important;
        right: auto !important;
        left: 50% !important;
        transform: translateX(-50%) !important;
        max-width: calc(100vw - 40px) !important;
        width: auto !important;
        min-width: 150px !important;
        z-index: 99999 !important;
    }
    
    /* Items del selector de idioma */
    .trp-ls-shortcode-language a,
    .trp-language-switcher li,
    .trp-floater-ls-lang-list li {
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        max-width: 100% !important;
    }
    
    /* Selector de idioma en el header */
    .header-language-switcher,
    .site-header .trp-language-switcher {
        margin: 0 !important;
        padding: 0 5px !important;
    }
    
    /* Botón flotante de idioma - Let TranslatePress handle positioning */
    #trp-floater-ls {
        /* Position and basic styling handled by TranslatePress CSS */
        /* Only override specific mobile adjustments if needed */
        z-index: 9998 !important;
    }
    
    #trp-floater-ls.trp-floater-ls-opened .trp-floater-ls-lang-list {
        right: 0 !important;
        left: auto !important;
        transform: none !important;
        max-width: 200px !important;
    }
}

@media screen and (max-width: 480px) {
    .trp-ls-shortcode-dropdown,
    .trp-language-switcher-dropdown {
        left: 0 !important;
        right: 0 !important;
        transform: none !important;
        margin: 0 10px !important;
        width: calc(100% - 20px) !important;
    }
    
    /* Let TranslatePress handle floater positioning and sizing */
    /* #trp-floater-ls {
        bottom: 120px !important;
        width: 45px !important;
        height: 45px !important;
    } */
}

/* ========================================
   Header Mobile Fixes
   ======================================== */
@media screen and (max-width: 768px) {
    /* Header principal */
    #site-header,
    .site-header,
    #main-header {
        overflow-x: hidden !important;
        max-width: 100vw !important;
    }
    
    /* Inner header (solo header de navegación, no el carousel) */
    .header-inner {
        max-width: 100% !important;
        padding: 10px 15px !important;
        overflow-x: hidden !important;
    }
    
    /* Logo */
    .site-logo,
    .custom-logo-link {
        max-width: 150px !important;
        height: auto !important;
    }
    
    /* Menu móvil */
    .mobile-menu,
    .nav-toggle {
        position: relative !important;
        z-index: 10000 !important;
    }
    
    /* Prevenir que elementos floten fuera del viewport */
    .header-right,
    .header-actions {
        display: flex !important;
        align-items: center !important;
        gap: 10px !important;
        max-width: fit-content !important;
    }
}

/* ========================================
   Footer Mobile Fixes
   ======================================== */
@media screen and (max-width: 768px) {
    #site-footer,
    .site-footer {
        overflow-x: hidden !important;
        max-width: 100vw !important;
    }
    
    .footer-widgets,
    .footer-content {
        padding: 20px 15px !important;
        max-width: 100% !important;
    }
}

/* ========================================
   Z-Index Management
   ======================================== */
@media screen and (max-width: 768px) {
    /* Orden de capas para elementos flotantes */
    .mobile-menu-overlay {
        z-index: 99999 !important;
    }
    
    .mobile-menu {
        z-index: 100000 !important;
    }
    
    .trp-language-switcher-dropdown,
    .trp-floater-ls-lang-list {
        z-index: 99998 !important;
    }
    
    .whatsapp-button,
    .wa-button {
        z-index: 99997 !important;
    }
    
    .whatsapp-widget,
    .wa-chat-box {
        z-index: 99996 !important;
    }
}

/* ========================================
   Carousel / Splide Mobile Fixes
   ======================================== */
@media screen and (max-width: 768px) {
    /* Carousel principal */
    #main-header {
        height: auto !important;
        min-height: 200px;
    }

    /* No sobreescribir padding del inner-main-header dentro del carousel */
    #main-header .inner-main-header {
        width: calc(100% - 30px) !important;
        padding: 15px !important;
        gap: 15px !important;
        flex-direction: column !important;
        justify-content: center !important;
        align-items: center !important;
        min-height: 200px !important;
    }

    /* Product slides - hacer column layout centrado verticalmente */
    #main-header .inner-main-header article {
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 12px !important;
        text-align: center;
    }

    /* Right side (product slideshow) centrado vertical */
    #main-header .inner-main-header .right {
        min-height: auto !important;
        justify-content: center !important;
        align-items: center !important;
    }

    /* Left side centrado */
    #main-header .inner-main-header .left {
        justify-content: center !important;
        align-items: center !important;
        text-align: center !important;
    }

    #main-header .inner-main-header article .wp-post-image {
        min-width: auto !important;
        width: 120px !important;
        height: 120px !important;
    }

    #main-header .inner-main-header article .title {
        text-align: center !important;
    }

    #main-header .inner-main-header article .title .big {
        font-size: 24px !important;
    }

    #main-header .inner-main-header article .title .small {
        font-size: 16px !important;
    }

    #main-header .inner-main-header article .info {
        justify-content: center !important;
    }

    /* Banner call - centrado vertical */
    .banner-call-top-home {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
    }

    .banner-call-top-home .banner-inner {
        flex-direction: column !important;
        padding: 20px 15px 30px !important;
        justify-content: center !important;
        align-items: center !important;
        width: 100% !important;
    }

    .banner-call-top-home .left-banner {
        margin: 0 !important;
        text-align: center;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
    }

    .banner-call-top-home .banner-content {
        flex-direction: column !important;
        align-items: center !important;
        gap: 10px !important;
    }

    .banner-call-top-home .text {
        font-size: 18px !important;
        line-height: 24px !important;
    }

    .banner-call-top-home .desc {
        font-size: 14px !important;
        margin-bottom: 15px !important;
    }

    .banner-call-top-home .img_bg {
        display: none !important;
    }

    /* Splide arrows mobile */
    #main-header .splide__arrow {
        width: 30px !important;
        height: 30px !important;
    }

    #main-header .splide__arrow svg {
        width: 16px !important;
        height: 16px !important;
    }
}

@media screen and (max-width: 480px) {
    #main-header .inner-main-header {
        padding: 12px 10px !important;
    }

    #main-header .inner-main-header article .wp-post-image {
        width: 90px !important;
        height: 90px !important;
    }

    #main-header .inner-main-header article .title .big {
        font-size: 20px !important;
    }

    .banner-call-top-home .text {
        font-size: 16px !important;
        line-height: 22px !important;
    }
}

/* ========================================
   SeQura Bar Mobile Fixes
   ======================================== */
@media screen and (max-width: 768px) {
    .sequra-top-bar {
        padding: 12px 15px !important;
    }

    .sequra-top-bar img {
        max-width: 100% !important;
        height: auto !important;
    }
}

@media screen and (max-width: 480px) {
    /* La imagen de 1920x30 es ilegible en móvil, reemplazar con texto */
    .sequra-top-bar {
        padding: 15px !important;
        background: linear-gradient(135deg, #00c389 0%, #00a876 100%) !important;
        border-radius: 8px;
        margin: 10px 15px !important;
    }

    .sequra-top-bar img {
        display: none !important;
    }

    .sequra-top-bar a {
        color: #fff !important;
        text-decoration: none !important;
        font-weight: 700 !important;
        font-size: 14px !important;
        line-height: 1.4 !important;
        display: block !important;
        text-align: center !important;
    }

    .sequra-top-bar a::before {
        content: "Recíbelo primero y págalo después" !important;
        display: block !important;
        font-size: 16px !important;
        margin-bottom: 4px !important;
    }

    .sequra-top-bar a::after {
        content: "Sin ningún coste con seQura →" !important;
        display: block !important;
        font-size: 13px !important;
        font-weight: 400 !important;
        opacity: 0.9;
    }
}

/* ========================================
   Utilities
   ======================================== */
@media screen and (max-width: 768px) {
    /* Clase helper para ocultar overflow */
    .no-overflow {
        overflow: hidden !important;
    }
    
    /* Clase helper para elementos que deben permanecer dentro del viewport */
    .stay-in-viewport {
        max-width: 100vw !important;
        overflow-x: hidden !important;
    }
    
    /* Fix para elementos absolutamente posicionados */
    [style*="position: absolute"] {
        max-width: 100vw !important;
    }
    
    /* Fix para elementos con position fixed */
    [style*="position: fixed"] {
        max-width: calc(100vw - 20px) !important;
    }
}