:root {
  --ranking-cyan: #35faff;
  --ranking-orange: #ff9c3c;
  --ranking-bg: rgba(5, 18, 32, 0.92);
  --ranking-border: rgba(53, 250, 255, 0.35);
  --ranking-shadow: 0 0 16px rgba(53, 250, 255, 0.25);
  --ranking-row-height: clamp(38px, 4vw, 52px);
}

/* Mount: used only as logical container */
#rankingpanel-mount {
  position: fixed;
  top: 0;
  right: 0;
  z-index: 35;        /* same layer as stats */
  pointer-events: none;
}

/* Wrapper is neutral now – no fixed positioning, no centering */
.ranking-panel {
  position: static;
  pointer-events: none;
  z-index: 32;
}

.ranking-panel.open {
  pointer-events: auto;
}

.ranking-panel.is-hidden {
  display: none !important;
}

/* VERTICAL RANKING BUTTON
   - independent, fixed on right edge
   - sits below Stats (adjust top as you like)
*/
.ranking-toggle {
  position: fixed;
  right: var(--side-toggle-right, 4px);
  top: calc(var(--side-toggle-top, 8%) + var(--stats-toggle-height, 100px) + var(--side-toggle-gap, 0px));
  transform: none;
  padding: 12px 6px;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 20px 0 0 20px;
  border: 1px solid var(--ranking-border);
  background: rgba(0, 0, 0, 0.68);
  color: var(--ranking-cyan);
  letter-spacing: 0.26em;
  font-size: clamp(10px, 0.95vw, 12px);
  cursor: pointer;
  text-transform: uppercase;
  box-shadow: var(--ranking-shadow);
  pointer-events: auto;
  writing-mode: vertical-rl;
  text-orientation: mixed;
  width: var(--side-toggle-width, clamp(36px, 3vw, 52px));
  height: var(--ranking-toggle-height, clamp(140px, 32vh, 140px));
  gap: 8px;
}

.ranking-toggle.is-active {
  background: rgba(0, 0, 0, 0.92);
  box-shadow: 0 0 18px rgba(53, 250, 255, 0.7);
}

.ranking-toggle:hover {
  background: rgba(0, 0, 0, 0.82);
}

.ranking-toggle .chevron {
  width: 10px;
  height: 10px;
  border-right: 2px solid var(--ranking-cyan);
  border-bottom: 2px solid var(--ranking-cyan);
  transform: rotate(-45deg);
  transition: transform 0.3s ease;
}

.ranking-panel.open .ranking-toggle .chevron {
  transform: rotate(135deg);
}

/* RANKING PANEL BODY
   - fully independent from button
   - you control size/position with top/right/bottom/width
*/
.ranking-body {
  position: fixed;
  top: var(--side-panel-top, 10px);
  right: calc(var(--side-toggle-right, 4px) + var(--side-toggle-width, 36px) + var(--side-panel-gap, 8px));
  bottom: 10px;                       /* distance from bottom → height */
  width: clamp(240px, 24vw, 360px);  /* PANEL WIDTH */
  background: var(--ranking-bg);
  border: 1px solid var(--ranking-border);
  border-radius: 24px;
  padding: clamp(12px, 1.6vw, 18px);
  box-shadow: var(--ranking-shadow);
  backdrop-filter: blur(8px);
  transform: translateX(135%);        /* hidden off-screen */
  opacity: 0;
  pointer-events: none;
  transition: transform 0.35s ease, opacity 0.35s ease;
  overflow: hidden;
}

/* Slide in horizontally when open */
.ranking-panel.open .ranking-body {
  transform: translateX(0);
  opacity: 1;
  pointer-events: auto;
}

.ranking-section header {
  margin: 20px 0 12px;
  color: var(--ranking-cyan);
  font-size: clamp(12px, 1.2vw, 14px);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.ranking-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-height: calc(var(--ranking-row-height) * 6);
  overflow-y: auto;
  padding-right: 0.4rem;
  scrollbar-width: thin;
  scrollbar-color: rgba(53, 250, 255, 0.35) rgba(5, 18, 32, 0.6);
}

.ranking-list::-webkit-scrollbar {
  width: 6px;
}

.ranking-list::-webkit-scrollbar-track {
  background: rgba(5, 18, 32, 0.6);
}

.ranking-list::-webkit-scrollbar-thumb {
  background: rgba(53, 250, 255, 0.35);
  border-radius: 3px;
}

.ranking-list li {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 12px;
  align-items: center;
  padding: 10px 12px;
  min-height: var(--ranking-row-height);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(53, 250, 255, 0.18);
  color: rgba(255, 255, 255, 0.9);
  font-size: clamp(11px, 1vw, 13px);
}

.ranking-avatar {
  width: 24px;
  height: 24px;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.25);
  background: rgba(0, 0, 0, 0.4);
  display: flex;
  align-items: center;
  justify-content: center;
}

.ranking-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.ranking-info {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.ranking-info strong {
  font-size: clamp(11px, 1vw, 13px);
  color: #fff;
  text-overflow: ellipsis;
  overflow: hidden;
  white-space: nowrap;
}

.ranking-info span {
  font-size: clamp(10px, 0.95vw, 12px);
  color: rgba(255, 255, 255, 0.7);
  text-overflow: ellipsis;
  overflow: hidden;
  white-space: nowrap;
}

.ranking-score {
  font-weight: 700;
  color: var(--ranking-cyan);
  font-size: clamp(12px, 1vw, 14px);
}

.ranking-list li.attack .ranking-score {
  color: var(--ranking-orange);
}

.ranking-body::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  border: 1px solid rgba(53, 250, 255, 0.2);
  filter: blur(8px);
  z-index: -1;
  pointer-events: none;
}

/* Responsiveness: tweak button size & panel width/right, but
   keep them independent (no re-tying). */
@media (max-width: 900px) {
  .ranking-toggle {
    width: var(--side-toggle-width, 32px);
    height: var(--ranking-toggle-height, clamp(130px, 32vh, 200px));
    right: var(--side-toggle-right, 2px);
  }
  .ranking-body {
    right: calc(var(--side-toggle-right, 2px) + var(--side-toggle-width, 32px) + var(--side-panel-gap, 8px));
    width: clamp(280px, 55vw, 380px);
  }
}

@media (max-width: 640px) {
  .ranking-toggle {
    height: var(--ranking-toggle-height, clamp(110px, 36vh, 180px));
  }
  .ranking-body {
    top: 70px;
    right: 44px;
    bottom: 24px;
    width: min(86vw, 320px);
  }
}
