/* ============================================================================
   LANGUAGE SWITCHER - MULTI-COLUMN LAYOUT
   
   Purpose: Provides proper 2-column and 3-column layouts for language dropdown
   when there are 8+ or 24+ languages respectively.
   
   Location: surgivalley theme custom CSS
   Date: October 17, 2025
   ============================================================================ */

/* ═══════════════════════════════════════════════════════════════════════════
   BASE DROPDOWN STYLES
   ═══════════════════════════════════════════════════════════════════════════ */

.ps-dropdown.language .ps-dropdown-menu {
    min-width: 180px;
    max-height: 500px;
    overflow-y: auto;
    padding: 8px 0;
}

.ps-dropdown.language .ps-dropdown-menu li {
    list-style: none;
    margin: 0;
    padding: 0;
}

.ps-dropdown.language .ps-dropdown-menu li a {
    display: flex;
    align-items: center;
    padding: 8px 16px;
    text-decoration: none;
    transition: background-color 0.2s ease;
}

.ps-dropdown.language .ps-dropdown-menu li a img {
    margin-right: 8px;
    vertical-align: middle;
    flex-shrink: 0;
    width: 20px;
    height: 14px;
    object-fit: cover;
    border-radius: 2px;
}

/* Better text rendering for language names */
.ps-dropdown.language .ps-dropdown-menu li a {
    font-weight: 500;
    letter-spacing: 0.01em;
}

/* Ensure text is crisp and readable */
.ps-dropdown.language .ps-dropdown-menu li a span,
.ps-dropdown.language .ps-dropdown-menu li a {
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* ═══════════════════════════════════════════════════════════════════════════
   CRITICAL FIX: Language name visibility in dropdown
   The <span> elements containing language names must have explicit white color
   ═══════════════════════════════════════════════════════════════════════════ */
.ps-dropdown.language .ps-dropdown-menu li a span {
    color: #ffffff !important;
    display: inline !important;
    visibility: visible !important;
    opacity: 1 !important;
    font-size: inherit !important;
}

/* Ensure the language name text doesn't get hidden */
.navigation__extra .ps-dropdown.language .ps-dropdown-menu li a span,
.header .ps-dropdown.language .ps-dropdown-menu li a span {
    color: #ffffff !important;
    display: inline !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   TWO-COLUMN LAYOUT (8-23 languages)
   NUCLEAR FIX: Use ultra-high specificity to override dropdown-fix-clean.css
   ═══════════════════════════════════════════════════════════════════════════ */

/* Base two-column styles */
.ps-dropdown-menu.ps-dropdown-menu--two-col {
    min-width: 500px !important;
    max-width: 550px !important;
    column-count: 2 !important;
    column-gap: 20px !important;
    padding: 12px 8px !important;
}

/* NUCLEAR: Override dropdown-fix-clean.css with higher specificity */
.navigation__extra .ps-dropdown.language .ps-dropdown-menu.ps-dropdown-menu--two-col,
.header .ps-dropdown.language .ps-dropdown-menu.ps-dropdown-menu--two-col,
body .navigation__extra .ps-dropdown.language .ps-dropdown-menu.ps-dropdown-menu--two-col {
    min-width: 500px !important;
    max-width: 550px !important;
    column-count: 2 !important;
    column-gap: 20px !important;
}

.ps-dropdown-menu.ps-dropdown-menu--two-col li {
    break-inside: avoid;
    page-break-inside: avoid;
    -webkit-column-break-inside: avoid;
    display: inline-block;
    width: 100%;
    margin-bottom: 4px;
}

/* Link styles - CRITICAL: overflow visible to show text */
.ps-dropdown-menu.ps-dropdown-menu--two-col li a {
    padding: 10px 14px !important;
    white-space: nowrap !important;
    overflow: visible !important;  /* CHANGED from hidden to show full text */
    text-overflow: clip !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    line-height: 1.3 !important;
    border-radius: 4px !important;
    transition: all 0.2s ease !important;
    min-height: 38px !important;
    width: auto !important;  /* Let width expand naturally */
    min-width: 180px !important;  /* Ensure enough room for flag + text */
}

/* NUCLEAR: Override all competing selectors for link width */
.navigation__extra .ps-dropdown.language .ps-dropdown-menu.ps-dropdown-menu--two-col li a,
.header .ps-dropdown.language .ps-dropdown-menu.ps-dropdown-menu--two-col li a,
body .ps-dropdown-menu.ps-dropdown-menu--two-col li a {
    overflow: visible !important;
    width: auto !important;
    min-width: 180px !important;
    display: flex !important;
}

.ps-dropdown-menu.ps-dropdown-menu--two-col li a:hover {
    background-color: rgba(255, 255, 255, 0.1);
    padding-left: 16px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   THREE-COLUMN LAYOUT (24+ languages)
   NUCLEAR FIX: Use ultra-high specificity to override dropdown-fix-clean.css
   ═══════════════════════════════════════════════════════════════════════════ */

/* Base three-column styles */
.ps-dropdown-menu.ps-dropdown-menu--three-col {
    min-width: 750px !important;
    max-width: 820px !important;
    column-count: 3 !important;
    column-gap: 16px !important;
    padding: 12px 8px !important;
}

/* NUCLEAR: Override dropdown-fix-clean.css with higher specificity */
.navigation__extra .ps-dropdown.language .ps-dropdown-menu.ps-dropdown-menu--three-col,
.header .ps-dropdown.language .ps-dropdown-menu.ps-dropdown-menu--three-col,
body .navigation__extra .ps-dropdown.language .ps-dropdown-menu.ps-dropdown-menu--three-col {
    min-width: 750px !important;
    max-width: 820px !important;
    column-count: 3 !important;
    column-gap: 16px !important;
}

.ps-dropdown-menu.ps-dropdown-menu--three-col li {
    break-inside: avoid;
    page-break-inside: avoid;
    -webkit-column-break-inside: avoid;
    display: inline-block;
    width: 100%;
    margin-bottom: 3px;
}

/* Link styles - CRITICAL: overflow visible to show text */
.ps-dropdown-menu.ps-dropdown-menu--three-col li a {
    padding: 9px 12px !important;
    white-space: nowrap !important;
    overflow: visible !important;  /* CHANGED from hidden to show full text */
    text-overflow: clip !important;
    display: flex !important;
    align-items: center !important;
    gap: 7px !important;
    font-size: 0.92em !important;
    line-height: 1.3 !important;
    border-radius: 4px !important;
    transition: all 0.2s ease !important;
    min-height: 36px !important;
    width: auto !important;  /* Let width expand naturally */
    min-width: 160px !important;  /* Ensure enough room for flag + text */
}

/* NUCLEAR: Override all competing selectors for link width */
.navigation__extra .ps-dropdown.language .ps-dropdown-menu.ps-dropdown-menu--three-col li a,
.header .ps-dropdown.language .ps-dropdown-menu.ps-dropdown-menu--three-col li a,
body .ps-dropdown-menu.ps-dropdown-menu--three-col li a {
    overflow: visible !important;
    width: auto !important;
    min-width: 160px !important;
    display: flex !important;
}

.ps-dropdown-menu.ps-dropdown-menu--three-col li a:hover {
    background-color: rgba(255, 255, 255, 0.1);
    padding-left: 14px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   IMPROVED MOBILE RESPONSIVENESS
   Updated: October 19, 2025
   ═══════════════════════════════════════════════════════════════════════════ */

/* Prevent horizontal overflow on all devices */
.ps-dropdown.language {
    position: relative;
}

.ps-dropdown.language .ps-dropdown-menu {
    max-width: calc(100vw - 40px);
}

/* Tablet and below: reduce three-column to two-column */
@media (max-width: 768px) {
    .ps-dropdown-menu.ps-dropdown-menu--three-col {
        min-width: 400px !important;
        max-width: 480px;
        column-count: 2;
        column-gap: 12px;
    }
    
    .ps-dropdown-menu.ps-dropdown-menu--three-col li a {
        font-size: 0.85em;
        padding: 6px 8px;
        gap: 4px;
    }
}

/* Mobile: reduce two-column width */
@media (max-width: 576px) {
    .ps-dropdown-menu.ps-dropdown-menu--two-col {
        min-width: 320px !important;
        max-width: 380px;
        column-gap: 8px;
    }
    
    .ps-dropdown-menu.ps-dropdown-menu--two-col li a {
        font-size: 0.85em;
        padding: 6px 10px;
        gap: 4px;
    }
}

/* Small mobile: single column for better fit */
@media (max-width: 480px) {
    .ps-dropdown-menu.ps-dropdown-menu--two-col,
    .ps-dropdown-menu.ps-dropdown-menu--three-col {
        min-width: 220px !important;
        max-width: 280px;
        column-count: 1;
    }
    
    .ps-dropdown-menu.ps-dropdown-menu--two-col li a,
    .ps-dropdown-menu.ps-dropdown-menu--three-col li a {
        padding: 8px 12px;
        font-size: 0.9em;
    }
}

/* Extra small mobile (very narrow screens) */
@media (max-width: 360px) {
    .ps-dropdown-menu.ps-dropdown-menu--two-col,
    .ps-dropdown-menu.ps-dropdown-menu--three-col {
        min-width: 180px !important;
        max-width: 220px;
        max-height: 400px;
    }
}

/* ═══════════════════════════════════════════════════════════════════════════
   RTL SUPPORT
   ═══════════════════════════════════════════════════════════════════════════ */

body[dir="rtl"] .ps-dropdown.language .ps-dropdown-menu li a img {
    margin-right: 0;
    margin-left: 8px;
}

body[dir="rtl"] .ps-dropdown-menu.ps-dropdown-menu--two-col li a,
body[dir="rtl"] .ps-dropdown-menu.ps-dropdown-menu--three-col li a {
    direction: rtl;
    text-align: right;
}

/* ═══════════════════════════════════════════════════════════════════════════
   SCROLLBAR STYLING (optional enhancement)
   ═══════════════════════════════════════════════════════════════════════════ */

.ps-dropdown.language .ps-dropdown-menu::-webkit-scrollbar {
    width: 6px;
}

.ps-dropdown.language .ps-dropdown-menu::-webkit-scrollbar-track {
    background: rgba(0, 0, 0, 0.05);
    border-radius: 3px;
}

.ps-dropdown.language .ps-dropdown-menu::-webkit-scrollbar-thumb {
    background: rgba(0, 0, 0, 0.2);
    border-radius: 3px;
}

.ps-dropdown.language .ps-dropdown-menu::-webkit-scrollbar-thumb:hover {
    background: rgba(0, 0, 0, 0.3);
}

/* ═══════════════════════════════════════════════════════════════════════════
   COMPATIBILITY WITH HEADER DROPDOWN FIX
   Ensure this works with header-dropdown-fix.css
   ═══════════════════════════════════════════════════════════════════════════ */

/* Maintain header background color inheritance */
.navigation__extra .ps-dropdown.language .ps-dropdown-menu.ps-dropdown-menu--two-col,
.navigation__extra .ps-dropdown.language .ps-dropdown-menu.ps-dropdown-menu--three-col {
    background-color: var(--color-1st) !important;
}

/* Ensure white text on colored background */
.navigation__extra .ps-dropdown.language .ps-dropdown-menu--two-col li a,
.navigation__extra .ps-dropdown.language .ps-dropdown-menu--three-col li a {
    color: #ffffff !important;
}

/* Hover states */
.navigation__extra .ps-dropdown.language .ps-dropdown-menu--two-col li a:hover,
.navigation__extra .ps-dropdown.language .ps-dropdown-menu--three-col li a:hover {
    background-color: rgba(255, 255, 255, 0.15) !important;
}
