*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* ── surfaces ── */
  --bg:           #0a0c0f;
  --bg-panel:     #0d1014;
  --bg-elev:      #11151b;
  --bg-elev2:     #161b23;
  --bg-input:     #0d1014;
  --glass:        rgba(13,16,20,0.92);

  /* ── borders ── */
  --line:         #1f2731;
  --line-2:       #2a3441;
  --line-strong:  #3a4455;

  /* ── text ── */
  --text:         #e6ebf2;
  --text-2:       #aab2c0;
  --muted:        #6b7484;
  --hint:         #4a525f;

  /* ── accent (primary interactive + live data) ── */
  --accent:       #00d49a;
  --accent-dim:   rgba(0,212,154,0.10);
  --accent-line:  rgba(0,212,154,0.28);
  --accent-glow:  0 0 0 3px rgba(0,212,154,0.12);

  /* ── red — kept for backward compat with JS inline styles ── */
  --red:          #ff5d6c;
  --red-2:        #ff8a94;
  --red-dim:      rgba(255,93,108,0.10);
  --red-dim-2:    rgba(255,93,108,0.16);
  --red-line:     rgba(255,93,108,0.25);
  --red-glow:     0 0 0 3px rgba(255,93,108,0.12);

  /* ── cyan aliases to accent for backward compat ── */
  --cyn:          #00d49a;
  --cyn-dim:      rgba(0,212,154,0.10);
  --cyn-line:     rgba(0,212,154,0.28);

  /* ── statuses ── */
  --ok:           #00d49a;
  --ok-dim:       rgba(0,212,154,0.10);
  --ok-line:      rgba(0,212,154,0.28);
  --warn:         #f5b042;
  --warn-dim:     rgba(245,176,66,0.10);
  --warn-line:    rgba(245,176,66,0.28);
  --danger:       #ff5d6c;
  --danger-dim:   rgba(255,93,108,0.10);
  --danger-line:  rgba(255,93,108,0.25);

  /* ── id type colors ── */
  --blue:         #6aa6ff;
  --blue-dim:     rgba(106,166,255,0.10);
  --indigo:       #b18cff;

  /* ── shape ── */
  --r:  3px;
  --r2: 5px;
  --r3: 8px;

  /* ── layout ── */
  --sb-w:      268px;
  --topbar-h:  52px;

  /* ── fonts ── */
  --font:'Inter',ui-sans-serif,-apple-system,system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
}

[data-theme="light"]{
  --bg:           #f2f5f9;
  --bg-panel:     #ffffff;
  --bg-elev:      #e8eef6;
  --bg-elev2:     #dce4f0;
  --bg-input:     #ffffff;
  --glass:        rgba(242,245,249,0.94);
  --line:         #dae1ec;
  --line-2:       #c5cfe0;
  --line-strong:  #a0b0c8;
  --text:         #141c2c;
  --text-2:       #374155;
  --muted:        #616d84;
  --hint:         #8896a8;
  --red-2:        #e0505e;
}

[data-theme="light"] body::before{ display:none }

[data-theme="light"] .cmd{
  background:#fff;
  border-color:rgba(0,0,0,.07);
  box-shadow:0 1px 3px rgba(0,0,0,.08);
}

html,body{
  height:100%;
  background:var(--bg);
  color:var(--text);
  font-family:var(--font);
  font-size:14px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}


::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:99px}
::-webkit-scrollbar-thumb:hover{background:var(--line-strong)}
::selection{background:rgba(0,212,154,0.18);color:var(--text)}

/* ═══════════ SHELL ═══════════ */
.app{
  position:relative;z-index:1;
  display:grid;
  grid-template-columns:var(--sb-w) 1fr;
  grid-template-rows:var(--topbar-h) 1fr;
  grid-template-areas:"topbar topbar" "sidebar main";
  min-height:100vh;
}

/* ═══════════ TOPBAR ═══════════ */
.topbar{
  grid-area:topbar;
  display:flex;align-items:center;gap:16px;
  padding:0 16px;
  border-bottom:1px solid var(--line);
  background:var(--bg-panel);
  position:sticky;top:0;z-index:50;
}

/* brand */
.brand{
  display:flex;align-items:center;gap:10px;
  cursor:pointer;user-select:none;
  text-decoration:none;
}
.brand-mark{
  width:22px;height:22px;
  position:relative;display:inline-flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.brand-mark::before{
  content:"";position:absolute;
  width:12px;height:12px;
  border:1.5px solid var(--accent);border-radius:2px;
  transform:rotate(45deg);
}
.brand-mark::after{display:none}
.brand-name{
  font-family:var(--mono);font-weight:600;font-size:13.5px;
  color:var(--text);letter-spacing:.02em;
}
.brand-name .x{color:var(--accent)}
.brand-tag{
  color:var(--muted);font-family:var(--font);font-size:12px;
  font-weight:400;padding-left:2px;
}
.brand-version{
  font-family:var(--mono);font-size:9.5px;
  padding:2px 6px;border-radius:3px;
  background:var(--bg-elev);color:var(--hint);border:1px solid var(--line);
  letter-spacing:.04em;flex-shrink:0;
}

.topbar-right{
  margin-left:auto;display:flex;align-items:center;gap:10px;
}
.topbar-meta{
  display:flex;align-items:center;gap:7px;
  font-family:var(--mono);font-size:11px;color:var(--muted);
}
.topbar-meta .led{
  width:5px;height:5px;border-radius:50%;background:var(--ok);display:inline-block;
  animation:ledpulse 2.8s ease-in-out infinite;flex-shrink:0;
}
@keyframes ledpulse{50%{opacity:.25}}
.topbar-btns{display:flex;align-items:center;gap:2px}

/* ═══════════ SIDEBAR ═══════════ */
.sidebar{
  grid-area:sidebar;
  background:var(--bg-panel);
  border-right:1px solid var(--line);
  display:flex;flex-direction:column;
  overflow:hidden;
  position:sticky;
  top:var(--topbar-h);
  height:calc(100vh - var(--topbar-h));
  transition:transform .22s ease,opacity .2s ease;
}
.sidebar-scroll{flex:1;overflow-y:auto;padding:6px 0 8px}

/* section label */
.s-label{
  display:flex;align-items:center;gap:5px;
  font-size:10px;font-weight:600;
  color:var(--muted);text-transform:uppercase;letter-spacing:.07em;
  padding:10px 14px 4px;font-family:var(--font);
}
.s-label .s-count{
  margin-left:auto;font-family:var(--mono);font-size:9.5px;
  padding:1px 6px;border-radius:99px;
  background:var(--bg-elev);border:1px solid var(--line);color:var(--hint);
}
.s-empty{padding:8px 16px 14px;font-size:11.5px;color:var(--hint);line-height:1.65}
.s-empty .k{font-family:var(--mono);color:var(--muted);font-size:11px}
.side-group{padding:10px 8px 4px}
.side-group+.side-group{padding-top:2px}

/* history item */
.hi{
  display:flex;align-items:center;gap:8px;
  padding:8px 8px;border-radius:var(--r2);
  margin:0 4px 2px;cursor:pointer;
  border:1px solid transparent;
  transition:background .1s,border-color .1s;
}
.hi:hover{background:var(--bg-elev);border-color:var(--line)}
.hi.active{background:var(--bg-elev);border-color:var(--line)}
.hi-dot{
  width:7px;height:7px;border-radius:50%;background:var(--hint);
  flex-shrink:0;transition:background .2s,box-shadow .2s;
}
.hi-dot.up{background:var(--ok);box-shadow:0 0 0 2.5px rgba(0,212,154,.14)}
.hi-dot.down{background:var(--danger);box-shadow:0 0 0 2.5px rgba(255,93,108,.14)}
.hi-info{flex:1;min-width:0}
.hi-name{font-size:12.5px;font-weight:500;color:var(--text-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hi-sub{font-size:10.5px;color:var(--hint);font-family:var(--mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}
.hi-actions{display:flex;align-items:center;gap:1px;flex-shrink:0}
.hi-pin,.hi-del{
  border:none;background:transparent;color:var(--hint);cursor:pointer;
  padding:3px;border-radius:3px;font-size:12px;
  opacity:0;transition:opacity .1s,color .1s;
}
.hi:hover .hi-pin,.hi:hover .hi-del{opacity:1}
.hi-pin:hover{color:var(--accent)}
.hi-pin.pinned{color:var(--accent);opacity:1}
.hi.pinned .hi-pin{color:var(--accent);opacity:1}
.hi-del:hover{color:var(--danger)}

/* sidebar footer */
.sidebar-foot{padding:10px 10px 12px;border-top:1px solid var(--line)}
.sidebar-foot-btns{display:flex;gap:4px}
.sidebar-foot-btns .btn-clear{flex:1;justify-content:center}

/* ═══════════ MAIN ═══════════ */
.main{
  grid-area:main;
  overflow-y:auto;
  padding:28px 32px 80px;
  max-width:100%;min-width:0;
}

/* ═══════════ COMMAND BAR ═══════════ */
.cmd{
  position:relative;z-index:10;
  background:var(--bg-panel);
  border:1px solid var(--line);
  border-radius:var(--r3);
  padding:16px 18px;
  margin-bottom:24px;
}
.cmd-head{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.cmd-label{
  font-size:10px;font-weight:500;
  color:var(--hint);text-transform:uppercase;letter-spacing:.12em;
  font-family:var(--mono);
}
.cmd-kbd{
  margin-left:auto;display:inline-flex;gap:3px;align-items:center;
  font-family:var(--mono);font-size:10px;color:var(--hint);
}
.cmd-kbd kbd{
  display:inline-block;padding:2px 5px;
  border:1px solid var(--line-2);border-radius:3px;
  background:var(--bg-elev);
  font-family:var(--mono);font-size:10px;color:var(--muted);
}

/* input */
.input-row{display:flex;gap:6px;align-items:stretch}
.input-wrap{
  flex:1;position:relative;display:flex;align-items:center;
  background:var(--bg-input);
  border:1px solid var(--line-2);border-radius:var(--r2);
  transition:border-color .15s,box-shadow .15s;
}
.input-wrap:focus-within{border-color:var(--accent-line);box-shadow:var(--accent-glow)}
.input-wrap > i.lead{padding:0 4px 0 12px;color:var(--hint);font-size:14px}
.input-row input{
  flex:1;background:transparent;border:none;outline:none;
  color:var(--text);font-size:14px;font-family:var(--mono);
  padding:12px 10px 12px 8px;letter-spacing:-.01em;
}
.input-row input::placeholder{color:var(--hint);font-family:var(--mono)}
.input-clr{
  background:transparent;border:none;color:var(--hint);cursor:pointer;
  padding:4px;margin-right:6px;border-radius:3px;font-size:13px;
  flex-shrink:0;display:none;align-items:center;justify-content:center;
  transition:color .1s;
}
.input-clr:hover{color:var(--text-2)}
.input-wrap.has-val .input-clr{display:inline-flex}

/* ═══════════ SEARCH DROPDOWN ═══════════ */
.search-box{position:relative}
#searchDropdown{
  position:absolute;left:0;right:0;top:100%;
  background:var(--bg-elev);
  border:1px solid var(--line-2);
  border-radius:0 0 var(--r2) var(--r2);
  max-height:300px;overflow-y:auto;
  box-shadow:0 20px 50px rgba(0,0,0,.65),0 4px 12px rgba(0,0,0,.3);
  z-index:200;
}
.dd-item{
  padding:10px 14px;cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;gap:12px;
  border-bottom:1px solid var(--line);font-size:13px;
  transition:background .08s;
}
.dd-item:last-child{border-bottom:none}
.dd-item:hover,.dd-item.dd-focused{background:var(--bg-elev2)}
.dd-name{font-weight:500;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text)}
.dd-meta{font-size:11px;color:var(--muted);white-space:nowrap;font-family:var(--mono)}
.dd-msg{color:var(--muted);cursor:default;font-size:13px;padding:10px 14px;font-family:var(--mono)}
.dd-filter{
  display:flex;align-items:center;gap:4px;
  padding:8px 12px;border-bottom:1px solid var(--line);
  background:var(--bg-panel);flex-wrap:wrap;
}
.dd-f-label{
  font-family:var(--mono);font-size:10px;color:var(--hint);
  text-transform:uppercase;letter-spacing:.08em;margin-right:4px;flex-shrink:0;
}
.dd-f-btn{
  background:transparent;border:1px solid var(--line);border-radius:4px;
  color:var(--muted);font-family:var(--mono);font-size:10.5px;
  padding:2px 7px;cursor:pointer;
  transition:background .08s,color .08s,border-color .08s;
}
.dd-f-btn:hover{color:var(--text-2);border-color:var(--line-2)}
.dd-f-btn.active{background:var(--accent-dim);color:var(--accent);border-color:var(--accent-line)}

/* ═══════════ STATUS BANNER ═══════════ */
.status{
  padding:9px 13px;border-radius:var(--r2);font-size:12.5px;
  display:flex;align-items:center;gap:8px;
  margin-top:10px;
  border:1px solid var(--line);background:var(--bg-elev);color:var(--text-2);
  font-family:var(--mono);
}
.status i{font-size:14px}
.status.loading{border-color:var(--accent-line);color:var(--accent);background:var(--accent-dim)}
.status.error{border-color:var(--danger-line);color:var(--danger);background:var(--danger-dim)}
.status.ok{border-color:var(--ok-line);color:var(--ok);background:var(--ok-dim)}
.status.warn{border-color:var(--warn-line);color:var(--warn);background:var(--warn-dim)}

/* progress bar */
.cmd-progress{
  position:absolute;left:0;bottom:0;height:2px;width:0%;
  background:linear-gradient(90deg,transparent,var(--accent),#1adfa6);
  border-radius:0 2px 2px 0;
  transition:width .1s linear;
}

/* ═══════════ BUTTONS ═══════════ */
.btn{
  padding:9px 14px;border-radius:var(--r2);
  border:1px solid var(--line-2);background:var(--bg-elev);
  color:var(--text-2);font-size:13px;font-weight:500;font-family:var(--font);
  cursor:pointer;display:inline-flex;align-items:center;gap:6px;
  white-space:nowrap;letter-spacing:-.01em;
  transition:background .12s,border-color .12s,color .12s;
}
.btn:hover{background:var(--bg-elev2);border-color:var(--line-strong);color:var(--text)}
.btn:active{opacity:.82}
.btn i{font-size:14px}
.btn.primary{background:var(--accent);color:#052018;border-color:var(--accent);font-weight:600}
.btn.primary:hover{background:#1adfa6;border-color:#1adfa6}
.btn.ghost{background:transparent;border-color:transparent}
.btn.ghost:hover{background:var(--bg-elev);border-color:var(--line)}
.btn.sm{padding:6px 10px;font-size:12px}
.btn.sm i{font-size:12px}
.btn.ico{padding:9px;aspect-ratio:1;justify-content:center}
.row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}

/* ═══════════ TAB BAR ═══════════ */
.tab-bar{
  display:flex;gap:0;
  border-bottom:1px solid var(--line);
  margin-bottom:26px;
  position:sticky;top:0;z-index:5;
  background:var(--bg);
  padding-top:4px;
}
.tab-btn{
  padding:11px 16px;border:none;background:transparent;
  color:var(--muted);font-size:13px;font-weight:500;cursor:pointer;
  display:flex;align-items:center;gap:6px;
  border-bottom:2px solid transparent;margin-bottom:-1px;
  transition:color .12s,border-color .12s;font-family:var(--font);
  letter-spacing:-.01em;
}
.tab-btn:hover{color:var(--text-2)}
.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}
.tab-btn i{font-size:13px;opacity:.6;transition:opacity .12s}
.tab-btn.active i{opacity:1}
.panel{display:none}.panel.active{display:block;animation:fadeIn .15s ease}
@keyframes fadeIn{from{opacity:0;translate:0 3px}to{opacity:1;translate:none}}

/* ═══════════ METRIC CARDS ═══════════ */
.mgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-bottom:16px}
.hero-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:10px}

.mc{
  background:var(--bg-panel);
  border:1px solid var(--line);
  border-radius:var(--r2);
  padding:14px 16px;
  overflow:hidden;
  transition:transform .12s ease,border-color .15s,box-shadow .12s ease;
}
.mc:hover{border-color:var(--line-2)}
.mc .ml{
  font-size:10.5px;font-weight:500;color:var(--muted);
  text-transform:uppercase;letter-spacing:.12em;margin-bottom:8px;
  font-family:var(--mono);display:flex;align-items:center;justify-content:space-between;
}
.mc .mv{
  font-size:22px;font-weight:500;color:var(--text);
  letter-spacing:-.02em;line-height:1.05;font-family:var(--mono);
}
.mc .mv.g{color:var(--accent)}
.mc .mv.b{color:var(--text)}
.mc .mv.warn{color:var(--warn)}
.mc .mv.sm{font-size:13px;font-family:var(--mono);letter-spacing:-.01em;font-weight:500;color:var(--text-2)}
.mc .ms{font-size:11px;color:var(--hint);margin-top:5px;font-family:var(--mono)}
.mv-suffix{font-size:13px;color:var(--muted);font-weight:400;letter-spacing:0}

.mc.hero{padding:18px 20px}
.mc.hero .mv{font-size:36px;letter-spacing:-.03em;line-height:1}
.mc.hero .mv-suffix{font-size:16px}
.mc.hero .ms{margin-top:6px;font-size:11px}
.mc.hero .spark-wrap{margin:12px -20px -18px}

.ov-section{margin-bottom:22px}

/* ═══════════ SECTION HEADER ═══════════ */
.sec{
  font-size:11px;font-weight:600;
  color:var(--text-2);text-transform:uppercase;letter-spacing:.07em;
  margin:0 0 10px;display:flex;align-items:center;gap:10px;
  font-family:var(--font);
}
.sec::after{content:'';flex:1;height:1px;background:var(--line)}

/* ═══════════ INFO TABLE ═══════════ */
.itbl{
  width:100%;border-collapse:separate;border-spacing:0;
  border:1px solid var(--line);border-radius:var(--r2);overflow:hidden;
  background:var(--bg-panel);margin-bottom:16px;
}
.ov-section .itbl{margin-bottom:0}
.itbl tr:not(:last-child) td{border-bottom:1px solid var(--line)}
.itbl td{padding:10px 14px;font-size:13px;vertical-align:top}
.itbl td:first-child{color:var(--muted);width:36%;white-space:nowrap;font-size:12.5px}
.itbl td:last-child{font-family:var(--mono);font-size:12.5px;word-break:break-all;color:var(--text-2)}
.itbl .td-text{font-family:var(--font);color:var(--text-2)}

/* ═══════════ COPY ROW ═══════════ */
.cprow{
  display:flex;align-items:center;justify-content:space-between;
  background:var(--bg-panel);border:1px solid var(--line);border-radius:var(--r2);
  padding:10px 13px;font-family:var(--mono);font-size:12.5px;
  margin-bottom:6px;cursor:pointer;gap:10px;
  transition:border-color .12s,background .12s;
}
.cprow:hover{border-color:var(--accent-line);background:var(--accent-dim)}
.cprow:hover .cpcopy{color:var(--accent)}
.cprow .cplabel{
  font-size:10px;font-weight:600;
  text-transform:uppercase;letter-spacing:.10em;color:var(--hint);
  flex-shrink:0;margin-right:6px;
  padding:1px 5px;border-radius:3px;
  background:var(--bg-elev);border:1px solid var(--line);
}
.cprow .cpval{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-2)}
.cprow .cpcopy{color:var(--hint);font-size:14px;flex-shrink:0;transition:color .1s}

/* ═══════════ PLAYER TABLE ═══════════ */
.ptbl{
  width:100%;border-collapse:separate;border-spacing:0;
  border:1px solid var(--line);border-radius:var(--r2);overflow:hidden;
  font-size:12.5px;margin-bottom:12px;background:var(--bg-panel);
}
.ptbl thead tr{background:var(--bg-elev)}
.ptbl th{
  padding:9px 14px;text-align:left;font-size:10.5px;
  color:var(--hint);font-weight:500;text-transform:uppercase;letter-spacing:.12em;
  border-bottom:1px solid var(--line);font-family:var(--mono);
}
.ptbl td{padding:10px 14px;border-bottom:1px solid var(--line);color:var(--text-2)}
.ptbl tbody tr:last-child td{border-bottom:none}
.ptbl tbody tr{transition:background .08s}
.ptbl tbody tr:hover{background:var(--bg-elev2)}
.ping-ok{color:var(--ok)}
.ping-mid{color:var(--warn)}
.ping-bad{color:var(--danger)}

/* ═══════════ BADGES ═══════════ */
.badge{
  display:inline-flex;align-items:center;gap:5px;
  font-size:11px;font-weight:600;font-family:var(--mono);
  padding:3px 9px;border-radius:99px;
  letter-spacing:.05em;text-transform:uppercase;
}
.badge.online{background:var(--ok-dim);color:var(--ok);border:1px solid var(--ok-line)}
.badge.online::before{
  content:'';width:5px;height:5px;border-radius:50%;background:var(--ok);
  animation:ledpulse 1.6s ease-in-out infinite;
}
.badge.offline{background:var(--danger-dim);color:var(--danger);border:1px solid var(--danger-line)}
.badge.offline::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--danger)}
.badge.cached{background:var(--warn-dim);color:var(--warn);border:1px solid var(--warn-line)}
.badge.cached::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--warn)}

.partial-notice{
  display:flex;align-items:center;gap:8px;
  background:var(--warn-dim);border:1px solid var(--warn-line);border-radius:var(--r2);
  padding:10px 14px;margin-bottom:14px;
  font-family:var(--mono);font-size:12px;color:var(--warn);
}

/* ═══════════ ID BADGES ═══════════ */
.id-badge{
  display:inline-flex;align-items:center;font-family:var(--mono);
  font-size:10px;font-weight:500;padding:1px 7px;border-radius:99px;margin-right:3px;
  border:1px solid var(--line);background:var(--bg-elev);color:var(--muted);
  letter-spacing:.04em;text-transform:uppercase;
}
.id-badge.steam{border-color:rgba(106,166,255,.28);color:var(--blue);background:var(--blue-dim)}
.id-badge.discord{border-color:rgba(177,140,255,.28);color:var(--indigo);background:rgba(177,140,255,.08)}
.id-badge.license{border-color:var(--accent-line);color:var(--accent);background:var(--accent-dim)}

/* ═══════════ RESOURCE TAGS ═══════════ */
.tag-wrap{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:0}
.tag{
  font-family:var(--mono);font-size:11.5px;font-weight:500;
  padding:4px 10px;border-radius:var(--r);
  background:var(--bg-elev);border:1px solid var(--line);color:var(--muted);
  transition:border-color .1s,color .1s,background .1s;
}
.tag:hover{border-color:var(--line-2);color:var(--text-2);background:var(--bg-elev2)}
.tag.core{color:var(--accent);border-color:var(--accent-line);background:var(--accent-dim)}
.tag.framework{color:var(--blue);border-color:rgba(106,166,255,.25);background:var(--blue-dim)}
.tag.script{color:var(--indigo);border-color:rgba(177,140,255,.18)}

/* ═══════════ ENDPOINT ITEMS ═══════════ */
.ep-item{margin-bottom:12px}
.ep-item:last-child{margin-bottom:0}
.ep-item-head{display:flex;align-items:center;gap:8px;margin-bottom:6px;flex-wrap:wrap}
.ep-item-chips{display:flex;gap:4px;flex-wrap:wrap}
.ep-hdr{
  background:var(--bg-panel);border:1px solid var(--line);border-radius:var(--r2);
  padding:12px 14px;margin-bottom:12px;
  display:flex;align-items:center;gap:12px;flex-wrap:wrap;
}
.ep-hdr-l{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.ep-addr{font-family:var(--mono);font-size:13px;font-weight:500;color:var(--accent)}
.ep-actions{margin-left:auto;display:flex;gap:6px}
.avail-chip{
  display:inline-flex;align-items:center;gap:3px;
  font-family:var(--mono);font-size:10px;font-weight:500;
  padding:2px 7px;border-radius:99px;letter-spacing:.02em;
}
.avail-chip i{font-size:11px}
.avail-chip.no{background:var(--bg-elev);color:var(--hint);border:1px solid var(--line)}
.avail-chip.err{background:var(--danger-dim);color:var(--danger);border:1px solid var(--danger-line)}

/* ═══════════ MISC ═══════════ */
.divider{height:1px;background:var(--line);margin:20px 0}
.empty{
  text-align:center;padding:48px 24px;color:var(--hint);
  background:var(--bg-panel);border:1px solid var(--line);border-radius:var(--r2);
}
.empty i{font-size:28px;display:block;margin-bottom:10px;color:var(--muted)}
.empty p{font-size:12px;font-family:var(--mono);letter-spacing:.02em}

/* ═══════════ PLAYER SEARCH ═══════════ */
.player-block{margin-bottom:0}
.player-search{
  display:flex;align-items:center;gap:8px;
  background:var(--bg-input);border:1px solid var(--line-2);border-radius:var(--r2);
  padding:0 10px;margin-bottom:10px;
  transition:border-color .15s,box-shadow .15s;
}
.player-search:focus-within{border-color:var(--accent-line);box-shadow:var(--accent-glow)}
.player-search i.lead{color:var(--hint);font-size:13px}
.player-search input{
  flex:1;background:transparent;border:none;outline:none;
  color:var(--text);font-size:13px;font-family:var(--mono);
  padding:10px 4px;letter-spacing:-.01em;
}
.player-search input::placeholder{color:var(--hint)}
.player-search .pc{font-family:var(--mono);font-size:11px;color:var(--hint);letter-spacing:.02em;flex-shrink:0}
.player-search .clr{
  background:transparent;border:none;color:var(--hint);cursor:pointer;
  padding:2px;border-radius:3px;font-size:13px;display:none;transition:color .1s;
}
.player-search .clr:hover{color:var(--accent)}
.player-search.has-q .clr{display:inline-flex}
.ptbl tbody tr.hidden{display:none}
.player-empty{
  padding:20px 14px;text-align:center;
  color:var(--hint);font-family:var(--mono);font-size:12px;
  border:1px dashed var(--line-2);border-radius:var(--r2);display:none;
}
.player-search.no-match ~ .ptbl{display:none}
.player-search.no-match ~ .player-empty{display:block}

/* ═══════════ WELCOME ═══════════ */
.welcome{max-width:520px;margin:60px auto 40px;text-align:center;padding:0 24px}
.welcome i.big{font-size:28px;color:var(--accent)}
.welcome h1{font-size:26px;font-weight:600;color:var(--text);letter-spacing:-.03em;margin-bottom:10px}
.welcome p{font-size:14.5px;color:var(--text-2);line-height:1.7;max-width:380px;margin:0 auto}
.welcome code{font-family:var(--mono);color:var(--accent);background:var(--accent-dim);padding:1px 6px;border-radius:3px;font-size:12.5px}
.welcome-blurb{font-size:11.5px;color:var(--hint);line-height:1.6;max-width:420px;margin:18px auto 0;padding-top:14px;border-top:1px solid var(--line)}
.site-footer{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:12px 24px;padding:16px 24px;border-top:1px solid var(--line);font-size:11px;color:var(--hint)}
.site-footer nav{display:flex;gap:16px}
.site-footer a{color:var(--muted);text-decoration:none}
.site-footer a:hover{color:var(--text)}
.fp-row{display:flex;flex-wrap:wrap;gap:5px;justify-content:center;margin-top:22px}
.fp{
  font-family:var(--mono);font-size:11px;font-weight:500;
  padding:4px 11px;border-radius:99px;
  background:var(--bg-panel);border:1px solid var(--line);color:var(--muted);
  display:inline-flex;align-items:center;gap:5px;
}
.fp::before{content:'';width:4px;height:4px;border-radius:50%;background:var(--accent)}

/* ═══════════ SPARKLINE ═══════════ */
.spark-wrap{margin:10px -16px -14px;border-top:1px solid var(--line);overflow:hidden;display:block}
.spark{display:block;width:100%;height:28px}

/* ═══════════ SKELETON ═══════════ */
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.skeleton{
  background:linear-gradient(90deg,var(--bg-elev) 25%,var(--bg-elev2) 50%,var(--bg-elev) 75%);
  background-size:200% 100%;
  animation:shimmer 1.5s ease infinite;
  border-radius:4px;
}

/* ═══════════ SPIN ═══════════ */
.spin{animation:spin .9s linear infinite;display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}

/* ═══════════ AUTO-REFRESH ═══════════ */
.auto-refresh{
  display:inline-flex;align-items:center;gap:2px;
  background:var(--bg-elev);border:1px solid var(--line);
  border-radius:var(--r2);padding:2px;
  font-family:var(--mono);font-size:10.5px;
}
.auto-refresh .ar-label{padding:0 7px 0 5px;color:var(--hint);text-transform:uppercase;letter-spacing:.08em}
.auto-refresh button{
  background:transparent;border:none;color:var(--muted);
  font-family:var(--mono);font-size:10.5px;font-weight:500;
  padding:3px 8px;border-radius:5px;cursor:pointer;
  transition:background .1s,color .1s;
}
.auto-refresh button:hover{color:var(--text)}
.auto-refresh button.active{background:var(--accent-dim);color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent-line)}

/* ═══════════ SHORTCUTS OVERLAY ═══════════ */
.kbd-overlay{
  position:fixed;inset:0;z-index:80;
  background:rgba(0,0,0,0.72);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  display:none;align-items:center;justify-content:center;
}
.kbd-overlay.show{display:flex;animation:fadeIn .12s ease}
.kbd-panel{
  width:min(420px,92vw);
  background:var(--bg-elev);
  border:1px solid var(--line-2);border-radius:var(--r3);
  padding:18px 20px;
  box-shadow:0 32px 80px rgba(0,0,0,.65),0 4px 16px rgba(0,0,0,.35);
}
.kbd-head{display:flex;align-items:center;gap:9px;margin-bottom:14px}
.kbd-head h3{font-size:14px;font-weight:600;color:var(--text);letter-spacing:-.02em}
.kbd-head .kbd-icon{
  width:26px;height:26px;border-radius:6px;
  background:var(--accent-dim);border:1px solid var(--accent-line);
  display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:13px;
}
.kbd-close{
  margin-left:auto;background:transparent;border:none;
  color:var(--muted);cursor:pointer;font-size:16px;padding:2px;
  border-radius:3px;transition:color .1s;
}
.kbd-close:hover{color:var(--text)}
.kbd-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:8px 0;border-bottom:1px solid var(--line);font-size:12.5px;
}
.kbd-row:last-child{border-bottom:none}
.kbd-row .desc{color:var(--text-2);letter-spacing:-.01em}
.kbd-row .keys{display:inline-flex;gap:3px;align-items:center}
.kbd-row .keys kbd{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:22px;padding:2px 6px;font-family:var(--mono);font-size:10px;font-weight:500;
  color:var(--text-2);background:var(--bg-elev2);
  border:1px solid var(--line-2);border-radius:4px;
}
.kbd-row .keys .sep{font-family:var(--mono);font-size:10px;color:var(--hint);padding:0 1px}

/* ═══════════ RESULTS HEADER ═══════════ */
.results-hdr{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:18px}
.results-hdr-name{
  font-size:20px;font-weight:600;letter-spacing:-.03em;
  color:var(--text);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.results-hdr-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.results-hdr-players{font-family:var(--mono);font-size:12px;color:var(--muted)}

/* ═══════════ MOBILE SIDEBAR BACKDROP ═══════════ */
.sidebar-backdrop{display:none}

/* ═══════════ DESKTOP SIDEBAR COLLAPSE ═══════════ */
.app.no-sidebar{grid-template-columns:0 1fr}
.app.no-sidebar .sidebar{transform:translateX(-110%);opacity:0;pointer-events:none}

/* ═══════════ HISTORY GRAPH ═══════════ */
.history-section{margin-bottom:0}
.hgraph-wrap{
  background:var(--bg-panel);border:1px solid var(--line);
  border-radius:10px;padding:14px 16px;
}
.hgraph-stats{
  display:flex;align-items:center;gap:18px;
  font-size:12px;color:var(--muted);margin-bottom:10px;
}
.hgraph-stats b{color:var(--text);font-weight:600}
.hgraph-pts{margin-left:auto;color:var(--hint);font-family:var(--mono);font-size:11px}
.hgraph-svg{width:100%;height:56px;display:block}
.hgraph-times{
  display:flex;justify-content:space-between;
  font-size:10px;color:var(--hint);font-family:var(--mono);margin-top:6px;
}
/* Active state for the Watch button */
button[id^="watchBtn"].active{color:var(--cyn);border-color:var(--cyn)}

/* ═══════════ TOAST ═══════════ */
.toast{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(12px);
  background:var(--bg-elev2);border:1px solid var(--line-2);
  color:var(--text-2);font-family:var(--mono);font-size:12.5px;
  padding:8px 18px;border-radius:99px;
  box-shadow:0 8px 24px rgba(0,0,0,.5);
  opacity:0;transition:opacity .2s,transform .2s;
  pointer-events:none;z-index:200;white-space:nowrap;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.toast-ok{border-color:var(--ok-line);color:var(--ok)}
.toast.toast-error{border-color:var(--danger-line);color:var(--danger)}
.toast.toast-warn{border-color:var(--warn-line);color:var(--warn)}

/* ═══════════ SORTABLE TABLE HEADERS ═══════════ */
.ptbl th.sortable{cursor:pointer;user-select:none;transition:color .1s}
.ptbl th.sortable:hover{color:var(--text-2)}
.ptbl th[data-sort="asc"]::after{content:' ↑';color:var(--accent)}
.ptbl th[data-sort="desc"]::after{content:' ↓';color:var(--accent)}

/* ═══════════ HISTORY FILTER ═══════════ */
.hist-filter{
  display:flex;align-items:center;gap:6px;
  margin:6px 8px 2px;
  background:var(--bg-input);border:1px solid var(--line);
  border-radius:var(--r2);padding:0 8px;
  transition:border-color .15s;
}
.hist-filter:focus-within{border-color:var(--accent-line)}
.hist-filter i{color:var(--hint);font-size:12px;flex-shrink:0}
.hist-filter input{
  flex:1;background:transparent;border:none;outline:none;
  color:var(--text);font-size:12px;font-family:var(--mono);
  padding:7px 4px;
}
.hist-filter input::placeholder{color:var(--hint)}

/* ═══════════ PREFERS-REDUCED-MOTION ═══════════ */
@media (prefers-reduced-motion: reduce){
  .led,.badge.online::before{animation:none}
  .skeleton{animation:none;background:var(--bg-elev2)}
  .spin{animation:none}
  .panel.active{animation:none}
  .toast{transition:opacity .1s}
  .sidebar,.app.no-sidebar .sidebar{transition:none}
  .cmd-progress{transition:none}
  .welcome-ring,.mc.anim-in,.fp{animation:none;opacity:1;transform:none}
  #welcomeCanvas{display:none}
  .tab-indicator{transition:none}
  .mc{transition:border-color .15s}
  .type-cursor,.hi.hi-enter,.hi.hi-exit{animation:none}
  .cmd{backdrop-filter:none;-webkit-backdrop-filter:none}
}

/* ═══════════ RESPONSIVE ═══════════ */
@media (max-width:900px){
  .app{
    grid-template-columns:1fr;
    grid-template-rows:var(--topbar-h) 1fr;
    grid-template-areas:"topbar" "main";
  }
  .sidebar{
    position:fixed;left:0;top:var(--topbar-h);bottom:0;
    z-index:50;height:calc(100vh - var(--topbar-h));
    width:var(--sb-w);max-width:88vw;
    transform:translateX(-110%);
    transition:transform .22s ease;
    box-shadow:6px 0 32px rgba(0,0,0,.7);
  }
  .app.sidebar-open .sidebar{transform:translateX(0);opacity:1;pointer-events:auto}
  .sidebar-backdrop{
    position:fixed;inset:0;z-index:49;
    background:rgba(0,0,0,0.62);
    backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);
  }
  .app.sidebar-open .sidebar-backdrop{display:block}
  .main{padding:18px 16px 64px}
  .brand-tag{display:none}
  .hero-grid{grid-template-columns:1fr 1fr}
  .ptbl th:nth-child(4),.ptbl td:nth-child(4){display:none}
}

/* ═══════════ SERVER BROWSER ═══════════ */
.sb-section-head{
  display:flex;align-items:center;gap:12px;
  margin-bottom:16px;
}
.sb-section-title{
  display:flex;align-items:center;gap:8px;
  font-size:16px;font-weight:600;letter-spacing:-.02em;color:var(--text);
}
.sb-section-title i{color:var(--accent);font-size:16px}
.sb-panel{
  background:var(--bg-panel);
  border:1px solid var(--line);
  border-radius:var(--r2);
  overflow:hidden;
}
.sb-toolbar{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.sb-search{flex:1;min-width:160px;background:var(--bg-input);border:1px solid var(--line);border-radius:var(--r);padding:7px 11px;color:var(--text);font-family:var(--mono);font-size:12px;outline:none}
.sb-search:focus{border-color:var(--accent-line);box-shadow:var(--accent-glow)}
.sb-toolbar select{background:var(--bg-input);border:1px solid var(--line);border-radius:var(--r);padding:7px 10px;color:var(--text);font-family:var(--mono);font-size:12px;outline:none;cursor:pointer}
.sb-count{font-family:var(--mono);font-size:10px;color:var(--hint);margin-left:auto;white-space:nowrap}
.sb-row{display:flex;align-items:center;gap:12px;padding:11px 16px;border-bottom:1px solid var(--line);transition:background 0.1s}
.sb-row:hover{background:var(--bg-elev)}
.sb-name{flex:1;font-size:13px;font-weight:500;color:var(--text);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sb-meta{display:flex;align-items:center;gap:8px;flex-shrink:0}
.sb-flag{font-size:14px}
.sb-players{font-family:var(--mono);font-size:11px;font-weight:600}
.sb-players.g{color:var(--ok)}
.sb-players.y{color:var(--warn)}
.sb-players.r{color:var(--red)}
.sb-gt{font-family:var(--mono);font-size:10px;color:var(--muted);max-width:110px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sb-code{font-family:var(--mono);font-size:10px;color:var(--hint)}
.sb-view{flex-shrink:0}
.sb-empty{text-align:center;padding:60px 24px}
.sb-empty i{font-size:32px;color:var(--hint);display:block;margin-bottom:12px}
.sb-empty p{font-family:var(--mono);font-size:12px;color:var(--muted);margin:0}
.sb-panel #sbMore{border-top:1px solid var(--line)}
@media(max-width:600px){.sb-code,.sb-gt{display:none}}

/* ═══════════ SERVER MEDIA (banner + icon) ═══════════ */
.srv-media{position:relative;margin-bottom:16px;border-radius:var(--r3);overflow:hidden;background:var(--bg-panel);border:1px solid var(--line)}
.srv-banner{display:block;width:100%;max-height:200px;object-fit:cover;object-position:center top}
.srv-icon{position:absolute;bottom:10px;left:12px;width:52px;height:52px;border-radius:var(--r2);border:2px solid var(--bg);background:var(--bg-panel);object-fit:cover;box-shadow:0 2px 8px rgba(0,0,0,.6)}

/* ═══════════ WELCOME ICON ═══════════ */
.welcome-icon-wrap{
  width:64px;height:64px;
  border-radius:var(--r3);
  background:var(--accent-dim);
  border:1px solid var(--accent-line);
  display:inline-flex;align-items:center;justify-content:center;
  margin:0 auto 24px;
}
.welcome-ring{display:none}

/* ═══════════ CARD ENTRANCE ═══════════ */
@keyframes card-enter{
  from{opacity:0;transform:translateY(12px)}
  to{opacity:1;transform:none}
}
.mc.anim-in{animation:card-enter .4s cubic-bezier(.22,.68,0,1.2) both}
.mc:hover{box-shadow:0 6px 22px rgba(0,0,0,.3)}

/* ═══════════ TAB INDICATOR ═══════════ */
.tab-indicator{
  position:absolute;bottom:-1px;height:2px;
  background:var(--accent);border-radius:2px;pointer-events:none;
  transition:left .22s cubic-bezier(.4,0,.2,1),width .22s cubic-bezier(.4,0,.2,1);
}

/* ═══════════ FP PILL STAGGER ═══════════ */
@keyframes fp-pop{
  from{opacity:0;transform:translateY(6px)}
  to{opacity:1;transform:none}
}
.fp{animation:fp-pop .45s cubic-bezier(.22,.68,0,1.2) both}
.fp:nth-child(1){animation-delay:.06s}
.fp:nth-child(2){animation-delay:.14s}
.fp:nth-child(3){animation-delay:.22s}
.fp:nth-child(4){animation-delay:.30s}

/* ═══════════ WELCOME CANVAS ═══════════ */
.welcome{position:relative;overflow:visible}
#welcomeCanvas{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);pointer-events:none;z-index:0;opacity:.2}
.welcome>*{position:relative;z-index:1}

/* ═══════════ TYPEWRITER CURSOR ═══════════ */
.type-cursor{color:var(--accent);font-weight:300;animation:cursor-blink .75s ease-in-out infinite;margin-left:1px}
@keyframes cursor-blink{0%,100%{opacity:1}50%{opacity:0}}

/* ═══════════ HISTORY SLIDE ANIMATIONS ═══════════ */
@keyframes hi-enter{from{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:none}}
@keyframes hi-exit{to{opacity:0;transform:translateX(-10px)}}
.hi.hi-enter{animation:hi-enter .18s ease both}
.hi.hi-exit{animation:hi-exit .18s ease both;pointer-events:none}
