/* ==========================================================================
   NAV FIX — Loaded AFTER style.css so cascade always wins
   Fixes desktop nav height + mobile menu layout
   v=9
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. HEADER AREA — compact branding row
   -------------------------------------------------------------------------- */
#branding {
  height: auto !important;
  min-height: 50px !important;
  padding: 8px 15px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  flex-wrap: wrap !important;
  max-width: none !important;
  width: 100% !important;
}

body #branding .aot-logo {
  float: none !important;
  margin: 0 !important;
  max-width: none !important;
  width: auto !important;
}

body #branding .aot-logo img {
  max-height: 52px !important;
  width: auto !important;
  max-width: none !important;
}

/* Header right side — SINGLE social-header column: phone, button, lang-switcher */
.social-header {
  float: none !important;
  padding: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-end !important;
  gap: 4px !important;
  margin-left: auto !important;
  width: auto !important;
}

.social-header-h3 {
  font-size: 18px !important;
  margin: 0 !important;
  text-align: right !important;
  line-height: 1.2 !important;
}

.social-header-h3::before {
  content: "Call or Text" !important;
  font-size: 9px !important;
  display: block !important;
  text-align: right !important;
  margin: 0 !important;
  padding: 0 !important;
  color: #888 !important;
  font-weight: normal !important;
}

/* Phone number ORANGE */
.social-header .feature,
.social-header-h3 .feature,
#branding .feature {
  color: #ff7f00 !important;
}

/* Book Online button — its own row */
.social-header .btn-primary {
  padding: 6px 14px !important;
  font-size: 13px !important;
  margin: 0 !important;
  display: inline-block !important;
}

/* Language switcher — its own row, both languages visible */
.social-header .lang-switcher {
  font-size: 13px !important;
  margin: 2px 0 0 0 !important;
  display: block !important;
  vertical-align: baseline !important;
  line-height: 1.4 !important;
  white-space: normal !important;
}

.social-header .lang-switcher a {
  color: #006699 !important;
  text-decoration: none !important;
  padding: 0 6px !important;
  display: inline !important;
}

.social-header .lang-switcher a:hover {
  text-decoration: underline !important;
}

.social-header .lang-switcher span {
  color: #ccc !important;
  padding: 0 2px !important;
}

/* --------------------------------------------------------------------------
   2. DESKTOP NAV BAR — compact, title case, no bold/uppercase
   -------------------------------------------------------------------------- */
.navbar {
  margin-bottom: 0 !important;
}

.main-navigation {
  clear: both !important;
  display: block !important;
  width: 100% !important;
  background-color: #006699 !important;
  min-height: 42px !important;
}

/* Desktop: show menu as inline horizontal */
.main-navigation .menu {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  justify-content: flex-start !important;
}

.main-navigation .menu > li {
  float: left !important;
  position: relative !important;
  margin: 0 !important;
}

.main-navigation .menu > li > a {
  display: block !important;
  padding: 10px 16px !important;
  color: #fdf5e3 !important;
  line-height: 22px !important;
  font-size: 15px !important;
  font-family: "Open Sans Condensed", sans-serif !important;
  font-weight: 400 !important;
  text-transform: none !important;
  letter-spacing: 0.02em !important;
  text-decoration: none !important;
  white-space: nowrap !important;
}

.main-navigation .menu > li > a:hover,
.main-navigation .menu > li > a:focus {
  background-color: #005580 !important;
  color: #fff !important;
}

.main-navigation .current-menu-item > a,
.main-navigation .current_page_item > a {
  background-color: #0085b0 !important;
  color: #fff !important;
}

/* Desktop dropdowns */
.main-navigation .sub-menu {
  display: none !important;
  position: absolute !important;
  top: 100% !important;
  left: 0 !important;
  z-index: 99999 !important;
  background-color: #006699 !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  min-width: 200px !important;
  box-shadow: 0 3px 6px rgba(0,0,0,0.2) !important;
}

.main-navigation .menu > li:hover > .sub-menu {
  display: block !important;
}

.main-navigation .sub-menu li {
  float: none !important;
  width: 100% !important;
}

.main-navigation .sub-menu a {
  display: block !important;
  padding: 8px 16px !important;
  color: #fdf5e3 !important;
  font-size: 14px !important;
  font-family: "Open Sans Condensed", sans-serif !important;
  font-weight: 400 !important;
  text-transform: none !important;
  text-decoration: none !important;
  white-space: nowrap !important;
}

.main-navigation .sub-menu a:hover {
  background-color: #005580 !important;
  color: #fff !important;
}

/* Nested sub-menus */
.main-navigation .sub-menu .sub-menu {
  top: 0 !important;
  left: 100% !important;
}

.main-navigation .sub-menu li:hover > .sub-menu {
  display: block !important;
}

/* Only hide mobile toggle on desktop — on mobile, nav-fix.css ::before overrides the original style.css */
.menu-toggle {
  display: none !important;
}

.menu-toggle:before {
  content: none !important;
  display: none !important;
}

/* --------------------------------------------------------------------------
   3. MOBILE NAV (< 1024px) — single column, clean dividers
   -------------------------------------------------------------------------- */
@media (max-width: 1023px) {

  /* Show hamburger, hide inline menu */
  .menu-toggle {
    display: block !important;
    width: 100% !important;
    background-color: #006699 !important;
    color: #fff !important;
    font-family: "Open Sans Condensed", sans-serif !important;
    font-size: 16px !important;
    font-weight: 400 !important;
    text-transform: none !important;
    letter-spacing: 0.04em !important;
    padding: 12px 20px !important;
    border: none !important;
    border-radius: 0 !important;
    cursor: pointer !important;
    text-align: left !important;
    box-sizing: border-box !important;
  }

  .menu-toggle::before {
    content: "☰  " !important;
    font-size: 18px !important;
    display: inline-block !important;
  }

  .menu-toggle:hover,
  .menu-toggle:focus {
    background-color: #005580 !important;
  }

  .menu-toggle[aria-expanded="true"]::before {
    content: "✕  " !important;
  }

  /* Hide menu by default on mobile */
  .main-navigation .menu {
    display: none !important;
    flex-direction: column !important;
  }

  /* Show when toggled */
  .main-navigation.toggled .menu {
    display: block !important;
    background-color: #006699 !important;
  }

  /* Single column stacking */
  .main-navigation .menu > li {
    float: none !important;
    width: 100% !important;
    border-bottom: 1px solid rgba(255,255,255,0.15) !important;
  }

  .main-navigation .menu > li:last-child {
    border-bottom: none !important;
  }

  .main-navigation .menu > li > a {
    padding: 12px 20px !important;
    font-size: 15px !important;
    line-height: 1.4 !important;
  }

  /* Sub-menus: indented with lighter background */
  .main-navigation .sub-menu {
    display: none !important;
    position: static !important;
    background-color: #005580 !important;
    box-shadow: none !important;
    min-width: 0 !important;
    width: 100% !important;
  }

  .main-navigation .menu > li.menu-item-has-children.toggled > .sub-menu {
    display: block !important;
  }

  .main-navigation .sub-menu li {
    border-bottom: 1px solid rgba(255,255,255,0.08) !important;
  }

  .main-navigation .sub-menu li:last-child {
    border-bottom: none !important;
  }

  .main-navigation .sub-menu a {
    padding: 10px 20px 10px 30px !important;
    font-size: 14px !important;
  }

  /* Nested sub-sub-menus: further indented */
  .main-navigation .sub-menu .sub-menu {
    background-color: #004466 !important;
  }

  .main-navigation .sub-menu .sub-menu a {
    padding-left: 40px !important;
  }

  /* Dropdown indicator for parent items */
  .main-navigation .menu-item-has-children > a::after {
    content: " ▾" !important;
    font-size: 10px !important;
  }

  /* Mobile header: compact single row — logo left, social column right */
  #branding {
    display: flex !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
    padding: 8px 12px !important;
    height: auto !important;
  }

  body #branding .aot-logo {
    max-width: none !important;
    width: auto !important;
    margin: 0 !important;
    flex-shrink: 0 !important;
  }

  body #branding .aot-logo img {
    max-height: 45px !important;
    width: auto !important;
    max-width: none !important;
  }

  .social-header {
    margin-left: auto !important;
    align-items: flex-end !important;
  }

  .social-header-h3 {
    font-size: 16px !important;
  }

  .social-header .btn-primary {
    font-size: 12px !important;
    padding: 5px 10px !important;
  }
}

/* --------------------------------------------------------------------------
   4. EXTRA SMALL MOBILE (< 480px)
   -------------------------------------------------------------------------- */
@media (max-width: 479px) {
  #branding {
    padding: 6px 10px !important;
    column-gap: 8px !important;
    row-gap: 3px !important;
  }

  body #branding .aot-logo {
    max-width: none !important;
    width: auto !important;
  }

  body #branding .aot-logo img {
    max-height: 40px !important; /* Increased from 30px */
    width: auto !important;
    max-width: none !important;
  }

  .social-header-h3 {
    font-size: 14px !important;
  }

  .social-header .btn-primary {
    font-size: 11px !important;
    padding: 4px 8px !important;
  }
}
