/* ========================================================================
   HL2MP — Maps image track (drag-to-pan slider)
   ===================================================================== */

/* Allow horizontal drag without hijacking vertical scroll on touch */
#image-track { touch-action: pan-y; cursor: grab; }

/* Wrapper variables for card sizing and spacing */
.maps-track-wrap{
  --gap: 6px;
  --card-w: clamp(200px, 22vmin, 320px);
  --ratio: 1.45;                         /* height = width * ratio */
  --card-h: calc(var(--card-w) * var(--ratio));
  --r: 14px;
}
.maps-track-wrap h2{ margin-bottom:8px; }

/* Card belt container */
.maps-frame{
  position:relative;
  border:1px solid var(--line);
  border-radius:16px;
  background: linear-gradient(180deg, #0f1827dd, #0b121ddd);
  padding: 14px;
  overflow:hidden;

  /* ensure a pleasant height even before JS moves things */
  min-height: calc(var(--card-h) + 28px);
}

/* The draggable track (centered vertically, moved horizontally via JS) */
#image-track{
  display:flex;
  gap: var(--gap);
  position:absolute;
  left:50%;
  top:50%;
  transform: translate(0%, -50%);
  user-select:none;
}

/* Individual map card */
.map-card{
  margin:0;
  position:relative;
  width: var(--card-w);
  height: var(--card-h);
  border-radius: var(--r);
  overflow:hidden;
  border:1px solid rgba(150,180,210,.22);
  box-shadow: 0 16px 30px rgba(0,0,0,.35);
  background:#000;
}

/* Images fill the card; object-position is animated by JS */
#image-track .image{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position: 100% center;     /* aligns with initial translateX(0%) */
  display:block;
}

/* Caption chip centered near the bottom */
.map-caption{
  position:absolute;
  left:50%;
  bottom:8px;
  transform:translateX(-50%);
  margin:0;
  padding:4px 10px;
  font-weight:800;
  font-size:13px;
  color:#fff;
  text-shadow:0 2px 4px rgba(0,0,0,.6);
  background: linear-gradient(180deg, transparent, rgba(0,0,0,.55));
  border-radius:999px;
  pointer-events:none;
}
