:root {
  --bg: #0d1117;
  --panel: rgba(13, 17, 23, 0.88);
  --text: #e6edf3;
  --muted: #9aa1ab;
  --accent: #4dabf7;
  --warn: #e03131;
  --gold: #f5c518;
  --green: #2f9e44;
  --cat-food: #e8590c;
  --cat-drink: #c2255c;
  --cat-shop: #1971c2;
  --cat-sight: #9c36b5;
  --cat-fun: #2f9e44;
  --cat-other: #495057;
}

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

#map { position: absolute; inset: 0; }

/* Fog canvas: inside the map's canvas container, above the GL canvas,
   below DOM markers and controls. Explicit z-indexes so stacking never
   depends on DOM insertion order (markers restored from persistence are
   appended before the fog canvas exists). Never eats input. */
.fog-canvas { position: absolute; top: 0; left: 0; pointer-events: none; z-index: 1; }
.maplibregl-marker { z-index: 2; }

.hidden { display: none !important; }

/* ---------- HUD ---------- */
#hud {
  position: fixed; top: 0; left: 0; right: 0;
  padding: calc(env(safe-area-inset-top, 0px) + 10px)
           max(10px, env(safe-area-inset-right, 0px))
           0
           max(10px, env(safe-area-inset-left, 0px));
  display: flex; flex-direction: column; gap: 8px; align-items: center;
  pointer-events: none; z-index: 20;
}
/* wrap instead of clipping at narrow phone widths */
#topbar { display: flex; flex-wrap: wrap; gap: 8px; width: 100%; align-items: center; }
#topbar .spacer { flex: 1; }
.chip {
  pointer-events: auto;
  background: var(--panel); color: var(--text);
  border: 1px solid rgba(255,255,255,0.12); border-radius: 999px;
  padding: 11px 13px; font-size: 14px; font-weight: 600;
  backdrop-filter: blur(6px); white-space: nowrap;
}
.chip.subtle { color: var(--muted); font-weight: 400; }
.chip.btn { cursor: pointer; min-width: 44px; min-height: 44px; text-align: center; }
.chip.btn:active { transform: scale(0.96); }
.chip.btn[aria-pressed="true"] { border-color: var(--accent); color: var(--accent); }
.chip.warn {
  background: var(--warn); color: #fff; border-color: transparent;
  animation: pulse 1.6s ease-in-out infinite;
}
@keyframes pulse { 50% { opacity: 0.75; } }
.statusline {
  pointer-events: none; background: var(--panel); color: var(--muted);
  border-radius: 8px; padding: 4px 10px; font-size: 12.5px;
}

/* ---------- Sim panel ---------- */
body.card-open #simPanel { display: none; } /* the card is a bottom sheet over it */
#simPanel {
  position: fixed;
  left: max(10px, env(safe-area-inset-left, 0px));
  bottom: calc(env(safe-area-inset-bottom, 0px) + 10px);
  background: var(--panel); border: 1px solid rgba(255,255,255,0.12);
  border-radius: 12px; padding: 10px 12px; z-index: 20; max-width: 320px;
  backdrop-filter: blur(6px);
}
#simPanel label { display: flex; align-items: center; gap: 8px; font-size: 13px; }
#simPanel input[type="range"] { flex: 1; accent-color: var(--accent); }
#simPanel .hint { margin-top: 6px; font-size: 12px; color: var(--muted); }

/* ---------- Avatar ---------- */
.avatar {
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--accent); border: 3px solid #fff;
  box-shadow: 0 0 0 6px rgba(77, 171, 247, 0.25), 0 1px 6px rgba(0,0,0,0.5);
  cursor: grab;
}

/* ---------- Revealed POI markers (DOM, above the fog canvas) ---------- */
.poi-marker {
  /* NOTE: no `position` here — MapLibre positions the marker element itself
     via `.maplibregl-marker { position: absolute }` + transform; overriding
     it (e.g. `relative`) makes every marker render at the wrong place. */
  width: 34px; height: 34px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 17px; line-height: 1; padding: 0;
  background: #fff; cursor: pointer;
  border: 3px solid var(--cat-other);
  box-shadow: 0 2px 8px rgba(0,0,0,0.45);
}
.poi-marker[data-cat="food"]  { border-color: var(--cat-food); }
.poi-marker[data-cat="drink"] { border-color: var(--cat-drink); }
.poi-marker[data-cat="shop"]  { border-color: var(--cat-shop); }
.poi-marker[data-cat="sight"] { border-color: var(--cat-sight); }
.poi-marker[data-cat="fun"]   { border-color: var(--cat-fun); }
.poi-marker.been { background: #d3f9d8; }
.poi-marker.rated { box-shadow: 0 0 0 3px var(--gold), 0 2px 8px rgba(0,0,0,0.45); }
.poi-marker .badge {
  position: absolute; top: -6px; right: -6px;
  min-width: 16px; height: 16px; border-radius: 8px;
  background: var(--green); color: #fff;
  font-size: 11px; font-weight: 700; line-height: 16px; text-align: center;
}
.poi-marker.rated:not(.been) .badge { background: var(--gold); color: #442; }
.poi-marker .badge:empty { display: none; }

/* ---------- Detail card ---------- */
#card {
  position: fixed;
  left: max(10px, env(safe-area-inset-left, 0px));
  right: max(10px, env(safe-area-inset-right, 0px));
  bottom: calc(env(safe-area-inset-bottom, 0px) + 10px);
  margin: 0 auto; max-width: 430px;
  background: var(--panel); border: 1px solid rgba(255,255,255,0.14);
  border-radius: 16px; padding: 14px 16px; z-index: 30;
  backdrop-filter: blur(10px); box-shadow: 0 8px 30px rgba(0,0,0,0.5);
}
#card h2 { margin: 0 26px 2px 0; font-size: 18px; }
#card .cat { color: var(--muted); font-size: 13px; margin-bottom: 8px; }
#card dl { margin: 0 0 10px; display: grid; gap: 4px; }
#card dl > div { display: flex; gap: 8px; font-size: 13.5px; }
#card dt { color: var(--muted); min-width: 62px; }
#card dd { margin: 0; overflow-wrap: anywhere; }
#cardClose {
  position: absolute; top: 6px; right: 6px;
  width: 40px; height: 40px; border-radius: 50%;
  border: none; background: rgba(255,255,255,0.1); color: var(--text);
  font-size: 20px; cursor: pointer;
}
.rate-row { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.star {
  background: none; border: none; padding: 8px 5px;
  font-size: 28px; line-height: 1; color: #3d444d; cursor: pointer;
}
.star.on { color: var(--gold); }
#beenBtn {
  border: 1px solid rgba(255,255,255,0.2); background: none; color: var(--text);
  border-radius: 999px; padding: 8px 16px; font-size: 14px; font-weight: 600;
  min-height: 44px; cursor: pointer;
}
#beenBtn.on { background: var(--green); border-color: transparent; color: #fff; }

/* ---------- Toast ---------- */
#toast {
  pointer-events: none; /* a notification must never steal map taps */
  position: fixed; top: calc(env(safe-area-inset-top, 0px) + 58px);
  left: 50%; transform: translateX(-50%);
  background: var(--accent); color: #08233c;
  font-weight: 700; font-size: 14px;
  padding: 8px 16px; border-radius: 999px; z-index: 40;
  box-shadow: 0 4px 16px rgba(0,0,0,0.4);
}

/* MapLibre tweaks */
.maplibregl-ctrl-attrib { font-size: 10px; }
