/* 
=====================================================================
   Media Queries for Responsive Design
===================================================================== 
*/

/* Mobile & Tablet Styles - hamburger menu below 1024px */
@media only screen and (max-width: 1024px) {

    /* Header */
    header .banner-text h1 {
        font-size: 40px;
    }
    
    header .scrolldown { display: none; }

    /* Navigation */
    #nav-wrap {
        background: transparent;
        height: 0; /* Prevent blocking clicks when closed */
    }

    #nav-wrap .mobile-btn {
        display: block;
        width: 48px;
        height: 48px;
        position: fixed;
        top: 20px;
        right: 20px;
        z-index: 200;
        background: rgba(44, 95, 141, 0.9);
        border-radius: 4px;
        text-indent: -9999px;
        border: none;
        cursor: pointer;
    }

    #nav-wrap .mobile-btn::before {
        content: '\f0c9'; /* fa-bars */
        font-family: FontAwesome;
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        text-indent: 0;
        color: #fff;
        font-size: 24px;
    }

    /* When menu is open, show X icon */
    #nav-wrap.menu-open .mobile-btn::before {
        content: '\f00d'; /* fa-times */
    }

    /* When menu is open */
    #nav-wrap.menu-open {
        height: auto;
    }

    ul#nav {
        display: none;
        flex-direction: column;
        background: rgba(17, 24, 39, 0.98);
        backdrop-filter: blur(10px);
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100vh;
        z-index: 150;
        padding-top: 100px;
        margin: 0;
    }

    #nav-wrap.menu-open ul#nav {
        display: flex;
    }

    ul#nav li {
        display: block;
        margin: 15px 0;
        text-align: center;
    }

    ul#nav li a {
        font-size: 18px;
        display: block;
        padding: 10px;
        color: #fff;
    }
}

/* Small mobile styles */
@media only screen and (max-width: 768px) {
    /* Sections */
    .about-grid, .events-grid, .team-grid {
        grid-template-columns: 1fr;
        padding: 0 20px;
    }

    /* Events responsive */
    .events-tabs {
        flex-direction: column;
        gap: 10px;
    }
    
    .events-tab {
        width: 100%;
        justify-content: center;
    }

    .past-event-header {
        flex-direction: column;
        gap: 15px;
    }

    .past-event-date {
        align-self: flex-start;
    }

    .gallery-indicator {
        flex-direction: row;
        align-self: flex-start;
    }

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

    .download-section {
        flex-direction: column;
        padding: 0 20px;
    }

    .download-section .button {
        width: 100%;
        text-align: center;
        margin-bottom: 10px;
    }
    
    .container {
        width: 90%;
    }
    
    /* Footer */
    footer .social-links {
        flex-wrap: wrap;
    }
}

/* Desktop nav - only show horizontal nav above 1024px */
@media only screen and (min-width: 1025px) {
    #nav-wrap .mobile-btn { display: none; }
    ul#nav { display: flex !important; }

    /* Tighten nav spacing for items to fit */
    ul#nav li {
        margin: 0 8px;
    }

    ul#nav li a {
        padding: 15px 8px;
        font-size: 11px;
    }
}

/* Large desktop - more spacious nav */
@media only screen and (min-width: 1280px) {
    ul#nav li {
        margin: 0 15px;
    }

    ul#nav li a {
        padding: 15px;
        font-size: 12px;
    }
}
