/* Menu Fixes - Smaller text, responsive display, and mobile improvements */

/* Reduce menu text size */
.main-menu .main-menu__list > li > a {
    font-size: 13px !important;
    white-space: nowrap;
}

/* Reduce spacing between menu items */
.main-menu .main-menu__list > li + li {
    margin-left: 20px !important;
}

/* Reduce padding on menu items */
.main-menu .main-menu__list > li {
    padding: 35px 0 !important;
}

.main-header--two .main-menu .main-menu__list > li {
    padding: 40px 0 !important;
}

/* Show desktop menu only on larger screens (1200px and above) */
@media (min-width: 1200px) {
    .main-menu .main-menu__list,
    .main-menu .main-menu__list ul {
        display: flex !important;
    }
}

/* Desktop: show burger menu too (so users can access address/contact/subscribe) */
@media (min-width: 1200px) {
    .mobile-nav__btn {
        display: flex !important;
        order: 3;
    }

    /* Hide the separate sidebar button to avoid duplication */
    .main-header__sidebar-btn {
        display: none !important;
    }
}

/* Mobile nav extra content (address + subscribe) */
.mobile-nav__extra {
    margin-top: 20px;
    padding-top: 20px;
    border-top: 1px solid rgba(255, 255, 255, 0.12);
}

.mobile-nav__address {
    display: flex;
    gap: 10px;
    color: rgba(255, 255, 255, 0.9);
    font-size: 14px;
    line-height: 1.4;
    margin-bottom: 18px;
}

.mobile-nav__address__icon {
    flex: 0 0 auto;
    color: var(--bbbringlanding-base, #FED100);
    margin-top: 2px;
}

.mobile-nav__newsletter__title {
    color: var(--bbbringlanding-white, #FFFFFF);
    font-size: 14px;
    font-weight: 600;
    margin: 0 0 10px 0;
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

.mobile-nav__newsletter__form {
    position: relative;
    display: flex;
    align-items: center;
}

.mobile-nav__newsletter__form input[type="email"] {
    width: 100%;
    height: 46px;
    padding: 0 44px 0 14px;
    border-radius: 10px;
    border: 1px solid rgba(255, 255, 255, 0.18);
    background: rgba(255, 255, 255, 0.06);
    color: var(--bbbringlanding-white, #FFFFFF);
    outline: none;
}

.mobile-nav__newsletter__form input[type="email"]::placeholder {
    color: rgba(255, 255, 255, 0.7);
}

.mobile-nav__newsletter__form button {
    position: absolute;
    right: 6px;
    width: 34px;
    height: 34px;
    border-radius: 10px;
    border: none;
    background: var(--bbbringlanding-base, #FED100);
    color: var(--bbbringlanding-black, #141414);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

/* Adjust spacing for medium screens */
@media (min-width: 768px) and (max-width: 1199px) {
    .main-menu .main-menu__list > li + li {
        margin-left: 15px !important;
    }
    
    .main-menu .main-menu__list > li > a {
        font-size: 12px !important;
    }
    
    /* Reduce padding on medium screens */
    .main-menu .main-menu__list > li {
        padding: 30px 0 !important;
    }
    
    .main-header--two .main-menu .main-menu__list > li {
        padding: 35px 0 !important;
    }
    
    /* Adjust header right spacing */
    .main-header__right {
        gap: 15px;
    }
    
    /* Make book button smaller on tablets */
    .main-header__book-btn {
        padding: 8px 15px !important;
        font-size: 13px !important;
    }
    
    .main-header__book-btn span {
        font-size: 13px !important;
    }
}

/* Further reduce for smaller tablets */
@media (min-width: 768px) and (max-width: 991px) {
    .main-menu .main-menu__list > li + li {
        margin-left: 12px !important;
    }
    
    .main-menu .main-menu__list > li > a {
        font-size: 11px !important;
    }
    
    .main-menu .main-menu__list > li {
        padding: 28px 0 !important;
    }
    
    .main-header--two .main-menu .main-menu__list > li {
        padding: 32px 0 !important;
    }
}

/* Mobile + tablets + small laptops: keep mobile slide-in menu */
@media (max-width: 1199px) {
    .main-menu .main-menu__list,
    .main-menu .main-menu__list ul {
        display: none !important;
    }
    
    .mobile-nav__btn {
        display: flex !important;
        order: 3;
        cursor: pointer !important;
        z-index: 10001 !important;
        position: relative !important;
    }
    
    /* Hide sidebar button on mobile */
    .main-header__sidebar-btn {
        display: none !important;
    }
    
    /* Ensure mobile nav wrapper is properly positioned and hidden by default */
    .mobile-nav__wrapper {
        z-index: 9999 !important;
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        width: 100vw !important;
        height: 100vh !important;
        opacity: 0 !important;
        visibility: hidden !important;
        transform: translateX(-100%) !important;
        transition: opacity 500ms ease, visibility 500ms ease, transform 500ms ease !important;
    }
    
    /* Ensure mobile nav content is visible when expanded */
    .mobile-nav__wrapper.expanded {
        opacity: 1 !important;
        visibility: visible !important;
        transform: translateX(0) !important;
        transition: opacity 500ms ease 0ms, visibility 500ms ease 0ms, transform 500ms ease 0ms !important;
    }
    
    .mobile-nav__wrapper.expanded .mobile-nav__content {
        opacity: 1 !important;
        visibility: visible !important;
        transform: translateX(0) !important;
    }
    
    /* Ensure mobile nav content is properly styled */
    .mobile-nav__content {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        width: 300px !important;
        max-width: 85vw !important;
        height: 100vh !important;
        /* Dark gray (requested) */
        background-color: #2b2f33 !important;
        z-index: 10000 !important;
        overflow-y: auto !important;
        padding: 50px 15px 30px 15px !important;
    }
    
    /* Ensure overlay is clickable */
    .mobile-nav__overlay {
        position: absolute !important;
        top: 0 !important;
        left: 0 !important;
        width: 100% !important;
        height: 100% !important;
        background-color: rgba(0, 0, 0, 0.5) !important;
        z-index: 9998 !important;
        cursor: pointer !important;
    }
    
    /* Ensure close button is visible and clickable */
    .mobile-nav__close {
        cursor: pointer !important;
        z-index: 10001 !important;
        position: absolute !important;
        top: 20px !important;
        right: 20px !important;
    }

    /* Ensure menu links are readable on dark background */
    .mobile-nav__container,
    .mobile-nav__container .main-menu__list,
    .mobile-nav__container .main-menu__list > li {
        background: transparent !important;
    }

    .mobile-nav__container .main-menu__list > li > a {
        color: #ffffff !important;
        background: transparent !important;
    }

    .mobile-nav__container .main-menu__list > li > a:hover {
        color: var(--bbbringlanding-base, #FED100) !important;
    }
}

/* Large screens - maintain original but with smaller text */
@media (min-width: 1200px) {
    .main-menu .main-menu__list > li + li {
        margin-left: 25px !important;
    }
    
    .main-menu .main-menu__list > li > a {
        font-size: 14px !important;
    }
}

/* Extra large screens - slightly larger but still reduced */
@media (min-width: 1400px) {
    .main-menu .main-menu__list > li + li {
        margin-left: 30px !important;
    }
    
    .main-menu .main-menu__list > li > a {
        font-size: 15px !important;
    }
}

/* Ensure mobile nav container works properly */
.mobile-nav__container {
    padding: 0;
    margin-bottom: 30px;
}

.mobile-nav__container .main-menu__list {
    display: block !important;
    list-style: none;
    padding: 0;
    margin: 0;
}

.mobile-nav__container .main-menu__list > li {
    padding: 0 !important;
    margin: 0 !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.mobile-nav__container .main-menu__list > li > a {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-family: var(--bbbringlanding-heading-font, "Lexend", serif);
    font-size: 15px;
    color: var(--bbbringlanding-white, #FFFFFF);
    text-transform: uppercase;
    font-weight: 500;
    line-height: 30px;
    height: 46px;
    padding: 0 10px;
    transition: 500ms;
    text-decoration: none;
}

.mobile-nav__container .main-menu__list > li > a:hover {
    color: var(--bbbringlanding-base, #FED100);
}

/* Ensure mobile nav wrapper shows properly - Global styles */
.mobile-nav__wrapper {
    z-index: 9999;
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
}

.mobile-nav__wrapper.expanded {
    opacity: 1 !important;
    transform: translateX(0%) !important;
    visibility: visible !important;
}

.mobile-nav__wrapper.expanded .mobile-nav__content {
    opacity: 1 !important;
    visibility: visible !important;
    transform: translateX(0) !important;
}

.mobile-nav__content {
    z-index: 10000;
    position: fixed;
    top: 0;
    left: 0;
}

/* Ensure mobile nav button is clickable */
.mobile-nav__btn {
    cursor: pointer !important;
    position: relative;
    z-index: 10001;
}

.mobile-nav__close {
    cursor: pointer !important;
    z-index: 10001;
}

.mobile-nav__overlay {
    cursor: pointer !important;
    z-index: 9998;
}

/* Ensure menu items are visible in mobile nav */
.mobile-nav__container .main-menu__list > li {
    opacity: 1 !important;
    visibility: visible !important;
}

.mobile-nav__container .main-menu__list > li > a {
    opacity: 1 !important;
    visibility: visible !important;
    display: flex !important;
}

/* Fix for main-header--two on smaller screens */
@media (min-width: 768px) and (max-width: 1199px) {
    .main-header--two .main-header__nav {
        margin-right: 20px !important;
    }
}

/* Ensure book button doesn't break layout */
@media (min-width: 768px) and (max-width: 991px) {
    .main-header__book-btn {
        padding: 6px 12px !important;
    }
    
    .main-header__book-btn .bbbringlanding-btn__icon {
        display: none;
    }
    
    .main-header__book-btn span:not(.bbbringlanding-btn__icon) {
        font-size: 11px !important;
    }
}

