/* Signal Run scoreboard + trophy + submit click hardening
   Drop-in override. Keep loaded after the main Signal Run styles. */

/* Keep the ending leaderboard inside its rail and away from the modal scrollbar. */
.signal-leaderboard-rail,
.signal-run-highscores,
.signal-leaderboard-card {
  position: relative !important;
  z-index: 80 !important;
  max-width: 100% !important;
  min-width: 0 !important;
  overflow: visible !important;
  pointer-events: auto !important;
}

.signal-ending-layout {
  grid-template-columns: minmax(0, 1fr) clamp(390px, 32vw, 450px) !important;
  gap: clamp(14px, 1.6vw, 20px) !important;
  overflow: visible !important;
}

.signal-run-highscore-form-row {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(142px, max-content) !important;
  align-items: stretch !important;
  gap: 10px !important;
  width: 100% !important;
  max-width: 100% !important;
  overflow: visible !important;
  position: relative !important;
  z-index: 100 !important;
  pointer-events: auto !important;
}

#highScoreName,
#highScoreSubmit {
  position: relative !important;
  z-index: 110 !important;
  pointer-events: auto !important;
  touch-action: manipulation !important;
  min-width: 0 !important;
}

#highScoreName {
  width: 100% !important;
}

#highScoreSubmit {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  min-width: 124px !important;
  max-width: 100% !important;
  cursor: pointer !important;
  user-select: none !important;
  white-space: nowrap !important;
}

/* Make leaderboard rows readable and stop names/scores from fighting each other. */
#highScoreList {
  display: grid !important;
  gap: 8px !important;
  margin-top: 10px !important;
  padding: 0 !important;
  max-width: 100% !important;
}

.signal-leaderboard-row {
  display: grid !important;
  grid-template-columns: 78px 3ch minmax(10ch, 1fr) 8ch !important;
  align-items: center !important;
  gap: 7px !important;
  max-width: 100% !important;
  min-width: 0 !important;
}

.signal-leaderboard-badge,
.score-badge {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 78px !important;
  min-width: 0 !important;
  height: 28px !important;
  padding: 0 !important;
  overflow: hidden !important;
}

.signal-leaderboard-rank,
.score-rank {
  justify-self: end !important;
  text-align: right !important;
}

.signal-leaderboard-name,
.score-name {
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  font-size: clamp(0.56rem, 0.68vw, 0.62rem) !important;
  letter-spacing: 0.02em !important;
}

.signal-leaderboard-score,
.score-value {
  justify-self: end !important;
  text-align: right !important;
  white-space: nowrap !important;
  font-variant-numeric: tabular-nums !important;
  letter-spacing: 0.04em !important;
}

/* Ace Pilot trophy sprite.
   The asset exists at assets/rail-shooter/ui/ace-pilot-trophy.png. */
.signal-leaderboard-icon-trophy {
  display: block !important;
  width: 42px !important;
  height: 24px !important;
  background: url("assets/rail-shooter/ui/ace-pilot-trophy.png") center / contain no-repeat !important;
  filter:
    drop-shadow(0 0 4px rgba(255, 217, 102, 0.65))
    drop-shadow(0 0 8px rgba(125, 231, 255, 0.22)) !important;
}

#highScoreList .score-badge.ace-pilot,
#highScoreList .signal-leaderboard-badge.ace-pilot {
  border-color: rgba(255, 217, 102, 0.58) !important;
  background: rgba(255, 217, 102, 0.12) !important;
}

@media (max-width: 980px) {
  .signal-ending-layout {
    grid-template-columns: 1fr !important;
  }

  .signal-leaderboard-rail {
    width: min(100%, 640px) !important;
    justify-self: center !important;
  }
}

@media (max-width: 860px) {
  .signal-run-highscore-form-row {
    grid-template-columns: 1fr !important;
  }

  #highScoreSubmit {
    width: 100% !important;
  }

  .signal-leaderboard-row {
    grid-template-columns: 72px 3ch minmax(8ch, 1fr) 8ch !important;
    gap: 6px !important;
  }

  .signal-leaderboard-badge,
  .score-badge {
    width: 72px !important;
    min-width: 0 !important;
  }
}


/* v3: Trophy is now an actual <img>, not a CSS background.
   This avoids silent failures if a previous .signal-leaderboard-icon background rule wins. */
img.signal-leaderboard-icon-trophy,
.signal-leaderboard-icon-trophy {
  display: block !important;
  width: 44px !important;
  height: 26px !important;
  max-width: 44px !important;
  max-height: 26px !important;
  object-fit: contain !important;
  object-position: center !important;
  background: none !important;
  clip-path: none !important;
  opacity: 1 !important;
  visibility: visible !important;
  filter:
    drop-shadow(0 0 4px rgba(255, 217, 102, 0.75))
    drop-shadow(0 0 8px rgba(125, 231, 255, 0.25)) !important;
}

#highScoreList .score-badge.ace-pilot,
#highScoreList .signal-leaderboard-badge.ace-pilot {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}
