/* ══════════════════════════════════════════════════
   MWGSM GAMEPANEL PRO — CORPORATE STEEL
   Clean professional SaaS. Deep navy backgrounds,
   crisp electric blue, sharp whites. No scan lines,
   no glow effects. Business-grade dashboard feel.
   Rounded corners, subtle shadows, polished.
══════════════════════════════════════════════════ */
:root {
  --bg0: #0d1117; --bg1: #161b22; --bg2: #21262d; --bg3: #2d333b;
  --border: #30363d; --border2: #444c56;
  --acc: #2f81f7; --acc2: #1a6bd8; --acc3: rgba(47,129,247,.12); --acc4: rgba(47,129,247,.05);
  --red: #f85149; --orange: #d29922; --yellow: #e3b341; --blue: #58a6ff; --purple: #bc8cff; --green: #3fb950;
  --text: #e6edf3; --textd: #8b949e; --textm: #484f58;
  --font-ui: -apple-system,'Segoe UI',system-ui,sans-serif;
  --font-h: -apple-system,'Segoe UI',system-ui,sans-serif;
  --font-mono: 'Share Tech Mono','SFMono-Regular','Consolas',monospace;
  --radius: 6px;
  --shadow: 0 1px 3px rgba(0,0,0,.3),0 4px 20px rgba(0,0,0,.4);
  --glow: none;
  --glow-strong: none;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;background:var(--bg0);color:var(--text);font-family:var(--font-ui);font-size:14px;font-weight:400;overflow:hidden;letter-spacing:0}

::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:var(--bg1)}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:6px}
::-webkit-scrollbar-thumb:hover{background:#6e7681}

/* Layout */
.app{display:grid;grid-template-columns:240px 1fr;grid-template-rows:52px 1fr;height:100vh}

/* Topbar */
.topbar{grid-column:1/-1;background:var(--bg1);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px;gap:16px;position:relative;z-index:100}

.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.brand-icon{width:32px;height:32px;background:var(--acc3);border:1px solid rgba(47,129,247,.25);border-radius:6px;display:grid;place-items:center;font-size:15px}
.brand-name{font-family:var(--font-h);font-size:15px;font-weight:600;letter-spacing:0;color:var(--text);text-transform:none}
.brand-ver{font-family:var(--font-mono);font-size:8px;color:var(--textd);letter-spacing:1px;margin-top:1px}
.topbar-mid{flex:1;display:flex;align-items:center;gap:8px}
.breadcrumb{font-family:var(--font-mono);font-size:11px;color:var(--textd);letter-spacing:.5px}
.breadcrumb .sep{color:var(--textm)}
.breadcrumb .cur{color:var(--text)}

.node-pill{display:flex;align-items:center;gap:6px;padding:4px 12px;font-family:var(--font-mono);font-size:10px;letter-spacing:.5px;text-transform:uppercase;background:var(--bg2);border:1px solid var(--border);border-radius:6px;cursor:pointer;color:var(--textd);transition:all .15s}
.node-pill:hover{border-color:var(--acc);color:var(--text);background:var(--bg3)}
.node-pill-dot{width:6px;height:6px;background:var(--green);border-radius:50%;box-shadow:0 0 0 2px rgba(63,185,80,.15)}
.node-pill-dot.warn{background:var(--orange)}
.node-pill-dot.off{background:var(--red)}

/* Sidebar */
.sidebar{background:var(--bg1);border-right:1px solid var(--border);overflow-y:auto;padding:8px 0 12px;display:flex;flex-direction:column}
.nav-section{font-family:var(--font-ui);font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--textm);padding:16px 16px 4px}
.nav-item{display:flex;align-items:center;gap:8px;padding:7px 16px;font-family:var(--font-ui);font-size:13px;font-weight:400;color:var(--textd);cursor:pointer;transition:all .1s;border-radius:0;border-left:3px solid transparent;margin:1px 0}
.nav-item:hover{color:var(--text);background:rgba(177,186,196,.08)}
.nav-item.active{color:var(--acc);background:rgba(47,129,247,.1);border-left-color:var(--acc);font-weight:500}
.nav-item .ico{display:flex;align-items:center;opacity:.7}
.nav-item.active .ico{opacity:1}
.nav-item .ico svg{stroke:currentColor}
.nav-badge{font-family:var(--font-mono);font-size:9px;padding:1px 6px;border-radius:10px;letter-spacing:.3px}
.nav-badge.ok{background:rgba(63,185,80,.12);color:var(--green);border:1px solid rgba(63,185,80,.2)}
.nav-badge.warn{background:rgba(210,153,34,.12);color:var(--orange);border:1px solid rgba(210,153,34,.2)}
.sidebar-footer{margin-top:auto;border-top:1px solid var(--border);padding:12px}
.user-tile{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:6px;cursor:pointer;transition:all .1s}
.user-tile:hover{background:rgba(177,186,196,.08)}
.user-ava{width:30px;height:30px;background:linear-gradient(135deg,#1a6bd8,#58a6ff);border-radius:50%;display:grid;place-items:center;font-family:var(--font-ui);font-size:12px;font-weight:600;color:#fff}
.user-name{font-size:13px;font-weight:500;color:var(--text)}
.user-role{font-family:var(--font-mono);font-size:9px;color:var(--textd);text-transform:uppercase;letter-spacing:1px}

/* Main */
.main{overflow-y:auto;padding:24px 28px;background:var(--bg0)}
.section-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.section-title{font-family:var(--font-h);font-size:18px;font-weight:600;letter-spacing:0;text-transform:none;color:var(--text);position:relative}

/* Cards */
.card{background:var(--bg1);border:1px solid var(--border);border-radius:var(--radius);padding:16px;position:relative;transition:border-color .15s,box-shadow .15s}
.card:hover{border-color:var(--border2);box-shadow:var(--shadow)}

/* Tables */
.tbl-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:13px}
thead th{font-family:var(--font-ui);font-size:11px;font-weight:600;letter-spacing:.3px;text-transform:uppercase;color:var(--textd);text-align:left;padding:10px 14px;border-bottom:1px solid var(--border);white-space:nowrap;background:var(--bg2)}
tbody td{padding:10px 14px;border-bottom:1px solid var(--border);color:var(--text);transition:background .1s}
tbody tr:hover td{background:rgba(177,186,196,.04)}
tbody td a{color:var(--acc);text-decoration:none}
tbody td a:hover{text-decoration:underline}

.badge{display:inline-flex;align-items:center;gap:4px;font-family:var(--font-ui);font-size:11px;font-weight:500;letter-spacing:.2px;padding:2px 8px;border-radius:20px}
.badge-ok{background:rgba(63,185,80,.12);color:var(--green);border:1px solid rgba(63,185,80,.2)}
.badge-err{background:rgba(248,81,73,.1);color:var(--red);border:1px solid rgba(248,81,73,.2)}
.badge-warn{background:rgba(210,153,34,.1);color:var(--orange);border:1px solid rgba(210,153,34,.2)}
.badge-info{background:rgba(47,129,247,.1);color:var(--acc);border:1px solid rgba(47,129,247,.2)}

.bar{height:6px;background:var(--bg3);border-radius:6px;overflow:hidden}
.bar-fill{height:100%;transition:width .4s;border-radius:6px}

/* Buttons */
.btn{font-family:var(--font-ui);font-size:13px;font-weight:500;letter-spacing:0;padding:6px 14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg2);color:var(--text);cursor:pointer;transition:all .1s}
.btn:hover{background:var(--bg3);border-color:var(--border2)}
.btn-acc{background:var(--acc);border-color:var(--acc2);color:#fff}
.btn-acc:hover{background:var(--acc2);border-color:#1558b8}
.btn-err{background:transparent;border-color:rgba(248,81,73,.4);color:var(--red)}
.btn-err:hover{background:rgba(248,81,73,.1);border-color:var(--red)}
.btn-ghost{background:transparent;border-color:var(--border);color:var(--textd)}
.btn-ghost:hover{background:var(--bg2);color:var(--text)}
.btn-ok{background:rgba(63,185,80,.12);border-color:rgba(63,185,80,.25);color:var(--green)}
.btn-icon{width:32px;height:32px;padding:0;display:grid;place-items:center}
.btn-warn{background:transparent;border-color:rgba(210,153,34,.4);color:var(--orange)}
.btn-warn:hover{background:rgba(210,153,34,.1);border-color:var(--orange)}

/* Console */
.console-wrap,.console-box{background:#0d1117;border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-mono);font-size:12px;position:relative;overflow:hidden}
.console-log,.console-body{height:350px;overflow-y:auto;padding:12px 14px;color:#c9d1d9;white-space:pre-wrap;word-break:break-all;line-height:1.65}
.console-in{display:flex;border-top:1px solid var(--border)}
.console-in input{flex:1;background:var(--bg1);border:none;padding:10px 14px;color:var(--text);font-family:var(--font-mono);font-size:12px;outline:none}
.console-in input::placeholder{color:var(--textm)}
.console-in button{padding:0 16px;background:var(--bg2);border:none;border-left:1px solid var(--border);color:var(--text);cursor:pointer;font-size:12px;font-weight:500}
.console-in button:hover{background:var(--bg3)}
.console-bar{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--bg2);border-bottom:1px solid var(--border);gap:8px}
.console-input-row{display:flex;border-top:1px solid var(--border)}
.console-prompt{padding:8px 4px 8px 12px;color:var(--green);font-family:var(--font-mono);font-size:12px;user-select:none}
.console-send{padding:0 14px;background:var(--bg2);border:none;border-left:1px solid var(--border);color:var(--text);cursor:pointer;font-size:12px}
.console-send:hover{background:var(--bg3)}

/* Node cards */
.node-card{background:var(--bg1);border:1px solid var(--border);border-radius:var(--radius);padding:18px;transition:all .15s}
.node-card:hover{border-color:var(--border2);box-shadow:var(--shadow)}
.node-card.online{border-top:2px solid var(--green)}
.node-card.offline{border-top:2px solid var(--red)}

/* Tabs */
.tab-btn{padding:8px 16px;font-family:var(--font-ui);font-size:13px;font-weight:400;color:var(--textd);background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all .1s}
.tab-btn:hover{color:var(--text)}
.tab-btn.active{color:var(--text);border-bottom-color:var(--acc);font-weight:500}
.stab{padding:8px 16px;font-family:var(--font-ui);font-size:13px;font-weight:400;color:var(--textd);background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all .1s}
.stab:hover{color:var(--text)}
.stab.active{color:var(--text);border-bottom-color:var(--acc);font-weight:500}
.stab-panel{animation:fadeIn .15s ease}
.cfg-tab-btn{padding:6px 12px;font-family:var(--font-ui);font-size:12px;font-weight:400;color:var(--textd);background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all .1s}
.cfg-tab-btn:hover{background:var(--bg3);color:var(--text)}
.cfg-tab-btn.active{background:var(--acc3);border-color:rgba(47,129,247,.3);color:var(--acc)}

/* Alerts */
.alert{padding:12px 16px;border-radius:var(--radius);font-size:13px;border:1px solid}
.alert-ok{background:rgba(63,185,80,.08);border-color:rgba(63,185,80,.2);color:var(--green)}
.alert-err{background:rgba(248,81,73,.08);border-color:rgba(248,81,73,.2);color:var(--red)}
.alert-warn{background:rgba(210,153,34,.08);border-color:rgba(210,153,34,.2);color:var(--orange)}

/* Forms */
.form-group{margin-top:10px}
.form-label{display:block;font-family:var(--font-ui);font-size:12px;font-weight:500;letter-spacing:0;text-transform:none;color:var(--textd);margin-bottom:5px}
.form-input,select{width:100%;background:var(--bg0);border:1px solid var(--border);border-radius:var(--radius);padding:8px 12px;color:var(--text);font-family:var(--font-ui);font-size:13px;outline:none;transition:border-color .1s,box-shadow .1s}
.form-input:focus,select:focus{border-color:var(--acc);box-shadow:0 0 0 3px rgba(47,129,247,.12)}
.form-input::placeholder{color:var(--textm)}
input[type="checkbox"]{accent-color:var(--acc);width:14px;height:14px}

/* Misc */
.rule-row{display:flex;align-items:center;gap:8px;padding:6px 0}
.rule-row input,.rule-row select{flex:1}
.price-tag{font-family:var(--font-mono);font-size:20px;font-weight:700;color:var(--acc)}
.gcfg-row{display:flex;gap:8px;align-items:center;margin-bottom:6px}
.gcfg-row input{flex:1}
.graph-container{background:var(--bg1);border:1px solid var(--border);border-radius:var(--radius);padding:16px}
.empty-state{text-align:center;padding:50px 20px;color:var(--textd)}
.fm-bar{display:flex;gap:8px;padding:10px;background:var(--bg2);border:1px solid var(--border);border-bottom:none;border-radius:var(--radius) var(--radius) 0 0;align-items:center}
.fm-path{flex:1;font-family:var(--font-mono);font-size:11px;color:var(--textd)}
.fm{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.fm-body{background:var(--bg0);max-height:500px;overflow-y:auto}
.fm-row{display:flex;align-items:center;gap:10px;padding:7px 14px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s}
.fm-row:hover{background:rgba(177,186,196,.05)}
.fm-ico{font-size:16px;width:22px;text-align:center;flex-shrink:0}
.fm-name{flex:1;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.fm-meta{font-size:11px;color:var(--textd);font-family:var(--font-mono);white-space:nowrap}
.fm-crumb-part{color:var(--acc);cursor:pointer;font-family:var(--font-mono);font-size:11px}
.fm-crumb-part:hover{text-decoration:underline}
.fm-crumb-sep{color:var(--textm);margin:0 2px}
.bar-wrap{margin-top:4px;position:relative;height:6px;background:var(--bg3);border-radius:6px;overflow:hidden}
.form-hint{font-size:11px;color:var(--textd);margin-top:3px}
.badge-ghost{background:var(--bg3);color:var(--textd);border:1px solid var(--border);border-radius:20px}
.var-input{width:100%;background:var(--bg0);border:1px solid var(--border);border-radius:var(--radius);padding:6px 10px;color:var(--text);font-family:var(--font-mono);font-size:12px;outline:none}
.var-input:focus{border-color:var(--acc);box-shadow:0 0 0 3px rgba(47,129,247,.12)}
.sd-nav-item{padding:7px 14px;font-size:13px;cursor:pointer;border-left:3px solid transparent;color:var(--textd);transition:all .1s}
.sd-nav-item:hover{color:var(--text);background:rgba(177,186,196,.06)}
.sd-nav-item.active{color:var(--acc);border-left-color:var(--acc);background:rgba(47,129,247,.08);font-weight:500}
.mono{font-family:var(--font-mono)}
.hi{color:var(--acc);font-weight:600}
.act-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.ws-btn{padding:4px 10px;font-size:12px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);color:var(--textd);cursor:pointer}
.ws-btn:hover{background:var(--bg3);color:var(--text)}
.wdot{width:8px;height:8px;border-radius:50%;display:inline-block}
.status-pill{display:inline-block;font-family:var(--font-ui);font-size:11px;letter-spacing:.2px;padding:2px 8px;border-radius:20px}
.user-info{overflow:hidden}
.ava{width:30px;height:30px;background:linear-gradient(135deg,#1a6bd8,#58a6ff);border-radius:50%;display:grid;place-items:center;font-family:var(--font-ui);font-size:11px;font-weight:600;color:#fff}
.content{min-height:100%}
.nav-group{margin-bottom:2px}
.nav-group-label{font-family:var(--font-ui);font-size:10px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--textm);padding:12px 16px 4px}
.sidebar-foot{margin-top:auto;border-top:1px solid var(--border);padding:10px}
.topbar-right{display:flex;align-items:center;gap:8px}
.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}
.stat-card{background:var(--bg1);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;text-align:center}
.stat-val{font-family:var(--font-mono);font-size:26px;font-weight:700;letter-spacing:1px;line-height:1.1;color:var(--text)}
.stat-label{font-family:var(--font-ui);font-size:12px;letter-spacing:0;text-transform:none;color:var(--textd);margin-top:6px}
.gl-card{background:var(--bg1);border:1px solid var(--border);border-radius:var(--radius);padding:16px;transition:all .15s}
.gl-card:hover{border-color:var(--border2);box-shadow:var(--shadow)}
.gl-installed{border-top:2px solid var(--green)}
.log-line{padding:2px 0;border-bottom:1px solid rgba(48,54,61,.3)}
.log-ts{color:var(--textm);font-size:11px;margin-right:8px}
.log-info{color:var(--text)}
.log-warn,.log-war{color:var(--orange)}
.log-error,.log-err{color:var(--red)}

/* Animations */
.fade{animation:fadeIn .2s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(3px)}to{opacity:1;transform:translateY(0)}}
.detail-overlay{animation:slideIn .15s ease}
@keyframes slideIn{from{transform:translateX(16px);opacity:0}to{transform:translateX(0);opacity:1}}

/* Modal */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .1s ease}
.modal-box{background:var(--bg1);border:1px solid var(--border);border-radius:10px;max-width:560px;width:90%;max-height:80vh;overflow-y:auto;position:relative;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.modal-hd{padding:16px 20px;font-family:var(--font-h);font-size:15px;font-weight:600;letter-spacing:0;color:var(--text);border-bottom:1px solid var(--border)}
.modal-body{padding:20px}
.modal-footer{padding:12px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}

/* Toast */
.toast-container{position:fixed;top:60px;right:20px;z-index:2000;display:flex;flex-direction:column;gap:8px}
.toast{padding:10px 16px;font-family:var(--font-ui);font-size:13px;border-radius:8px;animation:toastIn .2s ease,toastOut .3s ease 3s forwards;max-width:380px;border:1px solid;box-shadow:0 4px 20px rgba(0,0,0,.4)}
.toast.ok{background:var(--bg1);border-color:rgba(63,185,80,.3);color:var(--text)}
.toast.error{background:var(--bg1);border-color:rgba(248,81,73,.3);color:var(--text)}
.toast.info{background:var(--bg1);border-color:rgba(47,129,247,.3);color:var(--text)}
@keyframes toastIn{from{transform:translateX(100px);opacity:0}}
@keyframes toastOut{to{opacity:0;transform:translateY(-10px)}}

.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--acc);border-radius:50%;animation:spin .6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.pulse{width:8px;height:8px;border-radius:50%;background:var(--green)}
.pulse.warn{background:var(--orange)}
.pulse.off{background:var(--red)}
.bar-fill::after{display:none}

/* Login */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg0)}
.login-box{background:var(--bg1);border:1px solid var(--border);border-radius:12px;padding:40px;width:380px;box-shadow:0 20px 60px rgba(0,0,0,.4)}
.login-brand{font-family:var(--font-h);font-size:22px;font-weight:700;letter-spacing:0;color:var(--text);text-align:center;margin-bottom:6px}
.login-sub{font-size:13px;color:var(--textd);text-align:center;letter-spacing:0;margin-bottom:28px}

/* Mobile */
@media(max-width:768px){
  .app{grid-template-columns:1fr}
  .sidebar{position:fixed;left:-260px;top:52px;bottom:0;width:260px;z-index:200;transition:left .2s;background:var(--bg1);border-right:1px solid var(--border)}
  .sidebar.open{left:0;box-shadow:20px 0 40px rgba(0,0,0,.4)}
  .topbar{grid-column:1}
  .main{padding:16px}
  .hide-mobile{display:none!important}
}
.mob-toggle{display:none;position:fixed;bottom:20px;left:20px;width:44px;height:44px;border-radius:50%;background:var(--acc);color:#fff;border:none;font-size:20px;cursor:pointer;z-index:300;box-shadow:0 4px 16px rgba(47,129,247,.4)}
@media(max-width:768px){.mob-toggle{display:grid;place-items:center}}
