/* ============================================
   Detail panel — POI/route/area panel, Barcelona card layout, notes
   Loaded via <link> in index.html.
   Depends on tokens.css custom properties.
   ============================================ */

/* ---- POI Detail Panel ---- */
.panel {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  width: var(--panel-width);
  z-index: var(--z-panel);
  background: var(--color-surface);
  border-left: 1px solid var(--color-border);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  opacity: 1;
  transform: translateX(0);
  transition: opacity var(--duration-slow) var(--ease-default), transform var(--duration-slow) var(--ease-out), visibility var(--duration-slow) var(--ease-default);
}

.panel[hidden] {
  display: flex !important;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateX(16px);
}

.panel-header {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  padding: var(--spacing-8) var(--spacing-16);
  position: sticky;
  top: 0;
  background: var(--color-surface);
  z-index: 1;
}

.panel-body {
  flex: 1;
  padding: var(--spacing-20);
}

/* ---- POI Panel Content — Barcelona card layout ---- */
.poi-header-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--spacing-12);
}

.poi-neighborhood {
  font-family: var(--font-geist-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}

.poi-type-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-4);
  font-family: var(--font-geist-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 2px 8px;
  border-radius: 4px;
  border: 1px solid var(--color-border);
  color: var(--color-text-muted);
  white-space: nowrap;
}

.poi-type-badge--area {
  border-color: var(--color-accent);
  color: var(--color-accent);
}

.poi-color-dot {
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
}

.poi-card-name {
  font-size: var(--text-heading);
  font-weight: 700;
  line-height: 1.2;
  color: var(--color-text-heading);
  letter-spacing: var(--tracking-heading);
  margin-bottom: var(--spacing-12);
}

.poi-footer {
  border-top: 1px solid var(--color-border);
  padding-top: var(--spacing-12);
  margin-top: var(--spacing-16);
  margin-bottom: var(--spacing-12);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.poi-maps-link {
  font-family: var(--font-geist-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-accent-light);
  border: 1px solid var(--color-accent-light);
  padding: 3px 10px;
  border-radius: 4px;
  text-decoration: none;
  transition: all var(--duration-base);
}

.poi-maps-link:hover {
  background: var(--color-accent-light);
  color: var(--color-cta-text);
}

.poi-images {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
  gap: var(--spacing-6);
  margin-bottom: var(--spacing-16);
}

.poi-images img {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  border-radius: var(--radius-input);
  cursor: pointer;
  border: 1px solid var(--color-border);
  transition: border-color var(--duration-fast);
}

.poi-images img:hover { border-color: var(--color-border-hover); }

.poi-description {
  font-size: 13px;
  line-height: 1.65;
  color: var(--color-text-secondary);
  margin-bottom: var(--spacing-16);
}

.poi-description h1,
.poi-description h2,
.poi-description h3 {
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--tracking-heading);
  color: var(--color-text-heading);
  margin-top: var(--spacing-12);
  margin-bottom: var(--spacing-6);
}

.poi-description a { color: var(--color-text-primary); text-decoration: underline; }

.poi-description ul,
.poi-description ol { padding-left: var(--spacing-20); }

.poi-description p { margin-bottom: var(--spacing-8); }

/* Personal Notes — accent color with left border (matches Barcelona tip style) */
.poi-personal-notes {
  font-size: 12px;
  line-height: 1.55;
  color: var(--color-accent);
  border-left: 2px solid var(--color-accent);
  padding-left: var(--spacing-10);
  margin-bottom: var(--spacing-16);
}

.poi-personal-notes-label {
  font-family: var(--font-geist-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-accent-light);
  margin-bottom: var(--spacing-4);
  display: block;
}

.poi-video-embed {
  position: relative;
  padding-bottom: 56.25%;
  margin-bottom: var(--spacing-16);
  border-radius: var(--radius-input);
  overflow: hidden;
  border: 1px solid var(--color-border);
}

.poi-video-embed iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.poi-tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-4);
  margin-bottom: var(--spacing-16);
}

.poi-tags .tag {
  font-size: 10px;
  font-family: var(--font-geist-mono);
  padding: 2px 7px;
  background: var(--color-surface-alt);
  border: none;
  border-radius: 3px;
  color: var(--color-text-muted);
  cursor: default;
}

.poi-links {
  list-style: none;
  margin-bottom: var(--spacing-16);
}

.poi-links li { margin-bottom: var(--spacing-4); }

.poi-links a {
  color: var(--color-text-primary);
  font-size: var(--text-body);
  text-decoration: underline;
}

.poi-links a:hover { color: var(--color-text-muted); }

.poi-actions {
  display: flex;
  gap: var(--spacing-8);
  margin-top: var(--spacing-16);
  padding-top: var(--spacing-16);
  border-top: 1px solid var(--color-border);
}

.poi-coords {
  font-family: var(--font-geist-mono);
  font-size: 11px;
  color: var(--color-text-faint);
}

/* ---- Mobile: detail panel becomes a bottom sheet (#52) ----
   These rules must live here (not map.css): panel.css loads after map.css, so
   the same-specificity base `.panel` rule above would otherwise override a
   mobile block placed in map.css — which is exactly what left the panel
   rendering as the desktop side panel on phones (top-anchored, partial width,
   map showing through below). */
@media (max-width: 767px) {
  .panel {
    top: auto;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: auto;
    max-height: 75vh;
    border-left: none;
    border-top: 1px solid var(--color-border);
    border-radius: 16px 16px 0 0;
  }

  /* Slide the sheet down when hidden rather than sideways. */
  .panel[hidden] {
    transform: translateY(16px);
  }

  .panel-header {
    padding: var(--spacing-12) var(--spacing-16);
  }

  .panel-body {
    padding: var(--spacing-16);
  }
}
