/* ==========================================
   LRAL Website - Responsive Styles
   Mobile-First Responsive Design
   ========================================== */

/* ==========================================
   Tablet (768px and below)
   ========================================== */

@media (max-width: 768px) {
    /* Typography adjustments */
    :root {
        --text-6xl: 2.5rem;  /* Reduce hero title size */
        --text-5xl: 2rem;
        --text-4xl: 1.75rem;
        --text-3xl: 1.5rem;
        --header-height: 70px;
    }

    /* Container padding */
    .container {
        padding-left: var(--space-4);
        padding-right: var(--space-4);
    }

    /* Section padding */
    .section-padding {
        padding-top: var(--space-12);
        padding-bottom: var(--space-12);
    }

    /* ==========================================
       Header & Navigation
       ========================================== */

    .main-nav {
        height: var(--header-height);
    }

    /* Header layout - hamburger LEFT, language RIGHT */
    .nav-wrapper {
        display: flex;
        align-items: center;
        justify-content: space-between;
        width: 100%;
    }

    .mobile-menu-toggle {
        order: 1; /* LEFT SIDE */
        margin-right: auto;
    }

    .desktop-lang-switcher {
        order: 3; /* RIGHT SIDE - Hidden on mobile */
        display: none !important;
    }

    .mobile-lang-switcher {
        display: none !important; /* Hidden by default */
    }

    /* Show mobile lang switcher when inside nav-menu */
    .nav-menu .menu-item-lang-switcher {
        margin-top: auto !important;
        border-top: 2px solid rgba(255, 255, 255, 0.15);
        padding-top: var(--space-6) !important;
        order: 999 !important;
        width: 100% !important;
        list-style: none !important;
        border-bottom: none !important;
        background: transparent !important;
    }

    .nav-menu .menu-item-lang-switcher .mobile-lang-switcher {
        display: flex !important;
        justify-content: center;
        gap: 12px;
        padding: 0 var(--space-4) var(--space-6);
        width: 100%;
    }

    .nav-menu {
        order: 2; /* CENTER (hidden on mobile) */
    }

    .site-logo {
        height: 40px;
    }

    .logo-text {
        font-size: var(--text-lg);
    }

    /* Show mobile menu toggle - CRITICAL for mobile navigation */
    /* Using multiple selectors to increase specificity */
    .site-header .mobile-menu-toggle,
    .main-nav .mobile-menu-toggle,
    .nav-wrapper .mobile-menu-toggle,
    button.mobile-menu-toggle,
    .mobile-menu-toggle {
        display: block !important;
        width: 40px !important;
        height: 40px !important;
        z-index: 1001 !important;
        position: relative !important;
        background: transparent !important;
        border: 2px solid transparent !important;
        cursor: pointer !important;
        padding: var(--space-2) !important;
        visibility: visible !important;
        opacity: 1 !important;
        border-radius: 8px !important;
        transition: all 0.2s ease !important;
    }

    .mobile-menu-toggle:hover {
        background: rgba(255, 255, 255, 0.1) !important;
    }

    .mobile-menu-toggle:focus {
        outline: none !important;
        background: rgba(255, 255, 255, 0.15) !important;
        box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.3) !important;
    }

    /* Ensure hamburger lines are visible - with proper positioning */
    .mobile-menu-toggle .hamburger-line,
    .mobile-menu-toggle > span {
        display: block !important;
        width: 28px !important;
        height: 3px !important;
        background-color: #ffffff !important;
        border-radius: 9999px !important;
        transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
        visibility: visible !important;
        opacity: 1 !important;
        position: absolute !important;
        left: 0 !important;
    }

    /* Position lines in hamburger state */
    .mobile-menu-toggle .hamburger-line:nth-child(1) {
        top: 2px !important;
    }

    .mobile-menu-toggle .hamburger-line:nth-child(2) {
        top: 50% !important;
        transform: translateY(-50%) !important;
    }

    .mobile-menu-toggle .hamburger-line:nth-child(3) {
        bottom: 2px !important;
    }

    /* Perfect X Animation for Hamburger */
    .mobile-menu-toggle[aria-expanded="true"] .hamburger-line:nth-child(1) {
        top: 50% !important;
        transform: translateY(-50%) rotate(45deg) !important;
    }

    .mobile-menu-toggle[aria-expanded="true"] .hamburger-line:nth-child(2) {
        opacity: 0 !important;
        transform: translateY(-50%) scale(0) !important;
    }

    .mobile-menu-toggle[aria-expanded="true"] .hamburger-line:nth-child(3) {
        bottom: 50% !important;
        transform: translateY(50%) rotate(-45deg) !important;
    }

    /* Mobile Menu Backdrop Overlay - Enhanced blur for "airiness" */
    .menu-backdrop {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        width: 100% !important;
        height: 100% !important;
        background: rgba(0, 0, 0, 0.4) !important;
        backdrop-filter: blur(8px) saturate(120%) !important;
        -webkit-backdrop-filter: blur(8px) saturate(120%) !important;
        opacity: 0 !important;
        visibility: hidden !important;
        transition: all 0.35s cubic-bezier(0.4, 0, 0.2, 1) !important;
        z-index: 999 !important;
    }

    .menu-backdrop.active {
        opacity: 1 !important;
        visibility: visible !important;
    }

    body.menu-open {
        overflow: hidden !important;
    }

    /* Mobile Navigation Menu - SLIDES FROM LEFT */
    /* Dark glassmorphism with white text */
    .nav-menu {
        position: fixed;
        top: 0;
        left: -100%;
        width: 320px;
        max-width: 85vw;
        height: 100vh;
        display: flex;
        flex-direction: column;
        /* Dark glass: semi-transparent black with blur */
        background: rgba(0, 0, 0, 0.6) !important;
        backdrop-filter: blur(16px) saturate(180%) brightness(0.9) !important;
        -webkit-backdrop-filter: blur(16px) saturate(180%) brightness(0.9) !important;
        /* Enhanced shadows and border for depth */
        border-right: 1px solid rgba(255, 255, 255, 0.15);
        box-shadow:
            2px 0 24px rgba(0, 0, 0, 0.3),
            0 0 0 1px rgba(255, 255, 255, 0.1) inset;
        padding: var(--space-20) var(--space-6) var(--space-6);
        gap: 0;
        overflow-y: auto;
        transition: left 0.35s cubic-bezier(0.4, 0, 0.2, 1);
        z-index: 1000;
    }

    .nav-menu.active {
        left: 0;
    }

    /* Fallback for browsers without backdrop-filter support */
    @supports not (backdrop-filter: blur(1px)) {
        .nav-menu {
            background: rgba(0, 0, 0, 0.95) !important;
        }
    }

    /* Mobile language switcher buttons styling - LRAL red gradient with WHITE text */
    .nav-menu .menu-item-lang-switcher .lang-btn {
        padding: 14px 28px !important;
        background: linear-gradient(135deg, #73281E 0%, #9e3039 100%) !important;
        color: #ffffff !important;
        border: none !important;
        border-radius: 14px !important;
        font-weight: 700 !important;
        font-size: 16px !important;
        cursor: pointer !important;
        transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
        min-width: 80px !important;
        box-shadow: 0 6px 20px rgba(115, 40, 30, 0.35) !important;
        text-transform: uppercase !important;
        letter-spacing: 1.2px !important;
        -webkit-text-fill-color: #ffffff !important;
        text-shadow: none !important;
    }

    .nav-menu .menu-item-lang-switcher .lang-btn:hover {
        transform: translateY(-3px) scale(1.05) !important;
        box-shadow: 0 8px 28px rgba(115, 40, 30, 0.45) !important;
        background: linear-gradient(135deg, #8a2f24 0%, #b23a45 100%) !important;
        color: #ffffff !important;
        -webkit-text-fill-color: #ffffff !important;
    }

    .nav-menu .menu-item-lang-switcher .lang-btn.active {
        background: linear-gradient(135deg, #8a2f24 0%, #b23a45 100%) !important;
        box-shadow: 0 8px 32px rgba(115, 40, 30, 0.55) !important;
        transform: scale(1.1) !important;
        font-weight: 800 !important;
        color: #ffffff !important;
        -webkit-text-fill-color: #ffffff !important;
    }

    .nav-item {
        width: 100%;
        border-bottom: 1px solid var(--color-gray-200);
    }

    .nav-item:last-child {
        border-bottom: none;
    }

    .nav-link {
        width: 100%;
        padding: var(--space-4) var(--space-3);
        justify-content: flex-start;
        color: #1f2937 !important;
        font-weight: 500 !important;
        font-size: 16px !important;
        border-radius: 8px;
        transition: all 0.2s ease;
        text-decoration: none !important;
        display: block !important;
    }

    .nav-link:hover,
    .nav-item.current-menu-item .nav-link {
        background: rgba(115, 40, 30, 0.08) !important;
        color: #73281E !important;
    }

    /* Ensure menu items are visible - CRITICAL */
    .nav-menu li,
    .nav-menu li a,
    .nav-menu .menu-item,
    .nav-menu .menu-item a,
    .nav-menu .menu-item > a {
        color: #1f2937 !important;
        display: block !important;
        visibility: visible !important;
        opacity: 1 !important;
    }

    /* WordPress default menu item styling for mobile */
    .nav-menu .menu-item {
        list-style: none !important;
        margin: 0 0 8px 0 !important;
        padding: 0 !important;
    }

    .nav-menu .menu-item a,
    .nav-menu .menu-item > a {
        padding: 18px 20px !important;
        /* White text for dark background */
        color: rgba(255, 255, 255, 0.95) !important;
        font-size: 18px !important;
        font-weight: 600 !important;
        text-decoration: none !important;
        width: 100% !important;
        display: block !important;
        border-radius: 12px !important;
        background: transparent !important;
        -webkit-text-fill-color: rgba(255, 255, 255, 0.95) !important;
        /* Subtle dark shadow for depth on glass */
        text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3) !important;
        letter-spacing: -0.01em !important;
        transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
        position: relative !important;
        text-rendering: optimizeLegibility !important;
        -webkit-font-smoothing: antialiased !important;
    }

    .nav-menu .menu-item a:hover,
    .nav-menu .menu-item.current-menu-item > a {
        /* Glassmorphic hover - lighter glass effect */
        background: rgba(255, 255, 255, 0.15) !important;
        color: #ffffff !important;
        -webkit-text-fill-color: #ffffff !important;
        transform: translateX(6px) !important;
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2) !important;
    }

    .nav-menu .menu-item.current-menu-item > a {
        font-weight: 700 !important;
        border-left: 3px solid #ffffff !important;
        padding-left: 17px !important;
        background: rgba(255, 255, 255, 0.12) !important;
    }

    /* Mobile Dropdown */
    .dropdown-menu {
        position: static;
        opacity: 1;
        visibility: visible;
        transform: none;
        box-shadow: none;
        background-color: var(--color-gray-50);
        padding: var(--space-3);
        margin-top: var(--space-2);
        max-height: 0;
        overflow: hidden;
        transition: max-height var(--transition-base);
    }

    .dropdown-toggle[aria-expanded="true"] + .dropdown-menu {
        max-height: 500px;
    }

    .dropdown-link {
        padding: var(--space-3);
    }

    /* Language Switcher - move to mobile menu */
    .language-switcher {
        margin-top: var(--space-6);
        justify-content: center;
    }

    /* ==========================================
       Hero Section
       ========================================== */

    .hero-section {
        padding: var(--space-12) 0;
    }

    .hero-section .container {
        grid-template-columns: 1fr;
        gap: var(--space-8);
    }

    .hero-content {
        text-align: center;
    }

    .hero-title {
        font-size: var(--text-4xl);
    }

    .hero-subtitle {
        font-size: var(--text-lg);
    }

    .hero-ctas {
        justify-content: center;
    }

    .hero-logo {
        max-width: 250px;
        margin: 0 auto;
    }

    .frequency-display {
        bottom: 10%;
        right: 10%;
    }

    /* ==========================================
       News Grid
       ========================================== */

    .news-grid {
        grid-template-columns: 1fr;
        gap: var(--space-6);
    }

    /* ==========================================
       Events Slider
       ========================================== */

    .event-card {
        width: 280px;
    }

    /* ==========================================
       Activities Grid
       ========================================== */

    .activities-grid {
        grid-template-columns: 1fr;
        gap: var(--space-6);
    }

    .activity-block {
        padding: var(--space-6);
    }

    .activity-icon {
        width: 64px;
        height: 64px;
    }

    /* ==========================================
       Photo Gallery
       ========================================== */

    .photo-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--space-3);
    }

    .photo-item.photo-large,
    .photo-item.photo-wide {
        grid-column: span 2;
    }

    .photo-item.photo-tall {
        grid-row: span 1;
    }

    /* ==========================================
       CTA Section
       ========================================== */

    .cta-title {
        font-size: var(--text-3xl);
    }

    .cta-text {
        font-size: var(--text-lg);
    }

    /* ==========================================
       Footer
       ========================================== */

    .footer-grid {
        grid-template-columns: 1fr;
        gap: var(--space-6);
    }

    .footer-bottom {
        flex-direction: column;
        gap: var(--space-4);
        text-align: center;
    }

    /* ==========================================
       Back to Top Button
       ========================================== */

    .back-to-top {
        bottom: var(--space-6);
        right: var(--space-6);
        width: 44px;
        height: 44px;
    }

    /* ==========================================
       Section Headers
       ========================================== */

    .section-header {
        flex-direction: column;
        gap: var(--space-4);
        align-items: flex-start;
    }

    .section-title {
        font-size: var(--text-3xl);
    }

    /* ==========================================
       Buttons
       ========================================== */

    .btn {
        width: 100%;
        justify-content: center;
    }

    .hero-ctas .btn {
        width: auto;
        min-width: 160px;
    }

    /* ==========================================
       Tables
       ========================================== */

    .table th,
    .table td {
        padding: var(--space-3) var(--space-4);
        font-size: var(--text-sm);
    }
}

/* ==========================================
   Mobile (480px and below)
   ========================================== */

@media (max-width: 480px) {
    /* Typography adjustments */
    :root {
        --text-6xl: 2rem;
        --text-5xl: 1.75rem;
        --text-4xl: 1.5rem;
        --text-3xl: 1.25rem;
    }

    /* Container padding */
    .container {
        padding-left: var(--space-3);
        padding-right: var(--space-3);
    }

    /* Section padding */
    .section-padding {
        padding-top: var(--space-10);
        padding-bottom: var(--space-10);
    }

    /* Hero Section */
    .hero-section {
        padding: var(--space-10) 0;
    }

    .hero-title {
        font-size: var(--text-3xl);
    }

    .hero-subtitle {
        font-size: var(--text-base);
    }

    .hero-ctas {
        flex-direction: column;
        width: 100%;
    }

    .hero-ctas .btn {
        width: 100%;
    }

    /* Event Cards */
    .event-card {
        width: 260px;
        flex-direction: column;
        gap: var(--space-4);
    }

    .event-date-badge {
        width: 100%;
        height: auto;
        flex-direction: row;
        padding: var(--space-3);
        gap: var(--space-3);
    }

    .event-day {
        font-size: var(--text-2xl);
    }

    /* Photo Gallery - Single Column */
    .photo-grid {
        grid-template-columns: 1fr;
    }

    .photo-item.photo-large,
    .photo-item.photo-wide,
    .photo-item.photo-tall {
        grid-column: span 1;
        grid-row: span 1;
    }

    /* CTA Section */
    .cta-section {
        padding: var(--space-12) 0;
    }

    .cta-title {
        font-size: var(--text-2xl);
    }

    .cta-text {
        font-size: var(--text-base);
    }

    /* Footer */
    .footer-bottom-links {
        flex-direction: column;
        gap: var(--space-2);
    }

    .separator {
        display: none;
    }

    /* Section Titles */
    .section-title {
        font-size: var(--text-2xl);
    }

    .section-subtitle {
        font-size: var(--text-base);
    }

    /* Activity Blocks */
    .activity-icon {
        width: 56px;
        height: 56px;
    }

    .activity-title {
        font-size: var(--text-xl);
    }
}

/* ==========================================
   Desktop Large (1440px and above)
   ========================================== */

@media (min-width: 1440px) {
    :root {
        --container-max-width: 1400px;
        --text-6xl: 4rem;
    }

    .hero-section {
        padding: var(--space-24) 0;
    }

    .section-padding {
        padding-top: var(--space-20);
        padding-bottom: var(--space-20);
    }

    .news-grid,
    .activities-grid {
        gap: var(--space-10);
    }
}

/* ==========================================
   Tablet Landscape (769px to 1024px)
   ========================================== */

@media (min-width: 769px) and (max-width: 1024px) {
    .news-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .activities-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .footer-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .hero-section .container {
        gap: var(--space-10);
    }
}

/* ==========================================
   Print Styles
   ========================================== */

@media print {
    /* Hide non-essential elements */
    .site-header,
    .site-footer,
    .back-to-top,
    .mobile-menu-toggle,
    .language-switcher,
    .radio-waves-bg,
    .hero-ctas,
    .cta-section {
        display: none !important;
    }

    /* Adjust colors for print */
    body {
        color: #000;
        background: #fff;
    }

    /* Ensure good contrast */
    .card,
    .activity-block,
    .event-card {
        box-shadow: none;
        border: 1px solid #000;
    }

    /* Page breaks */
    .news-card,
    .activity-block {
        page-break-inside: avoid;
    }

    h1, h2, h3 {
        page-break-after: avoid;
    }

    /* Links */
    a {
        text-decoration: underline;
        color: #000;
    }

    /* Images */
    img {
        max-width: 100% !important;
    }
}

/* ==========================================
   Accessibility - Reduced Motion
   ========================================== */

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
}

/* ==========================================
   Dark Mode Support (Future Enhancement)
   ========================================== */

@media (prefers-color-scheme: dark) {
    /* Dark mode variables would go here if implemented */
    /* Currently using light mode only */
}

/* Cache buster: 2024-11-28-v20 - Removed conflicting dark text overrides for glassmorphism */

/* CRITICAL: Force WHITE text on dark glassmorphism mobile menu */
@media (max-width: 768px) {
    /* Ultra-specific selectors to override everything with WHITE text */
    body.menu-open .nav-menu *,
    body.menu-open .nav-menu a,
    body.menu-open .nav-menu li,
    body.menu-open .nav-menu ul li a,
    body.menu-open .nav-menu .menu-item a,
    body.menu-open .nav-menu #primary-menu li a,
    .nav-menu.active *,
    .nav-menu.active a,
    .nav-menu.active li,
    .nav-menu.active ul li a,
    .nav-menu.active .menu-item a,
    .nav-menu.active #primary-menu li a,
    .nav-menu .menu-item a,
    .nav-menu .nav-link,
    #primary-menu .menu-item a {
        color: rgba(255, 255, 255, 0.95) !important;
        -webkit-text-fill-color: rgba(255, 255, 255, 0.95) !important;
        text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3) !important;
        opacity: 1 !important;
    }

    /* Extra aggressive override for WHITE text */
    .main-nav .nav-menu a,
    .main-nav .nav-menu .menu-item a,
    .site-header .nav-menu a {
        color: rgba(255, 255, 255, 0.95) !important;
        -webkit-text-fill-color: rgba(255, 255, 255, 0.95) !important;
    }

    /* Remove ::after pseudo-elements on mobile */
    .nav-menu.active .menu-item a::after,
    .nav-menu .menu-item a::after,
    .nav-menu .nav-link::after {
        display: none !important;
    }

    /* Hover state */
    .nav-menu.active a:hover,
    .nav-menu.active .menu-item a:hover {
        background: rgba(115, 40, 30, 0.1) !important;
        color: #73281E !important;
    }

    /* Current page */
    .nav-menu.active .current-menu-item a,
    .nav-menu.active .current_page_item a,
    .nav-menu .current-menu-item a {
        background: rgba(115, 40, 30, 0.08) !important;
        color: #73281E !important;
        font-weight: 600 !important;
    }
}

/* ==========================================
   High Contrast Mode
   ========================================== */

@media (prefers-contrast: high) {
    :root {
        --color-primary: #0000ff;
        --color-gray-700: #000;
        --shadow-md: none;
        --shadow-lg: none;
    }

    .card,
    .activity-block,
    .event-card {
        border: 2px solid #000;
    }

    .btn {
        border-width: 3px;
    }
}

/* ==========================================
   Landscape Mobile Orientation
   ========================================== */

@media (max-height: 500px) and (orientation: landscape) {
    .hero-section {
        padding: var(--space-8) 0;
    }

    .nav-menu {
        max-height: calc(100vh - 60px);
    }

    .mobile-menu-toggle {
        padding: var(--space-1);
    }
}
