/* /frontend/servers-list.css
   Stile dedicato per servers.html (Public User Servers)
*/

:root {
  --bg:#0b0e14;
  --panel:#111827;
  --border:rgba(148,163,184,.35);
  --text:#e5e7eb;
  --muted:#9ca3af;
  --accent:#f97316;
  --accent-soft:rgba(249,115,22,.14);
  --danger:#ef4444;
  --danger-soft:rgba(239,68,68,.18);
  --muted-soft:rgba(148,163,184,.18);
}

body.pd-dark.servers-page{
  margin:0;
  min-height:100vh;
  font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  font-size:15px;
  background:
    radial-gradient(1200px 600px at 0% 0%, rgba(249,115,22,.18), transparent 60%),
    radial-gradient(1000px 500px at 100% 0%, rgba(96,165,250,.20), transparent 55%),
    var(--bg);
  color:var(--text);
}

.servers-page .container{
  max-width: 1520px;
  margin: 80px auto 40px;
  padding: 0 18px 32px;
}

/* Card + filters */
.servers-page .card{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:14px;
  padding:18px 18px 20px;
  box-shadow:0 18px 45px rgba(15,23,42,.65);
}

.servers-page .servers-container h1{
  margin:0 0 4px;
  font-size:22px;
  display:flex;
  align-items:center;
  gap:8px;
}

.servers-page .servers-container p{
  margin:4px 0 14px;
  font-size:13px;
  color:var(--muted);
}

.servers-page .filters{
  display:flex;
  flex-wrap:wrap;
  gap:.6rem;
  align-items:center;
}

.servers-page .filters .pd-input{
  min-width:200px;
}

/* Table wrapper */
.servers-page .table-wrapper{
  margin-top:1rem;
  border-radius:10px;
  border:1px solid var(--border);
  background:#020617;
  overflow-x:auto;
}

.servers-page .pd-table{
  width:100%;
  border-collapse:collapse;
  font-size:13px;
}

.servers-page .pd-table th,
.servers-page .pd-table td{
  padding:8px 10px;
  border-bottom:1px solid rgba(30,64,175,.55);
  text-align:left;
  white-space:nowrap;
}

.servers-page .pd-table thead{
  background:#020617;
}

.servers-page .pd-table th{
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.03em;
  color:#9ca3af;
}

.servers-page .pd-table tbody tr:nth-child(even){
  background:rgba(15,23,42,.65);
}

.servers-page .pd-table tbody tr:hover{
  background:rgba(30,64,175,.45);
}

/* Action buttons */
.servers-page .btn-small{
  padding:4px 8px;
  font-size:12px;
  border-radius:6px;
}

.servers-page .btn-info{
  background:var(--accent-soft);
  border:1px solid var(--accent);
  color:var(--accent);
}

/* Responsivo */
@media (max-width:1200px){
  .servers-page .container{
    margin-top:70px;
  }
  .servers-page .filters{
    flex-direction:column;
    align-items:stretch;
  }
  .servers-page .filters .pd-input,
  .servers-page .filters .btn{
    width:100%;
  }
}

.hoster-link {
  color: #ffd27f;
  text-decoration: underline;
  cursor: pointer;
  font-weight: 500;
}

.hoster-link:hover {
  text-decoration: none;
  opacity: .85;
}

/* Lascia wrappare SOLO la colonna "SERVER NAME" */
.servers-page .pd-table th:nth-child(2),
.servers-page .pd-table td:nth-child(2){
  white-space: normal;
}

/* Mantieni address e actions compatti */
.servers-page .pd-table th:nth-child(4),
.servers-page .pd-table td:nth-child(4),
.servers-page .pd-table th:nth-child(11),
.servers-page .pd-table td:nth-child(11){
  white-space: nowrap;
}

/* Actions sticky a destra: anche se c'è scroll, i bottoni restano visibili */
.servers-page .pd-table th:last-child{
  position: sticky;
  right: 0;
  background: #020617;
  z-index: 3;
}

.servers-page .pd-table td:last-child{
  position: sticky;
  right: 0;
  background: #020617;
  z-index: 2;
  box-shadow: -10px 0 14px rgba(0,0,0,.35);
}

/* ===== My Servers: la colonna NAME è la 3ª, non la 2ª ===== */
.servers-page #myServersTable th:nth-child(3),
.servers-page #myServersTable td:nth-child(3){
  white-space: normal;
}

/* (opzionale) anche STOP REASON può andare a capo */
.servers-page #myServersTable th:nth-child(5),
.servers-page #myServersTable td:nth-child(5){
  white-space: normal;
}

/* Actions sticky già ok (last-child), ma assicuriamo nowrap */
.servers-page #myServersTable th:last-child,
.servers-page #myServersTable td:last-child{
  white-space: nowrap;
}

/* ===== Server Info Modal readability ===== */

.modal__backdrop{
  background: rgba(0,0,0,.70);
}

.modal__card{
  width: min(980px, 92vw);
  max-height: 82vh;
  display: flex;
  flex-direction: column;
  background: rgba(10,16,30,.92);
  border: 1px solid rgba(148,163,184,.22);
  border-radius: 14px;
  box-shadow: 0 18px 60px rgba(0,0,0,.6);
}

.modal__card h2, .modal__card h3{
  text-shadow: 0 1px 1px rgba(0,0,0,.55);
}

.modal__body--server{
  margin-top: 0.75rem;
  padding: 12px;
  border: 1px solid rgba(148,163,184,.16);
  background: rgba(2,6,23,.28);
  border-radius: 12px;
  overflow: auto;
  flex: 1 1 auto;
}

/* griglia sezioni: General | Runtime */
.srv-sections{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.srv-section{
  background: rgba(15,23,42,.55);
  border: 1px solid rgba(148,163,184,.16);
  border-radius: 12px;
  padding: 12px;
}

.srv-section--full{
  grid-column: 1 / -1;
}

.srv-section-title{
  margin: 0 0 10px;
  font-size: 14px;
  letter-spacing: .2px;
  color: #f1f5f9;
  display:flex;
  align-items:center;
  gap:8px;
}

.srv-kv{
  display: grid;
  grid-template-columns: 150px 1fr;
  gap: 6px 10px;
  font-size: 13px;
  line-height: 1.35;
}

.srv-k{
  color: rgba(203,213,225,.92);
  font-weight: 700;
}

.srv-v{
  color: #f1f5f9;
  word-break: break-word;
}

.srv-divider{
  height: 1px;
  background: rgba(148,163,184,.16);
  margin: 10px 0;
}

/* box liste stile "TSPG-like" */
.srv-list{
  margin-top: 6px;
  padding: 10px;
  border-radius: 12px;
  border: 1px solid rgba(148,163,184,.16);
  background: rgba(2,6,23,.35);
  max-height: 220px;
  overflow: auto;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  font-size: 12px;
  line-height: 1.35;
}

.srv-item{
  padding: 2px 0;
  border-bottom: 1px dashed rgba(148,163,184,.12);
}
.srv-item:last-child{ border-bottom: none; }

.srv-empty{ opacity: .85; color: rgba(203,213,225,.85); }

.srv-spoiler{
  padding: 2px 8px;
  border-radius: 8px;
  border: 1px solid rgba(148,163,184,.18);
  background: rgba(2,6,23,.45);
}

/* azioni sempre leggibili */
.modal__actions{
  border-top: 1px solid rgba(148,163,184,.14);
  padding-top: 10px;
  margin-top: 10px;
}

/* responsive */
@media (max-width: 900px){
  .srv-sections{ grid-template-columns: 1fr; }
  .srv-kv{ grid-template-columns: 130px 1fr; }
}

/* ===== Modal base (fix click + layering) ===== */
.modal{
  position: fixed;
  inset: 0;
  display: none;            /* hidden di default */
  align-items: center;
  justify-content: center;
  padding: 24px;
  z-index: 4000;
}

.modal.open{
  display: flex;
}

.modal__backdrop{
  position: absolute;
  inset: 0;
  z-index: 0;
}

.modal__card{
  position: relative;
  z-index: 1;               /* sopra al backdrop */
  pointer-events: auto;
}

/* ===== Wider public servers layout ===== */
body.pd-dark.servers-page{
  overflow-x: hidden;
}

.servers-page .container{
  width: min(1960px, calc(100vw - 24px));
  max-width: none;
  margin: 76px auto 36px;
  padding: 0 12px 28px;
}

.servers-page .pd-header{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:14px;
}

.servers-page .servers-hero-card{
  margin: 0 0 16px;
  max-width: none;
  width: 100%;
}

.servers-page .servers-container{
  width: 100%;
}

.servers-page .filters{
  display:grid;
  grid-template-columns: minmax(340px, 1.8fr) minmax(180px, .8fr) auto;
  gap: 10px;
  align-items:center;
}

.servers-page .filters .pd-input{
  width: 100%;
  min-width: 0;
}

.servers-page #systemCpuInfo{
  margin-top: 10px !important;
}

.servers-page .servers-table-shell{
  width: 100%;
  margin: 0;
  overflow-x: visible;
  border-radius: 12px;
}

.servers-page .servers-wide-table{
  width: 100%;
  table-layout: auto;
  font-size: 12.5px;
}

/* larghezze colonne */
.servers-page .servers-wide-table col.col-id{ width: 74px; }
.servers-page .servers-wide-table col.col-name{ width: auto; }
.servers-page .servers-wide-table col.col-players{ width: 104px; }
.servers-page .servers-wide-table col.col-hoster{ width: 110px; }
.servers-page .servers-wide-table col.col-address{ width: 180px; }
.servers-page .servers-wide-table col.col-iwad{ width: 110px; }
.servers-page .servers-wide-table col.col-start{ width: 176px; }
.servers-page .servers-wide-table col.col-uptime{ width: 100px; }
.servers-page .servers-wide-table col.col-last{ width: 178px; }
.servers-page .servers-wide-table col.col-cpu{ width: 106px; }
.servers-page .servers-wide-table col.col-mem{ width: 104px; }
.servers-page .servers-wide-table col.col-actions{ width: 126px; }

.servers-page .pd-table th,
.servers-page .pd-table td{
  padding: 7px 8px;
  vertical-align: top;
}

.servers-page .pd-table thead th{
  position: sticky;
  top: 0;
  z-index: 3;
  background: #020617;
}

/* niente tagli */
.servers-page .pd-table tbody td{
  overflow: visible;
  text-overflow: clip;
}

/* SOLO il nome server va a capo */
.servers-page .pd-table th:nth-child(2),
.servers-page .pd-table td:nth-child(2){
  white-space: normal;
}

.servers-page .pd-table td:nth-child(2) > div:first-child{
  display:block;
  line-height:1.28;
  word-break: break-word;
}

/* tutte le altre colonne compatte e leggibili */
.servers-page .pd-table th:nth-child(1),
.servers-page .pd-table td:nth-child(1),
.servers-page .pd-table th:nth-child(3),
.servers-page .pd-table td:nth-child(3),
.servers-page .pd-table th:nth-child(4),
.servers-page .pd-table td:nth-child(4),
.servers-page .pd-table th:nth-child(5),
.servers-page .pd-table td:nth-child(5),
.servers-page .pd-table th:nth-child(6),
.servers-page .pd-table td:nth-child(6),
.servers-page .pd-table th:nth-child(7),
.servers-page .pd-table td:nth-child(7),
.servers-page .pd-table th:nth-child(8),
.servers-page .pd-table td:nth-child(8),
.servers-page .pd-table th:nth-child(9),
.servers-page .pd-table td:nth-child(9),
.servers-page .pd-table th:nth-child(10),
.servers-page .pd-table td:nth-child(10),
.servers-page .pd-table th:nth-child(11),
.servers-page .pd-table td:nth-child(11),
.servers-page .pd-table th:nth-child(12),
.servers-page .pd-table td:nth-child(12){
  white-space: nowrap;
}

/* numeri/date più leggibili */
.servers-page .pd-table th:nth-child(1),
.servers-page .pd-table td:nth-child(1),
.servers-page .pd-table th:nth-child(7),
.servers-page .pd-table td:nth-child(7),
.servers-page .pd-table th:nth-child(8),
.servers-page .pd-table td:nth-child(8),
.servers-page .pd-table th:nth-child(9),
.servers-page .pd-table td:nth-child(9),
.servers-page .pd-table th:nth-child(10),
.servers-page .pd-table td:nth-child(10),
.servers-page .pd-table th:nth-child(11),
.servers-page .pd-table td:nth-child(11){
  font-variant-numeric: tabular-nums;
}

.servers-page .pd-table td:nth-child(5),
.servers-page .pd-table td:nth-child(7),
.servers-page .pd-table td:nth-child(8),
.servers-page .pd-table td:nth-child(9),
.servers-page .pd-table td:nth-child(10),
.servers-page .pd-table td:nth-child(11){
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  font-size: 12px;
}

.servers-page .runtime-line{
  display:none;
  margin-top:4px !important;
  color:#94a3b8 !important;
  font-size:11px !important;
  line-height:1.25 !important;
}

.servers-page .runtime-line [data-rt-players],
.servers-page .runtime-line [data-rt-map]{
  white-space: nowrap;
}

.servers-page .btn-small{
  min-width: 34px;
  padding: 4px 7px;
}

/* ===== Players column: compact TSPG-like bar + tooltip ===== */
.servers-page .pd-table td.sv-col-players,
.servers-page .pd-table th:nth-child(3){
  overflow: visible !important;
  text-overflow: clip !important;
  white-space: nowrap !important;
}

.servers-page .pd-table td.sv-col-players{
  position: relative;
  z-index: 1;
  padding-top: 6px;
  padding-bottom: 6px;
}

.servers-page .pd-table tbody tr:hover td.sv-col-players,
.servers-page .pd-table td.sv-col-players:focus-within{
  z-index: 5;
}

.pd-players-empty{
  color: #94a3b8;
  opacity: .85;
}

.pd-players-chip{
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 86px;
  height: 20px;
  border: 1px solid rgba(148,163,184,.28);
  border-radius: 999px;
  background: rgba(15,23,42,.92);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03);
  cursor: default;
  user-select: none;
  outline: none;
}

.pd-players-bar{
  position: absolute;
  inset: 2px;
  display: flex;
  gap: 1px;
  overflow: hidden;
  border-radius: 999px;
  z-index: 0;
}

.pd-players-seg{
  flex: 1 1 0;
  min-width: 0;
  background: rgba(255,255,255,.08);
}

.pd-players-seg.is-player{
  background: #ff6a2b;
}

.pd-players-seg.is-spectator{
  background: #57d5ff;
}

.pd-players-seg.is-bot{
  background: #b78cff;
}

.pd-players-count{
  position: relative;
  z-index: 1;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  font-size: 11.5px;
  font-weight: 800;
  line-height: 1;
  color: #ffffff;
  text-shadow: 0 1px 2px rgba(0,0,0,.85);
}

.pd-players-tooltip{
  position: absolute;
  left: calc(100% + 10px);
  top: 50%;
  transform: translateY(-50%) translateX(-4px);
  min-width: 154px;
  padding: 8px 10px;
  border-radius: 10px;
  border: 1px solid rgba(148,163,184,.24);
  background: rgba(3,7,18,.97);
  box-shadow: 0 14px 28px rgba(0,0,0,.45);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .14s ease, transform .14s ease, visibility .14s ease;
  z-index: 30;
}

.pd-players-tooltip::before{
  content: "";
  position: absolute;
  left: -5px;
  top: 50%;
  width: 10px;
  height: 10px;
  background: rgba(3,7,18,.97);
  border-left: 1px solid rgba(148,163,184,.24);
  border-bottom: 1px solid rgba(148,163,184,.24);
  transform: translateY(-50%) rotate(45deg);
}

.pd-players-chip:hover .pd-players-tooltip,
.pd-players-chip:focus-visible .pd-players-tooltip,
.pd-players-chip:focus .pd-players-tooltip{
  opacity: 1;
  visibility: visible;
  transform: translateY(-50%) translateX(0);
}

.pd-players-tip-row{
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: center;
  font-size: 12px;
  line-height: 1.25;
  color: #dbe6f3;
}

.pd-players-tip-row + .pd-players-tip-row{
  margin-top: 4px;
}

.pd-players-tip-row span{
  color: #a8b6c9;
}

.pd-players-tip-row strong{
  color: #ffffff;
  font-weight: 800;
}

/* actions sticky solo se serve davvero */
@media (min-width: 1650px){
  .servers-page .pd-table th:last-child,
  .servers-page .pd-table td:last-child{
    position: static;
    box-shadow: none;
  }
}

@media (max-width: 1649px){
  .servers-page .servers-table-shell{
    overflow-x: auto;
  }

  .servers-page .servers-wide-table{
    min-width: 1500px;
  }
}

/* tooltip players sopra su schermi più stretti */
@media (max-width: 1500px){
  .pd-players-tooltip{
    left: 50%;
    top: auto;
    bottom: calc(100% + 10px);
    transform: translateX(-50%) translateY(4px);
  }

  .pd-players-tooltip::before{
    left: 50%;
    top: auto;
    bottom: -6px;
    border-left: none;
    border-bottom: none;
    border-right: 1px solid rgba(148,163,184,.24);
    border-top: 1px solid rgba(148,163,184,.24);
    transform: translateX(-50%) rotate(45deg);
  }

  .pd-players-chip:hover .pd-players-tooltip,
  .pd-players-chip:focus-visible .pd-players-tooltip,
  .pd-players-chip:focus .pd-players-tooltip{
    transform: translateX(-50%) translateY(0);
  }
}

@media (max-width: 1200px){
  .servers-page .container{
    width: auto;
    margin-top: 70px;
    padding: 0 12px 24px;
  }

  .servers-page .filters{
    grid-template-columns: 1fr;
  }

  .servers-page .servers-table-shell{
    overflow-x: auto;
  }

  .servers-page .servers-wide-table{
    min-width: 1280px;
    table-layout: auto;
  }
}

/* ===== Sortable headers ===== */
.servers-page .pd-table thead th.is-sortable{
  cursor: pointer;
  user-select: none;
  -webkit-user-select: none;
  position: relative;
  transition: color .14s ease, background-color .14s ease, box-shadow .14s ease;
}

.servers-page .pd-table thead th.is-sortable:hover{
  color: #f8fafc;
  background: rgba(249,115,22,.10);
}

.servers-page .pd-table thead th.is-sortable:active{
  background: rgba(249,115,22,.16);
}

.servers-page .pd-table thead th.is-sortable:focus-visible{
  outline: 2px solid rgba(249,115,22,.65);
  outline-offset: -2px;
  color: #ffffff;
  background: rgba(249,115,22,.12);
}

/* header attivo */
.servers-page .pd-table thead th.is-sort-active{
  color: #ffffff;
  background: rgba(249,115,22,.14);
  box-shadow: inset 0 -2px 0 rgba(249,115,22,.95);
}

/* piccolo hint visivo sempre presente */
.servers-page .pd-table thead th.is-sortable::after{
  content: "↕";
  display: inline-block;
  margin-left: 6px;
  font-size: 11px;
  line-height: 1;
  opacity: .45;
  transform: translateY(-1px);
}

.servers-page .pd-table thead th.is-sortable:hover::after,
.servers-page .pd-table thead th.is-sort-active::after{
  opacity: .95;
}