/* ==========================================================================
   media.css — all responsive overrides
   ========================================================================== */

/* ==========================================================================
   FOOTER RESPONSIVE
   ========================================================================== */

@media (max-width: 1024px) {
    .gfFooter__nav .gfFooter__inner {
        grid-template-columns: repeat(2, 1fr);
    }

    .gfFooter__bottom .gfFooter__inner {
        grid-template-columns: 1fr 1fr;
    }

    .gfFooter__offices {
        grid-column: 1 / -1;
        min-width: 0;
    }
}

@media (max-width: 640px) {
    .gfFooter__nav .gfFooter__inner {
        grid-template-columns: 1fr 1fr;
        gap: 32px 16px;
    }

    .gfFooter__bottom .gfFooter__inner {
        grid-template-columns: 1fr;
    }

    .gfFooter__bar .gfFooter__inner {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }
}

/* ==========================================================================
   HEADER RESPONSIVE
   ========================================================================== */

@media (max-width: 1024px) {
    .gfNav,
    .gfHeader__actions {
        display: none;
    }

    .gfHeader__burger {
        display: flex;
        margin-left: auto;
    }

    .gfNav.is-open {
        display: block;
        position: fixed;
        top: 68px;
        height: 100vh;
        left: 0;
        right: 0;
        bottom: 0;
        background: var(--base-white);
        overflow-y: auto;
        padding: 16px;
        border-top: 1px solid var(--base-border-black);
    }

    .gfNav.is-open .gfNav__list {
        flex-direction: column;
        align-items: stretch;
        gap: 2px;
    }

    .gfNav.is-open .gfNav__link {
        padding: 12px 16px;
        font-size: 16px;
        border-radius: 8px;
    }

    .gfNav.is-open .gfNav__dropdown {
        position: static;
        transform: none !important;
        box-shadow: none;
        border: none;
        border-radius: 0;
        padding: 0 0 0 16px;
        transition: none;
        background: transparent;
        min-width: 0;
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
    }

    /* hide dropdowns in mobile nav when parent not open */
    .gfNav.is-open .gfNav__item:not(.is-open) > .gfNav__dropdown {
        display: none;
    }

    .gfNav.is-open .gfNav__item.is-open > .gfNav__dropdown {
        display: flex;
    }

    .gfNav.is-open .gfNav__dropdown--tabs {
        flex-direction: column;
        min-width: 0;
    }

    .gfNav.is-open .gfNav__tabs-nav {
        width: 100%;
        flex-direction: row;
        flex-wrap: wrap;
        border-right: none;
        border-bottom: 1px solid var(--base-border-black);
        background: transparent;
    }

    .gfNav.is-open .gfNav__mega-grid {
        grid-template-columns: 1fr;
    }

    .gfNav.is-open .gfNav__columns-wrap,
    .gfNav.is-open .gfNav__columns {
        flex-direction: column;
    }

    .gfNav.is-open .gfNav__promo {
        width: 100%;
    }

    .gfNav.is-open .gfNav__featured-wrap {
        flex-direction: column;
    }

    .gfNav.is-open .gfNav__featured-cards {
        width: 100%;
        border-right: none;
        border-bottom: 1px solid var(--base-border-black);
        background: transparent;
    }

    .gfNav.is-open .gfNav__featured-grid {
        grid-template-columns: 1fr;
    }

    .gfNav.is-open .gfNav__sections-wrap {
        flex-direction: column;
        gap: 16px;
    }

    .gfNav.is-open .gfNav__section {
        padding: 0;
        border-right: none;
        border-bottom: 1px solid var(--base-border-black);
        padding-bottom: 16px;
    }

    .gfNav.is-open .gfNav__section:last-child {
        border-bottom: none;
        padding-bottom: 0;
    }

    .gfNav.is-open .gfNav__section-grid {
        grid-template-columns: 1fr;
    }

    .gfNav.is-open .gfHeader__actions {
        display: flex;
        padding: 16px;
        border-top: 1px solid var(--base-border-black);
    }
}

/* ==========================================================================
   SEARCH RESPONSIVE
   ========================================================================== */

@media (max-width: 1024px) {
    .gfHeader__searchPanel {
        padding: 10px 16px;
    }

    .gfHeader__searchPanel-inner {
        max-width: 100%;
    }
}

@media (max-width: 640px) {
    .gfHeader__searchPanel {
        padding: 8px 12px;
    }

    .gfSearch__input {
        font-size: 14px;
    }
}
