body {
  font-family: "Philosopher", sans-serif;
  line-height: 1.47;
  font-size: 16px;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: "Philosopher", sans-serif;
}
.eorik-nav-style .navbar-area .navbar-brand img {
  max-height: 60px;
  background-color: #fff;
  padding: 10px;
  border-radius: 10px;
}
@media only screen and (max-width: 991px) {
  .mobile-nav .logo {
    top: 7px !important ;
  }
  .mobile-nav .logo img {
    padding: 5px;
    border-radius: 10px;
    background: #fff;
  }
}
.article-content h1 {
  font-size: 20px;
}
.article-content h2 {
  font-size: 18px;
}

.article-content h3 {
  font-size: 16px !important;
}
.article-content ul {
  list-style: disc;
  padding-left: 20px;
}
.article-content table {
  margin-bottom: 15px;
}
/* Reduce orange overlay intensity on featured gallery hover */
.restaurants-area .single-restaurants::after {
  opacity: 0.45;
}

.service-board-group {
  margin-bottom: 24px;
}
.service-page-intro {
  font-size: 17px;
  color: #333;
  line-height: 1.75;
  width: 100%;
  max-width: 100%;
  background: #fff8ef;
  border-left: 4px solid #d08a3c;
  border-radius: 10px;
  padding: 18px 22px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.06);
}
.service-page-intro__label {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  color: #b66a1b;
  margin-bottom: 8px;
}
.service-page-intro p:last-child {
  margin-bottom: 0;
}
.service-board-title {
  font-weight: 700;
  letter-spacing: 1px;
  margin-bottom: 16px;
  font-size: 34px;
}
.service-board-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.service-board-item {
  margin-bottom: 14px;
}
.service-board-item-top {
  display: flex;
  align-items: center;
  gap: 8px;
}
.service-name {
  white-space: nowrap;
  font-size: 18px;
  font-weight: 600;
}
.service-dot {
  flex: 1;
  border-bottom: 2px dotted #666;
  transform: translateY(2px);
}
.service-price {
  white-space: nowrap;
  font-weight: 800;
  font-size: 16px;
  color: #b71c1c;
}
.service-price-old {
  white-space: nowrap;
  font-weight: 500;
  font-size: 14px;
  color: #777;
  text-decoration: line-through;
  margin-right: 4px;
}
.service-subtext {
  font-size: 14px;
  color: #555;
  margin-top: 3px;
}
.service-gallery-wrap {
  width: 100%;
}
.service-gallery-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}
.service-gallery-popup {
  display: block;
}
.service-gallery-thumb {
  width: 100%;
  height: 250px;
  object-fit: cover;
  border-radius: 8px;
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.12);
  transition: transform 0.25s ease;
}
.service-gallery-popup:hover .service-gallery-thumb {
  transform: translateY(-2px);
}

@media (min-width: 992px) {
  .service-board-row {
    --bs-gutter-x: 60px;
  }
}
@media (max-width: 991px) {
  .service-gallery-row {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
@media (max-width: 575px) {
  .service-gallery-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.product-gallery-wrap {
  margin-bottom: 30px;
}
.product-gallery-main-link {
  display: block;
}
.product-gallery-main-image {
  width: 100%;
  height: 420px;
  object-fit: cover;
}
.product-gallery-thumbs {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
  margin-top: 10px;
}
.product-gallery-thumb {
  display: block;
  border: 2px solid transparent;
}
.product-gallery-thumb.active {
  border-color: #c2b59b;
}
.product-gallery-thumb img {
  width: 100%;
  height: 70px;
  object-fit: cover;
}
.product-booking-card {
  border: 1px solid #e6e6e6;
  padding: 16px 20px 20px;
  width: 100%;
  max-width: 100%;
  margin-left: 0;
}
.product-booking-card .from-text {
  font-style: italic;
  color: #666;
}
.product-booking-card .price {
  margin-top: 2px;
  margin-bottom: 14px;
}
.product-booking-card .new-price {
  font-size: 42px;
  font-weight: 700;
  color: #1a2f5f;
  line-height: 1;
}
.product-booking-card .old-price {
  margin-left: 8px;
  color: #888;
  text-decoration: line-through;
}
.product-booking-btn.default-btn {
  width: 100%;
  text-align: center;
  padding-left: 10px;
  padding-right: 10px;
}
.products-details-tab .tabs {
  border-right: 1px solid #ddd;
  padding-right: 24px;
}
.products-details-tab .tabs li {
  width: 100%;
}
.products-details-tab .tabs li a {
  width: 100%;
  min-height: 44px;
  display: flex;
  align-items: center;
}
.product-details-area
  .products-details-tab
  .tab_content
  .tabs_item
  .products-details-tab-content
  p {
  color: #444;
  font-size: 18px;
}

.page-navigation-area .pagination {
  justify-content: center;
  gap: 8px;
}
.page-navigation-area .pagination .page-item .page-link {
  border: 1px solid #e2e2e2;
  min-width: 42px;
  height: 42px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #444;
  border-radius: 4px;
  font-weight: 600;
  background: #fff;
}
.page-navigation-area .pagination .page-item.active .page-link {
  background: #c2b59b;
  border-color: #c2b59b;
  color: #fff;
}
.page-navigation-area .pagination .page-item .page-link:hover {
  background: #f6f2eb;
  border-color: #c2b59b;
  color: #333;
}

.service-booking-block {
  border: 1px solid #e8e8e8;
  border-radius: 8px;
  padding: 22px;
}
.service-booking-heading {
  margin-bottom: 18px;
  font-size: 26px;
}
.service-booking-day {
  font-size: 22px;
  font-weight: 700;
}
.service-booking-form .form-control:not(textarea),
.service-booking-form .form-select {
  height: 54px;
  padding-top: 10px;
  padding-bottom: 10px;
}
.service-time-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 10px;
}
.service-time-slot {
  border: 1px solid #ddd;
  border-radius: 6px;
  background: #fff;
  padding: 8px 6px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  font-weight: 600;
}
.service-time-slot .status {
  font-size: 14px;
}
.service-time-slot.is-disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.service-time-slot.is-selected {
  border-color: #c2b59b;
  background: #f6f2eb;
}
@media (max-width: 991px) {
  .service-time-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}
@media (max-width: 575px) {
  .service-time-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.service-picks-hint {
  line-height: 1.5;
}
.service-picks-hint-plus {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.35em;
  height: 1.35em;
  margin: 0 0.15em;
  border: 1px solid #ccc;
  border-radius: 4px;
  font-weight: 700;
  font-size: 0.95em;
  line-height: 1;
  vertical-align: middle;
  color: #333;
}
.service-pick-list .service-pick-select {
  min-width: 0;
}
.service-pick-line .service-pick-add,
.service-pick-line .service-pick-remove {
  flex-shrink: 0;
  width: 54px;
  min-height: 54px;
  padding: 0;
  font-size: 24px;
  font-weight: 500;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.service-pick-line .service-pick-remove {
  font-size: 28px;
  font-weight: 300;
}

/* Form tìm phòng: chữ + icon luôn một hàng; không ẩn icon ở breakpoint theme */
#form-search-room.check-form .check-btn .default-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-wrap: nowrap;
  white-space: nowrap;
  max-width: 100%;
  box-sizing: border-box;
}

#form-search-room.check-form .check-btn .default-btn i {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  vertical-align: middle;
}

@media only screen and (min-width: 992px) and (max-width: 1199px) {
  #form-search-room.check-form .check-content .default-btn i {
    display: inline-flex !important;
  }
}

/* Google Translate (footer): giữ widget trong DOM nhưng ẩn — UI dùng .lang-switcher */
.lang-switcher #google_translate_element2.lang-switcher__google,
.lang-switcher__google {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  border: 0 !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.lang-switcher__google .skiptranslate {
  display: none !important;
}

.eorik-nav-style .others-option {
  display: flex;
  align-items: center;
  gap: 12px;
}

/*
 * MeanMenu copies #navbarSupportedContent into .mean-nav; .others-option sits beside the ul.
 * When the menu is closed the ul is hidden but .others-option stays visible — a second white strip.
 * Pull .others-option into the dark .mean-bar row (containing block: .mean-bar) so hotline + lang sit
 * between logo and hamburger. Breakpoint must match meanScreenWidth in custom.js (991px).
 */
@media only screen and (max-width: 991px) {
  .eorik-nav-style .mobile-nav.mean-container .mean-nav > .others-option {
    position: absolute;
    left: 50%;
    top: 0;
    transform: translateX(-50%);
    height: 70px;
    margin: 0;
    padding: 0 10px;
    max-width: min(300px, calc(100vw - 168px));
    display: flex !important;
    align-items: center;
    justify-content: center;
    gap: 12px;
    z-index: 10002;
    background: transparent;
    border: none;
    box-shadow: none;
    pointer-events: auto;
    white-space: nowrap;
  }

  .eorik-nav-style .mobile-nav.mean-container .mean-nav > .others-option .call-us {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin: 0;
  }

  /* On mobile hide phone text, keep only icon (space-saving) */
  .eorik-nav-style .mobile-nav.mean-container .mean-nav > .others-option .call-us {
    font-size: 0;
    line-height: 0;
  }

  .eorik-nav-style .mobile-nav.mean-container .mean-nav > .others-option .call-us i {
    font-size: 22px;
    line-height: 30px;
    margin-right: 0;
  }

  /* Make language button height match the meanmenu icon area */
  .eorik-nav-style .mobile-nav.mean-container .mean-nav > .others-option .lang-switcher__trigger {
    width: 30px;
    height: 30px;
    font-size: 13px;
    box-shadow: 0 0 0 3px rgba(114, 187, 80, 0.45);
  }

  @media only screen and (max-width: 400px) {
    .eorik-nav-style .mobile-nav.mean-container .mean-nav > .others-option .call-us i {
      font-size: 20px;
      line-height: 28px;
    }
  }
}

/* Nút tròn + dropdown (Vi / En) */
.lang-switcher {
  position: relative;
  display: flex;
  align-items: center;
  flex-shrink: 0;
}

.lang-switcher__trigger {
  width: 40px;
  height: 40px;
  padding: 0;
  border: none;
  border-radius: 50%;
  cursor: pointer;
  background: #72bb50;
  color: #fff;
  font-weight: 700;
  font-size: 15px;
  letter-spacing: 0.02em;
  line-height: 1;
  box-shadow: 0 0 0 4px rgba(114, 187, 80, 0.45);
  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    background 0.2s ease;
}

.lang-switcher__trigger:hover {
  background: #6aa545;
  box-shadow: 0 0 0 5px rgba(114, 187, 80, 0.55);
}

.lang-switcher__trigger:focus {
  outline: 2px solid rgba(255, 255, 255, 0.85);
  outline-offset: 3px;
}

.lang-switcher.is-open .lang-switcher__trigger {
  transform: scale(1.03);
}

.lang-switcher__panel {
  position: absolute;
  top: calc(100% + 12px);
  right: 0;
  min-width: 148px;
  padding: 8px;
  border-radius: 14px;
  background: rgba(32, 34, 38, 0.92);
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.35);
  border: 1px solid rgba(255, 255, 255, 0.08);
  z-index: 9999;
  display: none;
}

.lang-switcher.is-open .lang-switcher__panel {
  display: block;
}

.lang-switcher__item {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  margin: 0;
  border: none;
  border-radius: 10px;
  background: transparent;
  color: #fff;
  font-weight: 600;
  font-size: 15px;
  cursor: pointer;
  text-align: left;
  transition: background 0.15s ease;
}

.lang-switcher__item:hover,
.lang-switcher__item:focus {
  background: rgba(61, 111, 184, 0.95);
  outline: none;
}

.lang-switcher__item.is-active {
  background: rgba(61, 111, 184, 0.85);
}

.lang-switcher__check {
  width: 1.1em;
  opacity: 0;
  font-size: 14px;
  color: rgba(255, 255, 255, 0.95);
}

.lang-switcher__item.is-active .lang-switcher__check {
  opacity: 1;
}

.lang-switcher__code {
  flex: 1;
}

@media (max-width: 576px) {
  .lang-switcher__trigger {
    width: 44px;
    height: 44px;
    font-size: 14px;
  }
}
