:root {
  --bg: #0f1216;
  --panel: #171c23;
  --panel-2: #1f262f;
  --line: #2a323d;
  --text: #e6e9ef;
  --muted: #93a0b1;
  --accent: #fbbf24;
}

* { box-sizing: border-box; }
html, body { margin: 0; height: 100%; }
body {
  font: 14px/1.4 system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  color: var(--text);
  background: var(--bg);
  display: flex;
  overflow: hidden;
}

#sidebar {
  width: 300px;
  flex: 0 0 300px;
  height: 100vh;
  background: var(--panel);
  border-right: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  z-index: 1000;
}
#sidebar header { padding: 14px 16px 10px; border-bottom: 1px solid var(--line); }
#sidebar h1 { margin: 0; font-size: 18px; letter-spacing: .5px; }
#sidebar .sub { margin: 2px 0 0; color: var(--muted); font-size: 12px; }

.search-wrap { padding: 12px 16px 4px; position: relative; }
#search {
  width: 100%; padding: 8px 10px; border-radius: 8px;
  border: 1px solid var(--line); background: var(--panel-2); color: var(--text);
}
#search:focus { outline: none; border-color: var(--accent); }
#search-results {
  list-style: none; margin: 4px 0 0; padding: 0;
  max-height: 220px; overflow: auto;
  border: 1px solid var(--line); border-radius: 8px; background: var(--panel-2);
  display: none;
}
#search-results.show { display: block; }
#search-results li {
  padding: 7px 10px; cursor: pointer; display: flex; justify-content: space-between; gap: 8px;
}
#search-results li:hover { background: #2a323d; }
#search-results .tag { color: var(--muted); font-size: 11px; }

.filters-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 16px 6px; color: var(--muted); font-size: 12px; text-transform: uppercase; letter-spacing: .5px;
}
.filters-head button {
  background: var(--panel-2); color: var(--text); border: 1px solid var(--line);
  border-radius: 6px; padding: 3px 8px; cursor: pointer; font-size: 11px; margin-left: 4px;
}
.filters-head button:hover { border-color: var(--accent); }

#filters { overflow: auto; flex: 1; padding: 0 10px 10px; }
.group-title {
  padding: 10px 6px 4px; font-size: 11px; color: var(--muted); text-transform: uppercase; letter-spacing: .5px;
  display: flex; align-items: center; justify-content: space-between; cursor: pointer; user-select: none;
}
.group-title:hover { color: var(--text); }
.group-eye { opacity: .45; font-size: 12px; }
.group-title:hover .group-eye { opacity: 1; }
.filter {
  display: flex; align-items: center; gap: 8px; padding: 5px 6px; border-radius: 6px; cursor: pointer;
}
.filter:hover { background: var(--panel-2); }
.filter input { accent-color: var(--accent); }
.swatch { width: 14px; height: 14px; border-radius: 50%; display: inline-grid; place-items: center; font-size: 9px; color: #0b0e12; flex: 0 0 14px; }
.filter .label { flex: 1; }
.filter .count { color: var(--muted); font-size: 11px; }

#sidebar footer { border-top: 1px solid var(--line); padding: 10px 16px 14px; max-height: 46vh; overflow: auto; }
#label-toggle, #lootzones-toggle, #coord-toggle, #dev-toggle, #clear-cache {
  width: 100%; padding: 8px; border-radius: 8px; cursor: pointer; margin-bottom: 6px;
  background: var(--panel-2); color: var(--text); border: 1px solid var(--line);
}
#clear-cache:hover { border-color: #ef4444; color: #ef4444; }
#label-toggle.on { border-color: #34d399; color: #34d399; }
#lootzones-toggle.on { border-color: #fb923c; color: #fb923c; }

#lootzones-legend {
  display: flex; flex-direction: column; gap: 3px;
  margin: -2px 0 8px; padding: 8px 10px;
  border: 1px solid var(--line); border-radius: 8px;
  font-size: 12px; color: var(--muted);
}
#lootzones-legend[hidden] { display: none; }
#lootzones-legend .zone-key { display: flex; align-items: center; gap: 7px; }
#lootzones-legend .zone-swatch { width: 12px; height: 12px; border-radius: 3px; flex: 0 0 12px; }

/* while drawing a zone or placing markers, existing zone polygons must not
   swallow map clicks */
.gv-drawing .leaflet-overlay-pane svg { pointer-events: none; }
#coord-toggle.on { border-color: var(--accent); color: var(--accent); }
#dev-toggle.on { border-color: #f472b6; color: #f472b6; }

#dev-panel { margin-top: 4px; padding: 8px; border: 1px dashed #f472b6; border-radius: 8px; }
.dev-new { display: flex; gap: 6px; margin-top: 6px; }
.dev-new select { flex: 1; min-width: 0; background: var(--panel-2); color: var(--text); border: 1px solid var(--line); border-radius: 7px; padding: 6px; }
.dev-new button { flex: 1; padding: 6px; border-radius: 7px; cursor: pointer; background: var(--panel-2); color: var(--text); border: 1px solid var(--line); }
.dev-new button.on { border-color: #22d3ee; color: #22d3ee; }
.dev-actions { display: flex; flex-direction: column; gap: 6px; margin-top: 6px; }
.dev-actions button {
  padding: 7px; border-radius: 7px; cursor: pointer;
  background: var(--panel-2); color: var(--text); border: 1px solid var(--line);
}
.dev-actions button:hover { border-color: #f472b6; }
.dev-actions button.danger:hover { border-color: #ef4444; color: #ef4444; }
.dev-readout { color: #f9a8d4; font-size: 11px; margin: 8px 0 0; min-height: 14px; }

.credits { margin-top: 12px; padding-top: 10px; border-top: 1px solid var(--line); color: var(--muted); font-size: 13px; line-height: 1.55; }
.credits p { margin: 0 0 3px; }
.credits a { color: var(--accent); text-decoration: none; }
.credits a:hover { text-decoration: underline; }
.credits .discord { color: var(--text); font-weight: 600; user-select: all; }
.gv-pin.dev { cursor: grab; }
.leaflet-marker-draggable { cursor: grab; }
.note { color: var(--muted); font-size: 11px; margin: 8px 0 0; }
.note code { background: var(--panel-2); padding: 1px 4px; border-radius: 4px; }

#map { flex: 1; height: 100vh; background: #0b0e12; }

/* marker pins — 22px circle in a 22px box, anchored bottom-center (matches the
   original footprint exactly so saved coordinates stay pixel-accurate). */
.gv-pin {
  width: 22px; height: 22px; border-radius: 50%;
  display: grid; place-items: center; line-height: 1; font-size: 12px;
  color: #0b0e12;
  background: radial-gradient(circle at 32% 26%, rgba(255,255,255,.45), rgba(255,255,255,0) 58%), var(--c, #888);
  border: 2px solid #fff;
  box-shadow: 0 2px 5px rgba(0,0,0,.55);
  transition: transform .08s ease;
  transform-origin: 50% 100%;
}
.gv-pin:hover { transform: scale(1.14); }
.gv-pin.moved { border-color: #22d3ee; box-shadow: 0 0 0 2px rgba(34,211,238,.55), 0 2px 5px rgba(0,0,0,.55); }
.gv-pin.dev { cursor: grab; }

/* permanent name labels */
.leaflet-tooltip.gv-label {
  background: rgba(15,18,22,.82); color: var(--text);
  border: 1px solid var(--line); border-radius: 5px;
  padding: 1px 6px; font: 600 11px/1.2 system-ui; white-space: nowrap;
  box-shadow: 0 1px 3px rgba(0,0,0,.5); pointer-events: none;
}
.leaflet-tooltip.gv-label::before { display: none; }

/* dev edit form (in popup) */
.gv-edit { display: flex; flex-direction: column; gap: 6px; min-width: 210px; }
.gv-edit label { display: flex; flex-direction: column; gap: 2px; font-size: 11px; color: var(--muted); }
.gv-edit input, .gv-edit select, .gv-edit textarea {
  background: var(--panel-2); color: var(--text); border: 1px solid var(--line);
  border-radius: 6px; padding: 5px 7px; font: 13px system-ui; resize: vertical;
}
.gv-edit input:focus, .gv-edit select:focus, .gv-edit textarea:focus { outline: none; border-color: var(--accent); }
.gv-edit-actions { display: flex; gap: 6px; margin-top: 2px; }
.gv-edit-actions button { flex: 1; padding: 6px; border-radius: 6px; cursor: pointer; border: 0; font-weight: 600; background: var(--accent); color: #0b0e12; }
.gv-edit-actions .danger { background: #ef4444; color: #fff; }
.gv-edit .f-xy { display: flex; gap: 6px; }
.gv-edit .f-xy label { flex: 1; }
.gv-popup .coords { font: 11px/1.3 monospace; color: var(--muted); margin: 2px 0 6px; cursor: pointer; user-select: all; }
.gv-popup .coords:hover { color: var(--accent); }
.gv-popup .share { font-size: 11px; color: var(--muted); margin: 0 0 6px; cursor: pointer; }
.gv-popup .share:hover { color: var(--accent); }

.leaflet-popup-content-wrapper { background: var(--panel); color: var(--text); border: 1px solid var(--line); }
.leaflet-popup-tip { background: var(--panel); border: 1px solid var(--line); }
.gv-popup h3 { margin: 0 0 2px; font-size: 15px; }
.gv-popup .meta { color: var(--muted); font-size: 12px; margin: 0 0 6px; }
.gv-popup .chips { display: flex; flex-wrap: wrap; gap: 4px; margin: 4px 0 0; }
.gv-popup .chip { background: var(--panel-2); border: 1px solid var(--line); border-radius: 10px; padding: 1px 7px; font-size: 11px; }
.gv-popup .row { margin: 4px 0 0; font-size: 12px; }
.gv-popup .row b { color: var(--muted); font-weight: 600; }

#coord-readout {
  position: fixed; bottom: 12px; right: 12px; z-index: 1200;
  background: var(--panel); border: 1px solid var(--accent); color: var(--text);
  padding: 8px 12px; border-radius: 8px; font: 12px/1.3 monospace; box-shadow: 0 4px 16px rgba(0,0,0,.5);
}

/* shown over the map whenever localStorage holds dev-mode edits */
#local-edits-banner {
  position: absolute; top: 12px; left: 50%; transform: translateX(-50%);
  z-index: 1200;
  display: flex; align-items: center; justify-content: center; flex-wrap: wrap; gap: 10px;
  max-width: calc(100% - 24px);
  background: var(--panel); border: 1px solid var(--accent); color: var(--text);
  padding: 8px 12px; border-radius: 8px; font-size: 13px; box-shadow: 0 4px 16px rgba(0,0,0,.5);
}
#local-edits-banner button {
  background: var(--panel-2); border: 1px solid var(--line); color: var(--text);
  padding: 4px 10px; border-radius: 6px; cursor: pointer; font-size: 12px; white-space: nowrap;
}
#local-edits-banner button:hover { border-color: var(--accent); }
/* "display: flex" above would defeat the hidden attribute without this */
#local-edits-banner[hidden] { display: none; }

@media (max-width: 720px) {
  body { flex-direction: column; }
  #sidebar { width: 100%; flex: 0 0 auto; height: 42vh; }
  #map { height: 58vh; }
}
