/* Modern Language Bar - Clean Design with Flags Only */

/* Language Button */
#languageDropdown,
#languageDropdownDesktop,
.language-btn {
    width: 44px !important;
    height: 44px !important;
    border-radius: 10px !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border: 2px solid rgba(99, 102, 241, 0.3) !important;
    transition: all 0.2s ease !important;
    background: rgba(99, 102, 241, 0.08) !important;
    box-shadow: 0 2px 6px rgba(99, 102, 241, 0.15) !important;
    position: relative !important;
    overflow: visible !important;
    font-size: 0 !important;
    text-indent: -9999px !important;
    color: transparent !important;
}

/* Hide ALL text content in button EXCEPT language-flag */
#languageDropdown > *:not(.language-flag),
#languageDropdownDesktop > *:not(.language-flag),
.language-btn > *:not(.language-flag) {
    display: none !important;
    font-size: 0 !important;
    width: 0 !important;
    height: 0 !important;
    opacity: 0 !important;
    visibility: hidden !important;
}

/* Ensure language-flag span is always visible */
#languageDropdown .language-flag,
#languageDropdownDesktop .language-flag,
.language-btn .language-flag {
    display: block !important;
    opacity: 1 !important;
    visibility: visible !important;
    width: auto !important;
    height: auto !important;
    font-size: 1.75rem !important;
}

/* Hide pseudo-elements */
#languageDropdown::before,
#languageDropdown::after,
#languageDropdownDesktop::before,
#languageDropdownDesktop::after,
.language-btn::before,
.language-btn::after {
    display: none !important;
    content: none !important;
}

.language-btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.1) 0%, rgba(255, 255, 255, 0.05) 100%);
    opacity: 0;
    transition: opacity 0.3s ease;
}

.language-btn:hover::before {
    opacity: 1;
}

#languageDropdown:hover,
#languageDropdownDesktop:hover,
.language-btn:hover {
    background: rgba(99, 102, 241, 0.15) !important;
    border-color: rgba(99, 102, 241, 0.5) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px rgba(99, 102, 241, 0.25) !important;
}

#languageDropdown:active,
#languageDropdownDesktop:active,
.language-btn:active {
    transform: translateY(0) scale(0.98) !important;
}

/* Dark mode button */
[data-bs-theme="dark"] #languageDropdown,
[data-bs-theme="dark"] #languageDropdownDesktop,
[data-bs-theme="dark"] .language-btn {
    background: rgba(99, 102, 241, 0.15) !important;
    border-color: rgba(99, 102, 241, 0.4) !important;
    box-shadow: 0 2px 6px rgba(99, 102, 241, 0.2) !important;
}

[data-bs-theme="dark"] #languageDropdown:hover,
[data-bs-theme="dark"] #languageDropdownDesktop:hover,
[data-bs-theme="dark"] .language-btn:hover {
    background: rgba(99, 102, 241, 0.25) !important;
    border-color: rgba(99, 102, 241, 0.6) !important;
    box-shadow: 0 4px 12px rgba(99, 102, 241, 0.35) !important;
}

/* Language Flag in Button - MUST be visible */
.language-flag,
#languageDropdown .language-flag,
#languageDropdownDesktop .language-flag,
.language-btn .language-flag,
.app-header .language-btn .language-flag,
.app-header #languageDropdown .language-flag,
.app-header #languageDropdownDesktop .language-flag {
    font-size: 1.75rem !important;
    line-height: 1 !important;
    display: block !important;
    filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.1)) !important;
    transition: transform 0.2s ease !important;
    z-index: 10 !important;
    position: relative !important;
    text-indent: 0 !important;
    color: inherit !important;
    opacity: 1 !important;
    visibility: visible !important;
    width: auto !important;
    height: auto !important;
    font-family: "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji", sans-serif !important;
    font-style: normal !important;
    font-weight: normal !important;
    text-rendering: auto !important;
    -webkit-font-smoothing: antialiased !important;
    -moz-osx-font-smoothing: grayscale !important;
}

.language-btn:hover .language-flag {
    transform: scale(1.1) !important;
}

/* Hide any text or code */
.language-btn .language-code,
#languageDropdownDesktop .language-code,
#languageDropdown .language-code,
.language-btn > *:not(.language-flag),
#languageDropdownDesktop > *:not(.language-flag),
#languageDropdown > *:not(.language-flag) {
    display: none !important;
}

/* Dropdown Menu */
.dropdown-menu.language-dropdown {
    border: none !important;
    border-radius: 16px !important;
    padding: 12px !important;
    margin-top: 8px !important;
    min-width: auto !important;
    width: auto !important;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15) !important;
    backdrop-filter: blur(20px) !important;
    background: rgba(255, 255, 255, 0.95) !important;
    animation: slideDown 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

[data-bs-theme="dark"] .dropdown-menu.language-dropdown {
    background: rgba(31, 41, 55, 0.95) !important;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.4) !important;
}

.dropdown-menu.language-dropdown::before {
    content: '';
    position: absolute;
    top: -6px;
    right: 20px;
    width: 0;
    height: 0;
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    border-bottom: 6px solid rgba(255, 255, 255, 0.95);
}

[data-bs-theme="dark"] .dropdown-menu.language-dropdown::before {
    border-bottom-color: rgba(31, 41, 55, 0.95);
}

@keyframes slideDown {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Language Grid - Clean grid with only flags */
.language-grid {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 8px !important;
    padding: 0 !important;
    margin: 0 !important;
    width: 100% !important;
    justify-items: center !important;
    align-items: center !important;
    visibility: visible !important;
    opacity: 1 !important;
}

/* Language Flag Items - ONLY FLAGS, NO TEXT */
.language-flag-item {
    width: 56px !important;
    height: 56px !important;
    border-radius: 12px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    position: relative !important;
    background: rgba(0, 0, 0, 0.02) !important;
    border: 2px solid transparent !important;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
    text-decoration: none !important;
    cursor: pointer !important;
    overflow: visible !important;
    visibility: visible !important;
    opacity: 1 !important;
}

/* Hide text content but keep structural elements visible */
.language-flag-item > *:not(.flag-emoji):not(.active-indicator) {
    display: none !important;
}

.language-flag-item::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(135deg, rgba(102, 126, 234, 0.1) 0%, rgba(118, 75, 162, 0.1) 100%);
    opacity: 0;
    transition: opacity 0.3s ease;
}

.language-flag-item:hover {
    transform: translateY(-2px) scale(1.05) !important;
    background: rgba(102, 126, 234, 0.1) !important;
    border-color: rgba(102, 126, 234, 0.3) !important;
    box-shadow: 0 4px 12px rgba(102, 126, 234, 0.2) !important;
}

.language-flag-item:hover::before {
    opacity: 1;
}

.language-flag-item:active {
    transform: translateY(0) scale(0.98) !important;
}

.language-flag-item.active {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%) !important;
    border-color: rgba(255, 255, 255, 0.3) !important;
    box-shadow: 0 4px 16px rgba(102, 126, 234, 0.4) !important;
    transform: scale(1.05) !important;
}

.language-flag-item.active::before {
    opacity: 0;
}

/* Flag Emoji - MUST be visible */
.flag-emoji {
    font-size: 2rem !important;
    line-height: 1 !important;
    display: block !important;
    filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.1)) !important;
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
    z-index: 2 !important;
    position: relative !important;
    opacity: 1 !important;
    visibility: visible !important;
    width: auto !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    color: inherit !important;
    font-size: 2rem !important;
    text-indent: 0 !important;
    font-family: inherit !important;
}

.language-flag-item:hover .flag-emoji {
    transform: scale(1.15) rotate(5deg);
}

.language-flag-item.active .flag-emoji {
    filter: drop-shadow(0 2px 6px rgba(0, 0, 0, 0.2)) !important;
}

/* Active Indicator */
.active-indicator {
    position: absolute !important;
    bottom: 4px !important;
    right: 4px !important;
    width: 18px !important;
    height: 18px !important;
    border-radius: 50% !important;
    background: rgba(255, 255, 255, 0.95) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2) !important;
    z-index: 2 !important;
    animation: scaleIn 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.active-indicator i {
    font-size: 10px !important;
    color: #667eea !important;
}

@keyframes scaleIn {
    from {
        transform: scale(0);
        opacity: 0;
    }
    to {
        transform: scale(1);
        opacity: 1;
    }
}

/* Dark Mode Support */
[data-bs-theme="dark"] .language-flag-item {
    background: rgba(255, 255, 255, 0.05) !important;
}

[data-bs-theme="dark"] .language-flag-item:hover {
    background: rgba(102, 126, 234, 0.2) !important;
    border-color: rgba(102, 126, 234, 0.4) !important;
}

[data-bs-theme="dark"] .language-flag-item.active {
    background: linear-gradient(135deg, rgba(102, 126, 234, 0.9) 0%, rgba(118, 75, 162, 0.9) 100%) !important;
    border-color: rgba(255, 255, 255, 0.2) !important;
}

[data-bs-theme="dark"] .active-indicator {
    background: rgba(255, 255, 255, 0.95) !important;
}

[data-bs-theme="dark"] .active-indicator i {
    color: #667eea !important;
}

/* Mobile Responsive */
@media (max-width: 768px) {
    #languageDropdown,
    .language-btn {
        width: 42px !important;
        height: 42px !important;
        border-radius: 10px !important;
        border: 2px solid rgba(99, 102, 241, 0.3) !important;
        background: rgba(99, 102, 241, 0.08) !important;
        box-shadow: 0 2px 6px rgba(99, 102, 241, 0.15) !important;
    }
    
    .language-flag {
        font-size: 1.7rem !important;
        filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.1)) !important;
    }
    
    #languageDropdown:hover,
    .language-btn:hover {
        background: rgba(99, 102, 241, 0.15) !important;
        border-color: rgba(99, 102, 241, 0.5) !important;
        box-shadow: 0 4px 12px rgba(99, 102, 241, 0.25) !important;
    }
    
    .language-grid {
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 6px !important;
        padding: 4px !important;
    }
    
    .language-flag-item {
        width: 50px !important;
        height: 50px !important;
        border-radius: 10px !important;
    }
    
    /* Hide text but keep flags visible on mobile */
    .language-flag-item > *:not(.flag-emoji):not(.active-indicator) {
        display: none !important;
    }
    
    .flag-emoji {
        font-size: 1.75rem !important;
        display: block !important;
        opacity: 1 !important;
        visibility: visible !important;
    }
    
    .dropdown-menu.language-dropdown {
        padding: 10px !important;
        border-radius: 14px !important;
        min-width: auto !important;
        width: auto !important;
    }
}

/* Desktop Styles */
@media (min-width: 992px) {
    .app-header .language-btn,
    .app-header #languageDropdownDesktop,
    .app-header #languageDropdown {
        width: 46px !important;
        height: 46px !important;
        border-radius: 10px !important;
        padding: 0 !important;
        font-size: 0 !important;
        text-indent: -9999px !important;
        background: rgba(99, 102, 241, 0.08) !important;
        border: 2px solid rgba(99, 102, 241, 0.3) !important;
        box-shadow: 0 2px 6px rgba(99, 102, 241, 0.15) !important;
    }
    
    /* Override app.css desktop button styles - hide all text */
    .app-header .language-btn span:not(.language-flag),
    .app-header #languageDropdownDesktop span:not(.language-flag),
    .app-header #languageDropdown span:not(.language-flag) {
        display: none !important;
        font-size: 0 !important;
        width: 0 !important;
        height: 0 !important;
        opacity: 0 !important;
        visibility: hidden !important;
    }
    
    .app-header .language-flag {
        font-size: 1.9rem !important;
        display: block !important;
        text-indent: 0 !important;
        color: inherit !important;
        opacity: 1 !important;
        visibility: visible !important;
        filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.1)) !important;
    }
    
    .app-header .language-btn:hover,
    .app-header #languageDropdownDesktop:hover,
    .app-header #languageDropdown:hover {
        background: rgba(99, 102, 241, 0.15) !important;
        border-color: rgba(99, 102, 241, 0.5) !important;
        transform: translateY(-1px) !important;
        box-shadow: 0 4px 12px rgba(99, 102, 241, 0.25) !important;
    }
    
    [data-bs-theme="dark"] .app-header .language-btn,
    [data-bs-theme="dark"] .app-header #languageDropdownDesktop,
    [data-bs-theme="dark"] .app-header #languageDropdown {
        background: rgba(99, 102, 241, 0.15) !important;
        border-color: rgba(99, 102, 241, 0.4) !important;
        box-shadow: 0 2px 6px rgba(99, 102, 241, 0.2) !important;
    }
    
    [data-bs-theme="dark"] .app-header .language-btn:hover,
    [data-bs-theme="dark"] .app-header #languageDropdownDesktop:hover,
    [data-bs-theme="dark"] .app-header #languageDropdown:hover {
        background: rgba(99, 102, 241, 0.25) !important;
        border-color: rgba(99, 102, 241, 0.6) !important;
        box-shadow: 0 4px 12px rgba(99, 102, 241, 0.35) !important;
    }
    
    .language-grid {
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 10px !important;
        padding: 8px !important;
    }
    
    /* Desktop dropdown items - flags visible */
    .language-flag-item {
        width: 60px !important;
        height: 60px !important;
    }
    
    /* Hide text but keep flags visible on desktop */
    .language-flag-item > *:not(.flag-emoji):not(.active-indicator) {
        display: none !important;
    }
    
    .flag-emoji {
        font-size: 2.25rem !important;
        display: block !important;
        opacity: 1 !important;
        visibility: visible !important;
    }
}

/* Remove old styles - ensure no text codes are shown */
.language-option,
.language-name,
.flag-icon,
.check-icon,
.language-code {
    display: none !important;
    font-size: 0 !important;
    opacity: 0 !important;
    visibility: hidden !important;
    width: 0 !important;
    height: 0 !important;
}

/* Global rule: hide text but keep flags visible */
.language-dropdown .language-flag-item > *:not(.flag-emoji):not(.active-indicator) {
    display: none !important;
}

/* Ensure flags are always visible */
.language-dropdown .flag-emoji {
    display: block !important;
    opacity: 1 !important;
    visibility: visible !important;
    font-size: 2rem !important;
}
