/**
 * Listing modal gallery — authoritative overrides (load last).
 * Fixes legacy ld-* / duplicate thumb rails and centers arrows at bottom.
 */

body.listing-modal-open #listing-modal {
  position: fixed !important;
  inset: 0 !important;
  z-index: 25000 !important;
  display: flex !important;
  flex-direction: column !important;
  padding: 0 !important;
  margin: 0 !important;
  background: #fff !important;
}

body.listing-modal-open #listing-modal .listing-modal-dialog,
body.listing-modal-open #listing-modal .listing-modal-dialog.lp-dialog,
body.listing-modal-open #listing-modal .listing-detail-page {
  display: flex !important;
  flex-direction: column !important;
  flex: 1 1 auto !important;
  width: 100% !important;
  max-width: none !important;
  height: 100dvh !important;
  max-height: none !important;
  margin: 0 !important;
  padding: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  overflow: hidden !important;
  background: #fff !important;
}

body.listing-modal-open #listing-modal .lp-scroll,
body.listing-modal-open #listing-modal .listing-detail-scroll,
body.listing-modal-open #listing-modal #listing-modal-scroll-root {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  overflow-x: hidden !important;
  overflow-y: auto !important;
  -webkit-overflow-scrolling: touch !important;
}

/* Horizontal photo strip below hero (when JS populates thumbs) */
body.listing-modal-open #listing-modal #gallery-thumbs-side:not([hidden]),
body.listing-modal-open #listing-modal .ld-gallery__side:not([hidden]),
body.listing-modal-open #listing-modal #gallery-thumbs:not([hidden]),
body.listing-modal-open #listing-modal .gallery-thumbs:not([hidden]) {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  gap: 8px !important;
  width: 100% !important;
  max-height: none !important;
  height: auto !important;
  visibility: visible !important;
  padding: 10px 0 0 !important;
  margin: 0 !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  -webkit-overflow-scrolling: touch !important;
  background: transparent !important;
  border: none !important;
}

body.listing-modal-open #listing-modal #gallery-thumbs-side:not([hidden]) button,
body.listing-modal-open #listing-modal .ld-gallery__side:not([hidden]) button,
body.listing-modal-open #listing-modal #gallery-thumbs:not([hidden]) button {
  flex: 0 0 76px !important;
  width: 76px !important;
  height: 56px !important;
  padding: 0 !important;
  border: 2px solid #e2e8f0 !important;
  border-radius: 8px !important;
  overflow: hidden !important;
  cursor: pointer !important;
  background: #e8ecf0 !important;
}

body.listing-modal-open #listing-modal #gallery-thumbs-side:not([hidden]) button.is-active,
body.listing-modal-open #listing-modal .ld-gallery__side:not([hidden]) button.is-active,
body.listing-modal-open #listing-modal #gallery-thumbs:not([hidden]) button.is-active {
  border-color: #c9a24d !important;
  box-shadow: 0 0 0 1px #c9a24d !important;
}

body.listing-modal-open #listing-modal #gallery-thumbs-side:not([hidden]) img,
body.listing-modal-open #listing-modal .ld-gallery__side:not([hidden]) img,
body.listing-modal-open #listing-modal #gallery-thumbs:not([hidden]) img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  position: static !important;
  display: block !important;
}

body.listing-modal-open #listing-modal #gallery-thumbs-side[hidden],
body.listing-modal-open #listing-modal .ld-gallery__side[hidden],
body.listing-modal-open #listing-modal #gallery-thumbs[hidden] {
  display: none !important;
}

body.listing-modal-open #listing-modal #gallery-photo-count:not(.is-loading),
body.listing-modal-open #listing-modal .ld-gallery__badge:not(.is-loading),
body.listing-modal-open #listing-modal .lp-gallery-badge:not(.is-loading) {
  display: none !important;
}

body.listing-modal-open #listing-modal .listing-photo-loading,
body.listing-modal-open #listing-modal .listing-photo-loading--compact {
  pointer-events: none !important;
}

/* Keep compact loader visible over hero while remaining photos load */
body.listing-modal-open #listing-modal #listing-modal-gallery-wrap.has-hero-photo.is-loading-photos .listing-photo-loading,
body.listing-modal-open #listing-modal .listing-modal-media--hero.has-hero-photo.is-loading-photos .listing-photo-loading {
  display: flex !important;
  opacity: 1 !important;
  visibility: visible !important;
}

body.listing-modal-open #listing-modal .gallery-main.is-photo-loaded #gallery-skeleton {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

body.listing-modal-open #listing-modal .lp-gallery-main,
body.listing-modal-open #listing-modal .gallery-main {
  position: relative !important;
  isolation: isolate !important;
}

body.listing-modal-open #listing-modal #modal-image {
  z-index: 1 !important;
}

body.listing-modal-open #listing-modal #gallery-thumbs {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  gap: 8px !important;
  width: 100% !important;
  padding: 10px 12px 0 !important;
  margin: 0 !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  -webkit-overflow-scrolling: touch !important;
  scroll-snap-type: x proximity;
}

body.listing-modal-open #listing-modal #gallery-thumbs:not([hidden]) button {
  flex: 0 0 72px !important;
  width: 72px !important;
  height: 54px !important;
  scroll-snap-align: start;
}

body.listing-modal-open #listing-modal #gallery-photo-count.is-loading {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  position: absolute;
  top: 0.75rem;
  right: 0.75rem;
  z-index: 14;
  padding: 0.35rem 0.65rem;
  border-radius: 999px;
  background: rgba(7, 21, 38, 0.78);
  color: #fff;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.01em;
  pointer-events: none;
}

body.listing-modal-open #listing-modal #gallery-photo-count.is-loading .swmo-house-loader__icon--badge {
  width: 1rem;
  height: 1rem;
  color: #f5c542;
  flex-shrink: 0;
  animation: swmo-house-bob 1.4s ease-in-out infinite;
}

/* Single-column hero (no side thumb column) */
body.listing-modal-open #listing-modal .ld-gallery__mosaic,
body.listing-modal-open #listing-modal .lp-gallery-mosaic {
  display: block !important;
  grid-template-columns: 1fr !important;
  gap: 0 !important;
}

body.listing-modal-open #listing-modal .ld-gallery,
body.listing-modal-open #listing-modal .lp-gallery-block {
  margin-bottom: 1.5rem !important;
}

body.listing-modal-open #listing-modal .ld-gallery__main,
body.listing-modal-open #listing-modal .gallery-main:not(.lp-gallery-main) {
  position: relative !important;
  width: 100% !important;
  height: min(52vh, 480px) !important;
  min-height: 220px !important;
  max-height: 480px !important;
  border-radius: 12px !important;
  overflow: hidden !important;
  background: #e8eaed !important;
}

/* Homepage modal uses lp-gallery — match /homes hero size (property.css owns height) */
body.listing-modal-open #listing-modal .lp-gallery-mosaic {
  height: min(520px, 56vh) !important;
  max-height: 520px !important;
}

body.listing-modal-open #listing-modal .lp-gallery-main {
  height: 100% !important;
  min-height: 280px !important;
  max-height: none !important;
}

body.listing-modal-open #listing-modal .gallery-main img,
body.listing-modal-open #listing-modal #modal-image {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  z-index: 1 !important;
}

/* Bottom control bar (lp layout) */
body.listing-modal-open #listing-modal .lp-gallery-controls {
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  z-index: 12 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 10px !important;
  padding: 28px 14px 14px !important;
  background: linear-gradient(180deg, transparent 0%, rgba(7, 21, 38, 0.78) 100%) !important;
  pointer-events: none !important;
}

body.listing-modal-open #listing-modal .lp-gallery-controls > * {
  pointer-events: auto !important;
}

/* Legacy ld layout: position prev / counter / next at bottom */
body.listing-modal-open #listing-modal .ld-gallery__main .gallery-prev,
body.listing-modal-open #listing-modal .gallery-main .gallery-prev,
body.listing-modal-open #listing-modal .gallery-nav.gallery-prev {
  position: absolute !important;
  top: auto !important;
  left: 12px !important;
  bottom: 14px !important;
  right: auto !important;
  transform: none !important;
  z-index: 18 !important;
  pointer-events: auto !important;
}

body.listing-modal-open #listing-modal .ld-gallery__main .gallery-next,
body.listing-modal-open #listing-modal .gallery-main .gallery-next,
body.listing-modal-open #listing-modal .gallery-nav.gallery-next {
  position: absolute !important;
  top: auto !important;
  right: 12px !important;
  bottom: 14px !important;
  left: auto !important;
  transform: none !important;
  z-index: 18 !important;
  pointer-events: auto !important;
}

body.listing-modal-open #listing-modal .ld-gallery__counter,
body.listing-modal-open #listing-modal #gallery-counter,
body.listing-modal-open #listing-modal .lp-gallery-counter {
  position: absolute !important;
  top: auto !important;
  left: 50% !important;
  bottom: 20px !important;
  transform: translateX(-50%) !important;
  margin: 0 !important;
  padding: 0.4rem 0.75rem !important;
  border-radius: 999px !important;
  background: rgba(7, 21, 38, 0.75) !important;
  color: #fff !important;
  font-size: 0.85rem !important;
  font-weight: 700 !important;
  z-index: 17 !important;
  white-space: nowrap !important;
  pointer-events: none !important;
}

body.listing-modal-open #listing-modal .lp-gallery-controls,
body.listing-modal-open #listing-modal #gallery-controls {
  z-index: 18 !important;
  pointer-events: auto !important;
}

body.listing-modal-open #listing-modal .lp-gallery-controls .lp-gallery-counter {
  position: static !important;
  transform: none !important;
  flex: 1 !important;
  text-align: center !important;
}

body.listing-modal-open #listing-modal .gallery-nav,
body.listing-modal-open #listing-modal .lp-gallery-nav {
  width: 44px !important;
  height: 44px !important;
  border: none !important;
  border-radius: 50% !important;
  background: rgba(255, 255, 255, 0.95) !important;
  color: #071526 !important;
  font-size: 1.45rem !important;
  line-height: 1 !important;
  cursor: pointer !important;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.2) !important;
}

body.listing-modal-open #listing-modal .gallery-nav:hover,
body.listing-modal-open #listing-modal .lp-gallery-nav:hover {
  background: #fff !important;
  transform: none !important;
}

/* Mobile header */
@media (max-width: 768px) {
  body.listing-modal-open #listing-modal .listing-detail-mobile-bar {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 10px 12px !important;
    background: #fff !important;
    border-bottom: 1px solid #e8eaed !important;
    flex-shrink: 0 !important;
  }

  body.listing-modal-open #listing-modal .listing-detail-mobile-back {
    border: none !important;
    background: transparent !important;
    font-weight: 600 !important;
    padding: 8px 10px !important;
  }

  body.listing-modal-open #listing-modal .lp-mobile-bar {
    display: flex !important;
  }

  body.listing-modal-open #listing-modal .lp-close,
  body.listing-modal-open #listing-modal .listing-modal-close {
    display: none !important;
  }

  body.listing-modal-open #listing-modal .ld-gallery__main,
  body.listing-modal-open #listing-modal .gallery-main {
    height: min(42vh, 360px) !important;
    border-radius: 0 !important;
  }
}

@media (min-width: 769px) {
  body.listing-modal-open #listing-modal .listing-detail-mobile-bar {
    display: none !important;
  }

  body.listing-modal-open #listing-modal .lp-close,
  body.listing-modal-open #listing-modal .listing-modal-close {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
  }
}
