* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

/* Accessibility Styles */
.skip-to-main-content {
  position: absolute;
  top: -9999px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--accent);
  color: var(--background);
  padding: 1rem;
  z-index: 9999;
  text-decoration: none;
  border-radius: 0 0 4px 4px;
  transition: top 0.3s ease;
}

.skip-to-main-content:focus {
  top: 0;
}

/* High contrast mode adjustments */
@media (forced-colors: active) {
  .accent {
    /* Safari does not support forced-color-adjust; consider using background and color overrides for high contrast */
    background: Highlight;
    color: HighlightText;
  }
}

/* Reduced motion preferences */
@media (prefers-reduced-motion: reduce) {
  * {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* Print styles */
@media print {
  nav, footer, form {
    display: none !important;
  }
  
  body {
    background: white;
    color: black;
  }
  
  main {
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }
  
  @page {
    margin: 2cm;
  }
}

:root {
  /* Colors */
  --background: #faf9f6;
  --foreground: #1a1a1a;
  --muted: #6b6b6b;
  --neutral-light: #c4c4c4;
  --neutral-dark: #2a2a2a;
  --dark-blue: #1c2833;
  --accent: #c9a961;
  --accent-hover: #b89850;
}

body {
  font-family: "Inter", sans-serif;
  background-color: var(--background);
  color: var(--foreground);
}

.font-serif {
  font-family: "Cormorant Garamond", serif;
}

.font-sans {
  font-family: "Inter", sans-serif;
}

/* Custom Scrollbar */
::-webkit-scrollbar {
  width: 10px;
}

::-webkit-scrollbar-track {
  background: var(--neutral-dark);
}

::-webkit-scrollbar-thumb {
  background: var(--accent);
  border-radius: 5px;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--accent-hover);
}

/* Parallax Effect */
.parallax-bg {
  will-change: transform;
}

/* Smooth Scroll */
html {
  scroll-behavior: smooth;
}

/* Navbar Scrolled State */
.navbar-scrolled {
  background-color: var(--dark-blue) !important;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
}

.navbar-scrolled #nav-content {
  height: 4rem !important;
}

/* Added styles for logo positioning */
#logo-sticky {
  pointer-events: none;
}

#logo-sticky.opacity-100 {
  pointer-events: auto;
}

/* Body No Scroll */
body.no-scroll {
  overflow: hidden;
}

/* Utility Classes */
.bg-background {
  background-color: var(--background);
}

.bg-neutral-dark {
  background-color: var(--neutral-dark);
}

.bg-dark-blue {
  background-color: var(--dark-blue);
}

.bg-accent {
  background-color: var(--accent);
}

.bg-accent-hover:hover {
  background-color: var(--accent-hover);
}

.text-foreground {
  color: var(--foreground);
}

.text-muted {
  color: var(--muted);
}

.text-neutral-light {
  color: var(--neutral-light);
}

.text-accent {
  color: var(--accent);
}

.border-neutral-light {
  border-color: var(--neutral-light);
}

/* Logo transition and sizing */
.logo-transition {
  transition: opacity 220ms ease, height 220ms ease, max-height 220ms ease;
  display: block;
}

/* Responsive image handling */
img {
  max-width: 100%;
  height: auto;
}


/* Logo wrapper to handle vertical centering in sticky nav */
.logo-wrapper {
  width: auto;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* When navbar is sticky, ensure logo wrapper keeps logo vertically centered
   and the logo images don't exceed 64px */
.navbar-sticky .logo-wrapper {
  height: 60px; /* keep navbar logo area compact */
}

.navbar-sticky .logo-wrapper .logo-img {
  max-height: 60px;
  height: auto;
}


.side-menu-reservations-btn {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  background-color: var(--accent);
  color: var(--background);
  padding: 1rem;
  text-align: center;
  font-weight: 500;
  text-decoration: none;
  z-index: 1000;
  box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.3);
  transition: background-color 0.3s ease;
}

/* Sticky navbar styles when side menu is open */
body:has(#side-menu.translate-x-0) .navbar-scrolled {
  background-color: transparent !important;
  box-shadow: none;
}
body:has(#side-menu.translate-x-0) #logo-sticky {
  display: none;
}
/* Hide top navbar reservations button when side menu is open */
body:has(#side-menu.translate-x-0) nav a[href="reservations1.html"] {
  display: none;
}
/* Mobile fixed reservations button */
@media (max-width: 768px) {
  /* Hide the top navbar reservations button on mobile */
  nav a[href="reservations1.html"] {
    display: none;
  }
  
  
  .mobile-reservations-btn {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    background-color: var(--accent);
    color: var(--background);
    padding: 1rem;
    text-align: center;
    font-weight: 500;
    text-decoration: none;
    z-index: 1000;
    box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.3);
    transition: background-color 0.3s ease;
  }
  
  .mobile-reservations-btn:hover {
    background-color: var(--accent-hover);
    color: var(--background);
  }
    /* Increase side menu z-index to overlap all content on mobile */
    #side-menu {
      z-index: 9998;
    }
    /* Navbar on top to avoid close icon being hidden behind side menu */
    #navbar {
      z-index: 9999;
    }
    
    /* Hide initial logo when side menu is open on mobile */
    body:has(#side-menu.translate-x-0) #logo-initial {
      display: none;
    }
    /* Sticky navbar styles when side menu is open */
    body:has(#side-menu.translate-x-0) .navbar-scrolled {
      background-color: transparent !important;
      box-shadow: none;
    }
    /* Hide reservations button in mobile view when side menu is open */
    body:has(#side-menu.translate-x-0) .mobile-reservations-btn {
      display: none;
    }
  
  /* Add bottom padding to body to prevent content from being hidden behind fixed button */
  body {
    padding-bottom: 3.5rem;
  }

}