@font-face {
    font-family: 'wpml-language-popup';
    src:  url('../fonts/icons/wpml-language-popup.eot?xubzy6');
    src:  url('../fonts/icons/wpml-language-popup.eot?xubzy6#iefix') format('embedded-opentype'),
      url('../fonts/icons/wpml-language-popup.ttf?xubzy6') format('truetype'),
      url('../fonts/icons/wpml-language-popup.woff?xubzy6') format('woff'),
      url('../fonts/icons/wpml-language-popup.svg?xubzy6#wpml-language-popup') format('svg');
    font-weight: normal;
    font-style: normal;
    font-display: block;
}

[class^="wpml-language-popup-"], [class*=" wpml-language-popup-"] {
/* use !important to prevent issues with browser extensions that change fonts */
font-family: 'wpml-language-popup' !important;
speak: never;
font-style: normal;
font-weight: normal;
font-variant: normal;
text-transform: none;
line-height: 1;

/* Better Font Rendering =========== */
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
}

.wpml-language-popup-world:before {
content: "\e900";
}

.wpml-popup-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.7);
    z-index: 999999;
    display: flex;
    align-items: center;
    justify-content: center;
}

.wpml-popup-content {
    background: #fff;
    padding: 30px;
    border-radius: 8px;
    max-width: 750px;
    width: 90%;
    position: relative;
}

.wpml-popup-header {
    margin-bottom: 20px;
    text-align: center;

    .wpml-popup-title {
        margin: 0;
        font-size: 24px;
        line-height: 1.4;
        font-weight: 600;
        text-transform: uppercase;
        color: #000;
    }
}

.wpml-language-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 15px;
}

.wpml-language-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100%;
    gap: 10px;
    padding: 15px;
    background: #f6f7f7;
    border: 1px solid #ddd;
    border-radius: 4px;
    text-decoration: none;
    color: #333;
    transition: all 0.2s ease;

    &:hover {
        background: #f0f0f1;
        border-color: var(--mfn-button-bg);
        box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
        transform: translateY(-2px);
        -webkit-transform: translateY(-2px);
        -moz-transform: translateY(-2px);
        -ms-transform: translateY(-2px);
        -o-transform: translateY(-2px);
    }

    img {
        width: 100px;
        aspect-ratio: 1/0.67;
        object-fit: cover;
        border: 1px solid #ddd;
    }

    &.active {
        background: var(--mfn-button-bg);
        color: var(--mfn-button-color);
        border-color: var(--mfn-button-border-color);

        img {
            border-color: #fff;
        }
    }
}

/* Estilos para el botón fijo */
.wpml-fixed-button {
    position: fixed;
    z-index: 9999;

    &.wpml-fixed-button-right {
        right: var(--wpml-button-side-margin, 20px);
        bottom: var(--wpml-button-bottom-margin, 20px);
    }

    &.wpml-fixed-button-left {
        left: var(--wpml-button-side-margin, 20px);
        bottom: var(--wpml-button-bottom-margin, 20px);
    }

    a {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 40px;
        height: 40px;
        background: var(--mfn-button-bg);
        color: var(--mfn-button-color);
        font-size: 25px;
        line-height: 1;
        text-decoration: none;
        box-shadow: rgba(0, 0, 0, 0.19) 0px 10px 20px, rgba(0, 0, 0, 0.23) 0px 6px 6px;
        border-radius: 100px;
        -webkit-border-radius: 100px;
        -moz-border-radius: 100px;
        -ms-border-radius: 100px;
        -o-border-radius: 100px;

        &:hover {
            background: var(--mfn-button-bg);
            color: var(--mfn-button-color);
        }
    }
}

/* Estilos para el icono del shortcode */
.wpml-language-icon {
    display: inline-block;

    a {
        display: flex;
        align-items: center;
        gap: 8px;
        text-decoration: none;
        color: inherit;
    }

    i {
        font-size: 20px;
    }
}

/* Estilos responsivos */
@media screen and (max-width: 782px) {
    .wpml-popup-content {
        width: 95%;
        padding: 20px;
    }

    .wpml-language-list {
        grid-template-columns: 1fr;
    }

    .wpml-fixed-button {
        bottom: 10px;

        &-right {
            right: 10px;
        }

        &-left {
            left: 10px;
        }
    }
} 