/* === Mobile & Tablet (max 991px) === */
@media (max-width: 991px) {
  .manage-booking-content-header h1 {
    font-size: 28px !important;
    text-align: center;
  }

  .manage-booking-form-box {
    display: flex;
    flex-direction: column;
    gap: 30px;
  }

  .manage-booking-guest-box,
  .manage-booking-existing-customer-box {
    width: 88%;
    margin: auto;
  }

  .manage-booking-input-box {
    width: 100%;
    margin-bottom: 15px;
  }

  .manage-booking-input-box input,
  .manage-booking-input-box select {
    /* width: 100%; */
    font-size: 16px;
  }

  .manage-booking-content-divider {
    justify-content: center;
    margin: 15px 0;
  }

  button {
    width: 100%;
    font-size: 16px;
    padding: 10px;
  }

  .manage-booking-forgot-password-box {
    text-align: right;
    margin-bottom: 10px;
  }
}

/* === Small Mobile Devices (max 576px) === */
@media (max-width: 576px) {
  .manage-booking-content-header h1 {
    font-size: 22px !important;
    line-height: 1.3;
    padding: 0 10px;
  }
  .create-account-content h1{
    font-size: 20px;
  }

  .manage-booking-guest-box h1,
  .manage-booking-existing-customer-box h1 {
    font-size: 20px;
    text-align: center;
  }

  .manage-booking-input-box label {
    font-size: 14px;
  }

  .manage-booking-input-box input,
  .manage-booking-input-box select {
    font-size: 14px;
    padding: 8px;
  }
}


/* section 6 */
@media (max-width: 768px) {
  .booking-content-box {
    padding: 30px 15px;
  }

  .booking-content-box-icons-box {
    display: flex;
    flex-direction: column;
    gap: 0px;
    margin-top: -20px;
    align-items: center;
  }

  .booking-content-box-icons-box-item {
    display: flex;
    flex-direction: column;
    gap: 0px;
    align-items: center;
    width: 90%;
    margin: auto;
  }

  .booking-content-box-icons-box-item-icon {
    width: 100%;
    max-width: 500px; /* keep it centered and not too wide */
    text-align: center;
    padding: 10px;
  }

  .booking-content-box-icons-box-item-icon p {
    width: 100%;
    font-size: 16px;
    line-height: 1.5;
    word-spacing: 1px;
  }

  .booking-content-box-icons-box-item-icon h1 {
    font-size: 20px;
    /* margin: 10px 0; */
  }

  .booking-content-box h1 {
    font-size: 26px;
    text-align: center;
  }
  .booking-content-search-form{
    margin-top: -15px;
  }
}

@media (max-width: 480px) {
  .booking-content-box-icons-box-item-icon p {
    font-size: 14px;
  }

  .booking-content-box-icons-box-item-icon h1 {
    font-size: 18px;
  }

  .booking-content-box h1 {
    font-size: 22px;
  }
}

@media (max-width: 525px) {
  .elementor-body {
    display: flex;
    flex-direction: column !important;
    align-items: center;
    justify-content: center;
    gap: 20px;
  }}


/* navbar */
/* MOBILE MENU STYLING */
.navbar-content{
  width: 90% !important;
  display: flex !important;
  justify-content: space-between !important;
}
@media (max-width:1300px){
  .navbar-content{
  width: 94% !important;
  display: flex !important;
  justify-content: space-between !important;
}}
.nav-container {
  display: none;
  flex-direction: column;
  width: 100%;
  background-color: #fff;
  position: absolute;
  top: 120px;
  left: 0px;
  z-index: 999;
}

.nav-container.active-nav {
  display: flex !important;
}

.header-nav-links {
  display: flex;
  flex-direction: column;
  padding: 0;
  margin: 0;
  list-style: none;
  width: 100%;
} 

@media (max-width: 768px) {
  .header-nav-links li {
    width: 100% !important;
    text-align: center !important;
    padding: 14px 0;
    border-bottom: 1px solid #ddd;
  }

  .header-nav-links li a {
    display: block;
    width: 100%;
    text-align: center;
    text-decoration: none;
    color: #333;
    font-weight: bold;
  }
  
}

/* Submenu (mobile view) */
.sub-menu {
  display: none;
  flex-direction: column;
  background: #f9f9f9;
}

.hfe-has-submenu-container.active>.sub-menu {
  display: flex;
}

.sub-menu li {
  padding: 12px 0;
  border-bottom: 1px solid #ccc;
}

.sub-menu li a {
  text-align: center;
  width: 100%;
}

/* === MOBILE HOVER FULL WIDTH === */
.header-nav-links li:hover {
  background-color: #f0f0f0 !important;
  /* change to your desired hover color */
}

.header-nav-links li a:hover {
  background-color: transparent !important;
  /* prevent double background */
  color: #000 !important;
  /* optional: text color on hover */
}
.hfe-has-submenu-container:hover .sub-menu {
  visibility: visible;
  opacity: 1;
  transition: visibility 0s, opacity 0.3s ease-in;
}

.sub-menu {
  padding: 0px;
  position: absolute;
  visibility: visible;
  opacity: 0;
  background-color: #fff;
  min-width: 230px;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
  z-index: 1000;
  transition: visibility 0s 0.3s, opacity 0.3s ease-in;
}
.sub-menu li a {
  color: #333;
  text-decoration: none;
  display: block;
  width: 100%;
  text-align: left;
}
.sub-menu li {
  padding: 15px 5px !important;
  border-bottom: 0.1px solid #ccc;
}

.sub-menu li:hover {
  background-color: #252d87 !important;
  color: #fff !important;
}
.sub-menu li:hover a {
  /* background-color: #252d87 !important; */
  color: #fff !important;
}

/* DESKTOP STYLES */
@media (min-width: 768px) {
  .nav-container {
    display: block !important;
    position: static;
    background: none;
  }

  .header-nav-links {
    flex-direction: row;
    justify-content: flex-end;
    gap: 20px;
  }

  .header-nav-links li {
    border: none;
    padding: 0;
    text-align: left;
  }

  .hfe-nav-menu__toggle {
    display: none;
  }

  .sub-menu {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
  }

  .hfe-has-submenu-container:hover .sub-menu {
    display: block;
  }
}
/* Hide by default */
.hfe-has-submenu-container {
  position: relative;
}

.sub-menu {
  display: none;
  flex-direction: column;
  background: white; /* or match your nav background */
  padding: 10px;
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  z-index: 999;
  text-align: center;
  min-width: 200px;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
}

.sub-menu a {
  text-align: center;
  padding: 8px 0;
  display: block;
  color: #000;
  text-decoration: none;
}

/* Show when toggled */
.sub-menu.show-submenu {
  display: flex;
}

