/* ═══════════════════════════════════════════
   POI-Styles (extrahiert aus trips.css)
   Enthält: POI-Verwaltung, Import, Karten-Marker,
   Kategorie-Editor, Duplikat-Finder, Sidebar, InfoWindows
   ═══════════════════════════════════════════ */

/* ═══════════════════════════════════════════
   POI-Verwaltung
   ═══════════════════════════════════════════ */

/* ── Page ── */
.poi-page {
  padding: 1.5rem 2rem;
  display: flex;
  flex-direction: column;
  height: 100%;
}

/* ── Header (2-Zeilen, konsistent mit Trip-Detail) ── */
.poi-header {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 12px;
}

/* Zeile 1: Zurück + Titel + Count + Aktionen */
.poi-hd-row1 {
  display: flex;
  align-items: center;
  gap: 8px;
}
.poi-hd-back {
  border: none;
  background: none;
  cursor: pointer;
  color: var(--text-muted);
  padding: 4px;
  border-radius: var(--radius);
  display: flex;
  transition: color 120ms, background 120ms;
  flex-shrink: 0;
}
.poi-hd-back:hover { color: var(--text-primary); background: rgba(60,66,80,0.05); }
.poi-hd-back svg { width: 16px; height: 16px; }
.poi-hd-title {
  font-size: 17px;
  font-weight: 700;
  color: var(--text-primary);
  letter-spacing: -0.02em;
}
.poi-hd-count {
  font-size: 11px;
  color: var(--text-muted);
  margin-right: auto;
}
.poi-hd-filtered { color: var(--accent); }

/* Aktions-Buttons — einheitliche Icon-Buttons (wie Trip-Header) */
.poi-hd-actions {
  display: flex;
  align-items: center;
  gap: 2px;
  flex-shrink: 0;
}
.poi-hd-action {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border: none;
  border-radius: var(--radius);
  background: none;
  color: var(--text-muted);
  cursor: pointer;
  transition: color 120ms, background 120ms;
}
.poi-hd-action svg { width: 15px; height: 15px; }
.poi-hd-action:hover {
  color: var(--text-primary);
  background: rgba(60,66,80,0.06);
}
.poi-hd-action--primary {
  color: var(--accent);
}
.poi-hd-action--primary:hover {
  background: rgba(13,148,136,0.08);
}

/* Zeile 2: Suche + Kategorie-Pills + View-Toggle */
.poi-hd-row2 {
  display: flex;
  align-items: center;
  gap: 8px;
}

/* ── View-Toggle ── */
.poi-view-toggle {
  display: flex;
  border: 1px solid rgba(60,66,80,0.10);
  border-radius: var(--radius);
  overflow: hidden;
  flex-shrink: 0;
}
.poi-view-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 28px;
  border: none;
  background: none;
  color: var(--text-muted);
  cursor: pointer;
  transition: background 120ms, color 120ms;
}
.poi-view-btn + .poi-view-btn { border-left: 1px solid rgba(60,66,80,0.10); }
.poi-view-btn:hover { background: rgba(60,66,80,0.04); color: var(--text-primary); }
.poi-view-btn--active {
  background: rgba(13,148,136,0.10);
  color: var(--accent);
}
.poi-view-btn svg { width: 14px; height: 14px; }

/* ── POI-Karte ── */
.poi-map-container {
  flex: 1;
  min-height: 300px;
  border-radius: 8px;
  overflow: hidden;
  border: 1px solid rgba(60,66,80,0.08);
}
.poi-map-iw {
  display: flex;
  flex-direction: column;
  gap: 3px;
  padding: 2px 0;
  max-width: 220px;
}
.poi-map-iw strong { font-size: 13px; }
.poi-map-iw-cat { font-size: 10px; font-weight: 600; }
.poi-map-iw-addr { font-size: 11px; color: #666; }
.poi-map-iw-notes { font-size: 11px; color: #888; }
.poi-map-iw-edit {
  margin-top: 4px;
  background: none;
  border: 1px solid rgba(13,148,136,0.25);
  border-radius: var(--radius);
  color: var(--accent);
  font-size: 11px;
  font-weight: 500;
  padding: 3px 10px;
  cursor: pointer;
  align-self: flex-start;
  transition: background 120ms;
}
.poi-map-iw-edit:hover { background: rgba(13,148,136,0.08); }

.poi-search-wrap {
  position: relative;
  width: 180px;
  flex-shrink: 0;
}
.poi-search-icon {
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-very-muted);
  pointer-events: none;
}
.poi-search {
  width: 100%;
  padding: 7px 10px 7px 32px;
  border-radius: 20px;
  border: 1px solid rgba(60,66,80,0.10);
  background: var(--card-bg);
  color: var(--text-primary);
  font-size: 12px;
  outline: none;
  transition: border-color 120ms, box-shadow 120ms;
}
.poi-search:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(13,148,136,0.08);
}
.poi-search::placeholder { color: var(--text-very-muted); }

/* ── Kategorie-Bar ── */
.poi-cat-bar {
  display: flex;
  gap: 4px;
  flex: 1;
  min-width: 0;
  overflow-x: auto;
  scrollbar-width: none;
}
.poi-cat-bar::-webkit-scrollbar { display: none; }
.poi-pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 11px;
  border-radius: 14px;
  border: 1px solid rgba(60,66,80,0.07);
  background: var(--card-bg);
  color: var(--text-secondary);
  font-size: 11px;
  font-weight: 500;
  cursor: pointer;
  transition: all 150ms ease;
  user-select: none;
}
.poi-pill:hover {
  border-color: rgba(60,66,80,0.14);
  background: rgba(60,66,80,0.02);
}
.poi-pill.active {
  background: color-mix(in srgb, var(--pc) 10%, var(--card-bg));
  color: var(--pc);
  border-color: color-mix(in srgb, var(--pc) 22%, transparent);
}
.poi-pill-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--pc);
  flex-shrink: 0;
  transition: transform 150ms;
}
.poi-pill.active .poi-pill-dot { transform: scale(1.3); }
.poi-pill-num {
  font-size: 10px;
  font-weight: 400;
  color: var(--text-very-muted);
  min-width: 12px;
  text-align: center;
}
.poi-pill.active .poi-pill-num { color: var(--pc); opacity: 0.6; }

/* ── Bulk-Bar ── */
.poi-bulk-bar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 7px 14px;
  background: rgba(229,83,75,0.04);
  border: 1px solid rgba(229,83,75,0.12);
  border-radius: 5px;
  margin-bottom: 10px;
  font-size: 12px;
}
.poi-bulk-count { color: var(--text-secondary); font-weight: 500; }

/* ── Card Grid ── */
.poi-grid {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

/* ── POI Card ── */
.poi-card {
  display: flex;
  border-radius: 5px;
  border: 1px solid rgba(60,66,80,0.06);
  background: var(--card-bg);
  overflow: hidden;
  transition: border-color 150ms, box-shadow 150ms;
}
.poi-card:hover {
  border-color: rgba(60,66,80,0.12);
  box-shadow: 0 1px 4px rgba(0,0,0,0.03);
}

/* Farbstreifen links — 4px Kategorie-Indikator */
.poi-card-stripe {
  width: 4px;
  flex-shrink: 0;
  background: var(--pc, #8E939E);
}

.poi-card-body {
  flex: 1;
  padding: 8px 12px;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 3px;
}

/* Top: Checkbox + Name + Delete */
.poi-card-top {
  display: flex;
  align-items: center;
  gap: 8px;
}
.poi-check { flex-shrink: 0; accent-color: var(--accent); }
.poi-card-name {
  flex: 1;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  padding: 1px 4px;
  margin: -1px -4px;
  border-radius: var(--radius);
  cursor: pointer;
  transition: color 120ms;
  letter-spacing: -0.01em;
}
.poi-card-name:hover { color: var(--accent); }
.poi-card-del {
  display: flex;
  align-items: center;
  background: none;
  border: none;
  padding: 3px;
  border-radius: var(--radius);
  cursor: pointer;
  color: var(--text-very-muted);
  opacity: 0;
  transition: opacity 120ms, color 120ms;
  flex-shrink: 0;
}
.poi-card:hover .poi-card-del { opacity: 1; }
.poi-card-del:hover { color: var(--danger); }

/* Info: Adresse + Koordinaten */
.poi-card-info {
  display: flex;
  align-items: center;
  gap: 10px;
  padding-left: 26px; /* align mit Name (checkbox 18px + gap 8px) */
  min-height: 16px;
}
.poi-card-addr {
  display: flex;
  align-items: center;
  gap: 3px;
  font-size: 11px;
  color: var(--text-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 300px;
}
.poi-card-coord {
  font-size: 10px;
  color: var(--text-very-muted);
  font-family: 'JetBrains Mono', monospace;
  letter-spacing: -0.02em;
  white-space: nowrap;
}
.poi-card-link {
  display: inline-flex;
  align-items: center;
  color: var(--accent);
  opacity: 0.6;
  transition: opacity 120ms;
}
.poi-card-link:hover { opacity: 1; }
.poi-card-edit {
  display: flex;
  align-items: center;
  background: none;
  border: none;
  padding: 3px;
  border-radius: var(--radius);
  cursor: pointer;
  color: var(--text-very-muted);
  opacity: 0;
  transition: opacity 120ms, color 120ms;
  flex-shrink: 0;
}
.poi-card:hover .poi-card-edit { opacity: 1; }
.poi-card-edit:hover { color: var(--accent); }

.poi-card-desc {
  font-size: 10.5px;
  color: var(--text-muted);
  line-height: 1.4;
  padding-left: 26px;
  max-height: 32px;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ── Pagination ── */
.poi-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 12px 0 4px;
}
.poi-page-info {
  font-size: 12px;
  color: var(--text-secondary);
  font-weight: 500;
}
.poi-page-total {
  color: var(--text-muted);
  font-weight: 400;
}
.poi-page-btn:disabled {
  opacity: 0.3;
  cursor: default;
}

/* ── Edit-Modal ── */
.poi-edit-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.3);
  z-index: 1100;
  display: flex;
  align-items: center;
  justify-content: center;
}
/* Google Places Autocomplete-Dropdown über dem Modal anzeigen */
.pac-container { z-index: 1200 !important; }
.poi-edit-modal {
  background: var(--card-bg);
  border: 1px solid rgba(60,66,80,0.12);
  border-radius: 8px;
  box-shadow: 0 16px 48px rgba(0,0,0,0.12);
  width: 90%;
  max-width: 480px;
  max-height: 85vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.poi-edit-modal--wide {
  max-width: 760px;
}
.poi-edit-content {
  display: flex;
  flex: 1;
  overflow: hidden;
}
.poi-edit-form {
  flex: 1;
  padding: 16px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.poi-edit-map {
  width: 280px;
  flex-shrink: 0;
  border-left: 1px solid rgba(60,66,80,0.08);
  min-height: 300px;
}
.poi-edit-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  border-bottom: 1px solid rgba(60,66,80,0.08);
}
.poi-edit-header h3 {
  font-size: 15px;
  font-weight: 600;
  color: var(--text-primary);
}
@media (max-width: 640px) {
  .poi-edit-modal--wide { max-width: 95%; }
  .poi-edit-content { flex-direction: column; }
  .poi-edit-map {
    width: 100%;
    min-height: 180px;
    border-left: none;
    border-top: 1px solid rgba(60,66,80,0.08);
  }
}
.poi-edit-label {
  font-size: 10px;
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-top: 8px;
}
.poi-edit-label:first-child { margin-top: 0; }
.poi-edit-input,
.poi-edit-select,
.poi-edit-textarea {
  width: 100%;
  padding: 7px 10px;
  border-radius: var(--radius);
  border: 1px solid rgba(60,66,80,0.12);
  background: rgba(60,66,80,0.03);
  color: var(--text-primary);
  font-size: 13px;
  font-family: inherit;
  outline: none;
  transition: border-color 120ms;
}
.poi-edit-input:focus,
.poi-edit-select:focus,
.poi-edit-textarea:focus {
  border-color: var(--accent);
}
.poi-edit-textarea {
  resize: vertical;
  min-height: 60px;
}
.poi-edit-coords {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.poi-edit-footer {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  padding: 12px 16px;
  border-top: 1px solid rgba(60,66,80,0.08);
}

.poi-card-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 10px;
  font-weight: 600;
  color: var(--pc);
  letter-spacing: 0.02em;
}
.poi-card-badge-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--pc);
}
.poi-card-cat {
  padding: 1px 6px;
  border-radius: var(--radius);
  border: 1px solid rgba(60,66,80,0.07);
  background: transparent;
  font-size: 10px;
  color: var(--text-muted);
  cursor: pointer;
  opacity: 0;
  transition: opacity 120ms;
}
.poi-card:hover .poi-card-cat { opacity: 1; }

/* ── Empty State ── */
.poi-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 240px;
  text-align: center;
  padding: 32px 20px;
}
.poi-empty-icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: rgba(60,66,80,0.04);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px;
  color: var(--text-very-muted);
}
.poi-empty-icon svg { width: 24px; height: 24px; }
.poi-empty-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 4px;
}
.poi-empty-sub {
  font-size: 12px;
  color: var(--text-muted);
  max-width: 320px;
  line-height: 1.5;
}
.poi-empty-actions {
  display: flex;
  gap: 8px;
  margin-top: 16px;
}

/* ═══════════════════════════════════════════
   POI Import-Panel
   ═══════════════════════════════════════════ */

.poi-import-panel {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 90%;
  max-width: 640px;
  max-height: 80vh;
  background: var(--card-bg);
  border: 1px solid rgba(60,66,80,0.12);
  border-radius: 8px;
  box-shadow: 0 16px 48px rgba(0,0,0,0.12), 0 4px 16px rgba(0,0,0,0.06);
  z-index: 1000;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.poi-import-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  border-bottom: 1px solid rgba(60,66,80,0.08);
}
.poi-import-header h3 {
  font-size: 15px;
  font-weight: 600;
  color: var(--text-primary);
}
.poi-import-stats {
  font-size: 11px;
  color: var(--text-muted);
  margin-left: auto;
}
.poi-import-header .btn { margin-left: auto; }

/* ── Drop-Zone ── */
.poi-import-drop {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 40px 20px;
  margin: 16px;
  border: 2px dashed rgba(60,66,80,0.15);
  border-radius: 8px;
  cursor: pointer;
  transition: border-color 120ms, background 120ms;
  color: var(--text-muted);
  text-align: center;
}
.poi-import-drop:hover,
.poi-import-drop--active {
  border-color: var(--accent);
  background: rgba(13,148,136,0.03);
}
.poi-import-hint { font-size: 11px; color: var(--text-very-muted); margin-top: 4px; }
.poi-import-formats { padding: 0 16px 12px; font-size: 11px; color: var(--text-very-muted); }

/* ── Vorschau ── */
.poi-import-toolbar {
  display: flex;
  gap: 6px;
  padding: 8px 16px;
  border-bottom: 1px solid rgba(60,66,80,0.08);
}
.poi-import-preview {
  flex: 1;
  overflow-y: auto;
  padding: 8px 16px;
  max-height: 45vh;
}
.poi-import-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 4px 0;
  font-size: 12px;
  border-bottom: 1px solid rgba(60,66,80,0.04);
}
.poi-import-row--dupe {
  background: rgba(217,119,6,0.04);
  border-left: 3px solid var(--warning);
  padding-left: 6px;
}
.poi-import-name {
  flex: 1;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
}
.poi-import-coords {
  font-size: 10px;
  color: var(--text-very-muted);
  font-family: 'JetBrains Mono', monospace;
  white-space: nowrap;
}
.poi-import-cat {
  padding: 2px 6px;
  border-radius: var(--radius);
  border: 1px solid rgba(60,66,80,0.10);
  font-size: 10px;
}
.poi-import-dupe-badge {
  font-size: 9px;
  font-weight: 700;
  color: var(--warning);
  background: rgba(217,119,6,0.10);
  padding: 1px 6px;
  border-radius: 3px;
  white-space: nowrap;
}

/* ── Footer ── */
.poi-import-footer {
  display: flex;
  justify-content: space-between;
  padding: 12px 16px;
  border-top: 1px solid rgba(60,66,80,0.08);
}

/* ── POI Map-Marker (Custom Icons) ── */
.poi-map-marker {
  display: flex;
  flex-direction: column;
  align-items: center;
  cursor: pointer;
  transition: transform 120ms ease;
}
.poi-map-marker:hover,
.poi-map-marker:active {
  transform: scale(1.15);
}
.poi-map-marker--highlight {
  transform: scale(1.3);
  filter: drop-shadow(0 0 6px rgba(13,148,136,0.6));
  z-index: 10;
}
.poi-map-marker-icon {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 6px rgba(0,0,0,0.25);
  border: 2px solid #fff;
}
.poi-map-marker-icon svg {
  width: 14px;
  height: 14px;
  stroke: #fff;
  fill: none;
}
.poi-map-marker-arrow {
  width: 0;
  height: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 6px solid;
  margin-top: -1px;
}

/* ── POI Kategorie-Filter ── */
.trip-poi-category-select {
  font-size: 11px;
  padding: 4px 8px;
  border: 1px solid rgba(60,66,80,0.12);
  border-radius: 6px;
  background: var(--card-bg);
  color: var(--text-primary);
  cursor: pointer;
  max-width: 150px;
}
.trip-poi-category-select:focus {
  border-color: rgba(13,148,136,0.4);
  outline: none;
}
@media (max-width: 768px) {
  .trip-poi-category-select { max-width: 120px; font-size: 10px; }
}

/* ── POI Pill-Zähler ── */
.trip-dc-pill-pois {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  color: var(--accent);
  font-weight: 600;
  font-size: 10px;
  cursor: pointer;
  padding: 0 4px;
  border-radius: 3px;
  transition: background 120ms;
}
.trip-dc-pill-pois:hover {
  background: rgba(13,148,136,0.1);
}
.trip-dc-pill-pois svg {
  flex-shrink: 0;
}

/* ── POI-Sidebar Panel ── */
.poi-sidebar {
  display: flex;
  flex-direction: column;
  height: 100%;
  min-height: 400px;
  background: rgba(13,148,136,0.02);
  border: 1px solid rgba(13,148,136,0.12);
  border-radius: 5px;
}
.poi-sidebar-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px;
  border-bottom: 1px solid rgba(60,66,80,0.08);
}
.poi-sidebar-header-left { display: flex; align-items: center; gap: 8px; }
.poi-sidebar-title { font-size: 13px; font-weight: 600; }
.poi-sidebar-body { flex: 1; overflow-y: auto; padding: 8px; }

.poi-sidebar-group { margin-bottom: 4px; border: 1px solid rgba(60,66,80,0.06); border-radius: 6px; overflow: hidden; }
.poi-sidebar-group-header {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 12px; background: rgba(60,66,80,0.03);
  font-size: 12px; font-weight: 600; cursor: pointer;
  user-select: none;
}
.poi-sidebar-group-header:hover { background: rgba(60,66,80,0.06); }
.poi-sidebar-chevron { flex-shrink: 0; transition: transform 150ms; }
.poi-sidebar-group--collapsed .poi-sidebar-chevron { transform: rotate(-90deg); }
.poi-sidebar-group-title { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.poi-sidebar-group-count {
  font-size: 10px; color: var(--text-muted);
  background: rgba(60,66,80,0.06); padding: 1px 6px; border-radius: 10px;
}
.poi-sidebar-group-body { padding: 0; }

.poi-sidebar-row {
  display: grid;
  grid-template-columns: 10px 1fr auto auto;
  gap: 8px;
  padding: 6px 12px;
  align-items: center;
  font-size: 12px;
  cursor: pointer;
  transition: background 120ms;
}
.poi-sidebar-row:hover { background: rgba(60,66,80,0.04); }
.poi-sidebar-row + .poi-sidebar-row { border-top: 1px solid rgba(60,66,80,0.04); }

.poi-sidebar-dot { width: 8px; height: 8px; border-radius: 50%; }
.poi-sidebar-name { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-weight: 500; }
.poi-sidebar-dist { font-size: 10px; color: var(--text-muted); white-space: nowrap; }
.poi-sidebar-add { padding: 2px; }
.poi-sidebar-add[disabled] { opacity: 0.4; cursor: default; }

.poi-sidebar-empty, .poi-sidebar-empty-group {
  padding: 16px; text-align: center; color: var(--text-muted); font-size: 12px;
}
.poi-sidebar-empty-group { padding: 8px 12px; text-align: left; font-style: italic; }

.poi-sidebar-group--flash { animation: poi-sidebar-flash 1.5s ease; }
@keyframes poi-sidebar-flash {
  0%, 100% { background: transparent; }
  20% { background: rgba(13,148,136,0.08); }
}

/* ── POI InfoWindow ── */
.poi-iw {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  color: #1a1a1a;
  font-size: 12px;
  width: 300px;
  line-height: 1.45;
}
.poi-iw-header {
  display: flex;
  align-items: baseline;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 6px;
}
.poi-iw-name {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: #111;
}
.poi-iw-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 10px;
  font-weight: 600;
  white-space: nowrap;
  letter-spacing: 0.01em;
}
.poi-iw-addr {
  font-size: 11px;
  color: #777;
  margin-bottom: 3px;
}
.poi-iw-note {
  font-size: 11px;
  color: #555;
  margin: 4px 0;
  line-height: 1.45;
  max-height: 44px;
  overflow: hidden;
}
.poi-iw-wiki-img {
  max-width: 100%;
  max-height: 120px;
  border-radius: 4px;
  object-fit: cover;
  margin: 6px 0 4px;
}
.poi-iw-wiki-desc {
  font-size: 11px;
  color: #555;
  line-height: 1.45;
  margin: 4px 0;
}
.poi-iw-wiki-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 3px;
  margin: 4px 0;
}
.poi-iw-links {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 6px 0 2px;
}
.poi-iw-link {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: 11px;
  color: #0D9488;
  text-decoration: none;
  margin: 3px 0;
}
.poi-iw-link:hover { text-decoration: underline; }

/* Actions-Block: vertikal gestapelt für genug Platz */
.poi-iw-actions {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px solid rgba(0,0,0,0.06);
}
.poi-iw-btn {
  padding: 6px 14px;
  border: none;
  border-radius: 5px;
  background: #0D9488;
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition: background 120ms, transform 80ms;
  text-align: center;
}
.poi-iw-btn:hover { background: #0B7D72; }
.poi-iw-btn:active { transform: scale(0.97); }
.poi-iw-btn:disabled { opacity: 0.5; cursor: default; }
.poi-iw-hint {
  font-size: 10px;
  color: #999;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* ── Etappen-Auswahl (InfoWindow) ── */
.poi-iw-day-select {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 0;
}
.poi-iw-day-label { font-size: 10px; color: #888; white-space: nowrap; font-weight: 500; }
.poi-iw-day-dropdown {
  font-size: 11px;
  padding: 4px 8px;
  border: 1px solid rgba(0,0,0,0.12);
  border-radius: 5px;
  background: #fafafa;
  flex: 1;
  min-width: 0;
  color: #333;
}
.poi-iw-day-dropdown:focus { border-color: #0D9488; outline: none; }

/* ── Route-Preview (InfoWindow) ── */
.poi-iw-preview {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 0;
}
.poi-iw-preview-delta {
  font-size: 12px;
  font-weight: 700;
  color: #0D9488;
  white-space: nowrap;
  flex: 1;
  letter-spacing: -0.01em;
}
.poi-iw-preview-confirm {
  font-size: 11px;
  padding: 5px 12px;
}
.poi-iw-preview-cancel {
  font-size: 11px;
  padding: 5px 10px;
  background: transparent;
  border: 1px solid rgba(0,0,0,0.12);
  border-radius: 5px;
  color: #888;
  cursor: pointer;
  transition: background 120ms;
}
.poi-iw-preview-cancel:hover { background: rgba(0,0,0,0.04); color: #555; }

/* ── Route-Preview (Sidebar) ── */
.poi-sidebar-preview {
  grid-column: 2 / -1;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 4px 0 2px;
}
.poi-sidebar-preview-delta {
  font-size: 10px;
  font-weight: 600;
  color: var(--accent);
  white-space: nowrap;
  flex: 1;
}

/* ═══════════════════════════════════════════
   POI Kategorie-Editor Modal
   ═══════════════════════════════════════════ */

.poi-cat-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.3);
  z-index: 1100;
  display: flex;
  align-items: center;
  justify-content: center;
}
.poi-cat-modal {
  background: var(--card-bg);
  border: 1px solid rgba(60,66,80,0.12);
  border-radius: 8px;
  box-shadow: 0 16px 48px rgba(0,0,0,0.12);
  width: 90%;
  max-width: 560px;
  max-height: 80vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.poi-cat-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  border-bottom: 1px solid rgba(60,66,80,0.08);
}
.poi-cat-modal-header h3 {
  font-size: 15px;
  font-weight: 600;
  color: var(--text-primary);
}
.poi-cat-modal-body {
  flex: 1;
  overflow-y: auto;
  padding: 12px 16px;
}
.poi-cat-modal-footer {
  display: flex;
  justify-content: flex-end;
  padding: 10px 16px;
  border-top: 1px solid rgba(60,66,80,0.08);
}

/* ── Editor-Zeilen ── */
.poi-cat-editor-list {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: 12px;
}
.poi-cat-editor-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 4px 0;
}
.poi-cat-editor-color {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  flex-shrink: 0;
}
.poi-cat-editor-label {
  flex: 1;
  padding: 3px 8px;
  border-radius: var(--radius);
  border: 1px solid rgba(60,66,80,0.10);
  background: transparent;
  font-size: 12px;
  color: var(--text-primary);
  outline: none;
}
.poi-cat-editor-label:focus { border-color: var(--accent); }
.poi-cat-editor-picker {
  width: 28px;
  height: 24px;
  border: 1px solid rgba(60,66,80,0.10);
  border-radius: var(--radius);
  padding: 0;
  cursor: pointer;
  background: none;
}
.poi-cat-editor-icon {
  padding: 2px 4px;
  border-radius: var(--radius);
  border: 1px solid rgba(60,66,80,0.10);
  font-size: 11px;
  color: var(--text-secondary);
  background: transparent;
}
.poi-cat-editor-del {
  display: flex;
  align-items: center;
  background: none;
  border: none;
  padding: 3px;
  border-radius: var(--radius);
  cursor: pointer;
  color: var(--text-very-muted);
  transition: color 120ms;
}
.poi-cat-editor-del:hover { color: var(--danger); }

/* ── Neue Kategorie ── */
.poi-cat-editor-add {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 0;
  border-top: 1px solid rgba(60,66,80,0.08);
}
.poi-cat-editor-input {
  flex: 1;
  padding: 3px 8px;
  border-radius: var(--radius);
  border: 1px solid rgba(60,66,80,0.12);
  background: rgba(60,66,80,0.03);
  font-size: 11px;
  color: var(--text-primary);
  outline: none;
}
.poi-cat-editor-input:focus { border-color: var(--accent); }

/* ─── Duplikat-Banner (im POI-Modal) ─── */
.poi-dup-banner {
  margin-top: 6px;
}
.poi-dup-banner-inner {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  background: rgba(217,119,6,0.08);
  border: 1px solid rgba(217,119,6,0.18);
  border-radius: 6px;
  font-size: 12px;
  color: var(--warning);
}
.poi-dup-banner-text { flex: 1; color: var(--text-secondary); }
.poi-dup-banner-text strong { color: var(--warning); }
.poi-dup-open-btn {
  background: none;
  border: 1px solid rgba(217,119,6,0.25);
  border-radius: var(--radius);
  padding: 3px 10px;
  font-size: 11px;
  font-weight: 500;
  color: var(--warning);
  cursor: pointer;
  white-space: nowrap;
  transition: background 120ms;
}
.poi-dup-open-btn:hover { background: rgba(217,119,6,0.08); }

/* ─── Duplikat-Finder Modal ─── */
.poi-dupes-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.3);
  z-index: 1100;
  display: flex;
  align-items: center;
  justify-content: center;
}
.poi-dupes-modal {
  background: var(--card-bg);
  border-radius: 10px;
  box-shadow: 0 16px 48px rgba(0,0,0,0.12);
  width: 90%;
  max-width: 620px;
  max-height: 85vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.poi-dupes-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  border-bottom: 1px solid rgba(60,66,80,0.08);
}
.poi-dupes-header h3 { font-size: 14px; font-weight: 700; }
.poi-dupes-count { font-size: 11px; color: var(--text-muted); margin-right: auto; }
.poi-dupes-empty {
  padding: 3rem;
  text-align: center;
  color: var(--text-muted);
}
.poi-dupes-empty svg { width: 32px; height: 32px; margin-bottom: 8px; color: var(--accent); }
.poi-dupes-body {
  overflow-y: auto;
  padding: 12px 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.poi-dupes-group {
  border: 1px solid rgba(60,66,80,0.08);
  border-radius: 8px;
  overflow: hidden;
  flex-shrink: 0;
}
.poi-dupes-group-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 12px;
  background: rgba(60,66,80,0.03);
  border-bottom: 1px solid rgba(60,66,80,0.06);
}
.poi-dupes-group-title { font-size: 13px; font-weight: 600; }
.poi-dupes-group-count { font-size: 11px; color: var(--text-muted); }
.poi-dupes-row {
  display: grid;
  grid-template-columns: 10px 1fr auto auto;
  grid-template-rows: auto auto;
  gap: 2px 8px;
  padding: 8px 12px;
  font-size: 12px;
  align-items: center;
  cursor: pointer;
  transition: background 120ms;
}
.poi-dupes-row:hover { background: rgba(60,66,80,0.04); }
.poi-dupes-row + .poi-dupes-row { border-top: 1px solid rgba(60,66,80,0.04); }
.poi-dupes-row-dot { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; grid-row: 1 / 3; align-self: center; }
.poi-dupes-row-name { font-weight: 500; grid-column: 2; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.poi-dupes-row-meta { grid-column: 2; display: flex; gap: 4px; align-items: center; font-size: 10px; overflow: hidden; }
.poi-dupes-row-cat { color: var(--text-muted); flex-shrink: 0; }
.poi-dupes-row-addr { color: var(--text-very-muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.poi-dupes-row-addr::before { content: '· '; }
.poi-dupes-row-coords { color: var(--text-very-muted); font-size: 10px; font-family: var(--font-mono, monospace); flex-shrink: 0; }
.poi-dupes-row-coords::before { content: '· '; font-family: inherit; }
.poi-dupes-del { grid-column: 4; grid-row: 1 / 3; align-self: center; }
.poi-dupes-group-actions {
  padding: 6px 12px;
  border-top: 1px solid rgba(60,66,80,0.06);
  display: flex;
  justify-content: flex-end;
}
.poi-dupes-merge { font-size: 11px; color: var(--danger); }

/* ── Wiki-Info im Edit-Modal ── */
.poi-wiki-info {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid rgba(60,66,80,0.08);
}
.poi-wiki-image {
  max-width: 200px;
  max-height: 150px;
  border-radius: 6px;
  object-fit: cover;
  margin-bottom: 8px;
  cursor: pointer;
}
.poi-wiki-image:hover { opacity: 0.85; }
.poi-wiki-desc {
  font-size: 12px;
  color: var(--text-secondary);
  line-height: 1.5;
  margin: 0 0 8px;
}
.poi-wiki-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}
.poi-wiki-tag {
  font-size: 10px;
  font-weight: 500;
  color: var(--accent);
  background: rgba(13,148,136,0.08);
  padding: 2px 8px;
  border-radius: 10px;
}
.poi-card-wiki {
  color: var(--accent);
  opacity: 0.6;
  margin-left: 4px;
}

/* ─── POI Responsive: Mobile ─── */
@media (max-width: 768px) {
  .poi-page { padding: 12px; }
  .poi-hd-row1 { flex-wrap: wrap; }
  .poi-hd-row2 { flex-wrap: wrap; }
  .poi-hd-count { margin-right: 0; }
  .poi-hd-actions { margin-left: auto; }
  .poi-search-wrap { width: 100%; }
  .poi-card-addr { display: none; }
  .poi-card-coord { display: none; }
  .poi-card-del { opacity: 0.5; }
  .poi-card-cat { opacity: 1; }
  .poi-card-body { padding: 10px; }
  .poi-import-panel { width: 95%; max-height: 85vh; }
}
