/* Mobile Menu Overrides - This file should be loaded last to ensure it has highest priority */

@media (max-width: 768px) {
  /* Reset body overflow */
  html, body {
    overflow-x: hidden;
    width: 100%;
    position: relative;
  }
  
  /* Mobile Toggle Button */
  .mobile-toggle {
    display: block !important;
    background: transparent !important;
    border: none !important;
    cursor: pointer !important;
    padding: 0 !important;
    width: 30px !important;
    height: 24px !important;
    position: relative !important;
    z-index: 100 !important;
  }

  /* Mobile Menu Container */
  #header .main-nav {
    display: block !important;
    flex-direction: column !important;
    position: fixed !important;
    top: 0 !important;
    right: 0 !important;
    width: 280px !important;
    height: 100vh !important;
    background-color: #0f172a !important; /* Use direct color instead of var to ensure consistency */
    padding: 6rem 2rem 2rem !important;
    transform: translateX(100%) !important;
    transition: transform 0.4s ease !important;
    box-shadow: -5px 0 30px rgba(0, 0, 0, 0.15) !important;
    overflow-y: auto !important;
    z-index: 99 !important;
    justify-content: flex-start !important;
    align-items: flex-start !important;
  }
  
  /* Active State */
  #header .main-nav.active {
    transform: translateX(0) !important;
  }
  
  /* Navigation List */
  #header .nav-list {
    display: block !important;
    flex-direction: column !important;
    width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
    flex-wrap: nowrap !important;
    gap: 0 !important;
    text-align: left !important;
    align-items: flex-start !important;
    justify-content: flex-start !important;
  }
  
  /* List Items */
  #header .nav-list li {
    display: block !important;
    width: 100% !important;
    margin-bottom: 1.25rem !important;
    text-align: left !important;
    float: none !important;
    clear: both !important;
  }
  
  /* Links */
  #header .nav-link,
  #header .contact-link {
    display: block !important;
    width: 100% !important;
    padding: 0.5rem 0 !important;
    font-size: 1.1rem !important;
    text-align: left !important;
    white-space: normal !important;
  }
  
  /* Contact Button - now styled like regular links */
  #header .contact-link {
    margin-top: 0 !important;
    text-align: left !important;
    background: none !important;
    color: var(--text-secondary) !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    border: none !important;
  }
  
  /* Prevent horizontal scrolling when menu is open */
  body.menu-open {
    overflow: hidden !important;
    position: fixed !important;
    width: 100% !important;
    height: 100% !important;
  }
  
  /* Background overlay */
  body.menu-open::after {
    content: '' !important;
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background-color: rgba(0, 0, 0, 0.5) !important;
    z-index: 98 !important;
  }
} 