/* ===================================
   RESPONSIVE DESIGN
   =================================== */

@media (max-width: 968px) {
    .navbar {
        overflow: visible;
    }

    .top-bar {
        font-size: 9px;
        letter-spacing: 0.15px;
    }

    .top-bar-container {
        padding: 5px 12px;
        gap: 6px;
        justify-content: space-between;
    }

    .nav-menu {
        position: fixed;
        left: 0;
        right: 0;
        top: var(--header-offset);
        flex-direction: column;
        background-color: var(--white);
        text-align: center;
        transition: opacity 0.25s ease, transform 0.25s ease;
        box-shadow: var(--shadow-md);
        padding: 40px 0;
        gap: 24px;
        opacity: 0;
        pointer-events: none;
        transform: translateY(-12px);
    }

    .nav-container {
        overflow: visible;
        position: relative;
        padding: 12px 16px;
        padding-right: clamp(52px, 14vw, 72px);
    }

    .nav-logo img {
        width: min(220px, 50vw);
    }

    .nav-menu.active {
        opacity: 1;
        pointer-events: auto;
        transform: translateY(0);
    }

    .hamburger {
        display: flex;
        position: absolute;
        right: clamp(12px, 4vw, 20px);
        top: 50%;
        transform: translateY(-50%);
        width: clamp(36px, 10vw, 44px);
        height: clamp(36px, 10vw, 44px);
        align-items: center;
        justify-content: center;
        gap: 4px;
        z-index: var(--z-hamburger);
    }

    .hamburger span {
        position: absolute;
        left: 50%;
        width: 18px;
        height: 2px;
        transform: translateX(-50%);
    }

    .hamburger span:nth-child(1) {
        top: 14px;
    }

    .hamburger span:nth-child(2) {
        top: 50%;
        transform: translate(-50%, -50%);
    }

    .hamburger span:nth-child(3) {
        bottom: 14px;
    }

    .hamburger.active span:nth-child(1) {
        top: 50%;
        transform: translate(-50%, -50%) rotate(45deg);
    }

    .hamburger.active span:nth-child(2) {
        opacity: 0;
    }

    .hamburger.active span:nth-child(3) {
        top: 50%;
        bottom: auto;
        transform: translate(-50%, -50%) rotate(-45deg);
    }

    .location-content {
        grid-template-columns: 1fr;
        gap: 48px;
    }

    .menu-tabs {
        padding: 0 16px;
    }

    .menu-tab {
        padding: 12px 16px;
        font-size: 13px;
        letter-spacing: 0.5px;
    }

    .menu-categories {
        padding: 0 16px;
    }

    .press-grid {
        grid-template-columns: 1fr;
        gap: 36px;
    }

    .call-us-link-mobile {
        display: inline-flex;
    }

    .call-us-btn,
    .call-us-pop {
        display: none;
    }
}

@media (max-width: 640px) {
    .container {
        padding: 0 16px;
    }

    .sticky-actions-shell {
        padding: 0 max(16px, env(safe-area-inset-left, 0px)) calc(14px + env(safe-area-inset-bottom, 0px)) max(16px, env(safe-area-inset-right, 0px));
        background: none;
        box-shadow: none;
    }

    .sticky-actions {
        width: 100%;
        max-width: 420px;
        margin-bottom: 0;
        padding: 0;
        gap: 10px;
        background: none;
        border-radius: 0;
        box-shadow: none;
    }

    .top-bar-container {
        padding: 4px 10px;
        gap: 4px;
    }

    .nav-container {
        padding: 11px 14px;
        padding-right: 58px;
    }

    .hero {
        min-height: 500px;
    }

    .btn-hero {
        padding: 14px 32px;
        font-size: 15px;
        max-width: 260px;
        width: 100%;
    }

    body.form-field-focused .sticky-actions-shell {
        opacity: 0;
        pointer-events: none;
        --sticky-hide-shift: 12px;
    }

    .menu {
        padding: 60px 0;
    }

    .location {
        padding: 80px 0;
    }

    .section-header {
        margin-bottom: 40px;
    }

    .sticky-order,
    .call-us-btn,
    .call-us-link-mobile {
        padding: 0 16px;
    }

    .menu-category {
        padding: 32px 24px;
    }

    .location-info {
        text-align: center;
        align-items: center;
    }

    .press {
        padding: 40px 0 120px;
    }

    .press .section-title {
        margin-top: -40px;
        margin-bottom: 20px;
    }
}

@media (max-width: 420px) {
    .sticky-actions {
        max-width: 360px;
        gap: 6px;
    }

    .sticky-order,
    .call-us-btn,
    .call-us-link-mobile {
        height: 48px;
        padding: 0 14px;
        font-size: 12px;
        letter-spacing: 0.6px;
    }

    .label-full {
        display: none;
    }

    .label-short {
        display: inline;
    }
}
