/* Common Header Styles for All Pages */

/* Mobile Navigation Styles - High Specificity to Override Bootstrap */
@media (max-width: 767.98px) {
    /* Force mobile navigation to be hidden by default */
    header#topnav #navigation {
        position: fixed !important;
        top: 0 !important;
        left: -100% !important;
        width: 100% !important;
        height: 100vh !important;
        background: white !important;
        z-index: 99999 !important;
        transition: left 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
        display: inline-table !important;
        align-items: center !important;
        justify-content: center !important;
        overflow: hidden !important;
        margin: 0 !important;
        padding: 0 !important;
        border: none !important;
        box-shadow: none !important;
        backdrop-filter: blur(10px) !important;
    }
    
    /* Show navigation when open */
    header#topnav #navigation.nav-open {
        left: 0 !important;
    }
    
    /* Add subtle food-themed pattern overlay for visual interest */
    header#topnav #navigation::before {
        content: '' !important;
        position: absolute !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        background-image: radial-gradient(circle at 25% 25%, rgba(255, 165, 0, 0.08) 0%, transparent 50%), 
                        radial-gradient(circle at 75% 75%, rgba(255, 140, 0, 0.06) 0%, transparent 50%) !important;
        pointer-events: none !important;
        z-index: -1 !important;
    }
    
    /* Style navigation menu */
    header#topnav #navigation .navigation-menu {
        flex-direction: column !important;
        text-align: center !important;
        padding: 20px 20px !important;
        margin-top: 70px !important;
        list-style: none !important;
        width: 100% !important;
        max-width: 450px !important;
        background: transparent !important;
    }
    
    /* Style navigation menu items - SIMPLIFIED AND FIXED */
    header#topnav #navigation .navigation-menu > li {
        margin: 8px 0 !important;
        display: block !important;
        visibility: visible !important;
        opacity: 1 !important;
        transform: none !important;
        background: transparent !important;
        border: none !important;
        padding: 0 !important;
        position: relative !important;
        list-style: none !important;
    }
    
    /* Minimal spacing before Home and after Contact */
    header#topnav #navigation .navigation-menu > li:first-child {
        margin-top: 15px !important;
    }
    
    header#topnav #navigation .navigation-menu > li:last-child {
        margin-bottom: 15px !important;
    }
    
    /* Submenu Styles */
    header#topnav #navigation .navigation-menu .submenu {
        display: none !important;
        list-style: none !important;
        margin: 0 !important;
        padding: 8px !important;
        background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%) !important;
        border: 1px solid #dee2e6 !important;
        border-radius: 12px !important;
        margin-top: 8px !important;
        overflow: hidden !important;
        max-height: 0 !important;
        transition: max-height 0.3s ease !important;
        box-shadow: 0 4px 16px rgba(76, 175, 80, 0.15) !important;
    }
    
    /* Show submenu when parent is open */
    header#topnav #navigation .navigation-menu li.has-submenu.open .submenu {
        display: block !important;
        max-height: 200px !important;
    }
    
    /* Submenu items */
    header#topnav #navigation .navigation-menu .submenu li {
        margin: 0 !important;
        display: block !important;
        visibility: visible !important;
        opacity: 1 !important;
        transform: none !important;
        transition: none !important;
        list-style: none !important;
    }
    
    header#topnav #navigation .navigation-menu .submenu a {
        padding: 6px 20px !important;
        font-size: 14px !important;
        background: linear-gradient(135deg, #ffffff 0%, #f8f9fa 100%) !important;
        border: 1px solid #dee2e6 !important;
        margin: 2px 8px !important;
        border-radius: 6px !important;
        color: #333 !important;
        font-weight: 600 !important;
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1) !important;
    }
    
    /* Submenu hover effects */
    header#topnav #navigation .navigation-menu .submenu a:hover {
        background: linear-gradient(135deg, #e9ecef 0%, #dee2e6 100%) !important;
        color: #000 !important;
        border-color: #adb5bd !important;
        transform: translateY(-1px) !important;
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
    }
    
    /* Menu arrow indicator */
    header#topnav #navigation .navigation-menu .menu-arrow {
        display: inline-block !important;
        margin-left: 8px !important;
        transition: transform 0.3s ease !important;
        font-size: 12px !important;
        color: #8B4513 !important;
    }
    
    /* Rotate arrow when submenu is open */
    header#topnav #navigation .navigation-menu li.has-submenu.open .menu-arrow {
        transform: rotate(180deg) !important;
    }
    
    /* Style navigation links */
    header#topnav #navigation .navigation-menu a {
        color: #8B4513 !important;
        font-size: 20px !important;
        font-weight: 600 !important;
        text-decoration: none !important;
        padding: 6px 25px !important;
        display: block !important;
        border-radius: 12px !important;
        transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
        cursor: pointer !important;
        user-select: none !important;
        background: rgba(255, 255, 255, 0.3) !important;
        border: 1px solid rgba(139, 69, 19, 0.3) !important;
        margin: 0 !important;
        backdrop-filter: blur(10px) !important;
        box-shadow: 0 8px 32px rgba(139, 69, 19, 0.15) !important;
        position: relative !important;
        overflow: hidden !important;
    }
    
    /* Hover effects for navigation links */
    header#topnav #navigation .navigation-menu a:hover {
        background: rgba(255, 255, 255, 0.5) !important;
        color: #D2691E !important;
        transform: translateY(-3px) scale(1.02) !important;
        text-decoration: none !important;
        box-shadow: 0 15px 40px rgba(139, 69, 19, 0.25) !important;
        border-color: rgba(210, 105, 30, 0.5) !important;
    }
    
    /* Style current city indicator for mobile */
    header#topnav #navigation .navigation-menu a.current-city {
        color: #FF6B35 !important;
        font-weight: 700 !important;
        cursor: default !important;
        position: relative !important;
        background: rgba(255, 107, 53, 0.1) !important;
        border: 1px solid rgba(255, 107, 53, 0.3) !important;
    }
    
    header#topnav #navigation .navigation-menu a.current-city::after {
        content: ' (Current)' !important;
        font-size: 14px !important;
        color: #FF6B35 !important;
        font-weight: 500 !important;
    }
    
    /* Disable hover effects for current city */
    header#topnav #navigation .navigation-menu a.current-city:hover {
        background: rgba(255, 107, 53, 0.1) !important;
        color: #FF6B35 !important;
        transform: none !important;
        box-shadow: 0 8px 32px rgba(139, 69, 19, 0.15) !important;
        border-color: rgba(255, 107, 53, 0.3) !important;
    }
    
    /* Add shimmer effect on hover */
    header#topnav #navigation .navigation-menu a::before {
        content: '' !important;
        position: absolute !important;
        top: 0 !important;
        left: -100% !important;
        width: 100% !important;
        height: 100% !important;
        background: linear-gradient(90deg, transparent, rgba(255, 165, 0, 0.3), transparent) !important;
        transition: left 0.6s ease !important;
    }
    
    header#topnav #navigation .navigation-menu a:hover::before {
        left: 100% !important;
    }
    
    /* Social Media Container - Separate from navigation items */
    header#topnav #navigation .navigation-menu .container {
        margin-top: 20px !important;
        padding: 0 !important;
        width: 100% !important;
        display: inline-flex !important;
        list-style: none !important;
    }
    
    header#topnav #navigation .navigation-menu .container h4 {
        margin: 8px 0 !important;
        font-size: 16px !important;
        text-align: center !important;
        display: inline-flex !important;
        padding-inline: 25px;
    }
    
    header#topnav #navigation .navigation-menu .container a {
        color: #8B4513 !important;
        font-size: 16px !important;
        font-weight: 600 !important;
        text-decoration: none !important;
        padding: 6px 0px !important;
        display: inline-block !important;
        border-radius: 8px !important;
        background: rgba(255, 255, 255, 0.3) !important;
        border: 1px solid rgba(139, 69, 19, 0.3) !important;
        margin: 0 0px !important;
        backdrop-filter: blur(10px) !important;
        box-shadow: 0 4px 15px rgba(139, 69, 19, 0.15) !important;
    }
    
    header#topnav #navigation .navigation-menu .container a:hover {
        background: rgba(255, 255, 255, 0.5) !important;
        color: #D2691E !important;
        transform: translateY(-2px) !important;
        box-shadow: 0 6px 20px rgba(139, 69, 19, 0.25) !important;
    }
    
    /* Hamburger Menu Button */
    header#topnav .navbar-toggle {
        cursor: pointer !important;
        padding: 12px !important;
        z-index: 100000 !important;
        display: block !important;
        position: relative !important;
        background: transparent !important;
        border: none !important;
        outline: none !important;
        border-radius: 12px !important;
        min-width: 55px !important;
        min-height: 55px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        box-shadow: none !important;
        transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
    }
    
    /* Hover effect for hamburger */
    header#topnav .navbar-toggle:hover {
        background: rgba(139, 69, 19, 0.1) !important;
        transform: translateY(-3px) scale(1.05) !important;
    }
    
    /* Hamburger Lines */
    header#topnav .navbar-toggle .lines {
        width: 25px !important;
        height: 20px !important;
        position: absolute !important;
        transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
    }
    
    /* Individual Lines */
    header#topnav .navbar-toggle .lines span {
        display: block !important;
        width: 100% !important;
        height: 3px !important;
        background: #8B4513 !important;
        position: absolute !important;
        left: 0 !important;
        transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
        border-radius: 2px !important;
        box-shadow: 0 1px 3px rgba(139, 69, 19, 0.3) !important;
    }
    
    /* Line Positions */
    header#topnav .navbar-toggle .lines span:nth-child(1) {
        top: 0 !important;
    }
    
    header#topnav .navbar-toggle .lines span:nth-child(2) {
        top: 8px !important;
    }
    
    header#topnav .navbar-toggle .lines span:nth-child(3) {
        top: 16px !important;
    }
    
    /* Hamburger to X Animation */
    header#topnav .navbar-toggle.open .lines span:nth-child(1) {
        transform: rotate(45deg) !important;
        top: 8px !important;
    }
    
    header#topnav .navbar-toggle.open .lines span:nth-child(2) {
        opacity: 0 !important;
        transform: scale(0) !important;
    }
    
    header#topnav .navbar-toggle.open .lines span:nth-child(3) {
        transform: rotate(-45deg) !important;
        top: 8px !important;
    }
    
    /* Logo positioning */
    header#topnav .logo {
        z-index: 100000 !important;
        position: relative !important;
    }
    
    /* Hide any Bootstrap navigation classes */
    header#topnav .navbar,
    header#topnav .navbar-nav,
    header#topnav .navbar-collapse {
        display: none !important;
    }
}

/* Desktop Navigation - Ensure it works */
@media (min-width: 768px) {
    /* Fix header alignment */
    header#topnav {
        display: flex !important;
        align-items: center !important;
        min-height: 100px !important;
        padding: 0 20px !important;
        flex-wrap: nowrap !important;
    }
    
    /* Fix container alignment - Override inline styles */
    header#topnav .container {
        display: flex !important;
        align-items: center !important;
        justify-content: flex-start !important;
        width: 100% !important;
        height: 100% !important;
        gap: 20px !important;
    }
    
    /* Fix logo container alignment */
    header#topnav .logo-container {
        display: flex !important;
        align-items: center !important;
        height: 100px !important;
        margin-right: 0px !important;
        min-width: 110px !important;
        flex-shrink: 0 !important;
    }
    
    /* Logo positioning */
    header#topnav .logo {
        z-index: 100000 !important;
        position: relative !important;
        display: flex !important;
        align-items: center !important;
        height: 100px !important;
        line-height: 1 !important;
    }
    
    header#topnav #navigation {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        position: static !important;
        background: transparent !important;
        left: auto !important;
        width: auto !important;
        height: auto !important;
        z-index: auto !important;
    }
    
    /* Desktop Navigation Menu - Horizontal Layout */
    header#topnav #navigation .navigation-menu {
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: flex-start !important;
        margin: 0 !important;
        padding: 0 !important;
        list-style: none !important;
        background: transparent !important;
        width: auto !important;
        max-width: none !important;
        flex-wrap: nowrap !important;
        gap: 0 !important;
        flex-shrink: 0 !important;
    }
    
    /* Desktop Navigation Menu Items */
    header#topnav #navigation .navigation-menu li {
        margin: 0 5px !important;
        opacity: 1 !important;
        transform: none !important;
        transition: none !important;
        background: transparent !important;
        border: none !important;
        padding: 0 !important;
        position: relative !important;
        display: flex !important;
        align-items: center !important;
    }
    
    /* Add more space after logo */
    header#topnav #navigation .navigation-menu li:first-child {
        margin-left: 20px !important;
    }
    
    /* Desktop Navigation Links */
    header#topnav #navigation .navigation-menu a {
        color: #333 !important;
        font-size: 14px !important;
        font-weight: 500 !important;
        text-decoration: none !important;
        padding: 25px 8px !important;
        display: block !important;
        border-radius: 6px !important;
        transition: all 0.3s ease !important;
        
    /* Style current city indicator for desktop */
    header#topnav #navigation .navigation-menu a.current-city {
        color: #FF6B35 !important;
        font-weight: 700 !important;
        cursor: default !important;
        position: relative !important;
    }
    
    header#topnav #navigation .navigation-menu a.current-city::after {
        content: ' (Current)' !important;
        font-size: 10px !important;
        color: #FF6B35 !important;
        font-weight: 500 !important;
    }
    
    /* Disable hover effects for current city on desktop */
    header#topnav #navigation .navigation-menu a.current-city:hover {
        color: #FF6B35 !important;
        background: transparent !important;
        transform: none !important;
    }
        cursor: pointer !important;
        user-select: none !important;
        background: transparent !important;
        border: none !important;
        margin: 0 !important;
        backdrop-filter: none !important;
        box-shadow: none !important;
        position: relative !important;
        overflow: visible !important;
    }
    
    /* Desktop Navigation Hover Effects */
    header#topnav #navigation .navigation-menu a:hover {
        color: #007bff !important;
        background: rgba(0, 123, 255, 0.1) !important;
        transform: none !important;
        text-decoration: none !important;
        box-shadow: none !important;
        border-color: transparent !important;
    }
    
    /* Desktop Submenu Styles */
    header#topnav #navigation .navigation-menu .submenu {
        display: none !important;
        position: absolute !important;
        top: 100% !important;
        left: 0 !important;
        background: white !important;
        border: 1px solid #ddd !important;
        border-radius: 6px !important;
        box-shadow: 0 4px 12px rgba(0,0,0,0.1) !important;
        min-width: 200px !important;
        z-index: 1000 !important;
        padding: 8px 0 !important;
        margin-top: 5px !important;
    }
    
    /* Show submenu on hover */
    header#topnav #navigation .navigation-menu li.has-submenu:hover .submenu {
        display: block !important;
    }
    
    /* Desktop Submenu Items */
    header#topnav #navigation .navigation-menu .submenu li {
        margin: 0 !important;
        padding: 0 !important;
    }
    
    header#topnav #navigation .navigation-menu .submenu a {
        padding: 8px 20px !important;
        font-size: 14px !important;
        color: #333 !important;
        background: transparent !important;
        border: none !important;
        margin: 0 !important;
        border-radius: 0 !important;
    }
    
    header#topnav #navigation .navigation-menu .submenu a:hover {
        background: rgba(0, 123, 255, 0.1) !important;
        color: #007bff !important;
    }
    
    /* Desktop Social Media Links - Inside Navigation Menu */
    header#topnav #navigation .navigation-menu .container {
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: flex-start !important;
        gap: 10px !important;
        margin: 0 0 0 10px !important;
        width: auto !important;
        flex-wrap: nowrap !important;
    }
    
    header#topnav #navigation .navigation-menu .container h4 {
        margin: 0 !important;
        font-size: 14px !important;
        display: inline-block !important;
        vertical-align: middle !important;
        white-space: nowrap !important;
    }
    
    /* Fix dropdown arrow positioning */
    header#topnav #navigation .navigation-menu .menu-arrow {
        display: inline-block !important;
        margin-left: 5px !important;
        vertical-align: middle !important;
        line-height: 1 !important;
        font-size: 12px !important;
        color: #333 !important;
        position: relative !important;
        top: -1px !important;
    }
    
    /* Ensure social media links are on same line */
    header#topnav #navigation .navigation-menu .container a {
        display: inline-block !important;
        vertical-align: middle !important;
        line-height: 1 !important;
    }
    
    /* Hide mobile-specific styles on desktop */
    header#topnav #navigation .navigation-menu a::before {
        display: none !important;
    }
    
    header#topnav .navbar-toggle {
        display: none !important;
    }
}

/* FINAL UNIVERSAL RULE: Ensure header is ALWAYS visible on ANY screen size */
header#topnav {
    visibility: visible !important;
    opacity: 1 !important;
    z-index: 1000 !important;
    background: white !important;
    box-shadow: 0 2px 10px rgba(0,0,0,0.1) !important;
}

header#topnav #navigation {
    visibility: visible !important;
    opacity: 1 !important;
}

header#topnav .logo {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
}

/* CRITICAL: Force hamburger lines to be visible on ALL screen sizes with maximum specificity */
header#topnav .navbar-toggle .lines {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    z-index: 100001 !important;
    pointer-events: auto !important;
}

header#topnav .navbar-toggle .lines span {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    z-index: 100002 !important;
    pointer-events: auto !important;
    /* Override any Bootstrap or other CSS that might hide lines */
    clip: auto !important;
    clip-path: none !important;
    overflow: visible !important;
}

/* EXTRA CRITICAL: Override any CSS that might be hiding the lines */
header#topnav .navbar-toggle .lines,
header#topnav .navbar-toggle .lines * {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
}
