/* ==================================
   PLACE MODAL — Venue detail overlay
   ================================== */

/* ── Reset: override the global `button` rule from components.css ── */
.place-trigger,
.place-modal-close,
.place-gallery-btn,
.place-gallery-dot {
  background: none;
  border: none;
  padding: 0;
  color: inherit !important;
  font-weight: inherit !important;
  font-size: inherit;
  transform: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  border-radius: 0;
}

/* Also prevent the global hover scale from firing on these */
.place-trigger:hover,
.place-modal-close:hover,
.place-gallery-btn:hover,
.place-gallery-dot:hover {
  transform: none;
}


/* ── Location trigger ────────────────────────────────────────────── */

.place-trigger {
  font: inherit;
  text-decoration: underline;
  text-decoration-style: dotted;
  text-decoration-color: var(--color-primary);
  text-underline-offset: 3px;
  transition: color 0.15s ease, text-decoration-color 0.15s ease;
  gap: var(--space-xs);
  line-height: inherit;
}

.place-trigger:hover,
.place-trigger:focus-visible {
  color: var(--color-primary) !important;
  text-decoration-style: solid;
}

.place-trigger:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 3px;
  border-radius: var(--border-radius);
}

.place-trigger-icon {
  flex-shrink: 0;
  opacity: 0.55;
  transition: opacity 0.15s ease;
}

.place-trigger:hover .place-trigger-icon,
.place-trigger:focus-visible .place-trigger-icon {
  opacity: 1;
}


/* ── Backdrop ────────────────────────────────────────────────────── */

.place-modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 400;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-xl);
  background: rgba(38, 65, 60, 0.6);
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
  opacity: 0;
  transition: opacity 0.25s ease;
}

.place-modal-backdrop.is-open {
  opacity: 1;
}

@media (max-width: 480px) {
  .place-modal-backdrop {
    padding: 0;
    align-items: flex-end;
  }
}


/* ── Modal dialog ────────────────────────────────────────────────── */

.place-modal {
  position: relative;
  background: var(--color-bg);
  border-radius: 12px;
  box-shadow:
    0 24px 64px rgba(0, 0, 0, 0.22),
    0 4px 16px rgba(0, 0, 0, 0.08);
  max-width: 860px;
  width: 100%;
  max-height: 90dvh;
  max-height: 90vh; /* fallback */
  overflow-y: auto;
  overflow-x: hidden;
  overscroll-behavior: contain;
  transform: translateY(18px) scale(0.985);
  opacity: 0;
  transition:
    transform 0.3s cubic-bezier(0.22, 1, 0.36, 1),
    opacity 0.25s ease;
}

.place-modal-backdrop.is-open .place-modal {
  transform: translateY(0) scale(1);
  opacity: 1;
}

@media (max-width: 480px) {
  .place-modal {
    max-height: 95dvh;
    max-height: 95vh;
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
    transform: translateY(24px);
  }
  .place-modal-backdrop.is-open .place-modal {
    transform: translateY(0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .place-modal-backdrop,
  .place-modal {
    transition: opacity 0.15s ease;
  }
  .place-modal {
    transform: none;
  }
  .place-modal-backdrop.is-open .place-modal {
    transform: none;
  }
}


/* ── Close button ────────────────────────────────────────────────── */

.place-modal-close {
  position: absolute;
  top: var(--space-m);
  right: var(--space-m);
  z-index: 10;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.88) !important;
  border: var(--border-grey) !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  color: var(--color-text) !important;
  transition: background 0.15s ease, box-shadow 0.15s ease;
  flex-shrink: 0;
}

.place-modal-close:hover {
  background: var(--color-bg) !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.14);
}

.place-modal-close:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

.place-modal-close-icon {
  width: 16px;
  height: 16px;
  pointer-events: none;
}


/* ── Gallery ─────────────────────────────────────────────────────── */

.place-gallery {
  position: relative;
  overflow: hidden;
  aspect-ratio: 16 / 7;
  background: var(--color-text);
  flex-shrink: 0;
}

.place-gallery-track {
  display: flex;
  height: 100%;
  transition: transform 0.38s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  will-change: transform;
}

@media (prefers-reduced-motion: reduce) {
  .place-gallery-track {
    transition: none;
  }
}

.place-gallery-slide {
  min-width: 100%;
  height: 100%;
  flex-shrink: 0;
  position: relative;
  overflow: hidden;
}

/* Gradient placeholders — shown when image fails or hasn't loaded yet */
.place-gallery-slide:nth-child(1) {
  background: linear-gradient(135deg, #26413C 0%, #3B9A8D 100%);
}
.place-gallery-slide:nth-child(2) {
  background: linear-gradient(150deg, #3B9A8D 0%, #26413C 65%, #cee3e0 100%);
}
.place-gallery-slide:nth-child(3) {
  background: linear-gradient(135deg, #26413C 0%, #3B9A8D 50%, #D9E76C 100%);
}
.place-gallery-slide:nth-child(4) {
  background: linear-gradient(160deg, #cee3e0 0%, #3B9A8D 55%, #26413C 100%);
}

.place-gallery-slide img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Navigation buttons */
.place-gallery-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 5;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.82) !important;
  border: none !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.18);
  color: var(--color-text) !important;
  transition: background 0.15s ease, transform 0.15s ease, box-shadow 0.15s ease;
  flex-shrink: 0;
}

.place-gallery-btn:hover {
  background: rgba(255, 255, 255, 0.97) !important;
  transform: translateY(-50%) scale(1.07) !important;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.22);
}

.place-gallery-btn:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

.place-gallery-btn-prev { left: var(--space-m); }
.place-gallery-btn-next { right: var(--space-m); }

.place-gallery-btn svg {
  /* Don't inherit the box-container svg rule */
  background: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
  width: 16px;
  height: 16px;
  pointer-events: none;
}

/* Dot indicators */
.place-gallery-dots {
  position: absolute;
  bottom: var(--space-m);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: var(--space-xs);
  z-index: 5;
}

.place-gallery-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.45);
  border: 1.5px solid rgba(255, 255, 255, 0.7) !important;
  transition: background 0.2s ease, transform 0.2s ease;
}

.place-gallery-dot.is-active {
  background: white;
  transform: scale(1.2);
}

.place-gallery-dot:focus-visible {
  outline: 2px solid white;
  outline-offset: 2px;
}

/* Slide counter badge */
.place-gallery-counter {
  position: absolute;
  top: var(--space-m);
  left: var(--space-m);
  background: rgba(38, 65, 60, 0.55);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  color: white;
  font-size: var(--fs-xs);
  font-weight: var(--fw-medium);
  padding: 3px var(--space-xs);
  border-radius: 20px;
  letter-spacing: 0.04em;
  pointer-events: none;
}

@media (max-width: 640px) {
  .place-gallery {
    aspect-ratio: 4 / 3;
  }
}


/* ── Modal content area ──────────────────────────────────────────── */

.place-modal-content {
  padding: var(--space-xxl);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-xxl);
  align-items: start;
}

@media (max-width: 640px) {
  .place-modal-content {
    grid-template-columns: 1fr;
    padding: var(--space-xl);
    gap: var(--space-xl);
  }
}


/* ── Left column: name, description, highlights ──────────────────── */

.place-modal-left {
  display: flex;
  flex-direction: column;
  gap: var(--space-m);
}

.place-modal-name {
  font-size: var(--fs-h3);
  font-weight: var(--fw-bold);
  color: var(--color-text);
  line-height: var(--lh-heading);
  margin: 0;
}

.place-modal-desc {
  font-size: var(--fs-small);
  color: var(--color-text-muted);
  line-height: var(--lh-body);
  margin: 0;
}

/* Rating */
.place-rating {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  flex-wrap: wrap;
}

.place-rating-value {
  font-size: var(--fs-body);
  font-weight: var(--fw-semibold);
  color: var(--color-text);
}

.place-rating-stars {
  display: flex;
  align-items: center;
  gap: 2px;
}

.place-rating-stars svg {
  /* Override box-container svg rule */
  background: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
  display: block;
}

.place-rating-count {
  font-size: var(--fs-small);
  color: var(--color-text-muted);
}

/* Highlights chips */
.place-highlights {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-xs);
  margin-top: var(--space-xxs);
}

.place-highlight-chip {
  display: inline-block;
  font-size: var(--fs-xs);
  font-weight: var(--fw-medium);
  color: var(--color-primary);
  background: var(--color-primary-bg-20);
  border-radius: 20px;
  padding: 3px var(--space-s);
  letter-spacing: 0.01em;
}


/* ── Right column: address, map CTA ─────────────────────────────── */

.place-modal-right {
  display: flex;
  flex-direction: column;
  gap: var(--space-l);
}

.place-modal-divider {
  border: none;
  border-top: var(--border-primary);
  margin: 0;
}

.place-address {
  display: flex;
  gap: var(--space-s);
  align-items: flex-start;
}

.place-address-icon {
  flex-shrink: 0;
  margin-top: 2px;
}

.place-address-icon svg {
  /* Override box-container svg rule */
  background: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
}

.place-address-text {
  font-size: var(--fs-small);
  color: var(--color-text-muted);
  line-height: 1.7;
  white-space: pre-line; /* Render \n line breaks from JSON */
  margin: 0;
}

/* Maps CTA */
.place-maps-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  font-size: var(--fs-small);
  font-weight: var(--fw-semibold);
  color: var(--color-primary);
  background: var(--color-bg);
  border: 1px solid var(--color-primary);
  border-radius: var(--border-radius);
  padding: var(--space-xs) var(--space-l);
  text-decoration: none;
  cursor: pointer;
  transition: background 0.15s ease, color 0.15s ease;
  align-self: flex-start;
}

.place-maps-btn:hover {
  background: var(--color-primary);
  color: var(--color-bg) !important;
}

.place-maps-btn:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

.place-maps-btn svg {
  background: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
  flex-shrink: 0;
}

/* Google source note */
.place-source-note {
  font-size: var(--fs-xs);
  color: var(--color-text-muted);
  opacity: 0.7;
  margin: 0;
}
