/*
 * TS50 Hot Servers - CSS
 *
 * OBJETIVO:
 * - Layout dark, compacto e responsivo.
 * - Manter a linha "agora/antes" em 1 linha (sem quebrar e sem aumentar altura do card).
 */

.ts50-hs{width:100%;max-width:520px;margin:0 auto;box-sizing:border-box;font-family:inherit}

.ts50-hs-topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin:10px 0 8px;flex-wrap:wrap}
.ts50-hs-left{min-width:0;flex:1 1 240px}
.ts50-hs-title{font-weight:800;font-size:16px;letter-spacing:.2px}
.ts50-hs-subtitle{opacity:.78;font-size:12px;margin-top:2px;line-height:1.2}

.ts50-hs-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end;flex:0 0 auto}

.ts50-hs-tabs{display:flex;gap:6px}
.ts50-hs-tab{cursor:pointer;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.06);color:inherit;
  padding:6px 10px;border-radius:999px;font-size:12px;font-weight:700;line-height:1;user-select:none;white-space:nowrap}
.ts50-hs-tab.is-active{border-color:rgba(255,255,255,.22);background:rgba(255,255,255,.12)}

.ts50-hs-select{border:1px solid rgba(255,255,255,.14);background:rgba(0,0,0,.20);color:inherit;
  padding:6px 10px;border-radius:999px;font-size:12px;font-weight:700;outline:none}

.ts50-hs-list{display:flex;flex-direction:column;gap:6px}

.ts50-hs-row{display:flex;align-items:center;gap:10px;padding:10px 10px;border-radius:14px;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.10);box-sizing:border-box}

.ts50-hs-row.is-winner{
  position:relative;
  border-color:rgba(210,170,90,.34) !important;
  background:linear-gradient(90deg,
    rgba(210,170,90,.22) 0%,
    rgba(210,170,90,.10) 45%,
    rgba(255,255,255,.04) 100%
  ) !important;
  box-shadow:0 0 0 1px rgba(210,170,90,.18) inset,0 10px 18px rgba(0,0,0,.18) !important;
}

.ts50-hs-row.is-winner:before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:4px;
  border-radius:14px 0 0 14px;
  background:rgba(210,170,90,.85);
}

/*
 * [MUDANÇA v1.2.9]
 * Medalhas para Top 3 (fundo + faixa lateral), sem aumentar a altura do card.
 * - #1 (gold) continua usando .is-winner (mantemos compatibilidade)
 * - #2 (silver) e #3 (bronze) recebem classes .medal-silver/.medal-bronze
 */

/* #1 Gold (reforço visual também na bolinha do rank) */
.ts50-hs-row.medal-gold .ts50-hs-rank{
  background:rgba(210,170,90,.18);
  border-color:rgba(210,170,90,.28);
}

/* #2 Silver */
.ts50-hs-row.medal-silver{
  position:relative;
  border-color:rgba(220,220,220,.20) !important;
  background:linear-gradient(90deg,
    rgba(220,220,220,.18) 0%,
    rgba(220,220,220,.08) 45%,
    rgba(255,255,255,.04) 100%
  ) !important;
  box-shadow:0 0 0 1px rgba(220,220,220,.10) inset,0 10px 18px rgba(0,0,0,.18) !important;
}

.ts50-hs-row.medal-silver:before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:4px;
  border-radius:14px 0 0 14px;
  background:rgba(220,220,220,.85);
}

.ts50-hs-row.medal-silver .ts50-hs-rank{
  background:rgba(220,220,220,.14);
  border-color:rgba(220,220,220,.22);
}

/* #3 Bronze */
.ts50-hs-row.medal-bronze{
  position:relative;
  border-color:rgba(205,127,50,.22) !important;
  background:linear-gradient(90deg,
    rgba(205,127,50,.18) 0%,
    rgba(205,127,50,.08) 45%,
    rgba(255,255,255,.04) 100%
  ) !important;
  box-shadow:0 0 0 1px rgba(205,127,50,.10) inset,0 10px 18px rgba(0,0,0,.18) !important;
}

.ts50-hs-row.medal-bronze:before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:4px;
  border-radius:14px 0 0 14px;
  background:rgba(205,127,50,.85);
}

.ts50-hs-row.medal-bronze .ts50-hs-rank{
  background:rgba(205,127,50,.14);
  border-color:rgba(205,127,50,.22);
}

.ts50-hs-rank{width:30px;height:30px;border-radius:999px;display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.12);font-weight:900;font-size:13px;flex:0 0 auto}

.ts50-hs-main{min-width:0;flex:1 1 auto;display:flex;flex-direction:column;gap:6px}

/*
 * IMPORTANTE (bug #1):
 * - flex-wrap permite que o badge do vencedor desça para a linha de baixo em telas estreitas
 *   sem esmagar o nome.
 */
.ts50-hs-line1{display:flex;align-items:center;gap:8px;min-width:0;flex-wrap:wrap}

.ts50-hs-name{min-width:0;flex:1 1 240px;font-weight:900;font-size:14px;line-height:1.1;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-decoration:none;color:inherit}

.ts50-hs-winner{display:none} /* [MUDANÇA v1.2.2] Badge do vencedor não é mais exibido (evita aumentar altura). */

.ts50-hs-line2{display:flex;align-items:center;gap:6px;flex-wrap:nowrap;min-width:0}


.ts50-hs-badge{flex:0 0 auto;font-size:10px;font-weight:800;padding:3px 7px;border-radius:999px;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);white-space:nowrap;
  max-width:92px;overflow:hidden;text-overflow:ellipsis}

.ts50-hs-meta{font-size:10px;opacity:.80;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1 1 auto}

.ts50-hs-right{display:flex;align-items:center;gap:6px;flex:0 0 auto}

/* Coluna de números (delta/pct OU votos) */
.ts50-hs-growth{display:flex;flex-direction:column;align-items:flex-end;line-height:1;gap:4px;min-width:44px}
.ts50-hs-delta{font-weight:900;font-size:12px}
.ts50-hs-pct{font-weight:800;font-size:11px;opacity:.82}

.ts50-hs-votes{display:flex;flex-direction:column;align-items:flex-end;line-height:1;gap:4px;min-width:44px}
.ts50-hs-votes strong{font-weight:900;font-size:14px}
.ts50-hs-votes span{font-weight:800;font-size:11px;opacity:.82}

/* Sparkline */
.ts50-hs-sparkwrap{display:flex;align-items:center;justify-content:flex-end;opacity:.92;max-width:76px;}
.ts50-hs-spark{color:rgba(255,255,255,.70);width:76px;height:auto;}

/*
 * [MUDANÇA v1.2.6] Cores do gráfico (sparkline)
 * - Verde quando "em alta"
 * - Vermelho quando "caindo"
 * Obs: usa "currentColor" no SVG, então basta mudar a cor do .ts50-hs-spark.
 */
.ts50-hs-row.trend-up .ts50-hs-spark{color:rgba(46,204,113,.95);}   /* verde */
.ts50-hs-row.trend-down .ts50-hs-spark{color:rgba(231,76,60,.95);}  /* vermelho */
.ts50-hs-row.trend-flat .ts50-hs-spark{color:rgba(255,255,255,.65);}/* neutro */

.ts50-hs-empty{padding:12px 10px;border-radius:12px;background:rgba(255,255,255,.04);border:1px dashed rgba(255,255,255,.18);opacity:.9;font-size:13px}

/* Responsivo */
@media (max-width: 420px){
  .ts50-hs{max-width:100%}
  .ts50-hs-right{gap:8px}
  .ts50-hs-growth,.ts50-hs-votes{min-width:56px}
  .ts50-hs-sparkwrap{display:none;} /* em telas pequenas, some o spark para sobrar espaço pro nome */
  .ts50-hs-name{flex-basis:260px}
}