/* ================================================================
 * TOURS PAGES — archive, single, taxonomy archives
 * Scoped: .em-tours-page  (archive + taxonomy)
 *         .em-single-tour-page  (single tour)
 * Enqueued conditionally in functions.php (is_post_type_archive /
 * is_singular('tour') / is_tax).
 * ================================================================ */

/* ---------------------------------------------------------------
 * SHARED BASE
 * ------------------------------------------------------------- */
.em-tours-page,
.em-single-tour-page {
  background: var(--em-bg);
  color: var(--em-ink);
}

/* ---------------------------------------------------------------
 * ARCHIVE HERO  (dark header above the grid)
 * ------------------------------------------------------------- */
.em-archive-hero {
  position: relative;
  background: var(--em-dark);
  padding: 9rem 0 4.5rem;
  overflow: hidden;
}

.em-archive-hero__inner {
  max-width: 760px;
}

.em-archive-hero .em-subtitle {
  color: var(--em-gold);
}

.em-archive-hero .em-title {
  color: var(--em-bg);
  margin: .7rem 0 1.1rem;
}

.em-archive-hero__sub {
  color: rgba(244,236,224,.55);
  font-size: 1.05rem;
  max-width: 580px;
  line-height: 1.65;
}

.em-archive-hero__wm {
  position: absolute;
  bottom: -.08em;
  right: -.04em;
  font-family: var(--em-font-head);
  font-size: clamp(5rem, 18vw, 15rem);
  font-weight: 700;
  letter-spacing: -.04em;
  text-transform: uppercase;
  color: transparent;
  -webkit-text-stroke: 1px rgba(255,255,255,.05);
  pointer-events: none;
  line-height: 1;
  user-select: none;
}

/* ---------------------------------------------------------------
 * BREADCRUMB
 * ------------------------------------------------------------- */
.em-breadcrumb {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .4rem .6rem;
  font-family: var(--em-font-head);
  font-size: .75rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(244,236,224,.35);
  margin-bottom: 1.8rem;
}

.em-breadcrumb a {
  color: rgba(244,236,224,.55);
  transition: color .2s;
}

.em-breadcrumb a:hover {
  color: var(--em-gold);
}

.em-breadcrumb [aria-current="page"],
.em-single-tour-page .em-breadcrumb [aria-current="page"] {
  color: var(--em-gold);
}

/* On single pages the breadcrumb sits on the dark hero */
.em-single-tour-page .em-breadcrumb {
  color: rgba(255,255,255,.35);
}

.em-single-tour-page .em-breadcrumb a {
  color: rgba(255,255,255,.55);
}

/* ---------------------------------------------------------------
 * FILTER BAR
 * ------------------------------------------------------------- */
.em-filter-bar {
  display: flex;
  align-items: center;
  gap: .55rem;
  flex-wrap: wrap;
  margin-bottom: 3rem;
  padding-top: 3rem;
}

.em-filter-bar a {
  font-family: var(--em-font-head);
  font-size: .8rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  font-weight: 600;
  padding: .5rem 1.25rem;
  border-radius: 999px;
  border: 1px solid rgba(28,24,19,.18);
  color: var(--em-muted);
  transition: background .3s, color .3s, border-color .3s;
  white-space: nowrap;
}

.em-filter-bar a:hover {
  border-color: var(--em-gold);
  color: var(--em-gold);
}

.em-filter-bar a.is-active {
  background: var(--em-gold);
  color: #fff;
  border-color: var(--em-gold);
}

/* ---------------------------------------------------------------
 * TOURS ARCHIVE GRID
 * ------------------------------------------------------------- */
.em-tours-archive {
  padding: 0 0 clamp(5rem,11vw,9rem);
}

.em-tours-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.6rem;
}

.em-no-results {
  grid-column: 1 / -1;
  padding: 6rem 0;
  text-align: center;
  color: var(--em-muted);
  font-family: var(--em-font-head);
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: .14em;
}

/* ---------------------------------------------------------------
 * TOUR CARD  (used in archive + related tours on single page)
 * ------------------------------------------------------------- */
.em-tcard {
  background: #fff;
  border-radius: 20px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform .4s var(--em-ease), box-shadow .4s;
}

.em-tcard:hover {
  transform: translateY(-6px);
  box-shadow: 0 22px 60px rgba(28,24,19,.14);
}

/* Image */
.em-tcard__img {
  display: block;
  position: relative;
  aspect-ratio: 4/3;
  overflow: hidden;
  background: var(--em-bg2);
}

.em-tcard__img .ph {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  transition: transform .6s var(--em-ease);
}

.em-tcard:hover .em-tcard__img .ph {
  transform: scale(1.06);
}

/* Badges */
.em-tcard__badge {
  position: absolute;
  top: .9rem;
  left: .9rem;
  background: var(--em-gold);
  color: #fff;
  font-family: var(--em-font-head);
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .12em;
  font-weight: 600;
  padding: .28rem .75rem;
  border-radius: 999px;
  z-index: 2;
}

.em-tcard__diff {
  position: absolute;
  top: .9rem;
  right: .9rem;
  background: rgba(22,19,13,.72);
  color: var(--em-bg);
  font-family: var(--em-font-head);
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-weight: 600;
  padding: .28rem .75rem;
  border-radius: 999px;
  z-index: 2;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}

/* Card body */
.em-tcard__body {
  padding: 1.4rem 1.5rem;
  display: flex;
  flex-direction: column;
  flex: 1;
}

.em-tcard__meta {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
  font-size: .76rem;
  color: var(--em-muted);
  font-family: var(--em-font-head);
  text-transform: uppercase;
  letter-spacing: .07em;
  margin-bottom: .7rem;
}

.em-tcard__meta-item {
  display: flex;
  align-items: center;
  gap: .3rem;
}

.em-tcard__meta-item svg {
  color: var(--em-gold);
  flex-shrink: 0;
}

.em-tcard__title {
  font-family: var(--em-font-head);
  font-weight: 600;
  font-size: 1.4rem;
  line-height: 1.06;
  letter-spacing: -.01em;
  text-transform: uppercase;
  color: var(--em-ink);
  margin-bottom: .6rem;
  transition: color .3s;
}

.em-tcard__title a {
  color: inherit;
}

.em-tcard:hover .em-tcard__title {
  color: var(--em-gold);
}

.em-tcard__highlight {
  font-size: .88rem;
  color: var(--em-muted);
  line-height: 1.55;
  flex: 1;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin-bottom: 1.2rem;
}

/* Card footer */
.em-tcard__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-top: 1px solid rgba(28,24,19,.09);
  padding-top: 1rem;
  margin-top: auto;
  gap: 1rem;
}

.em-tcard__price {
  font-family: var(--em-font-head);
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--em-muted);
  line-height: 1.2;
}

.em-tcard__price strong {
  display: block;
  font-size: 1.55rem;
  color: var(--em-gold);
  letter-spacing: -.02em;
  line-height: 1;
  margin-top: .1rem;
}

.em-tcard__cta {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  font-family: var(--em-font-head);
  text-transform: uppercase;
  letter-spacing: .1em;
  font-weight: 600;
  font-size: .78rem;
  padding: .6rem 1.15rem;
  border-radius: 999px;
  background: var(--em-ink);
  color: var(--em-bg);
  white-space: nowrap;
  transition: background .3s, transform .3s var(--em-ease);
}

.em-tcard__cta:hover {
  background: var(--em-gold);
  transform: translateY(-2px);
}

/* ---------------------------------------------------------------
 * PAGINATION
 * ------------------------------------------------------------- */
.em-pagination {
  margin-top: 4rem;
  display: flex;
  justify-content: center;
}

.em-pagination .nav-links {
  display: flex;
  align-items: center;
  gap: .45rem;
  flex-wrap: wrap;
  justify-content: center;
}

.em-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  height: 44px;
  padding: 0 .5rem;
  border-radius: 999px;
  font-family: var(--em-font-head);
  font-size: .9rem;
  letter-spacing: .04em;
  font-weight: 600;
  border: 1px solid rgba(28,24,19,.16);
  color: var(--em-ink);
  transition: background .25s, border-color .25s, color .25s;
}

.em-pagination .page-numbers:hover,
.em-pagination .page-numbers.current {
  background: var(--em-gold);
  border-color: var(--em-gold);
  color: #fff;
}

.em-pagination .page-numbers.dots {
  border: none;
  background: none;
  color: var(--em-muted);
  pointer-events: none;
}

/* ================================================================
 * SINGLE TOUR
 * ================================================================ */

/* ---------------------------------------------------------------
 * SINGLE HERO
 * ------------------------------------------------------------- */
.em-single-hero {
  position: relative;
  height: 88vh;
  min-height: 560px;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}

.em-single-hero__img {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  transition: transform 1.6s var(--em-ease);
  transform: scale(1.06);
}

.em-single-hero.is-loaded .em-single-hero__img {
  transform: scale(1);
}

.em-single-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(22,19,13,.92) 0%,
    rgba(22,19,13,.5)  45%,
    rgba(22,19,13,.18) 100%
  );
}

.em-single-hero__content {
  position: relative;
  z-index: 2;
  width: 100%;
  padding-bottom: 3.5rem;
}

.em-single-hero h1 {
  font-family: var(--em-font-head);
  font-weight: 600;
  font-size: clamp(2.4rem, 5.5vw, 4.8rem);
  text-transform: uppercase;
  letter-spacing: -.02em;
  line-height: .96;
  color: #fff;
  margin: .8rem 0 1.4rem;
  max-width: 840px;
}

.em-single-hero h1 em {
  font-style: italic;
  font-weight: 500;
  color: var(--em-gold);
  font-family: Georgia, serif;
  text-transform: none;
  letter-spacing: 0;
}

/* Key facts strip */
.em-single-facts {
  display: flex;
  align-items: center;
  gap: 2.2rem;
  flex-wrap: wrap;
  padding-top: 1.6rem;
  border-top: 1px solid rgba(255,255,255,.13);
}

.em-single-fact {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-family: var(--em-font-head);
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: rgba(255,255,255,.6);
}

.em-single-fact svg {
  color: var(--em-gold);
  flex-shrink: 0;
}

.em-single-fact strong {
  color: #fff;
  font-weight: 600;
}

/* ---------------------------------------------------------------
 * SINGLE BODY LAYOUT  (2-col: main left, sidebar right)
 * ------------------------------------------------------------- */
.em-single-body {
  background: var(--em-bg);
}

.em-single-layout {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 4.5rem;
  padding: 5rem 0 7rem;
  align-items: start;
}

/* ---------------------------------------------------------------
 * SINGLE CONTENT (left col)
 * ------------------------------------------------------------- */
.em-single-content h2 {
  font-family: var(--em-font-head);
  font-size: 1.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: -.01em;
  color: var(--em-ink);
  margin: 2.8rem 0 1.1rem;
}

.em-single-content h2:first-child {
  margin-top: 0;
}

.em-single-desc {
  font-size: 1.04rem;
  line-height: 1.74;
  color: var(--em-ink);
}

.em-single-desc p + p {
  margin-top: .9rem;
}

/* Itinerary */
.em-itinerary {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: .5rem;
  margin-top: .5rem;
}

.em-itinerary__item {
  background: #fff;
  border-radius: 14px;
  padding: 1.1rem 1.4rem 1.1rem 1.6rem;
  border-left: 3px solid var(--em-gold);
  transition: box-shadow .3s, border-color .3s;
}

.em-itinerary__item:hover {
  box-shadow: 0 4px 24px rgba(28,24,19,.08);
  border-color: var(--em-gold-d);
}

.em-itinerary__label {
  font-family: var(--em-font-head);
  font-size: .68rem;
  text-transform: uppercase;
  letter-spacing: .18em;
  color: var(--em-gold);
  font-weight: 600;
  margin-bottom: .2rem;
}

.em-itinerary__text {
  font-size: .93rem;
  line-height: 1.57;
  color: var(--em-ink);
}

/* Included / Not Included */
.em-inc-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.2rem;
  margin-top: .5rem;
}

.em-inc-box {
  background: #fff;
  border-radius: 16px;
  padding: 1.4rem 1.5rem;
}

.em-inc-box__title {
  font-family: var(--em-font-head);
  font-size: .76rem;
  text-transform: uppercase;
  letter-spacing: .14em;
  font-weight: 600;
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  gap: .4rem;
}

.em-inc-box--yes .em-inc-box__title {
  color: var(--em-teal);
}

.em-inc-box--no .em-inc-box__title {
  color: var(--em-muted);
}

.em-inc-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: .55rem;
}

.em-inc-list li {
  display: flex;
  align-items: flex-start;
  gap: .5rem;
  font-size: .88rem;
  line-height: 1.48;
  color: var(--em-ink);
}

.em-inc-list li svg {
  flex-shrink: 0;
  margin-top: .15em;
}

.em-inc-box--yes .em-inc-list li svg {
  color: var(--em-teal);
}

.em-inc-box--no .em-inc-list li svg {
  color: rgba(122,111,95,.5);
}

/* Photo gallery */
.em-single-gallery {
  margin-top: .5rem;
}

.em-gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .5rem;
  border-radius: 16px;
  overflow: hidden;
}

.em-gallery-item {
  aspect-ratio: 4/3;
  overflow: hidden;
  background: var(--em-bg2);
}

.em-gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .5s var(--em-ease);
}

.em-gallery-item:hover img {
  transform: scale(1.08);
}

/* ---------------------------------------------------------------
 * BOOKING SIDEBAR  (right col, sticky)
 * ------------------------------------------------------------- */
.em-booking-box {
  background: #fff;
  border-radius: 22px;
  padding: 2rem;
  box-shadow: 0 2px 32px rgba(28,24,19,.08);
  position: sticky;
  top: 100px;
}

.em-booking-box__price-label {
  font-family: var(--em-font-head);
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .16em;
  color: var(--em-muted);
  margin-bottom: .2rem;
}

.em-booking-box__price {
  font-family: var(--em-font-head);
  font-size: 2.8rem;
  font-weight: 700;
  color: var(--em-gold);
  letter-spacing: -.03em;
  line-height: 1;
  margin-bottom: .3rem;
}

.em-booking-box__price-note {
  font-size: .8rem;
  color: var(--em-muted);
  margin-bottom: 1.8rem;
}

.em-btn-whatsapp {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .7rem;
  width: 100%;
  padding: 1rem 1.4rem;
  border-radius: 999px;
  background: #25d366;
  color: #fff;
  font-family: var(--em-font-head);
  font-weight: 600;
  font-size: .95rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  transition: background .3s, transform .3s var(--em-ease);
  margin-bottom: .7rem;
}

.em-btn-whatsapp:hover {
  background: #128c7e;
  transform: translateY(-2px);
}

.em-btn-enquire {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  width: 100%;
  padding: .8rem 1.3rem;
  border-radius: 999px;
  border: 1px solid rgba(28,24,19,.18);
  color: var(--em-ink);
  font-family: var(--em-font-head);
  font-weight: 600;
  font-size: .88rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  transition: border-color .3s, color .3s;
  margin-bottom: 1.8rem;
}

.em-btn-enquire:hover {
  border-color: var(--em-gold);
  color: var(--em-gold);
}

.em-booking-box__divider {
  height: 1px;
  background: rgba(28,24,19,.09);
  margin-bottom: 1.5rem;
}

.em-booking-box__facts {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: .8rem;
  margin-bottom: 1.6rem;
}

.em-booking-box__fact {
  display: flex;
  align-items: flex-start;
  gap: .7rem;
  font-size: .86rem;
  color: var(--em-ink);
  line-height: 1.4;
}

.em-booking-box__fact svg {
  color: var(--em-gold);
  flex-shrink: 0;
  margin-top: .1em;
}

.em-booking-box__fact-label {
  font-family: var(--em-font-head);
  font-size: .68rem;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--em-muted);
  display: block;
  margin-bottom: .1rem;
}

/* Share row */
.em-booking-box__share {
  display: flex;
  align-items: center;
  gap: .6rem;
  font-family: var(--em-font-head);
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--em-muted);
}

.em-booking-box__share a {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 1px solid rgba(28,24,19,.15);
  display: grid;
  place-items: center;
  color: var(--em-muted);
  transition: border-color .2s, color .2s;
}

.em-booking-box__share a:hover {
  border-color: var(--em-gold);
  color: var(--em-gold);
}

/* ---------------------------------------------------------------
 * RELATED TOURS SECTION
 * ------------------------------------------------------------- */
.em-related {
  background: var(--em-bg2);
  padding: clamp(4rem,9vw,7rem) 0;
}

.em-related .em-title {
  margin-bottom: 3rem;
}

.em-related .em-subtitle {
  margin-bottom: .6rem;
}

/* ================================================================
 * RESPONSIVE
 * ================================================================ */
@media (max-width: 1024px) {
  .em-single-layout {
    grid-template-columns: 1fr;
    gap: 3rem;
  }
  .em-booking-box {
    position: static;
    order: -1;
  }
}

@media (max-width: 860px) {
  .em-tours-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .em-tours-grid {
    grid-template-columns: 1fr;
  }
  .em-single-facts {
    gap: 1.4rem;
  }
  .em-inc-grid {
    grid-template-columns: 1fr;
  }
  .em-gallery-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .em-filter-bar {
    gap: .4rem;
  }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .em-tcard,
  .em-tcard__img .ph,
  .em-single-hero__img,
  .em-tcard__cta,
  .em-btn-whatsapp,
  .em-btn-enquire {
    transition: none !important;
    transform: none !important;
  }
}
