*,:before,:after{box-sizing:border-box}body{color:#c9d1d9;background:#0d1117;margin:0;padding:0;overflow:hidden}#root{width:100%;height:100vh;overflow:hidden}:root{--bg-app:#0d1117;--bg-panel:#161b22;--bg-input:#0d1117;--border:#30363d;--border-subtle:#21262d;--text:#c9d1d9;--text-muted:#8b949e;--text-heading:#f0f6fc;--accent:#1f6feb;--accent-hover:#388bfd;--color-success:#3fb950;--color-danger:#f85149;--color-warning:#d29922;--color-command:#e6b673;--mono:"JetBrains Mono", "Cascadia Code", "Fira Code", Consolas, "Courier New", monospace}.app{background:var(--bg-app);height:100vh;color:var(--text);font-family:var(--mono);flex-direction:column;font-size:13px;display:flex}.app-header{background:var(--bg-panel);border-bottom:1px solid var(--border);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:16px;padding:10px 20px;display:flex}.app-brand{color:var(--text-heading);letter-spacing:-.3px;white-space:nowrap;align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex}.app-icon{color:var(--color-success);font-size:10px}.connect-form{flex-wrap:wrap;flex:1;justify-content:flex-end;align-items:center;gap:8px;display:flex}.connect-status{align-items:center;gap:10px;margin-left:auto;display:flex}.status-text{color:var(--text-muted);font-size:12px}.status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.status-dot--connected{background:var(--color-success);box-shadow:0 0 6px var(--color-success)}.status-dot--connecting{background:var(--color-warning);animation:1s ease-in-out infinite blink}.status-dot--error{background:var(--color-danger)}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.input{background:var(--bg-input);border:1px solid var(--border);height:32px;color:var(--text);font-family:var(--mono);border-radius:6px;outline:none;min-width:0;padding:0 10px;font-size:12px}.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #1f6feb33}.input::placeholder{color:var(--text-muted)}.input--port{width:76px}.input--port::-webkit-inner-spin-button{-webkit-appearance:none}.input--port::-webkit-outer-spin-button{-webkit-appearance:none}.input--port{-moz-appearance:textfield}.btn{height:32px;font-family:var(--mono);cursor:pointer;white-space:nowrap;border:none;border-radius:6px;padding:0 14px;font-size:12px;font-weight:500;transition:opacity .15s,background .15s}.btn:disabled{opacity:.45;cursor:not-allowed}.btn--primary{background:var(--accent);color:#fff}.btn--primary:hover:not(:disabled){background:var(--accent-hover)}.btn--danger{color:var(--color-danger);border:1px solid var(--color-danger);background:0 0}.btn--danger:hover:not(:disabled){background:#f851491f}.btn-ghost{border:1px solid var(--border-subtle);height:24px;color:var(--text-muted);font-family:var(--mono);cursor:pointer;background:0 0;border-radius:5px;padding:0 10px;font-size:11px;transition:color .15s,border-color .15s}.btn-ghost:hover{color:var(--text);border-color:var(--border)}.app-body{flex:1;display:flex;overflow:hidden}.console{flex-direction:column;flex:1;display:flex;overflow:hidden}.console-toolbar{border-bottom:1px solid var(--border-subtle);background:var(--bg-panel);flex-shrink:0;justify-content:space-between;align-items:center;padding:6px 16px;display:flex}.console-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;font-size:10px;font-weight:600}.console-actions{align-items:center;gap:8px;display:flex}.console-hint{color:var(--text-muted);font-size:11px;font-style:italic}.output{scrollbar-width:thin;scrollbar-color:var(--border) transparent;flex:1;padding:10px 18px;overflow-y:auto}.output--empty{color:var(--text-muted);justify-content:center;align-items:center;font-size:12px;font-style:italic;display:flex}.line{gap:14px;padding:1px 0;font-size:13px;line-height:1.65;display:flex}.line-ts{color:var(--text-muted);opacity:.6;-webkit-user-select:none;user-select:none;flex-shrink:0;padding-top:2px;font-size:11px}.line-body{white-space:pre-wrap;word-break:break-word}.line--info .line-body{color:var(--text-muted)}.line--success .line-body{color:var(--color-success)}.line--error .line-body{color:var(--color-danger)}.line--command .line-body{color:var(--color-command);font-weight:500}.line--output .line-body{color:var(--text)}.right-sidebar{border-left:1px solid var(--border);background:var(--bg-panel);flex-direction:column;flex-shrink:0;width:240px;display:flex;overflow:hidden}.players-panel{border-bottom:1px solid var(--border);flex-direction:column;flex:2;display:flex;overflow:hidden}.players-header{border-bottom:1px solid var(--border-subtle);flex-shrink:0;align-items:center;gap:8px;padding:6px 12px;display:flex}.players-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;flex:1;font-size:10px;font-weight:600}.players-count{color:var(--color-success);background:#3fb9501f;border:1px solid #3fb9504d;border-radius:10px;padding:0 7px;font-size:11px;font-weight:600;line-height:18px}.players-list{scrollbar-width:thin;scrollbar-color:var(--border) transparent;flex:1;padding:6px 0;overflow-y:auto}.players-empty{text-align:center;color:var(--text-muted);padding:24px 12px;font-size:12px;font-style:italic}.player-row{border-bottom:1px solid var(--border-subtle);cursor:default;padding:7px 12px}.player-row:last-child{border-bottom:none}.player-row:hover{background:#ffffff08}.player-row-top{justify-content:space-between;align-items:baseline;gap:6px;margin-bottom:2px;display:flex}.player-name{color:var(--text-heading);white-space:nowrap;text-overflow:ellipsis;min-width:0;font-size:13px;overflow:hidden}.player-ping{flex-shrink:0;font-size:12px;font-weight:600}.player-ping--good{color:var(--color-success)}.player-ping--ok{color:var(--color-warning)}.player-ping--bad{color:var(--color-danger)}.ping-unit{opacity:.7;font-size:10px;font-weight:400}.player-row-bottom{justify-content:space-between;gap:4px;display:flex}.player-steam{color:var(--text-muted);opacity:.7;white-space:nowrap;text-overflow:ellipsis;min-width:0;font-size:10px;overflow:hidden}.player-meta{color:var(--text-muted);opacity:.6;flex-shrink:0;font-size:10px}.maps-panel{flex-direction:column;flex:3;display:flex;overflow:hidden}.maps-header{border-bottom:1px solid var(--border-subtle);flex-shrink:0;align-items:center;gap:8px;padding:6px 12px;display:flex}.maps-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;flex:1;font-size:10px;font-weight:600}.maps-count{color:var(--text-muted);background:#8b949e1f;border:1px solid #8b949e40;border-radius:10px;padding:0 7px;font-size:11px;font-weight:600;line-height:18px}.maps-confirm{border-bottom:1px solid var(--border-subtle);background:#f851490f;flex-direction:column;flex-shrink:0;gap:6px;padding:8px 12px;display:flex}.maps-confirm-label{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.maps-confirm-label strong{color:var(--text)}.maps-confirm-actions{gap:6px;display:flex}.maps-list{scrollbar-width:thin;scrollbar-color:var(--border) transparent;flex:1;padding:4px 0;overflow-y:auto}.maps-empty{text-align:center;color:var(--text-muted);padding:16px 12px;font-size:12px;font-style:italic}.map-item{border:none;border-bottom:1px solid var(--border-subtle);text-align:left;cursor:pointer;width:100%;font-family:var(--mono);color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;background:0 0;padding:5px 12px;font-size:11px;display:block;overflow:hidden}.map-item:last-child{border-bottom:none}.map-item:hover:not(:disabled){color:var(--text);background:#ffffff0a}.map-item:disabled{opacity:.4;cursor:not-allowed}.map-item--pending{color:var(--color-warning);background:#d2992214}.map-badge{color:var(--accent-hover);vertical-align:middle;background:#1f6feb33;border:1px solid #1f6feb59;border-radius:3px;flex-shrink:0;margin-right:6px;padding:0 4px;font-size:9px;font-weight:700;line-height:14px;display:inline-block}.map-preview{z-index:500;pointer-events:none;border:1px solid var(--border);border-radius:6px;position:fixed;overflow:hidden;transform:translate(calc(-100% - 8px));box-shadow:0 8px 24px #0009}.map-preview img{width:220px;height:auto;display:block}.ctx-menu{z-index:1000;background:var(--bg-panel);border:1px solid var(--border);border-radius:6px;min-width:160px;position:fixed;overflow:hidden;box-shadow:0 8px 24px #00000080}.ctx-menu-header{color:var(--text-muted);border-bottom:1px solid var(--border-subtle);white-space:nowrap;text-overflow:ellipsis;-webkit-user-select:none;user-select:none;padding:6px 12px;font-size:11px;overflow:hidden}.ctx-menu-item{text-align:left;cursor:pointer;width:100%;font-family:var(--mono);color:var(--text);background:0 0;border:none;padding:8px 12px;font-size:12px;display:block}.ctx-menu-item:hover{background:#ffffff0d}.ctx-menu-item--danger{color:var(--color-danger)}.ctx-menu-item--danger:hover{background:#f851491a}.ctx-confirm{flex-direction:column;gap:8px;padding:10px 12px;display:flex}.ctx-confirm-label{color:var(--text-muted);font-size:11px}.ctx-confirm-actions{gap:6px;display:flex}.ctx-confirm-btn{border:1px solid var(--border);font-family:var(--mono);cursor:pointer;color:var(--text-muted);background:0 0;border-radius:4px;flex:1;padding:5px 0;font-size:11px}.ctx-confirm-btn:hover{color:var(--text);background:#ffffff0d}.ctx-confirm-btn--danger{color:var(--color-danger);border-color:var(--color-danger)}.ctx-confirm-btn--danger:hover{color:var(--color-danger);background:#f8514926}.cmd-bar{border-top:1px solid var(--border);background:var(--bg-panel);flex-shrink:0;align-items:center;gap:0;padding:12px 18px;display:flex}.cmd-prompt{color:var(--color-success);-webkit-user-select:none;user-select:none;flex-shrink:0;padding-right:10px;font-size:15px;font-weight:700}.cmd-field{background:var(--bg-input);border:1px solid var(--border);height:36px;color:var(--text);font-family:var(--mono);border-right:none;border-radius:6px 0 0 6px;outline:none;flex:1;min-width:0;padding:0 12px;font-size:13px}.cmd-field:focus{border-color:var(--accent);z-index:1;position:relative}.cmd-field::placeholder{color:var(--text-muted)}.cmd-field:disabled{opacity:.45;cursor:not-allowed}.cmd-bar .btn{border-radius:0 6px 6px 0;height:36px}
