:root{--bg-deep:#0a0c0f;--bg-panel:#12151a;--bg-card:#191d24;--bg-hover:#1e232c;--border:#2a303a;--border-active:#3d4554;--text-pri:#e8ecf2;--text-sec:#8892a2;--text-mut:#5a6474;--green:#34d399;--green-dim:#1a7a52;--red:#f87171;--red-dim:#7f2020;--amber:#fbbf24;--blue:#60a5fa;--purple:#a78bfa;--shadow:0 8px 32px rgba(0,0,0,.5)}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Outfit',sans-serif;background:var(--bg-deep);color:var(--text-pri);min-height:100vh}
body::before{content:'';position:fixed;inset:0;background:radial-gradient(ellipse 80% 60% at 20% 10%,rgba(52,211,153,.04) 0%,transparent 60%),radial-gradient(ellipse 60% 40% at 80% 90%,rgba(96,165,250,.03) 0%,transparent 60%);pointer-events:none;z-index:0}
a{color:var(--green);text-decoration:none}
code{background:var(--bg-card);padding:1px 5px;border-radius:4px;font-family:'JetBrains Mono',monospace;font-size:12px}
.muted{color:var(--text-mut);font-size:13px;padding:12px}
.mono{font-family:'JetBrains Mono',monospace;font-size:11px}
.code-block{background:var(--bg-deep);border:1px solid var(--border);border-radius:8px;padding:14px;font-family:'JetBrains Mono',monospace;font-size:12px;line-height:1.7;color:var(--text-sec);overflow-x:auto;margin-top:10px}

.gate{display:flex;align-items:center;justify-content:center;min-height:100vh;position:relative;z-index:1}
.gate-box{background:var(--bg-panel);border:1px solid var(--border);border-radius:16px;padding:48px;width:440px;max-width:92vw;text-align:center;box-shadow:var(--shadow);position:relative;overflow:hidden}
.gate-box::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--green),var(--blue),var(--green));background-size:200% 100%;animation:shimmer 3s ease-in-out infinite}
.gate-box.blocked::before{background:linear-gradient(90deg,var(--red),#d44,var(--red));background-size:200% 100%}
@keyframes shimmer{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
.gate-icon{font-size:48px;margin-bottom:20px}.gate-title{font-size:24px;font-weight:700;margin-bottom:8px;letter-spacing:-.5px}
.gate-sub{font-size:14px;color:var(--text-sec);margin-bottom:28px;line-height:1.5}
.gate-input{width:100%;padding:13px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;color:var(--text-pri);font-family:'JetBrains Mono',monospace;font-size:14px;outline:none;margin-bottom:12px;transition:border-color .2s}
.gate-input:focus{border-color:var(--green)}.gate-input::placeholder{color:var(--text-mut);font-family:'Outfit',sans-serif}
.gate-btn{width:100%;padding:14px;background:var(--green);color:var(--bg-deep);border:none;border-radius:10px;font-family:'Outfit',sans-serif;font-size:15px;font-weight:700;cursor:pointer;text-transform:uppercase;transition:all .2s}
.gate-btn:hover{background:#4ae8ad;transform:translateY(-1px)}
.gate-error{color:var(--red);font-size:13px;margin-top:14px;font-family:'JetBrains Mono',monospace}
.gate-note{margin-top:20px;padding:12px;background:rgba(251,191,36,.06);border:1px solid rgba(251,191,36,.15);border-radius:8px;font-size:12px;color:var(--amber);line-height:1.6}

.topbar{position:sticky;top:0;z-index:100;background:rgba(18,21,26,.88);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);padding:0 24px;height:60px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.topbar-l,.topbar-r{display:flex;align-items:center;gap:14px}
.logo{width:38px;height:38px;background:linear-gradient(135deg,#5b8c3e,var(--green));border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:0 2px 8px rgba(52,211,153,.2);flex-shrink:0}
.brand{font-size:17px;font-weight:700;letter-spacing:-.4px}.brand-v{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--text-mut)}
#srv-sel{padding:6px 10px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;color:var(--text-pri);font-family:'Outfit',sans-serif;font-size:13px;outline:none;cursor:pointer;max-width:260px}
#srv-sel option{background:var(--bg-panel)}
.srv-chip{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-sec)}
.dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.dot.on{background:var(--green);box-shadow:0 0 6px var(--green);animation:pulse 2s ease-in-out infinite}
.dot.off{background:var(--text-mut);box-shadow:none}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
.ip-badge{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text-mut);padding:5px 11px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;white-space:nowrap}
.logout-btn{padding:5px 13px;background:transparent;border:1px solid var(--border);border-radius:8px;color:var(--text-sec);font-family:'Outfit',sans-serif;font-size:13px;cursor:pointer;transition:all .2s;white-space:nowrap}
.logout-btn:hover{border-color:var(--red);color:var(--red)}

.layout{display:grid;grid-template-columns:210px 1fr;min-height:calc(100vh - 60px)}
.sidebar{background:var(--bg-panel);border-right:1px solid var(--border);padding:18px 10px;display:flex;flex-direction:column;gap:2px}
.sb-lbl{font-size:10px;font-weight:700;color:var(--text-mut);text-transform:uppercase;letter-spacing:1.5px;padding:14px 12px 5px}
.nav{display:flex;align-items:center;gap:9px;padding:8px 11px;border-radius:8px;color:var(--text-sec);cursor:pointer;font-size:13px;font-weight:500;border:1px solid transparent;transition:all .12s}
.nav:hover{background:var(--bg-hover);color:var(--text-pri)}.nav.active{background:var(--bg-card);color:var(--green);border-color:var(--border)}
.nav svg{width:16px;height:16px;flex-shrink:0}
.sb-foot{margin-top:auto;padding:12px;border-top:1px solid var(--border);font-family:'JetBrains Mono',monospace;font-size:9px;color:var(--text-mut);line-height:1.9}
.main{padding:26px;overflow-y:auto;max-height:calc(100vh - 60px)}
.page{display:none}.page.active{display:block;animation:fadeIn .3s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.pg-t{font-size:24px;font-weight:900;letter-spacing:-.7px;margin-bottom:4px}
.pg-d{font-size:13px;color:var(--text-sec);margin-bottom:22px}

.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-bottom:20px}
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:20px;transition:border-color .2s}
.card:hover{border-color:var(--border-active)}
.card-lbl{font-size:10px;color:var(--text-mut);text-transform:uppercase;letter-spacing:1px;margin-bottom:5px;font-weight:600}
.card-val{font-size:28px;font-weight:900;letter-spacing:-1px;line-height:1;margin-bottom:4px}
.card-sub{font-size:11px;color:var(--text-sec)}
.c-green{color:var(--green)}.c-blue{color:var(--blue)}.c-amber{color:var(--amber)}.c-purple{color:var(--purple)}.c-red{color:var(--red)}

.btns{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}
.btn{padding:9px 18px;border-radius:8px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-pri);font-family:'Outfit',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
.btn:hover{border-color:var(--border-active);background:var(--bg-hover);transform:translateY(-1px)}
.btn.primary{background:var(--green);color:var(--bg-deep);border-color:var(--green)}.btn.primary:hover{background:#4ae8ad}
.btn.danger{border-color:var(--red-dim);color:var(--red)}.btn.danger:hover{background:rgba(248,113,113,.08)}
.btn.warn{border-color:rgba(251,191,36,.3);color:var(--amber)}.btn.warn:hover{background:rgba(251,191,36,.08)}
.btn.sm{padding:4px 9px;font-size:11px;border-radius:6px}

.con-wrap{background:#0d0f12;border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:20px}
.con-head{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--bg-panel);border-bottom:1px solid var(--border)}
.con-t{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text-mut);text-transform:uppercase;letter-spacing:1px}
.con-body{padding:12px;height:280px;overflow-y:auto;font-family:'JetBrains Mono',monospace;font-size:12px;line-height:1.7;color:var(--text-sec);white-space:pre-wrap;word-break:break-all}
.con-body::-webkit-scrollbar{width:5px}.con-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
.con-row{display:flex;align-items:center;border-top:1px solid var(--border)}
.con-pfx{padding:10px 6px 10px 14px;font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--green);background:var(--bg-panel);white-space:nowrap}
.con-in{flex:1;padding:10px 12px 10px 4px;background:var(--bg-panel);border:none;color:var(--text-pri);font-family:'JetBrains Mono',monospace;font-size:12px;outline:none}
.con-in::placeholder{color:var(--text-mut)}

.tbl-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:18px}
.tbl-hd{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border)}
.tbl-t{font-size:14px;font-weight:700}
table{width:100%;border-collapse:collapse}
th{text-align:left;padding:9px 16px;font-size:10px;font-weight:700;color:var(--text-mut);text-transform:uppercase;letter-spacing:1px;border-bottom:1px solid var(--border);background:rgba(0,0,0,.1)}
td{padding:9px 16px;font-size:13px;border-bottom:1px solid rgba(42,48,58,.3);vertical-align:middle}
tr:last-child td{border-bottom:none}tr:hover td{background:rgba(255,255,255,.01)}
.badge{display:inline-block;padding:2px 8px;border-radius:99px;font-size:10px;font-weight:600}
.badge.online{background:rgba(52,211,153,.12);color:var(--green)}
.badge.banned{background:rgba(248,113,113,.12);color:var(--red)}
.badge.off{background:rgba(90,100,116,.12);color:var(--text-mut)}
.badge.op{background:rgba(167,139,250,.12);color:var(--purple)}

.form-sec{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:20px;margin-bottom:14px}
.form-sec-t{font-size:15px;font-weight:700;margin-bottom:16px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-group{display:flex;flex-direction:column;gap:4px}
.form-lbl{font-size:10px;font-weight:600;color:var(--text-sec);text-transform:uppercase;letter-spacing:.5px}
.form-inp,.form-sel{padding:8px 12px;background:var(--bg-deep);border:1px solid var(--border);border-radius:8px;color:var(--text-pri);font-family:'JetBrains Mono',monospace;font-size:13px;outline:none;transition:border-color .2s}
.form-inp:focus,.form-sel:focus{border-color:var(--green)}
.form-sel{font-family:'Outfit',sans-serif;cursor:pointer}.form-sel option{background:var(--bg-panel)}
.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid rgba(42,48,58,.3)}
.toggle-row:last-child{border-bottom:none}
.toggle-lbl{font-size:13px;font-weight:500}
.toggle{width:40px;height:21px;background:var(--border);border-radius:11px;position:relative;cursor:pointer;transition:background .2s;flex-shrink:0;border:none}
.toggle.on{background:var(--green)}.toggle::after{content:'';position:absolute;top:2.5px;left:2.5px;width:16px;height:16px;background:#fff;border-radius:50%;transition:transform .2s}.toggle.on::after{transform:translateX(19px)}

.toast{position:fixed;bottom:22px;right:22px;padding:11px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;font-size:13px;font-weight:500;box-shadow:var(--shadow);z-index:9999;transform:translateY(80px);opacity:0;transition:all .3s;max-width:380px}
.toast.show{transform:translateY(0);opacity:1}
.toast.ok{border-color:var(--green-dim);color:var(--green)}.toast.err{border-color:var(--red-dim);color:var(--red)}.toast.info{border-color:rgba(96,165,250,.3);color:var(--blue)}

.pag{display:flex;align-items:center;justify-content:center;gap:4px;padding:10px 16px;border-top:1px solid var(--border)}
.pag button{min-width:32px;height:28px;padding:0 8px;border-radius:6px;border:1px solid var(--border);background:var(--bg-panel);color:var(--text-sec);font-family:'JetBrains Mono',monospace;font-size:11px;cursor:pointer;transition:all .15s}
.pag button:hover{border-color:var(--border-active);color:var(--text-pri);background:var(--bg-hover)}
.pag button.active{background:var(--green);color:var(--bg-deep);border-color:var(--green);font-weight:700}
.pag button:disabled{opacity:.3;cursor:default}
.pag-info{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--text-mut)}
.form-hint{font-size:12px;color:var(--text-mut);line-height:1.6;min-height:32px;display:flex;align-items:center}

/* Schema-driven param builder */
.param-row .form-inp,.param-row .form-sel{width:100%;box-sizing:border-box;margin-top:4px}
.param-row textarea.form-inp{min-height:60px}

/* Live event feed */
.feed{max-height:300px;overflow-y:auto;padding:8px 12px;font-family:'JetBrains Mono',monospace;font-size:12px;line-height:1.8;color:var(--text-sec);background:#0d0f12;border-radius:0 0 12px 12px}
.feed::-webkit-scrollbar{width:5px}.feed::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
.feed-item{padding:3px 0;border-bottom:1px solid rgba(255,255,255,.03);display:flex;gap:8px;align-items:baseline}
.feed-ts{color:var(--text-mut);font-size:10px;white-space:nowrap}
.feed-srv{color:var(--green);font-size:10px;padding:1px 5px;background:rgba(0,209,102,.1);border-radius:3px}
.feed-msg{color:var(--text-pri)}
.feed-join{color:#00d166}.feed-leave{color:#f04747}.feed-system{color:var(--amber)}
.live-dot{width:8px;height:8px;border-radius:50%;background:#00d166;display:inline-block;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

@media(max-width:860px){.layout{grid-template-columns:1fr}.sidebar{display:none}.main{padding:16px}.form-grid{grid-template-columns:1fr}.topbar{padding:0 12px;gap:8px;flex-wrap:wrap;height:auto;padding:10px 12px}}
@media(max-width:500px){.cards{grid-template-columns:1fr}#srv-sel{max-width:160px}}
