/**
* Theme Name: Traveler Child 
* Description: This is a child theme of the Traveler theme.
* Template: traveler
*/

.st-attributes {
  display: none !important;
}

.product-tripadvisor{
  margin-top: 10px;
}

.item-tour:hover .featured-image img {
  transform: scale(1.05);
}

.partner-item-tour:hover .featured-image img {
  transform: scale(1.05);
}

.item-tour .featured-image img,
.top-attraction-background {
  transition: all 1.5s cubic-bezier(0, 0, 0.2, 1);
}

.partner-item-tour .featured-image img {
  transition: all 1.5s cubic-bezier(0, 0, 0.2, 1);
}

.tour-card-image {
  overflow: hidden;
}

.item-tours h3.title{
  line-height: 25px !important;
  font-size: 18px !important;
}

/* EXPLORE PAGE */
.search-container {
  max-width: 1320px !important;
  margin: 0 auto;
}

.explore-page-container {
  padding-top: 40px;
  padding-bottom: 60px;
}

.explore-page-header {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 30px;
  margin-bottom: 40px;
  align-items: flex-start;
}

.explore-page-header > div:first-child {
  flex: 1 1 400px;
  min-width: 300px;
}

.explore-page-heading {
  font-size: 48px;
  color: #1a2b49;
  margin-bottom: 12px;
}

.explore-page-description {
  font-size: 18px;
  line-height: 1.6;
  color: #4a4a4a;
}

.explore-page-media {
  flex-shrink: 0;
  width: 500px;
  max-width: 100%;
  border-radius: 9px;
  overflow: hidden;
  position: relative;
}

.explore-video-wrapper {
  position: relative;
  padding-bottom: 56.25%; /* 16:9 ratio */
  height: 0;
  overflow: hidden;
}

.explore-video-wrapper iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
  border-radius: 9px;
}

.explore-page-media img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 9px;
}

@media (max-width: 768px) {
  .explore-page-header {
    flex-direction: column;
    align-items: stretch;
  }

  .explore-page-heading {
    font-size: 36px;
  }

  .explore-page-media {
    width: 100%;
  }
}

.home-page-custom-section {
  padding: 70px 0px 50px 0px;
}

.section-heading {
  font-size: 36px;
  text-align: center;
  margin-bottom: 34px;
}

.tour-card-section h3 {
  font-size: 32px;
  margin-bottom: 40px;
}

.tour-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
}

.tour-grid .item-tour {
  flex: 0 0 23%;
  max-width: 23%;
}

.tour-grid .partner-item-tour {
  flex: 0 0 31%;
  max-width: 32%;
}

/* Medium screens: 2 items per row */
@media (max-width: 1024px) {
  .tour-grid .item-tour {
    flex: 0 0 48%;
    max-width: 48%;
  }

  .tour-grid .partner-item-tour {
    flex: 0 0 48%;
    max-width: 48%;
  }
}

/* Small screens: 1 item per row */
@media (max-width: 768px) {
  .tour-grid .item-tour {
    flex: 0 0 100%;
    max-width: 100%;
  }

  .tour-grid .partner-item-tour {
    flex: 0 0 100%;
    max-width: 100%;
  }

  .tour-grid {
    gap: 14px;
  }
}

.tour-card {
  width: 300px;
  background: #fff;
  border-radius: 8px;
  box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.1);
  overflow: hidden;
  transition: transform 0.3s ease-in-out;
}

.tour-card:hover {
  transform: translateY(-5px);
}

.tour-image img {
  width: 100%;
  height: 200px;
  object-fit: cover;
}

.tour-details {
  padding: 15px;
  display: flex;
  flex-direction: column;
}

.tour-details h3 {
  font-size: 18px;
  margin-bottom: 10px;
}

.tour-details p {
  font-size: 14px;
  margin: 5px 0;
  color: #555;
}

.tour-card a {
  text-decoration: none;
  color: inherit;
}

.item .featured-image {
  position: relative;
}

.tour-card-type {
  font-size: 12px !important;
  color: #fd620b !important;
  text-align: left;
  margin-bottom: 2px !important;
  display: inline-block;

  position: absolute;
  bottom: -16px;
  left: 14px;
  overflow: hidden;
}

.tour-type-badge {
  padding: 5px 12px;
  border-radius: 15px;
}

.hidden-attraction {
  display: none;
}

.view-more-button {
  margin-top: 20px;
  padding: 10px 25px;
  background-color: #0073aa;
  color: #fff;
  border: none;
  font-size: 16px;
  cursor: pointer;
  border-radius: 4px;
  transition: background-color 0.2s ease;
}

.view-more-button:hover {
  background-color: #005f8d;
}

.view-more-container {
  display: flex;
  justify-content: center;
}

.badge-wrapper {
  position: absolute;
  top: 15px;
  left: 14px;
  display: flex;
  flex-direction: column;
  gap: 5px;
  z-index: 1;
}

.service-tag.best-tour-tag {
  position: static;
  padding: 5px 10px;
  font-size: 13px;
  font-weight: 600;
  border-radius: 8px;
}

.explore-no-results {
  color: red;
  font-size: 22px;
}
/* HOME PAGE TAB NAVIGATION AT BOTTOM */

.tabs-navigation {
  display: flex;
  align-items: center;
  position: relative;
  width: 100%;
  overflow: hidden;
  border-bottom: 2px solid #ddd;
}

.tabs-menu {
  display: flex;
  gap: 20px;
  list-style: none;
  padding: 0;
  flex-grow: 1;
  flex-wrap: nowrap;
  white-space: nowrap;
  overflow: hidden;
  margin-bottom: 0 !important;
}

.tabs-card-container ul {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 15px;
  margin: 20px 0;
  padding-left: 0 !important ;
}

/* Responsive Design */

@media (max-width: 768px) {
  .tabs-card-container ul {
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
  }
}

@media (max-width: 480px) {
  .tabs-card-container ul {
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
  }
}

.tabs-menu li {
  cursor: pointer;
  padding: 10px 15px;
  font-size: 18px;
  color: #555;
}
.tabs-menu li.active {
  font-weight: bold;
  border-bottom: 3px solid #0073aa;
  color: #0073aa;
}
.tab-panel {
  display: none;
}
.tab-panel.active {
  display: block;
}
.top-attractions-list,
.top-destinations-list,
.top-countries-list {
  text-align: center;
}
.top-attractions-list ul,
.top-destinations-list ul,
.top-countries-list ul {
  list-style: none;
  padding: 0;
}
.top-attractions-list li,
.top-destinations-list li,
.top-countries-list li {
  margin-bottom: 10px;
  font-size: 18px;
}

.tab-scroll-btn {
  display: none;
}

@media screen and (max-width: 768px) {
  .tab-scroll-btn {
    background: #fff;
    border: 1px solid #ccc;
    border-radius: 50%;
    width: 36px;
    height: 36px;
    cursor: pointer;
    z-index: 1;
    display: flex;
    justify-content: center;
    align-items: center;
  }

  .tab-scroll-btn.left {
    left: 0;
  }

  .tab-scroll-btn.right {
    right: 0;
  }

  .scroll-btn {
    display: flex;
    gap: 6px;
  }
}

/* EXPLORE PAGE CATEGORY BUTTON */

.tour-category-buttons {
  margin-bottom: 30px;
}

.filter-btn {
  display: inline-block;
  padding: 10px 15px;
  margin: 5px;
  background-color: #fff;
  color: #1a2b49;
  text-decoration: none;
  border-radius: 9px;
  border: 2px solid #dee2e6;
}

.filter-btn.active {
  background-color: #003c8b;
  color: #fff;
}

.card-container ul {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 15px;
  margin-bottom: 20px;
  padding-left: 0 !important ;
}

.card {
  background: #fff;
  padding: 10px;
  border-radius: 4px;
  text-align: left;
  border: 1px solid #eee;
  transition: transform 0.2s ease-in-out;
  padding-bottom: 15px;
}

.card:hover {
  transform: scale(1.05);
}

.card a {
  text-decoration: none;
  color: #333;
  font-weight: bold;
  display: block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.card span {
  display: block;
  font-size: 14px;
  color: #666;
  margin-top: 5px;
}

/* Responsive Design */
@media (max-width: 1024px) {
  .card-container {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 768px) {
  .card-container {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 480px) {
  .card-container {
    grid-template-columns: repeat(1, 1fr);
  }
}

/* Dropdown Menu Styling */

.header__center #st-main-menu .main-menu li.menu-item-has-children .fa {
  right: 0px !important;
}

.dropdown-toggle {
  position: relative;
  text-decoration: none;
}

.custom-dropdown-menu {
  /* z-index: 11001; */
  background-color: #fff;
  position: absolute;
  left: 0;
  top: 120%;
  padding-left: 0;
  margin-bottom: 0;
  padding-top: 10px;
  padding-bottom: 10px;
  z-index: 999;
  opacity: 0;
  visibility: hidden;
  transition: all 0.2s ease-in-out;
  border: 1px solid #dedede;
  box-sizing: border-box;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08), 0 4px 12px rgba(0, 0, 0, 0.05);
  border-radius: 10px;
}

.home-page-experiences,
.home-page-cities,
.home-page-attractions,
.explore-page-experiences,
.explore-page-attractions {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 14px;
  list-style-type: none;
  padding: 16px !important;
  overflow: hidden;
}

.menu-list-item {
  display: flex;
  padding: 8px;
  border-radius: 9px;
}

.menu-list-item:hover {
  background-color: #e9ecef;
}

.top-list-content {
  margin-left: 10px;
  font-family: "DM Sans", Sans-serif;
}

.exp-menu-list-item {
  font-family: "DM Sans", Sans-serif;
  display: flex;
  align-items: center;
  padding: 8px;
  border-radius: 9px;
}

.exp-menu-list-item:hover {
  background-color: #e9ecef;
}

.menu-content p {
  margin-bottom: 0;
  margin-left: 10px;
}

.top-list-content .attraction-name {
  margin-bottom: 0;
  font-weight: normal;
  line-height: 1;
}

.top-list-content .description {
  font-size: 14px;
  color: #63687a;
  margin-bottom: 0;
}

.menu-item:hover .custom-dropdown-menu {
  top: 100%;
  opacity: 1;
  visibility: visible;
}

.top-city-icon,
.top-exp-icon,
.top-attraction-icon {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  flex-shrink: 0;
  border: 2px solid #fff;
}

.top-city-icon img,
.top-exp-icon img,
.top-attraction-icon img {
  width: 100%;
  height: 100%;
  border-radius: 50%;
}

.top-city-icon:has(svg),
.top-exp-icon:has(svg),
.top-attraction-icon:has(svg) {
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #d1d5db;
  border-radius: 9px;
}

.top-city-icon svg,
.top-exp-icon svg,
.top-attraction-icon svg {
  width: 30px;
  height: 30px;
}

.tour-exp {
  display: flex !important;
}

@media screen and (max-width: 991px) {
  .custom-dropdown-menu {
    position: static;
    display: none;
    width: 100%;
    box-shadow: none;
    padding: 10px 0;
    border-radius: 0;
    border: none;
    opacity: 1;
    visibility: visible;
    transition: all 0.2s ease-in-out;
  }

  .custom-dropdown-menu.active {
    display: block;
  }

  .home-page-cities,
  .home-page-attractions,
  .home-page-experiences,
  .explore-page-attractions {
    display: block;
  }

  .dropdown-toggle {
    width: 100%;
    display: block;
    padding: 10px;
  }

  .top-city-icon,
  .top-attraction-icon {
    width: 35px;
    height: 35px;
  }

  .top-list-content {
    font-size: 14px;
  }

  .menu-item {
    position: static;
    width: 100%;
  }
}

/* HEADER SEARCH BLOCK */

.custom-search-block {
  width: 60%;
  position: relative;
}

.header-search-block {
  border: 1px solid #ced4da;
  border-radius: 16px;
  overflow: hidden;
  padding: 3px;
  display: flex;
  align-items: center;
  min-width: 250px;
  height: 100%;
}

.header-search-block input {
  box-shadow: none;
  border: none;
  font-size: 14px;
  padding: 5px 10px;
  color: var(--grey-color, #5e6d77);
  flex-grow: 1;
}

.header-search-block button {
  border: none;
  background: none;
  padding: 0 5px;
}

.custom-search-block,
#hero-search-form {
  transition: opacity 0.3s ease-in-out;
}

@media screen and (max-width: 782px) {
  .custom-search-block {
    width: 100%;
    margin-top: 10px;
  }
}

/* HEADER SEARCH BLOCK DROPDOWN */

.search-dropdown {
  display: block;
  white-space: nowrap;
  width: 400px;
  z-index: 10;
  position: absolute;
  top: 40px;
  border-radius: 15px;
  margin-top: 10px;
}

@media screen and (max-width: 480px) {
  .search-dropdown {
    width: 250px;
  }
}

.search-dropdown ul {
  background-color: #fff;
  box-shadow: rgba(0, 0, 0, 0.05) 0px 6px 24px 0px,
    rgba(0, 0, 0, 0.08) 0px 0px 0px 1px;
  overflow: auto;
  padding: 6px !important;
  border-radius: 5px;
  height: 400px;
}

.search-dropdown .search-result-item:not(:first-child) {
  margin-left: 0px;
}

.search-result-item {
  display: flex;
  align-items: center;
  padding: 8px 12px;
  cursor: pointer;
  list-style: none;
  overflow: hidden;
  border-bottom: 1px solid #ebeef1;
  margin-left: 0px !important;
  border-radius: 9px;
}

.search-result-item:last-child {
  border-bottom: 0;
}

.search-result-item .icon {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-shrink: 0;
  background: #d1d5db;
  margin-right: 8px;
  color: #1a2b49;
  width: 40px;
  height: 40px;
  padding: 3px;
  border-radius: 9px;
}

.search-result-item .icon svg {
  width: 20px;
  height: 20px;
}

.image-icon {
  width: 42px;
  height: 42px;
  display: flex;
  justify-content: center;
  border-radius: 50%;
  object-fit: cover;
  overflow: hidden;
  margin-right: 9px;
}
.image-icon {
  width: 42px;
  height: 42px;
  display: flex;
  justify-content: center;
  border-radius: 50%;
  object-fit: cover;
  overflow: hidden;
  margin-right: 9px;
}

.image-icon:has(svg) {
  align-items: center;
  background-color: #d1d5db;
  border-radius: 9px;
}

.image-icon img {
  width: full;
}

.image-icon svg {
  width: 20px;
  height: 20px;
}

.search-result-item .search-description {
  font-size: 16px;
  color: #868e96;
  font-family: "Roboto", serif;
  font-weight: 400;
  text-align: left;
}

.search-result-item p {
  text-align: left;
  margin-bottom: 0 !important;
}
.search-result-item:hover {
  background-color: #ebeef1;
}

.no-results {
  background-color: #fff;
  box-shadow: rgba(0, 0, 0, 0.05) 0px 6px 24px 0px,
    rgba(0, 0, 0, 0.08) 0px 0px 0px 1px;
  overflow: hidden;
  padding: 6px !important;
  border-radius: 5px;
}

/* HERO SEARCH FORM */

#hero-search-form {
  width: 100%;
  display: flex;
  justify-content: center;
}

.hero-section-form {
  width: 80%;
  margin: 0 auto;
}

.hero-section-form .hero-search {
  display: flex;
  justify-content: center;
  border-radius: 18px;
  overflow: hidden;
}

.hero-section-form input {
  width: 100%;
  padding: 10px 20px;
  border: none;
}

.hero-section-form button {
  border: none;
  margin-left: -12px;
  padding: 10px 15px;
  background-color: #fff;
}

.hero-search-dropdown {
  display: block;
  white-space: nowrap;
  width: 900px;
  z-index: 10;
  position: absolute;
  left: 150px;
  top: 40px;
  border-radius: 15px;
  margin-top: 10px;
}

.hero-search-dropdown ul {
  background-color: #fff;
  box-shadow: rgba(0, 0, 0, 0.05) 0px 6px 24px 0px,
    rgba(0, 0, 0, 0.08) 0px 0px 0px 1px;
  overflow: hidden;
  padding: 6px !important;
  border-radius: 5px;
  max-height: 500px;
  overflow-y: auto;
}

.hero-search-dropdown .search-result-item:not(:first-child) {
  margin-left: 0px;
}

.search-result-loading {
  background-color: #fff;
  box-shadow: rgba(0, 0, 0, 0.05) 0px 6px 24px 0px,
    rgba(0, 0, 0, 0.08) 0px 0px 0px 1px;
  overflow: hidden;
  padding: 6px !important;
  border-radius: 5px;
}

.header-main-menu {
  padding-top: 14px;
  max-width: 1400px;
  width: 100%;
  margin: 0 auto;
}

.header__center {
  max-width: 1350px;
  width: 100%;
  margin: 0 auto;
  padding: 0 20px;
}

.header__right {
  width: 100%;
  height: 100%;
}

.header__center #st-main-menu .main-menu > li > a {
  padding: 17px 18px !important;
}

.main-menu .fa-angle-down {
  margin-left: 10px;
}

.header__left .logo img {
  max-height: 60px !important;
  object-fit: cover;
}

@media screen and (max-width: 782px) {
  .header__left,
  .header__right {
    width: 100%;
    display: block;
  }

  .header-main-menu {
    flex-direction: column;
    align-items: center;
  }

  .header__right ul.items {
    justify-content: center;
    padding: 10px 0;
  }

  .custom-search-block {
    width: 80%;
  }

  .header__right {
    position: relative;
    z-index: 1;
  }

  .header__left {
    z-index: 2;
  }

  .header__left .logo img {
    max-height: 50px;
  }

  .header {
    padding-top: 0px !important;
    padding-bottom: 0px !important;
  }

  .st-mod-style .header__left .logo {
    top: 30% !important;
  }
}

@media screen and (max-width: 480px) {
  .custom-search-block {
    width: 100%;
  }
}
/* BREADCRUMBS */

.breadcrumb {
  padding: 20px 0 !important;
  border-bottom: 1px solid var(--light-grey-color, #eaeef3);
}

.breadcrumb ul {
  list-style: none;
  display: block;
  width: 100%;
  margin-bottom: 0;
  padding-left: 0;
  background: #fff;
}

.breadcrumb ul li:first-child {
  padding-left: 0;
}

.breadcrumb ul li {
  position: relative;
  display: inline-block;
  padding-left: 20px;
  padding-right: 20px;
  z-index: 0;
}

.breadcrumb ul li a {
  display: block;
  font-weight: 500;
  color: var(--link-color, #1a2b48);
  text-decoration: none;
  line-height: 21px;
}

.breadcrumb ul li:not(:last-child):after {
  position: absolute;
  content: "";
  top: 50%;
  right: -2px;
  margin-top: -2px;
  width: 4px;
  height: 4px;
  background: var(--light-grey-color, #eaeef3);
  z-index: 1;
}

.breadcrumb ul li.active {
  color: var(--grey-color, #5e6d77);
}

.single-tour-breadcrumb {
  padding: 20px 0 !important;
  border-bottom: 1px solid var(--light-grey-color, #eaeef3);
}

.single-tour-breadcrumb ul {
  list-style: none;
  display: block;
  width: 100%;
  margin-bottom: 0;
  padding-left: 0;
  background: #fff;
}

.single-tour-breadcrumb ul li:first-child {
  padding-left: 0;
}

.single-tour-breadcrumb ul li {
  position: relative;
  display: inline-block;
  padding-left: 20px;
  padding-right: 20px;
  z-index: 0;
}

.single-tour-breadcrumb ul li a {
  display: block;
  font-weight: 500;
  color: #ff6100 !important;
  text-decoration: none;
  line-height: 21px;
}

.single-tour-breadcrumb ul li:not(:last-child):after {
  position: absolute;
  content: "";
  top: 50%;
  right: -2px;
  margin-top: -2px;
  width: 4px;
  height: 4px;
  background: var(--light-grey-color, #eaeef3);
  z-index: 1;
}

.single-tour-breadcrumb ul li.active {
  color: var(--grey-color, #5e6d77);
}

@media screen and (max-width: 768px) {
  .single-tour-breadcrumb ul,
  .breadcrumb ul {
    font-size: 13px;
  }

  .single-tour-breadcrumb ul li,
  .breadcrumb ul {
    padding: 5px 8px;
  }

  .single-tour-breadcrumb ul li a,
  .breadcrumb ul {
    font-size: 13px;
  }
}

@media (max-width: 1024px) {
  .single-tour-breadcrumb ul li:last-child {
    padding-left: 0;
  }
}

/* Top Attractions Section */
.top-attractions-section {
  margin: 50px 0;
}

.top-attractions-section h3 {
  font-size: 32px;
  margin-bottom: 40px;
}

.top-attractions-section h4 {
  font-size: 24px;
  margin-bottom: 20px;
}

/* Default (Desktop) */
.attraction-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}

/* Tablet (2 per row) */
@media (max-width: 1024px) {
  .attraction-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* Mobile (1 per row) */
@media (max-width: 600px) {
  .attraction-grid {
    grid-template-columns: 1fr;
  }

  .attraction-card {
    height: 200px;
  }

  .attraction-card h3 {
    font-size: 16px;
    padding: 8px;
  }

  .top-attractions-section h3 {
    font-size: 20px;
    text-align: center;
  }

  .view-more-button {
    width: 100%;
    font-size: 15px;
    padding: 10px;
  }
}

/* City section in explore page */


.city-grid {
  display: flex;
  flex-wrap: wrap;
}

.city-grid a {
  text-decoration: none;
  font-size: 16px !important;
  color: #1a2b49;
  display: flex;
  align-items: center;
}

.city-grid a:hover {
  color: #ed6c2d;
}

.city-grid .divider {
  width: 2px;
  height: 16px;
  background-color: #444;
  margin: 0 10px;
  border-radius: 1px;
  flex-grow: 0;
}

.city-grid a:last-child .divider {
  display: none;
}

.partner-item-tour .service-avatar,
.explore-page-container .service-avatar,
.home-page-custom-section .service-avatar,
.most-clicked .service-avatar {
  position: absolute;
  bottom: -16px;
  right: 20px;
  height: 35px;
  width: 35px;
  border: 1px solid #dfdfdf;
  border-radius: 50% !important;
  overflow: hidden;
}

.top-experiences-dropdown {
  position: relative;
}
.top-experiences-dropdown .sub-menu {
  display: none;
  position: absolute;
  background-color: #fff;
  padding: 10px;
  min-width: 200px;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1);
  z-index: 1000;
}
.top-experiences-dropdown:hover .sub-menu {
  display: block;
}
.top-experiences-dropdown .sub-menu li {
  padding: 0;
  list-style: none;
}

.most-clicked,
.travel-guides-section {
  padding: 80px 0px 50px 0px;
}

.most-clicked-container {
  padding: 10px;
}

.most-clicked h2,
.travel-guides-section h2 {
  margin: 0px 0px 30px 0px;
}

.most-clicked-container h2,
.travel-guides-section h2 {
  font-family: "DM Sans", Sans-serif;
  font-size: 36px;
  font-weight: 700;
  line-height: 46px;
  color: #232323;
  text-align: center;
}

.most-clicked-container p,
.travel-guides-section p {
  font-family: "Roboto", Sans-serif;
  font-size: 16px;
  text-align: justify;
  font-weight: 400;
  color: #7a7a7a;
}

.most-clicked-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(250px, 1fr));
  gap: 20px;
  margin-top: 30px;
}

/* Base (Desktop) */
.most-clicked-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(250px, 1fr));
  gap: 20px;
  margin-top: 30px;
}

/* Tablet screens (2 per row) */
@media (max-width: 1024px) {
  .most-clicked-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* Mobile screens (1 per row) */
@media (max-width: 600px) {
  .most-clicked-grid {
    grid-template-columns: 1fr;
  }

  .top-city-content h3,
  .top-attraction-content h4 {
    font-size: 20px;
  }

  .most-clicked-container h2 {
    font-size: 28px;
  }

  .most-clicked-container p {
    font-size: 15px;
  }

  .top-city,
  .top-attraction {
    height: 180px;
  }
}

.top-city,
.travel-guide-card,
.top-attraction {
  position: relative;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  height: 200px;
  text-decoration: none;
  color: white;
  overflow: hidden;
  transition: transform 0.5s ease, background-size 0.5s ease;
}

.top-city-background,
.top-attraction-background,
.travel-guide-background {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  z-index: 0;
  transition: all 1.5s cubic-bezier(0, 0, 0.2, 1);
}

.background-overlay,
.travel-guide-background-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.6), rgba(0, 0, 0, 0.2));
  z-index: 1;
}

.top-city-card,
.top-attraction-card {
  overflow: hidden;
  border-radius: 10px;
}

.top-city:hover .top-city-background,
.top-attraction:hover .top-attraction-background {
  transform: scale(1.05);
  transition: all 1.5s cubic-bezier(0, 0, 0.2, 1);
}

.travel-guide-card:hover .travel-guide-background {
  transform: scale(1.05);
  color: #fff;
}

.top-city-content,
.top-attraction-content {
  position: relative;
  z-index: 2;
  padding: 20px;
  text-align: center;
}

.top-city-content h3,
.top-attraction-content h4 {
  font-family: "Lexend", sans-serif;
  margin: 0;
  font-size: 30px;
  font-weight: 700;
  color: #fff;
}

.travel-guide-content {
  position: relative;
  z-index: 2;
  width: 100%;
}

.travel-guide-content h3 {
  font-family: "Lexend", sans-serif;
  font-weight: 700;
  font-size: 18px;
  line-height: 26px;
  margin-top: 0;
  color: #fff;
}

.travel-guide-avatar {
  width: 100%;
  margin-top: 10px;
  display: flex;
  align-items: center;
  gap: 20px;
  z-index: 2;
  position: relative;
  color: rgba(255, 255, 255, 0.7);
  font-size: 14px;
}

.travel-guide-avatar img {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  border: 2px solid #fff;
  object-fit: cover;
}

.other-posts-section {
  padding: 40px 20px;
  margin-bottom: 40px;
}

.other-posts-section h2 {
  font-size: 2rem;
  margin-bottom: 30px;
  text-align: center;
  color: #333;
}

.other-post {
  position: relative;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  height: 300px;
  border-radius: 12px;
  overflow: hidden;
  margin-bottom: 30px;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.other-post:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.2);
}

.overlay-post {
  background: rgba(0, 0, 0, 0.5); /* semi-transparent black */
  color: #fff;
  position: absolute;
  bottom: 0;
  width: 100%;
  padding: 20px;
  transition: background 0.3s ease;
}

.other-post h3 {
  font-size: 1.5rem;
  margin-bottom: 10px;
}

.other-post h3 a {
  color: #fff;
  text-decoration: none;
}

.other-post h3 a:hover {
  text-decoration: underline;
}

.other-post p {
  font-size: 1rem;
  margin: 0;
}

.travel-guides-slider-wrapper {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin: 0 auto;
  padding-top: 40px;
}

swiper-container {
  overflow: visible !important;
  width: 100%;
  height: 100%;
  max-width: 1300px;
}

.travel-guide-card {
  height: 350px;
  background-size: cover;
  background-position: center;
  border-radius: 12px;
  padding: 20px;
  text-decoration: none;
  color: white;
  display: flex;
  align-items: flex-start;
  justify-content: flex-end;
  flex-direction: column;
}

.custom-swiper-prev,
.custom-swiper-next {
  width: 40px;
  height: 40px;
  background: #ffffff;
  border: 1px solid #dedede;
  box-shadow: 0px 1px 2px rgba(0, 0, 0, 0.08), 0px 4px 12px rgba(0, 0, 0, 0.05);
  border-radius: 50%;
  cursor: pointer;
  color: #333;
  z-index: 10;
  flex-shrink: 0;
  display: flex;
  justify-content: center;
  align-items: center;
}

.custom-swiper-prev:hover,
.custom-swiper-next:hover {
  background-color: #f0f0f0;
}

/* Pagination below */
swiper-container::part(pagination) {
  position: static;
  margin-top: 20px;
  text-align: center;
}

swiper-container::part(pagination-bullet) {
  background: rgba(255, 255, 255, 0.6);
  opacity: 1;
}

swiper-container::part(pagination-bullet-active) {
  background: #000;
}

/* Responsive */
@media (max-width: 1024px) {
  .custom-swiper-prev,
  .custom-swiper-next {
    display: none !important;
  }

  .travel-guide-card {
    height: 240px;
  }
}

.st-pagination {
  margin-top: 30px;
  text-align: center;
}

.st-pagination .page-numbers {
  display: inline-block;
  padding: 10px 15px;
  margin: 0 5px;
  border: 1px solid #ddd;
  color: #333;
  text-decoration: none;
}

.st-pagination .current {
  background-color: #ffab53;
  color: #fff;
  border-color: #ffab53;
}

.partner-tour-title {
  margin-bottom: 16px;
  font-size: 14px;
  font-weight: 500;
  color: #1a2b48;
  text-transform: uppercase;
  background: 0 0;
  border: none;
}

.partner-tour-title p {
  display: inline-block;
  padding: 15px 0;
  color: var(--main-color, #5191fa);
  border: none;
  border-bottom: 2px solid var(--main-color, #5191fa);
}

.custom-social-icons {
  display: flex;
  gap: 12px;
  list-style: none;
  padding: 0;
  margin: 10px 0;
}

.custom-social-icons li {
  display: inline-flex;
  align-items: center;
}

.custom-social-icons a img {
  width: 24px;
  height: 24px;
  transition: transform 0.3s ease, filter 0.3s ease;
}

/* Optional hover effect */
.custom-social-icons a:hover img {
  transform: scale(1.1);
  filter: brightness(1.2);
}

.tripadvisor-wrapper {
  box-shadow: 0px 1px 2px rgba(0, 0, 0, 0.08), 0px 4px 12px rgba(0, 0, 0, 0.05);
  border: none;
  margin-top: 20px;
  border-radius: 16px;
}

swiper-slide {
  height: auto !important;
}

.st-single-item-tour{
  height: 100%;
}

swiper-container.swiper-center-slides .swiper-wrapper {
  justify-content: center;
}

.explore-other-option-title {
  font-weight: 700 !important;
  font-size: 36px !important;
  line-height: 46px !important;
  margin-bottom: 60px !important;
  color: #003c8b !important;
}

.explore-hr {
  margin-top: 70px;
  margin-bottom: 70px;
  width: 100%;
  height: 1px;
  background: var(--light-grey-color, #eaeef3);
}

.item-tours .reviews {
  margin: 10px 0 6px 0 !important;
}

.socialWidget.cx_brand_refresh1 .socialWidgetCore.sm img {
  width: 19px !important;
  padding: 4px 0px 4px 0px !important;
}

.socialWidget.cx_brand_refresh1 .socialWidgetCore.sm {
  width: 25px !important;
  height: 25px !important;
  display: flex !important;
  justify-content: center !important;
}

.socialWidgetCallout .bubbles {
  font-size: 14px !important;
}

.socialWidgetCallout .borderBox {
  border: none !important;
}

.TA_socialButtonBubbles img {
    max-width: 25px;  
    height: 25px;
    transition: all 0.2s ease-in-out;
    /* display: inline-block; */
}