.tp-travel-google-map-block {
  width: 100%;
}

.tp-travel-google-map-canvas {
  width: 100%;
  border: 1px solid #eee;
}

/* Mobile: cap map height even if block sets e.g. 900px */
@media (max-width: 768px) {
  .tp-travel-google-map-canvas {
    max-height: 60vh;
  }
}

/* Tooltip content inside Google InfoWindow */
.tp-gmap-tooltip {
  --tp-hover-image-size: 180px;
  display: flex;
  flex-direction: column;
  gap: 0px;
  color: inherit;
  width: var(--tp-hover-image-size);
  max-width: min(calc(100vw - 32px), var(--tp-hover-image-size));
}

.tp-gmap-tooltip.is-portrait {
  width: fit-content;
  max-width: calc(100vw - 32px);
}

.tp-gmap-thumb,
.tp-preview-thumb {
  width: 100%;
  overflow: hidden;
  border-radius: 2px;
}

.tp-gmap-tooltip.is-portrait .tp-gmap-thumb,
.tp-gmap-tooltip.is-portrait .tp-preview-thumb {
  width: fit-content;
  max-width: calc(100vw - 32px);
}

.tp-gmap-date,
.tp-gmap-tooltip .tp-preview-date {
  font-size: 12px;
  white-space: nowrap;
  line-height: 1.2;
  margin-top: 0;
  padding-top: 0;
  margin-bottom: 6px;
}

.tp-gmap-thumb img,
.tp-preview-thumb img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 180 / 85;
  object-fit: cover;
  border: 0;
}

.tp-gmap-thumb.is-portrait img,
.tp-preview-thumb.is-portrait img {
  width: auto;
  max-width: calc(100vw - 32px);
  height: var(--tp-hover-image-size);
  max-height: calc(100vh - 140px);
  aspect-ratio: auto;
  object-fit: contain;
}

.tp-gmap-note,
.tp-gmap-tooltip .tp-preview-note {
  font-size: 12px;
  line-height: 1.25;
  max-width: 100%;
  word-break: break-word;
  margin-top: 6px;
}

.tp-gmap-hover-overlay {
  position: absolute;
  left: 0;
  top: 0;
  z-index: 2147483646;
  pointer-events: auto;
  transform: translateY(-50%);
}

.tp-gmap-hover-overlay.is-hidden {
  display: none;
}

/* Reduce default Google InfoWindow chrome within our block */
.tp-travel-google-map-block .gm-style .gm-style-iw-c {
  padding: 0 !important;
  border-radius: 2px !important;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.15) !important;
  z-index: 2147483646 !important;
}

.tp-travel-google-map-block .gm-style .gm-style-iw-d {
  overflow: hidden !important;
}

/* Remove the InfoWindow “pointer/tail” so it looks like a plain rectangle */
.tp-travel-google-map-block .gm-style .gm-style-iw-tc {
  display: none !important;
}

.tp-travel-google-map-block .gm-ui-hover-effect {
  display: none !important;
}

.tp-travel-google-map-note {
  padding: 10px;
  border: 1px solid #eee;
}

.tp-travel-google-map-fallback-note {
  margin-bottom: 12px;
}

.tp-travel-google-map-fallback-host[hidden] {
  display: none !important;
}

.tp-pic-preview {
  pointer-events: none;
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  transition: opacity 220ms ease, transform 220ms ease, visibility 220ms ease;
  will-change: opacity, transform;
}

.tp-pic-preview--fixed {
  position: fixed;
  right: 18px;
  bottom: 18px;
  width: 30vw;
  max-width: 520px;
  min-width: 300px;
  z-index: 2147483647;
}

.tp-pic-preview--below {
  position: relative;
  width: 100%;
  margin-top: 14px;
}

.tp-pic-preview.is-portrait {
  width: fit-content;
}

.tp-pic-preview--fixed.is-hidden {
  opacity: 0;
  visibility: hidden;
  transform: translateY(12px);
}

.tp-pic-preview--below.is-hidden {
  display: none;
}

.tp-pic-preview-inner {
  border-radius: 6px;
  overflow: hidden;
  box-shadow: 0 22px 70px rgba(0, 0, 0, 0.78);
}

.tp-pic-preview.is-portrait .tp-pic-preview-inner,
.tp-pic-preview.is-portrait .tp-pic-preview-thumb,
.tp-pic-preview.is-portrait .tp-preview-thumb {
  width: fit-content;
  max-width: 100%;
}

.tp-pic-preview-date {
  padding: 10px 12px 0;
  font-size: 13px;
  font-weight: 600;
}

.tp-pic-preview-thumb img,
.tp-preview-thumb img {
  display: block;
  width: 100%;
  height: auto;
  max-height: 50vh;
  object-fit: cover;
}

.tp-pic-preview-thumb.is-portrait img,
.tp-preview-thumb.is-portrait img {
  width: auto;
  max-width: calc(100vw - 36px);
  height: var(--tp-pic-preview-image-height, 50vh);
  max-height: calc(100vh - 120px);
  object-fit: contain;
}

.tp-pic-preview-note {
  padding: 10px 12px 12px;
  font-size: 13px;
  line-height: 1.3;
  word-break: break-word;
}

@media (max-width: 899px), (pointer: coarse) {
  .tp-pic-preview { display: none !important; }
}
