html{overflow-x:hidden;overflow-y:hidden}
body{margin:0;padding:0;height:100%;width:100%;overflow:hidden;overflow-x:hidden;touch-action:pan-y;-webkit-tap-highlight-color:transparent}
*{box-sizing:border-box}
:root{
  --bg:#0d1117;--bg2:#111827;--bg3:#0a0f1a;
  --border:#1e293b;--border2:#1a2332;
  --text:#f8fafc;--text2:#e2e8f0;--text3:#64748b;--text4:#475569;
  --accent:#0ea5e9;--accent2:#0284c7;
  --live:#22c55e;--pend:#f59e0b;
  --row-hover:#0a0f1a;
  --card-bg:#111827;
  --hdr-bg:#0d1117;
  --tag-gov-bg:rgba(59,130,246,.15);--tag-gov:rgba(59,130,246,.15);--tag-gov-c:#60a5fa;
  --tag-health-bg:rgba(20,184,166,.15);--tag-health-c:#2dd4bf;
  --tag-nfp-bg:rgba(168,85,247,.15);--tag-nfp-c:#c084fc;
  --dot-live-glow:none;--stat-glow:none;
  --shimmer-dur:.55s;
  --font:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
}
body.theme-blue{--bg:#070c18;--bg2:#0c1527;--bg3:#060a14;--border:#1a2d4a;--border2:#142238;--hdr-bg:#070c18;--card-bg:#0c1527;--row-hover:#0a1422;--accent:#3b82f6;--accent2:#2563eb;}
body.theme-midnight{--bg:#09050f;--bg2:#120a1f;--bg3:#060308;--border:#2a1445;--border2:#1e0f33;--hdr-bg:#09050f;--card-bg:#120a1f;--row-hover:#0f0819;--accent:#8b5cf6;--accent2:#7c3aed;}
body.theme-shiny{--bg:#080d14;--bg2:#0f1824;--bg3:#060a10;--border:#1e3a5f;--border2:#172d4a;--hdr-bg:#080d14;--card-bg:#0f1824;--row-hover:#0c1520;--accent:#06b6d4;--accent2:#0891b2;--dot-live-glow:0 0 8px rgba(34,197,94,.6);--stat-glow:0 0 20px rgba(6,182,212,.1);}

/* Layout */
#nrt-app{display:flex;flex-direction:column;height:100vh;height:100dvh;max-width:100%;overflow-x:hidden;background:var(--bg);font-family:var(--font);color:var(--text2);overflow-y:hidden}
body.theme-light{
  --bg:#f8fafc;--bg2:#f1f5f9;--bg3:#e2e8f0;
  --hdr-bg:#1e40af;--card-bg:#ffffff;
  --border:#cbd5e1;--border2:#e2e8f0;
  --row-hover:rgba(0,0,0,.04);
  --text:#0f172a;--text2:#1e293b;--text3:#334155;--text4:#64748b;
  --accent:#2563eb;--accent2:#1d4ed8;
  --live:#16a34a;--pend:#d97706;
  --tag-gov-bg:rgba(37,99,235,.1);--tag-gov-c:#1d4ed8;
  --tag-health-bg:rgba(109,40,217,.1);--tag-health-c:#7c3aed;
  --tag-nfp-bg:rgba(22,163,74,.1);--tag-nfp-c:#15803d;
}
body.theme-light .nav-header{background:#1e40af}
body.theme-light .tab{color:rgba(255,255,255,.7)}
body.theme-light .tab.active{background:rgba(255,255,255,.25);color:#fff;font-weight:600}
body.theme-light #nrt-app{background:var(--bg)}
body.theme-light .client-row{color:var(--text)}
body.theme-light .client-name{color:var(--text)}
body.theme-light .client-domain{color:var(--text3)}
body.theme-light .stat-card{background:#fff;border-color:#d1d5db}
body.theme-light .stat-val{color:var(--text)}
body.theme-light .stat-label{color:var(--text4)}
body.theme-light .tbl-hdr{background:var(--bg3);color:var(--text3);position:sticky;top:0;z-index:2}
.tbl-hdr,.client-row{display:grid;grid-template-columns:48px 1fr 200px 80px 140px;align-items:center}
body.theme-light .modal{background:#fff;color:var(--text)}
body.theme-light .sm-icon-wrap{font-size:32px;width:56px;height:56px;border-radius:14px;background:var(--bg3);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;flex-shrink:0;line-height:1}
.svc-nav{display:flex;align-items:center;gap:8px;width:100%}
.svc-nav-title{flex:1;font-size:15px;font-weight:600;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text)!important}
.modal-hdr h3,.modal-hdr span{color:var(--text)!important}
.modal-hdr{background:var(--bg2);border-color:var(--border)}
body.theme-light .page-hdr,.page-subhdr{color:var(--text)}
body.theme-light .attention-bar{background:#fef3c7;border-color:#fcd34d;color:#92400e}
body.theme-light .user-menu,body.theme-light .theme-panel{background:#fff!important;border-color:#e2e8f0!important;color:var(--text)!important}
body.theme-light .um-item{color:var(--text)!important}
body.theme-light .health-panel{background:#fff}
body.theme-light .outages-view,.ep-summary,.ep-wf-card,.ep-table,.ep-row{background:var(--card-bg);color:var(--text)}
body.theme-light .tab.active{background:rgba(255,255,255,.2);color:#fff}
body.effects-on #nrt-app{background:linear-gradient(160deg,var(--bg) 0%,var(--bg2) 60%,var(--bg) 100%)}

/* Header */
.hdr{position:relative;z-index:2500;background:var(--hdr-bg);border-bottom:1px solid var(--border);padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:56px;flex-shrink:0}
body.effects-on .hdr{background:linear-gradient(90deg,var(--bg),var(--bg2))}
.hdr-left{display:flex;align-items:center;gap:12px}
.nrt-logo{width:36px;height:36px;background:#119394;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;color:#fff;letter-spacing:.05em;flex-shrink:0}
body.effects-on .nrt-logo{background:linear-gradient(135deg,var(--accent2),var(--accent));box-shadow:0 0 12px rgba(6,182,212,.4)}
.hdr-title{font-size:14px;font-weight:700;color:var(--text);line-height:1.2}
.hdr-sub{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.1em}
.hdr-right{display:flex;align-items:center;gap:12px}
.hg-badge{background:#0f2a1a;border:1px solid #166534;border-radius:14px;padding:4px 12px;font-size:12px;color:var(--live);display:flex;align-items:center;gap:6px}
.hg-badge{cursor:pointer;position:relative}
.hg-popover{position:fixed;z-index:3000;display:none;background:var(--card-bg);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.5);padding:14px 16px;min-width:210px;display:none;width:max-content}
.hg-popover.open{display:block}
.hg-pop-title{font-size:12px;font-weight:600;color:var(--text2);margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid var(--border)}
.hg-pop-comm{font-size:11px;color:var(--text3);padding:3px 0;display:flex;align-items:center;gap:6px}
.hg-pop-comm::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--live);flex-shrink:0}
.hg-pop-links{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px;padding-top:8px;border-top:1px solid var(--border)}
.hg-pop-link{font-size:11px;color:var(--accent);text-decoration:none;cursor:pointer}
.hg-pop-link:hover{text-decoration:underline}
.hg-dot{width:7px;height:7px;border-radius:50%;background:var(--live);display:inline-block}
body.effects-on .hg-dot{box-shadow:0 0 6px rgba(34,197,94,.8)}
.user-btn{width:32px;height:32px;border-radius:50%;background:var(--border);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:#94a3b8;cursor:pointer;border:1px solid transparent;transition:border-color .15s}
.user-btn:hover{border-color:var(--accent)}

/* Tabs */
body.effects-on .tab{overflow:hidden;position:relative}
body.effects-on 
body.effects-on /* drag-over indicator - clean separate rule */
.tab.drag-over{border-bottom:3px solid var(--accent)!important;background:rgba(14,165,233,.10)!important;opacity:1!important}
.acc{border:1px solid var(--border);border-radius:8px;margin-bottom:7px;overflow:hidden}
.acc-hdr{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--bg3);cursor:pointer;border:none;width:100%;color:var(--text2);font-size:12px;font-weight:600;text-align:left;user-select:none;outline:none}
.acc-hdr:hover{background:var(--row-hover)}
.acc-chev{font-size:10px;transition:transform .2s;margin-left:auto}
.acc-hdr.open .acc-chev{transform:rotate(180deg)}
.acc-body{display:none;padding:10px 12px}
.acc-hdr.open + .acc-body{display:block}
.pt-btn{background:var(--bg3);border:1px solid var(--border);border-radius:6px;padding:4px 7px;font-size:13px;cursor:pointer;transition:all .15s;line-height:1}
.pt-btn.active{border-color:var(--accent);background:rgba(14,165,233,.18)}
.pt-btn:hover{border-color:var(--accent)}
.ptype-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:4px;margin-bottom:4px}
.rupee-color-row{display:none}
.rupee-color-row.active{display:block}
.tp-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.tp-hdr span{font-size:13px;font-weight:700;color:var(--text2)}
.tp-divider{border:none;border-top:1px solid var(--border2);margin:6px 0}
.tp-sec-label{font-size:10px;font-weight:700;color:var(--text4);text-transform:uppercase;letter-spacing:.07em;margin:8px 0 5px}

.tab[draggable]{cursor:grab}
.tabs{background:var(--hdr-bg);border-bottom:1px solid var(--border);padding:0 24px;display:flex;align-items:flex-end;flex-shrink:0;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.tab{display:flex;align-items:center;gap:7px;padding:10px 16px;cursor:pointer;border-bottom:2px solid transparent;color:var(--text4);font-size:13px;transition:color .15s;user-select:none}
.tab.active{border-bottom-color:var(--accent);color:var(--text)}
.tab-badge{border-radius:10px;padding:1px 7px;font-size:11px;font-weight:600}
.tab.active .tab-badge{background:var(--accent);color:#fff}
.tab:not(.active) .tab-badge{background:var(--border);color:var(--text4);font-size:10px}
.tab:not(.active):not([disabled]):hover{color:var(--text2)}

/* Main scroll area */
.main{flex:1;overflow-y:auto}

/* Page header row */
.page-hdr{padding:20px 24px 0;display:flex;align-items:center;justify-content:space-between}
.page-title{margin:0;font-size:18px;font-weight:700;color:var(--text);line-height:1}
.page-sub{margin:4px 0 0;font-size:13px;color:var(--text3)}
.page-hdr-right{display:flex;align-items:center;gap:12px;margin-left:auto!important;padding-left:16px}
#last-updated{font-size:13px;color:var(--text3)}
.btn-refresh{display:flex;align-items:center;gap:6px;background:var(--accent);color:#fff;border:none;border-radius:8px;padding:7px 14px;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s}
.btn-refresh:hover{background:var(--accent2)}
body.effects-on .btn-refresh{box-shadow:0 0 12px rgba(6,182,212,.3)}

/* Stats */
.stats-wrap{position:relative;margin:16px 24px}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border-radius:10px;overflow:hidden;border:1px solid var(--border)}
.stat-card{background:var(--card-bg);border:1px solid var(--border);border-radius:10px;padding:16px 20px;transition:all .2s;position:relative;overflow:hidden;cursor:default}
.stat-card::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent);border-radius:10px 10px 0 0;opacity:.6}

body.effects-on .stat-card{box-shadow:var(--stat-glow)}
.stat-label{font-size:11px;color:var(--text4);text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px}
.stat-val{font-size:30px;font-weight:700;line-height:1}
.stat-sub{font-size:12px;color:#374151;margin-top:6px}
.stat-cfg-btn{position:absolute;top:-2px;right:0;background:transparent;border:none;color:var(--text4);cursor:pointer;font-size:14px;padding:4px 6px;border-radius:4px;transition:color .15s}
.stat-cfg-btn:hover{color:var(--text2)}

/* Filters */
#filter-bar{padding:0 24px 10px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.fchip{border-radius:14px;padding:4px 12px;font-size:12px;overflow:hidden;position:relative;cursor:pointer;border:1px solid var(--border);background:transparent;color:var(--text3);transition:all .15s}
.fchip.active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}
.fchip:not(.active):hover{border-color:var(--text3);color:var(--text2)}
.search-input{margin-left:auto;background:var(--card-bg);border:1px solid var(--border);border-radius:6px;padding:5px 12px;color:var(--text2);font-size:12px;width:180px;outline:none;transition:border-color .15s}
.search-input:focus{border-color:var(--accent)}

/* Table header */
.tbl-hdr{display:grid;grid-template-columns:48px 1fr 200px 80px 140px;gap:12px;padding:6px 24px;border-top:1px solid var(--border2);border-bottom:1px solid var(--border2)}
.tbl-hdr-cell{font-size:11px;color:var(--text4);text-transform:uppercase;letter-spacing:.08em}

/* Client rows */
.client-row{display:grid;grid-template-columns:48px 1fr 200px 80px 140px;gap:12px;padding:13px 24px;border-bottom:1px solid var(--border2);align-items:center;cursor:pointer;transition:background .1s}
.client-row:hover{background:var(--row-hover)}
.client-avatar{width:42px;height:42px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
body.effects-on .client-avatar{box-shadow:0 2px 8px rgba(0,0,0,.4)}
.client-name{font-size:14px;font-weight:600;color:#f1f5f9}
.client-domain{font-size:12px;color:var(--text4);margin-top:2px}
.tag{border-radius:4px;padding:2px 8px;font-size:11px;font-weight:500;white-space:nowrap;margin-right:4px;display:inline-block}
.tag-gov{background:var(--tag-gov-bg);color:var(--tag-gov-c);overflow:hidden;position:relative}
.tag-health{background:var(--tag-health-bg);color:var(--tag-health-c);overflow:hidden;position:relative}
.tag-nfp{background:var(--tag-nfp-bg);color:var(--tag-nfp-c);overflow:hidden;position:relative}
body.effects-on .tag-gov::after,body.effects-on .tag-health::after,body.effects-on .tag-nfp::after{content:'';position:absolute;inset:0;border-radius:inherit;background:linear-gradient(105deg,transparent 30%,rgba(255,255,255,.22) 50%,transparent 70%);transform:translateX(-100%) skewX(-15deg);pointer-events:none}
body.effects-on .tag-gov:hover::after,body.effects-on .tag-health:hover::after,body.effects-on .tag-nfp:hover::after,body.effects-on .tag-gov.sh-hold::after,body.effects-on .tag-health.sh-hold::after,body.effects-on .tag-nfp.sh-hold::after{animation:shimmer-sweep var(--shimmer-dur,.55s) ease forwards}
.status-txt{font-size:13px;color:var(--text3);text-align:right}
.status-num{color:var(--live);font-weight:700}
.dots-wrap{display:flex;justify-content:flex-end;gap:5px}
.dot{width:12px;height:12px;border-radius:50%;cursor:pointer;transition:transform .1s}
.dot:hover{transform:scale(1.4)}
.dot-live{background:var(--live);box-shadow:var(--dot-live-glow)}
.dot-pend{background:var(--pend)}
.dot-none{background:var(--border);border:1px solid #334155}

.dot-legend{display:flex;align-items:center;gap:8px;padding:3px 10px;font-size:11px;color:var(--text4);background:var(--bg2);border:1px solid var(--border);border-radius:6px;width:auto;margin:0}
.dl-item{display:flex;align-items:center;gap:5px;white-space:nowrap}
.dl-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.dl-dot.live{background:var(--live);box-shadow:var(--dot-live-glow)}
.dl-dot.pend{background:var(--pend)}
.dl-dot.none{background:var(--border);border:1px solid #334155}
/* Tooltip */
.tt{position:relative;display:inline-block;overflow:visible;z-index:100}
.tp{visibility:hidden;background:#1e293b;color:var(--text2);border:1px solid #334155;border-radius:6px;padding:8px 12px;font-size:12px;white-space:nowrap;position:absolute;z-index:3100;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);pointer-events:none;opacity:0;transition:opacity .15s;box-shadow:0 4px 12px rgba(0,0,0,.4)}
.tt:hover .tp{visibility:visible;opacity:1}
.tp::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:#334155}

/* Overlay / modal base */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:1000;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(.2px)}
.modal{background:var(--bg2);border:1px solid var(--border);border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,.6);max-height:85vh;overflow:hidden;display:flex;flex-direction:column}
.modal-sm{width:400px}
.modal-md{width:520px}
.modal-lg{width:720px}
.modal-hdr{padding:20px 24px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.modal-hdr h3{margin:0;font-size:16px;font-weight:700;color:var(--text)}
.modal-body{padding:20px 24px;overflow-y:auto;flex:1}
.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end;flex-shrink:0}
.btn-close{background:transparent;border:none;color:var(--text3);font-size:20px;cursor:pointer;line-height:1;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}
.btn-close:hover{color:var(--text)}
.btn-primary{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:500;cursor:pointer}
.btn-primary:hover{background:var(--accent2)}
.btn-ghost{background:transparent;color:var(--text3);border:1px solid var(--border);border-radius:8px;padding:8px 16px;font-size:13px;cursor:pointer}
.btn-ghost:hover{color:var(--text2);border-color:var(--text3)}
.btn-danger{background:#dc2626;color:#fff;border:none;border-radius:8px;padding:8px 16px;font-size:13px;cursor:pointer}

/* Client modal specifics */
.cm-header-inner{display:flex;align-items:center;gap:16px}
.cm-avatar{width:56px;height:56px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;color:#fff;flex-shrink:0}
.cm-name{font-size:20px;font-weight:700;color:var(--text);margin:0 0 4px}
.cm-domain{font-size:13px;color:var(--text3)}
.cm-section{margin-bottom:20px}
.cm-section-title{font-size:11px;color:var(--text4);text-transform:uppercase;letter-spacing:.1em;margin-bottom:10px}
.cm-services{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.cm-svc{background:var(--bg3);border:1px solid var(--border2);border-radius:8px;padding:12px;display:flex;flex-direction:column;gap:6px;cursor:pointer;transition:border-color .15s}
.cm-svc:hover{border-color:var(--accent)}
.cm-isp-bar{display:flex;gap:8px;flex-wrap:wrap;padding:8px 0 10px;border-bottom:1px solid var(--border2);margin-bottom:10px}
.cm-isp-item{background:var(--bg3);border:1px solid var(--border);border-radius:6px;padding:4px 10px;font-size:12px;color:var(--text2)}
.cm-isp-lbl{display:block;font-size:10px;color:var(--text4);text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px}
.cm-svc-lbl{font-size:12px;color:var(--text3)}
.cm-svc-status{font-size:12px;font-weight:600}
.cm-svc-status.live{color:var(--live)}
.cm-svc-status.pending{color:var(--pend)}
.cm-svc-status.none{color:var(--text4)}
.cm-vars{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.cm-var{background:var(--bg3);border-radius:6px;padding:8px 12px;font-size:12px}
.cm-var-key{color:var(--text4);margin-bottom:2px}
.cm-var-val{color:var(--text2);font-family:monospace;word-break:break-all}

/* Service modal */
.sm-client{font-size:13px;color:var(--text3);margin-bottom:16px}
.sm-status-row{display:flex;gap:8px;margin-bottom:20px}
.sm-status-btn{flex:1;padding:10px;border-radius:8px;border:2px solid var(--border);background:transparent;color:var(--text3);font-size:13px;cursor:pointer;transition:all .15s;text-align:center}
.sm-status-btn:hover{border-color:var(--text3);color:var(--text2)}
.sm-status-btn.sel-live{border-color:var(--live);background:rgba(34,197,94,.1);color:var(--live)}
.sm-status-btn.sel-pending{border-color:var(--pend);background:rgba(245,158,11,.1);color:var(--pend)}
.sm-status-btn.sel-none{border-color:var(--text4);background:rgba(71,85,105,.1);color:var(--text4)}
.sm-svc-info{background:var(--bg3);border-radius:8px;padding:12px 16px;font-size:13px;color:var(--text3);margin-bottom:16px;line-height:1.6}
.sm-desc-wrap{position:relative}
.sm-edit-btn{position:absolute;top:4px;right:4px;background:transparent;border:none;cursor:pointer;color:var(--text4);font-size:13px;opacity:.6;padding:2px 5px;border-radius:4px;transition:opacity .15s}
.sm-edit-btn:hover{opacity:1;background:var(--bg3)}
.sm-desc-edit{width:100%;min-height:72px;background:var(--bg3);border:1px solid var(--accent);border-radius:6px;color:var(--text);padding:8px;font-size:13px;resize:vertical;box-sizing:border-box}
.sm-desc-save-row{display:flex;gap:6px;margin-top:6px;align-items:center}
.sm-desc-save-lbl{font-size:11px;color:var(--text4)}
.sm-toast{display:none;background:rgba(34,197,94,.15);border:1px solid var(--live);border-radius:6px;padding:8px 12px;font-size:12px;color:var(--live);margin-top:8px}

/* User menu */
.user-menu{position:fixed;z-index:1000;top:58px;right:16px;width:220px;background:var(--bg2);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.4);z-index:900;overflow:hidden}
.um-header{padding:14px 16px 12px;border-bottom:1px solid var(--border)}
.um-name{font-size:14px;font-weight:600;color:var(--text)}
.um-role{font-size:12px;color:var(--text3);margin-top:2px}
.um-item{display:flex;align-items:center;gap:10px;padding:10px 16px;font-size:13px;color:var(--text2);cursor:pointer;transition:background .1s;border:none;background:transparent;width:100%;text-align:left}
.um-item:hover{background:var(--border2)}
.um-item-icon{width:16px;text-align:center;color:var(--text3)}
.um-divider{height:1px;background:var(--border);margin:4px 0}
.um-item.danger{color:#f87171}
.um-item.danger .um-item-icon{color:#f87171}

/* Theme panel */
.theme-panel{position:fixed;top:58px;right:8px;z-index:1000;width:min(300px,calc(100vw - 16px));max-height:calc(100vh - 80px);overflow-y:auto;overflow-x:hidden;background:var(--bg2);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.4);z-index:900;padding:16px;max-height:none}
.theme-title{font-size:12px;color:var(--text4);text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px}
.theme-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.theme-swatch{border:2px solid var(--border);border-radius:8px;padding:10px;cursor:pointer;transition:border-color .15s}
.theme-swatch.active{border-color:var(--accent)}
.theme-swatch:hover:not(.active){border-color:var(--text3)}
.theme-preview{height:32px;border-radius:4px;margin-bottom:6px}
.theme-name{font-size:12px;color:var(--text2);text-align:center}

/* Stats config modal */
.stat-opt{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border2)}
.stat-opt:last-child{border-bottom:none}
.stat-opt-info{font-size:13px;color:var(--text2)}
.stat-opt-val{font-size:12px;color:var(--text3);margin-top:2px}
.stat-chk{width:18px;height:18px;accent-color:var(--accent);cursor:pointer}

/* Toast notification */
#toast{position:fixed;bottom:24px;right:24px;background:#1e293b;border:1px solid var(--border);border-radius:8px;padding:12px 16px;font-size:13px;color:var(--text2);box-shadow:0 4px 16px rgba(0,0,0,.4);z-index:2000;transition:opacity .3s;opacity:0;pointer-events:none}
#toast.show{opacity:1}

/* === SHINY EFFECTS === */
:root{
  --shimmer-color:rgba(255,255,255,.22);
  --shimmer-clr2:rgba(255,255,255,.08);
}


@keyframes shimmer-pulse{0%{box-shadow:0 0 0 0 var(--shimmer-color)}50%{box-shadow:0 0 18px 4px var(--shimmer-color)}100%{box-shadow:0 0 0 0 transparent}}
@keyframes shimmer-glow{0%,100%{filter:brightness(1)}50%{filter:brightness(1.35) drop-shadow(0 0 8px var(--shimmer-color))}}
@keyframes shimmer-rainbow{0%{background-position:-200%}100%{background-position:300%}}
body.effects-on.shake-s .client-row:hover,body.effects-on.shake-s .stat-card:hover,body.effects-on.shake-s .fchip:hover{animation:shake-s .4s ease!important}
body.effects-on.shake-m .client-row:hover,body.effects-on.shake-m .stat-card:hover,body.effects-on.shake-m .fchip:hover{animation:shake-m .4s ease!important}
body.effects-on.shake-w .client-row:hover,body.effects-on.shake-w .stat-card:hover,body.effects-on.shake-w .fchip:hover{animation:shake-w .5s ease!important}
@keyframes shake-s{0%,100%{transform:translateX(0)}20%{transform:translateX(-2px) rotate(-.5deg)}40%{transform:translateX(2px) rotate(.5deg)}60%{transform:translateX(-2px)}80%{transform:translateX(2px)}}
@keyframes shake-m{0%,100%{transform:translateX(0)}20%{transform:translateX(-4px) rotate(-1deg)}40%{transform:translateX(4px) rotate(1deg)}60%{transform:translateX(-3px)}80%{transform:translateX(3px)}}
@keyframes shake-w{0%,100%{transform:translateX(0) rotate(0)}15%{transform:translateX(-8px) rotate(-3deg)}30%{transform:translateX(8px) rotate(3deg)}45%{transform:translateX(-6px) rotate(-2deg)}60%{transform:translateX(6px) rotate(2deg)}75%{transform:translateX(-4px)}90%{transform:translateX(4px)}}
@keyframes dot-pulse{0%,100%{box-shadow:0 0 0 0 var(--live)}50%{box-shadow:0 0 6px 2px var(--live)}}
@keyframes dot-pulse-pend{0%,100%{box-shadow:0 0 0 0 var(--pend)}50%{box-shadow:0 0 6px 2px var(--pend)}}
@keyframes shimmer-fly{0%{transform:translateX(-110%) skewX(-12deg)}100%{transform:translateX(110%) skewX(-12deg)}}
@keyframes shimmer-pulse-anim{0%,100%{opacity:0}40%,60%{opacity:1}}
@keyframes shimmer-glow-anim{0%,100%{opacity:0}40%,60%{opacity:0.35}}
@keyframes shimmer-glow-outer{0%,100%{filter:none}50%{filter:drop-shadow(0 0 14px var(--shimmer-color))}}
body.effects-on .client-row{position:relative}
body.effects-on .client-row::after{content:'';position:absolute;inset:0;background:linear-gradient(105deg,transparent 35%,rgba(6,182,212,.12) 50%,transparent 65%);transform:translateX(-100%) skewX(-15deg);pointer-events:none;transition:none}
body.effects-on .client-row:hover::after,body.effects-on .client-row.sh-hold::after{animation:shimmer-sweep var(--shimmer-dur,.55s) ease forwards}
body.effects-on .stat-card{overflow:hidden;position:relative}
body.effects-on .stat-card::after{content:'';position:absolute;inset:0;background:linear-gradient(105deg,transparent 35%,rgba(6,182,212,.10) 50%,transparent 65%);transform:translateX(-100%) skewX(-15deg);pointer-events:none}
body.effects-on .stat-card:hover::after,body.effects-on .stat-card.sh-hold::after{animation:shimmer-sweep var(--shimmer-dur,.55s) ease forwards}
body.effects-on .cm-svc{overflow:hidden;position:relative}
body.effects-on .cm-svc::after{content:'';position:absolute;inset:0;background:linear-gradient(105deg,transparent 30%,rgba(6,182,212,.15) 50%,transparent 70%);transform:translateX(-100%) skewX(-15deg);pointer-events:none}
body.effects-on .cm-svc:hover::after,body.effects-on .cm-svc.sh-hold::after{animation:shimmer-sweep var(--shimmer-dur,.55s) ease forwards}
body.effects-on .fchip{overflow:hidden;position:relative}
body.effects-on .fchip::after{content:'';position:absolute;inset:0;border-radius:14px;background:linear-gradient(105deg,transparent 30%,rgba(255,255,255,.12) 50%,transparent 70%);transform:translateX(-100%) skewX(-15deg);pointer-events:none}
body.effects-on .fchip:hover::after,body.effects-on .fchip.sh-hold::after{animation:shimmer-sweep var(--shimmer-dur,.55s) ease forwards}
#nrt-particle-canvas{position:fixed;inset:0;pointer-events:none;z-index:2400}
body.effects-on{--dot-live-glow:0 0 8px rgba(34,197,94,.6);--stat-glow:0 0 20px rgba(6,182,212,.1)}
@keyframes logo-shine{0%{transform:translateX(-150%) rotate(-45deg)}50%{transform:translateX(300%) rotate(-45deg)}100%{transform:translateX(300%) rotate(-45deg)}}
.nrt-logo{overflow:hidden;position:relative}
.nrt-logo::after{content:'';position:absolute;inset:0;background:linear-gradient(to right,transparent,rgba(255,255,255,.3),transparent);transform:translateX(-150%) rotate(-45deg);animation:logo-shine 3.5s ease-in-out 1s infinite}
body.effects-on .client-avatar{overflow:hidden;position:relative}
body.effects-on .client-avatar::after{content:'';position:absolute;inset:0;background:linear-gradient(105deg,transparent 30%,rgba(255,255,255,.22) 50%,transparent 70%);transform:translateX(-100%) skewX(-15deg);pointer-events:none}
body.effects-on .client-avatar:hover::after{animation:shimmer-sweep var(--shimmer-dur,.55s) ease forwards}
@keyframes av-glow{0%,100%{box-shadow:0 0 6px 2px var(--av-c,rgba(6,182,212,.35)),0 2px 8px rgba(0,0,0,.35)}50%{box-shadow:0 0 18px 6px var(--av-c,rgba(6,182,212,.65)),0 2px 8px rgba(0,0,0,.35)}}
body.effects-on .client-avatar{animation:av-glow 3s ease-in-out infinite}
body.effects-on .client-avatar:hover{animation:av-glow .9s ease-in-out infinite}
#custom-color-panel{margin-top:10px;padding-top:10px;border-top:1px solid var(--border);display:none}
#custom-color-panel.active{display:block}
.cc-row{display:flex;align-items:center;justify-content:space-between;padding:5px 0;font-size:12px;color:var(--text3)}
.cc-row input[type=color]{width:40px;height:24px;border:1px solid var(--border);border-radius:4px;cursor:pointer;padding:1px;background:transparent}
.quick-dot-pop{position:fixed;z-index:3000;background:var(--card-bg);border:1px solid var(--border);border-radius:8px;padding:6px;box-shadow:0 4px 20px rgba(0,0,0,.6);display:none;min-width:160px}
.qdp-title{font-size:10px;color:var(--text4);padding:2px 6px 7px;border-bottom:1px solid var(--border2);margin-bottom:3px;text-transform:uppercase;letter-spacing:.06em}
.qdp-btn{display:flex;align-items:center;gap:8px;width:100%;padding:6px 8px;border:none;border-radius:5px;background:transparent;color:var(--text3);font-size:12px;cursor:pointer;transition:background .1s}
.qdp-btn:hover{background:var(--row-hover);color:var(--text)}
.qdp-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.qdp-chk{margin-left:auto;color:var(--accent)}
.effects-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;margin-top:10px;padding:8px;border:1.5px solid var(--border);border-radius:8px;background:transparent;color:var(--text3);font-size:12px;cursor:pointer;transition:all .15s}
.effects-btn.active{border-color:var(--accent);background:rgba(6,182,212,.1);color:var(--accent)}
.effects-btn:hover:not(.active){border-color:var(--text3);color:var(--text2)}
.speed-row{display:flex;gap:4px;margin-top:6px}
.health-btn{position:relative;z-index:auto;width:36px;height:36px;border-radius:50%;background:var(--card-bg);border:1px solid var(--border);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text3);transition:all .15s;font-size:14px}
.health-btn:hover{border-color:var(--accent);color:var(--accent)}
.health-btn.has-errors{border-color:#ef4444;color:#f87171}@keyframes fire-flicker{0%{box-shadow:0 0 5px #f97316,0 0 10px #ef4444}33%{box-shadow:0 0 14px #f97316,0 0 22px #dc2626,0 -5px 10px #fbbf24}66%{box-shadow:0 0 8px #ea580c,0 0 16px #b91c1c}100%{box-shadow:0 0 5px #f97316,0 0 10px #ef4444}}
.health-btn.on-fire{animation:fire-flicker .4s ease-in-out infinite!important;border-color:#f97316!important;color:#fbbf24!important}
.health-btn.status-ok{border-color:var(--live)!important;color:var(--live)!important}
.health-btn.status-warn{border-color:var(--pend)!important;color:var(--pend)!important}
.health-btn.status-err{border-color:#ef4444!important;color:#f87171!important}

@keyframes hb-pulse{0%,100%{box-shadow:0 0 0 0 rgba(239,68,68,.4)}50%{box-shadow:0 0 0 6px rgba(239,68,68,0)}}
.health-panel{position:fixed;top:58px;right:8px;z-index:1000;z-index:1000;bottom:64px;right:20px;width:420px;max-height:400px;background:var(--card-bg);border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.4);display:none;flex-direction:column}
.health-panel.open{display:flex}
.hp-hdr{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);font-size:13px;font-weight:600;color:var(--text)}
.hp-hdr-actions{display:flex;gap:6px}
.hp-action-btn{padding:4px 10px;border:1px solid var(--border);border-radius:5px;background:transparent;color:var(--text3);font-size:11px;cursor:pointer;transition:all .15s}
.hp-action-btn:hover{border-color:var(--accent);color:var(--accent)}
.hp-body{overflow-y:auto;flex:1;padding:8px 0}
.hp-empty{padding:24px;text-align:center;color:var(--text4);font-size:12px}
.hp-row{padding:8px 16px;border-bottom:1px solid var(--border2);font-size:11px}
.hp-row:last-child{border-bottom:none}
.hp-row:hover{background:var(--row-hover)}
.hp-time{color:var(--text4);margin-bottom:2px}
.hp-msg{color:var(--text2);word-break:break-word}
.hp-src{color:var(--text4);font-size:10px;margin-top:2px}
.hp-badge{display:inline-block;padding:1px 7px;border-radius:8px;font-size:10px;margin-right:6px}
.hp-badge.error{background:rgba(239,68,68,.15);color:#f87171}
.hp-badge.warn{background:rgba(245,158,11,.15);color:var(--pend)}
.hp-badge.info{background:rgba(6,182,212,.15);color:var(--accent)}
.ea-from-row{display:flex;gap:6px;margin-bottom:10px;flex-wrap:wrap}
.ea-from-btn{flex:1;padding:8px 6px;border:1.5px solid var(--border);border-radius:7px;background:transparent;color:var(--text3);font-size:11px;cursor:pointer;transition:all .15s;text-align:center;line-height:1.3}
.ea-from-btn.active{border-color:var(--accent);background:rgba(6,182,212,.1);color:var(--accent)}
.ea-from-btn:hover:not(.active){border-color:var(--text3);color:var(--text2)}
.outage-map-section{margin:0 12px 16px;border:1px solid var(--border);border-radius:10px;overflow:visible}
.outage-map-hdr{padding:10px 14px;background:var(--card-bg);border-bottom:1px solid var(--border);font-size:11px;color:var(--text4);text-transform:uppercase;letter-spacing:.08em;display:flex;justify-content:space-between;align-items:center}




#endpoints-view{display:none;padding:0 0 32px}
.ep-summary{display:flex;gap:12px;padding:16px 24px 8px;flex-wrap:wrap}
.ep-stat{background:var(--card-bg);border:1px solid var(--border);border-radius:8px;padding:12px 16px;min-width:110px}
.ep-stat-num{font-size:22px;font-weight:700;color:var(--text)}
.ep-stat-lbl{font-size:11px;color:var(--text4);margin-top:2px}
.ep-ok{color:var(--live)}.ep-warn{color:var(--pend)}.ep-err{color:#f87171}.ep-na{color:var(--text4)}
.ep-wf-grid{display:flex;flex-direction:column;gap:8px;margin-bottom:4px}
.ep-wf-card{display:flex;align-items:center;gap:12px;background:var(--card-bg);border:1px solid var(--border);border-radius:8px;padding:12px 16px}
.ep-wf-icon{font-size:20px;width:32px;text-align:center;flex-shrink:0}
.ep-wf-body{flex:1}
.ep-wf-name{font-size:13px;font-weight:600;color:var(--text2)}
.ep-wf-desc{font-size:11px;color:var(--text4);margin-top:2px}
.ep-wf-badge{font-size:10px;padding:3px 9px;border-radius:10px;font-weight:600;flex-shrink:0}
.ep-badge-ok{background:rgba(34,197,94,.15);color:var(--live)}
.ep-badge-pend{background:rgba(245,158,11,.12);color:var(--pend)}
.ep-table{margin:0 24px;border:1px solid var(--border);border-radius:8px;overflow:hidden}
.ep-row{display:grid;grid-template-columns:1fr 130px 70px 70px 70px 80px;gap:8px;padding:9px 14px;border-bottom:1px solid var(--border2);font-size:12px;align-items:center}
.ep-row:last-child{border-bottom:none}
.ep-row:hover{background:var(--row-hover)}
.ep-hdr{background:var(--card-bg);font-size:10px;color:var(--text4);text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.ep-hdr:hover{background:var(--card-bg)}
.ep-section{padding:0 24px}
#stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(120px,45%),1fr));gap:10px;padding:16px 24px 4px}
/* Tab CSS visibility */
body:not(.nrt-tab-clients) .page-hdr,body:not(.nrt-tab-clients) #stats-grid,body:not(.nrt-tab-clients) #filter-bar,body:not(.nrt-tab-clients) #view-toggle-bar,body:not(.nrt-tab-clients) .tbl-hdr,body:not(.nrt-tab-clients) #attention-bar,body:not(.nrt-tab-clients) #client-list,body:not(.nrt-tab-clients) .stat-cfg-btn,body:not(.nrt-tab-clients) #dot-legend-inline{display:none!important}
.tab:focus,.client-row:focus,.stat-card:focus,.fchip:focus,.tab-btn:focus,#game-btn:focus{outline:none}
body.theme-chrome{--bg:#070d12;--bg2:#0c1820;--bg3:#0a1520;--hdr-bg:#040c12;--card-bg:#0c1820;--border:#0e3d4a;--border2:#0a2d38;--row-hover:rgba(6,182,212,.06);--accent:#06b6d4;--accent2:#0891b2;--live:#06b6d4;--text:#d0f4fb;--text2:#a8e6f0;--text3:#5bb5cc;--text4:#3a7d8c;--stat-glow:0 0 20px rgba(6,182,212,.18)}
.shimmer-fly{position:fixed;pointer-events:none;z-index:1;overflow:hidden}
.shimmer-fly.sh-glow{overflow:visible}
.shimmer-fly.sh-pulse,.shimmer-fly.sh-rainbow,.shimmer-fly:not(.sh-glow){overflow:hidden}
.shimmer-fly-inner{position:absolute;inset:0;background:linear-gradient(105deg,transparent 10%,var(--shimmer-color) 45%,var(--shimmer-clr2) 55%,transparent 85%);transform:translateX(-110%) skewX(-12deg);animation:shimmer-fly var(--shimmer-dur,.55s) ease forwards}
.shimmer-fly.sh-pulse .shimmer-fly-inner{animation:shimmer-pulse-anim var(--shimmer-dur,.55s) ease forwards;background:var(--shimmer-color);opacity:0;transform:none}
.shimmer-fly.sh-glow{animation:shimmer-glow-outer var(--shimmer-dur,.55s) ease forwards}
.shimmer-fly.sh-glow .shimmer-fly-inner{background:var(--shimmer-color);transform:none;border-radius:inherit;animation:shimmer-glow-anim var(--shimmer-dur,.55s) ease forwards}
.shimmer-fly.sh-rainbow .shimmer-fly-inner{background:linear-gradient(105deg,#f00,#ff0,#0f0,#0ff,#00f,#f0f);animation:shimmer-fly var(--shimmer-dur,.55s) ease forwards}
.shimmer-fly.sh-pulse.sh-rainbow .shimmer-fly-inner{background:linear-gradient(90deg,#f00,#ff0,#0f0,#0ff,#00f,#f0f)!important;animation:shimmer-pulse-anim var(--shimmer-dur,.55s) ease forwards!important;transform:none!important}
.shimmer-fly.sh-glow.sh-rainbow .shimmer-fly-inner{background:linear-gradient(135deg,#f00,#ff0,#0f0,#0ff,#00f,#f0f)!important}
.legend{display:flex;align-items:center;gap:8px;padding:4px 8px;font-size:11px;color:var(--text3)}
.legend-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}
/* Shimmer targets must clip their ::after overflow */
.client-row{position:relative;overflow:hidden}
.tab{position:relative;overflow:clip}
.tag-gov,.tag-health,.tag-nfp{position:relative;overflow:hidden}
/* Explicit show rules for Clients tab */
body.nrt-tab-clients .page-hdr{display:flex!important;align-items:center!important}
body.nrt-tab-clients #stats-grid{display:grid!important}
body.nrt-tab-clients #filter-bar{display:flex!important}
body.nrt-tab-clients #view-toggle-bar{display:flex!important}
body.nrt-tab-clients .tbl-hdr{display:grid!important}
body.nrt-tab-clients #attention-bar{display:block!important}
body.nrt-tab-clients #client-list{display:block!important}
body.nrt-tab-clients .stat-cfg-btn{display:block!important}
body.nrt-tab-clients #dot-legend-inline{display:flex!important}
#outages-view,#endpoints-view,#networks-view,#projects-view,#reports-view{display:none!important}
body.nrt-tab-outages #outages-view{display:block!important}
body.nrt-tab-networks #networks-view{display:block!important}
body.nrt-tab-endpoints #endpoints-view{display:block!important}
body.nrt-tab-reports #reports-view{display:block!important}
body.nrt-tab-projects #projects-view{display:block!important}
body.nrt-tab-endpoints #endpoints-view{display:block!important}
/* Shimmer styles */

body.effects-on.sh-pulse .sh-hold,.sh-hold-b{animation:shimmer-pulse var(--shimmer-dur,.55s) ease!important;}
body.effects-on.sh-pulse .sh-hold::after{display:none!important}
body.effects-on.sh-glow .sh-hold,.sh-hold-b{animation:shimmer-glow var(--shimmer-dur,.55s) ease!important}
body.effects-on.sh-glow .sh-hold::after{display:none!important}
body.effects-on.sh-rainbow .sh-hold::after,body.effects-on.sh-rainbow .sh-hold-b::after{background:linear-gradient(105deg,transparent 0%,#f87171 25%,#fb923c 35%,#fbbf24 45%,var(--shimmer-color) 50%,#34d399 55%,#60a5fa 65%,#a78bfa 75%,transparent 100%);background-size:200% 100%;animation:shimmer-rainbow var(--shimmer-dur,.55s) linear forwards}
body.effects-on.shake-s .sh-hold:not(.tab){animation:shimmer-sweep var(--shimmer-dur,.55s) ease forwards,shake-s .35s ease!important}
body.effects-on.shake-m .sh-hold:not(.tab){animation:shimmer-sweep var(--shimmer-dur,.55s) ease forwards,shake-m .35s ease!important}
body.effects-on.shake-w .sh-hold:not(.tab){animation:shimmer-sweep var(--shimmer-dur,.55s) ease forwards,shake-w .4s ease!important}
body.effects-on.sh-pulse.shake-s .sh-hold:not(.tab){animation:shimmer-pulse var(--shimmer-dur,.55s) ease,shake-s .35s ease!important}
body.effects-on.sh-pulse.shake-m .sh-hold:not(.tab){animation:shimmer-pulse var(--shimmer-dur,.55s) ease,shake-m .35s ease!important}
body.effects-on.sh-pulse.shake-w .sh-hold:not(.tab){animation:shimmer-pulse var(--shimmer-dur,.55s) ease,shake-w .4s ease!important}
body.effects-on .live{box-shadow:0 0 5px 1px var(--live)!important;animation:dot-pulse 2.5s ease-in-out infinite}
body.effects-on .pend{box-shadow:0 0 5px 1px var(--pend)!important;animation:dot-pulse-pend 2s ease-in-out infinite}
body.effects-on .live:hover,body.effects-on .pend:hover{box-shadow:0 0 10px 3px currentColor!important}
/* Matrix view cm-svc shimmer */
body.effects-on .cm-svc-status{transition:all .15s}
body.effects-on .cm-svc-status.live{text-shadow:0 0 8px var(--live)}
body.effects-on .cm-svc-status.pending{text-shadow:0 0 8px var(--pend)}
#xp-hud{display:none}/* xp info moved to header */

#xp-level-badge{font-size:11px;font-weight:700;color:var(--accent);background:rgba(99,102,241,.15);border:1px solid var(--accent);border-radius:20px;padding:2px 8px;white-space:nowrap;flex-shrink:0}
#xp-label{font-size:10px;color:var(--text4);white-space:nowrap;flex-shrink:0}
#xp-track{flex:1;height:6px;background:var(--border);border-radius:3px;overflow:hidden;min-width:80px}
#xp-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--live));border-radius:3px;transition:width .4s ease;width:0%}
#xp-txt{font-size:10px;color:var(--text4);white-space:nowrap;flex-shrink:0}
.xp-float{position:fixed;pointer-events:none;z-index:3000;font-size:13px;font-weight:700;color:var(--accent);text-shadow:0 0 10px var(--accent);animation:xp-float-up 1.2s ease forwards}
@keyframes xp-float-up{0%{opacity:1;transform:translateY(0) scale(1)}100%{opacity:0;transform:translateY(-60px) scale(1.3)}}
.lvlup-toast{animation:lvlup .6s ease forwards}
@keyframes lvlup{0%{transform:scale(1)}40%{transform:scale(1.1)}70%{transform:scale(.95)}100%{transform:scale(1)}}
.gremlin{position:fixed;z-index:2200;cursor:pointer;user-select:none;pointer-events:all;padding:10px;box-sizing:content-box}
.gremlin.g-flee{pointer-events:none}
.g-inner{display:inline-block;animation:gremlin-bob .5s ease-in-out infinite;transform-origin:center bottom;filter:drop-shadow(0 3px 8px rgba(34,197,94,.5))}
.gremlin:not(.is-hamster):hover .g-inner{filter:drop-shadow(0 3px 14px rgba(34,197,94,.9)) brightness(1.15)}
@keyframes gremlin-bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}

.gremlin-badge{position:fixed;z-index:2200;pointer-events:none;font-size:10px;font-weight:700;color:#22c55e;text-shadow:0 0 6px #22c55e;animation:xp-float-up 1.2s ease forwards}
#gremlin-counter{position:fixed;bottom:30px;right:16px;z-index:3000;font-size:11px;color:var(--text4);background:rgba(0,0,0,.7);border:1px solid var(--border);border-radius:20px;padding:3px 10px;display:none;pointer-events:none}
#gremlin-counter.gc-show{display:block}
#outage-map{width:auto;height:auto;border-radius:8px;overflow:visible;background:#0a1628;position:relative}
.svg-map{width:100%;height:100%}
.map-marker{cursor:pointer;transition:transform .15s}
.map-marker:hover{transform:scale(1.4)}
.map-label{font-size:9px;fill:var(--text3);pointer-events:none;font-family:var(--font)}
.map-marker-dot{transition:all .2s}
#game-canvas-wrap{position:fixed;top:58px;left:0;right:0;bottom:80px;z-index:2000;display:none;background:#000;flex-direction:row}
#game-main-area{flex:1;position:relative;overflow:hidden;display:flex;flex-direction:column}
#game-sidebar{width:216px;flex-shrink:0;background:rgba(0,0,0,.85);border-left:1px solid #1a2d1a;display:flex;flex-direction:column;gap:8px;padding:8px;align-items:center}
@media(max-width:768px){#game-sidebar{display:none}}
#game-canvas-wrap.show{display:flex}
#game-canvas{display:block;width:100%;height:100%;image-rendering:pixelated;min-height:0;flex:1}
#game-hud{position:absolute;top:4px;left:4px;right:4px;display:flex;gap:6px;align-items:flex-start;pointer-events:none;flex-wrap:wrap}
#game-title-bar{background:rgba(0,0,0,.7);border:1px solid var(--border);border-radius:8px;padding:6px 14px;font-size:13px;font-weight:600;color:var(--accent)}
#game-controls-bar{background:rgba(0,0,0,.7);border:1px solid var(--border);border-radius:8px;padding:6px 10px;font-size:11px;color:var(--text3)}
#game-minimap{border:1px solid #1a4a20;border-radius:6px;background:#010306;display:block}
#minimap-zoom{display:flex;flex-direction:row;gap:4px;justify-content:center}
#minimap-zoom button{background:rgba(0,0,0,.6);border:1px solid var(--border);border-radius:4px;color:var(--text2);font-size:11px;width:20px;height:20px;cursor:pointer;padding:0;line-height:1}
#minimap-zoom button:hover{background:rgba(14,165,233,.3)}
#game-xp-bar{background:rgba(0,0,0,.7);border:1px solid var(--border);border-radius:8px;padding:6px 10px;font-size:11px;color:var(--text3);text-align:center;width:100%}
#boss-btn{display:none;pointer-events:all;z-index:2300}
#boss-btn.show{display:block}
#chaos-overlay{position:fixed;top:58px;left:0;right:0;bottom:0;z-index:2100;display:none;cursor:crosshair}
#chaos-overlay.show{display:block}
.chaos-grabbed{pointer-events:none!important;outline:3px dashed var(--chaos-color,var(--accent))!important;outline-offset:3px!important;filter:hue-rotate(40deg) brightness(1.12)!important;cursor:help!important;z-index:2200!important;box-shadow:0 0 16px var(--chaos-color,var(--accent)),inset 0 0 8px rgba(255,255,255,.05)!important;pointer-events:none!important}

.chaos-label{position:fixed;z-index:2200;background:rgba(239,68,68,.9);color:white;font-size:11px;padding:2px 8px;border-radius:4px;pointer-events:none;white-space:nowrap}
/* Particle selector UI */
.ptcl-section{margin-top:14px;padding-top:12px;border-top:1px solid var(--border)}
.ptcl-row{display:flex;gap:5px;flex-wrap:wrap;margin-top:6px}
.psel-btn{flex:1;min-width:52px;padding:6px 3px;border:1.5px solid var(--border);border-radius:7px;background:transparent;color:var(--text3);font-size:11px;cursor:pointer;text-align:center;transition:all .15s;line-height:1.3}
.psel-btn .pi{display:block;font-size:14px;margin-bottom:2px}
.psel-btn.active{border-color:var(--accent);background:rgba(6,182,212,.12);color:var(--accent)}
.psel-btn:hover:not(.active){border-color:var(--text3);color:var(--text2)}
.psel-size-row{display:flex;gap:4px;margin-top:6px}
.szsel-btn{flex:1;padding:5px 2px;border:1.5px solid var(--border);border-radius:6px;background:transparent;color:var(--text3);font-size:10px;cursor:pointer;text-align:center;transition:all .15s}
.szsel-btn.active{border-color:var(--accent);background:rgba(6,182,212,.12);color:var(--accent)}
.szsel-btn:hover:not(.active){border-color:var(--text3);color:var(--text2)}
.rcolor-row{display:none;flex-wrap:wrap;gap:4px;margin-top:6px}
.rcolor-row.active{display:flex}
.rcsel-btn{flex:1;padding:5px 2px;border:1.5px solid var(--border);border-radius:6px;background:transparent;font-size:13px;cursor:pointer;text-align:center;transition:all .15s}
.rcsel-btn.active{border-color:var(--accent);background:rgba(6,182,212,.12)}
.rcsel-btn:hover:not(.active){border-color:var(--text3)}



/* ── Outages Tab ─────────────────────────────────── */
#outages-view{display:none;padding:0 0 32px}
#outages-view.active{display:block}
.outage-section{padding:16px 24px 0}
.outage-section-title{font-size:11px;color:var(--text4);text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.outage-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px;margin-bottom:8px}
.outage-card{background:var(--card-bg);border:1px solid var(--border);border-radius:10px;padding:14px 16px;position:relative;overflow:hidden;transition:border-color .15s}
.outage-card.ok{border-left:3px solid var(--live)}
.outage-card.degraded{border-left:3px solid var(--pend)}
.outage-card.down{border-left:3px solid #ef4444}
.outage-card.manual{border-left:3px solid #8b5cf6}
.outage-card.unknown{border-left:3px solid var(--border)}
.oc-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.oc-name{font-size:13px;font-weight:600;color:var(--text)}
.oc-badge{border-radius:10px;padding:2px 9px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em}
.oc-badge.ok{background:rgba(34,197,94,.15);color:var(--live)}
.oc-badge.degraded{background:rgba(245,158,11,.15);color:var(--pend)}
.oc-badge.down{background:rgba(239,68,68,.15);color:#f87171}
.oc-badge.manual{background:rgba(139,92,246,.15);color:#c084fc}
.oc-badge.unknown{background:var(--border);color:var(--text4)}
.oc-meta{font-size:11px;color:var(--text4);margin-bottom:6px}
.oc-affected{font-size:11px;color:var(--text3)}
.oc-affected strong{color:var(--pend)}
.oc-affected.all-ok{color:var(--text4)}
.oc-actions{display:flex;gap:6px;margin-top:10px}
.oc-btn{font-size:11px;padding:4px 10px;border-radius:5px;border:1px solid var(--border);background:transparent;color:var(--text3);cursor:pointer;transition:all .15s}
.oc-btn:hover{border-color:var(--text3);color:var(--text2)}
.oc-btn.primary{border-color:var(--accent);color:var(--accent)}
.oc-btn.primary:hover{background:rgba(6,182,212,.1)}
.outage-setup-banner{margin:16px 24px;padding:16px 20px;background:rgba(139,92,246,.08);border:1px solid rgba(139,92,246,.25);border-radius:10px;font-size:13px;color:#c084fc;display:flex;gap:14px;align-items:flex-start}
.outage-setup-banner svg{flex-shrink:0;margin-top:1px}
.setup-steps{margin-top:8px;font-size:12px;color:var(--text3);line-height:1.8}
.setup-steps strong{color:var(--text2)}
.outage-log{margin:0 24px;border:1px solid var(--border);border-radius:8px;overflow:hidden}
.outage-log-header{padding:10px 14px;background:var(--card-bg);border-bottom:1px solid var(--border);font-size:11px;color:var(--text4);text-transform:uppercase;letter-spacing:.08em;display:flex;justify-content:space-between}
.outage-log-row{display:grid;grid-template-columns:90px 130px 80px 1fr;gap:12px;padding:9px 14px;border-bottom:1px solid var(--border2);font-size:12px;align-items:center}
.outage-log-row:last-child{border-bottom:none}
.outage-log-row:hover{background:var(--row-hover)}
.ol-time{color:var(--text4)}
.ol-provider{color:var(--text2);font-weight:500}
.ol-status{text-align:center}
.ol-clients{color:var(--text3)}
.outage-report-btn{display:flex;align-items:center;gap:6px;background:transparent;border:1px solid var(--border);border-radius:8px;padding:7px 14px;font-size:12px;color:var(--text3);cursor:pointer;transition:all .15s;margin:0 24px 16px}
.outage-report-btn:hover{border-color:var(--accent);color:var(--accent)}

/* Report outage modal */
.outage-form-row{margin-bottom:14px}
.outage-form-label{font-size:12px;color:var(--text4);margin-bottom:6px}
.outage-form-select,.outage-form-input{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:6px;padding:8px 10px;color:var(--text2);font-size:13px;outline:none}
.outage-form-select:focus,.outage-form-input:focus{border-color:var(--accent)}
.outage-form-select option{background:var(--bg2)}
.outage-form-textarea{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:6px;padding:8px 10px;color:var(--text2);font-size:13px;resize:vertical;min-height:70px;outline:none;font-family:inherit}
.outage-form-textarea:focus{border-color:var(--accent)}

/* Matrix view */
.view-toggle{display:flex;gap:4px;margin-right:6px}
.vtbtn{display:flex;align-items:center;gap:5px;padding:5px 10px;border:1px solid var(--border);border-radius:6px;background:transparent;color:var(--text3);font-size:12px;cursor:pointer;transition:all .15s}
.vtbtn.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.vtbtn:hover:not(.active){border-color:var(--text3);color:var(--text2)}
.svc-matrix{padding:0 24px 20px;overflow-x:auto}
.svc-matrix table{width:100%;border-collapse:collapse}
.svc-matrix th{padding:8px 4px;text-align:center;font-size:10px;color:var(--text4);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border2);white-space:nowrap}
.svc-matrix th.cc{text-align:left;padding-left:0;min-width:160px}
.svc-matrix tr:hover td{background:var(--row-hover)}
.svc-matrix td{padding:7px 4px;border-bottom:1px solid var(--border2);text-align:center;vertical-align:middle}
.svc-matrix td.cc{text-align:left;padding-left:0;cursor:pointer}
.cc-name{font-size:13px;font-weight:500;color:var(--text2)}
.cc-dom{font-size:11px;color:var(--text4)}
.mc{width:22px;height:20px;border-radius:4px;cursor:pointer;display:inline-block;vertical-align:middle;border:none;transition:transform .12s}
.mc:hover{transform:scale(1.4)}
.mc.live{background:var(--live)}
.mc.pend{background:var(--pend)}
.mc.none{background:var(--border);border:1px solid var(--border2)}
body.effects-on .mc.live{box-shadow:0 0 5px rgba(34,197,94,.5)}
/* Sortable columns */
.tbl-sort{cursor:pointer;user-select:none;transition:color .15s}
.tbl-sort:hover{color:var(--text2)}
.sort-icon{font-size:9px;opacity:.6;margin-left:3px}

/* Pending attention callout */
.attention-bar{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;margin:12px 24px 10px;background:rgba(245,158,11,.07);border:1px solid rgba(245,158,11,.22);border-radius:10px;font-size:12px;color:var(--text2);box-shadow:0 2px 8px rgba(245,158,11,.06);animation:attention-in .3s ease}
.attention-bar svg{flex-shrink:0}
.attention-clients{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px}
.ac-chip{background:rgba(245,158,11,.12);border:1px solid rgba(245,158,11,.25);border-radius:12px;padding:2px 10px;font-size:11px;color:var(--pend);cursor:pointer;transition:background .15s}
.ac-chip:hover{background:rgba(245,158,11,.22)}

.svc-nav{display:flex;align-items:center;gap:6px;width:100%;padding:0 0 4px}
.sm-icon-wrap{font-size:22px;flex-shrink:0;width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:var(--bg3)}

.svc-nav-btn{background:transparent;border:1px solid var(--border);border-radius:6px;color:var(--text3);cursor:pointer;font-size:18px;line-height:1;padding:2px 10px;transition:all .15s}
.svc-nav-btn:hover{border-color:var(--accent);color:var(--accent)}
.svc-nav-title{flex:1;text-align:center}

/* Version badge */
.ver-badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:2px 7px;border-radius:99px;
  background:linear-gradient(135deg,#0d9488 0%,#0ea5e9 100%);
  color:#fff;font-size:9px;font-weight:700;letter-spacing:.06em;
  cursor:default;opacity:.8;transition:opacity .2s,transform .15s;
  position:relative;border:1px solid rgba(255,255,255,.15);
  box-shadow:0 1px 6px rgba(14,165,233,.35);
  text-decoration:none;margin-left:6px;vertical-align:middle;
  font-family:ui-monospace,monospace;user-select:none;
}
.ver-badge:hover{opacity:1;transform:scale(1.07)}
.ver-badge::before{content:'';width:5px;height:5px;border-radius:50%;
  background:#a5f3fc;display:inline-block;flex-shrink:0;
  animation:ver-pulse 2.5s infinite}
@keyframes ver-pulse{0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.4;transform:scale(.7)}}

/* Version tooltip */
.ver-badge .ver-tip{
  display:none;position:absolute;top:calc(100% + 8px);left:50%;
  transform:translateX(-50%);
  background:var(--bg2);border:1px solid var(--border);
  border-radius:8px;padding:10px 14px;width:200px;
  font-family:var(--font);font-size:11px;color:var(--text2);
  box-shadow:0 4px 20px rgba(0,0,0,.4);z-index:3100;
  letter-spacing:0;font-weight:400;
}
.ver-badge .ver-tip::before{content:'';position:absolute;bottom:100%;
  left:50%;transform:translateX(-50%);
  border:5px solid transparent;border-bottom-color:var(--border)}
.ver-badge:hover .ver-tip{display:block}
.ver-tip-title{font-weight:700;color:var(--text);font-size:12px;margin-bottom:6px;
  display:flex;align-items:center;gap:6px}
.ver-tip-row{display:flex;justify-content:space-between;padding:2px 0;border-bottom:1px solid var(--border)}
.ver-tip-row:last-child{border:none}
.ver-tip-key{color:var(--text3);font-size:10px}
.ver-tip-val{color:var(--text);font-size:10px;font-family:ui-monospace,monospace}

/* Version badge */
.ver-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 7px;border-radius:99px;
background:linear-gradient(135deg,#0d9488 0%,#0ea5e9 100%);color:#fff;font-size:9px;
font-weight:700;letter-spacing:.06em;cursor:default;opacity:.8;transition:opacity .2s,transform .15s;
position:relative;border:1px solid rgba(255,255,255,.15);
box-shadow:0 1px 6px rgba(14,165,233,.35);margin-left:6px;vertical-align:middle;
font-family:ui-monospace,monospace;user-select:none;line-height:1}
.ver-badge:hover{opacity:1;transform:scale(1.07)}
.ver-badge::before{content:'';width:5px;height:5px;border-radius:50%;background:#a5f3fc;
display:inline-block;flex-shrink:0;animation:ver-pulse 2.5s infinite}
@keyframes ver-pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}
.ver-badge .ver-tip{display:none;position:absolute;top:calc(100% + 8px);left:50%;
transform:translateX(-50%);background:var(--bg2);border:1px solid var(--border);
border-radius:8px;padding:10px 14px;width:200px;font-family:var(--font);
font-size:11px;color:var(--text2);box-shadow:0 4px 20px rgba(0,0,0,.4);
z-index:3100;letter-spacing:0;font-weight:400;white-space:normal}
.ver-badge .ver-tip::before{content:'';position:absolute;bottom:100%;left:50%;
transform:translateX(-50%);border:5px solid transparent;border-bottom-color:var(--border)}
.ver-badge:hover .ver-tip{display:block}
.ver-tip-title{font-weight:700;color:var(--text);font-size:12px;margin-bottom:6px;
display:flex;align-items:center;gap:6px;white-space:nowrap}
.ver-tip-row{display:flex;justify-content:space-between;padding:2px 0;border-bottom:1px solid var(--border)}
.ver-tip-row:last-child{border:none}
.ver-tip-key{color:var(--text3);font-size:10px}
.ver-tip-val{color:var(--text);font-size:10px;font-family:ui-monospace,monospace}


.net-setup-banner{margin:16px 24px;background:var(--bg2);border:1px solid var(--border);
  border-radius:10px;padding:14px 16px;font-size:12px;color:var(--text2);
  display:flex;gap:12px;align-items:flex-start}
.net-setup-banner svg{flex-shrink:0;margin-top:2px;color:var(--accent)}
.net-setup-banner code{background:var(--bg3);padding:1px 5px;border-radius:4px;font-size:11px}
.net-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(310px,100%),1fr));
  gap:16px;padding:0 24px 24px;margin-top:8px}
.net-card{background:var(--card-bg);border:1px solid var(--border);border-radius:10px;overflow:hidden}
.net-card-hdr{display:flex;align-items:center;gap:10px;padding:10px 14px;
  background:var(--bg2);border-bottom:1px solid var(--border)}
.net-card-abbr{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;
  justify-content:center;font-weight:700;font-size:11px;flex-shrink:0}
.net-card-name{flex:1;font-weight:600;color:var(--text);font-size:13px;line-height:1.3}
.net-refresh-btn{background:none;border:none;cursor:pointer;color:var(--text3);font-size:16px;
  padding:4px;border-radius:4px;transition:color .15s}
.net-refresh-btn:hover{color:var(--accent)}
.net-section-label{font-size:9px;font-weight:700;letter-spacing:.08em;
  color:var(--text4);padding:8px 14px 4px;text-transform:uppercase}
.net-wan-row{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--border)}
.net-wan-block{padding:8px 14px;border-right:1px solid var(--border)}
.net-wan-block:last-child{border-right:none}
.net-wan-active{background:rgba(34,197,94,.04)}
.net-wan-label{font-size:10px;font-weight:700;color:var(--text3);margin-bottom:4px;
  display:flex;align-items:center;gap:5px;flex-wrap:wrap;line-height:1.5}
.net-active-pip{background:var(--live);color:#fff;font-size:8px;padding:1px 5px;
  border-radius:99px;font-weight:700}
.net-starlink-badge{background:rgba(14,165,233,.15);color:#38bdf8;font-size:8px;
  padding:1px 5px;border-radius:99px;font-weight:700}
.net-wan-ip{font-family:ui-monospace,monospace;font-size:12px;color:var(--text);font-weight:600}
.net-hw-list{padding:4px 14px 10px;border-bottom:1px solid var(--border)}
.net-hw-row{display:flex;align-items:center;gap:8px;padding:3px 0;
  border-bottom:1px solid var(--border)}
.net-hw-row:last-child{border:none}
.net-hw-model{font-family:ui-monospace,monospace;font-size:11px;color:var(--text);
  min-width:80px;font-weight:600}
.net-tools-row{display:flex;gap:6px;padding:8px 14px}
.net-tool-btn{flex:1;background:var(--bg2);border:1px solid var(--border);
  border-radius:6px;padding:5px 4px;font-size:11px;color:var(--text2);cursor:pointer;
  transition:background .15s,color .15s}
.net-tool-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.net-tool-result{margin:0 14px 10px;background:var(--bg3);border-radius:6px;
  padding:8px 10px;font-size:11px;color:var(--text2);font-family:ui-monospace,monospace;
  border:1px solid var(--border)}

/* Block tabs/nav during active game to prevent accidental clicks */
body.nrt-game-active .tabs{pointer-events:none;opacity:.4}
body.nrt-game-active .tab-badge{display:none}


.net-cfg-panel{margin:12px 24px 0;border:1px solid var(--border);border-radius:10px;overflow:hidden}
.net-cfg-hdr{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--bg2);cursor:pointer;font-size:12px;font-weight:600;color:var(--text);user-select:none}
.net-cfg-hdr:hover{background:var(--bg3)}
.net-cfg-status{font-size:10px;padding:2px 8px;border-radius:99px;font-weight:700}
.net-cfg-ok{background:rgba(34,197,94,.15);color:#22c55e}
.net-cfg-warn{background:rgba(245,158,11,.15);color:#f59e0b}
.net-cfg-body{display:none;padding:14px 16px;flex-direction:column;gap:8px;background:var(--card-bg)}
.net-cfg-body.open{display:flex}
.net-cfg-row{display:flex;align-items:center;gap:10px}
.net-cfg-label{font-size:11px;color:var(--text3);min-width:80px;flex-shrink:0}
.net-cfg-input{flex:1;background:var(--bg2);border:1px solid var(--border);border-radius:6px;padding:5px 8px;font-size:11px;color:var(--text);outline:none}
.net-cfg-input:focus{border-color:var(--accent)}
.net-cfg-org-input{max-width:200px;flex:none}
.net-cfg-section-hdr{font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text4);padding-top:6px;border-top:1px solid var(--border)}
.net-cfg-actions{display:flex;gap:8px;padding-top:8px;border-top:1px solid var(--border)}
.net-cfg-note{font-size:10px;color:var(--text3);line-height:1.7;padding-top:8px;border-top:1px solid var(--border)}
.net-cfg-note code{background:var(--bg3);padding:1px 4px;border-radius:3px;font-size:9px}
.net-updated{display:block;font-size:9px;color:var(--text4);font-weight:400;margin-top:1px}


#projects-view{height:calc(100vh - 90px)}
.proj-wrap{display:flex;flex-direction:column;height:100%;padding:16px 24px 0}
.proj-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.proj-hdr span{font-size:14px;font-weight:700;color:var(--text)}
.proj-open-btn{font-size:12px;color:var(--accent);text-decoration:none;padding:5px 10px;
  border:1px solid var(--accent);border-radius:6px;transition:background .15s}
.proj-open-btn:hover{background:var(--accent);color:#fff}
.proj-iframe{flex:1;border:1px solid var(--border);border-radius:10px;background:var(--bg2)}
.proj-fallback{display:none;flex-direction:column;align-items:center;justify-content:center;
  gap:12px;padding:40px;text-align:center;color:var(--text3);font-size:13px;
  border:1px solid var(--border);border-radius:10px;flex:1}

@keyframes lvlup-fall{0%{transform:translateY(0) rotate(0);opacity:1}100%{transform:translateY(110vh) rotate(var(--spin,360deg));opacity:0}}
@keyframes lvlup-burst-in{0%{transform:scale(0.3) translateY(30px);opacity:0}60%{transform:scale(1.12) translateY(-8px);opacity:1}100%{transform:scale(1) translateY(0);opacity:1}}
@keyframes lvlup-fade-out{0%{opacity:1}100%{opacity:0;transform:scale(1.08) translateY(-20px)}}
@keyframes lvlup-star-spin{0%{transform:rotate(0) scale(1)}50%{transform:rotate(180deg) scale(1.4)}100%{transform:rotate(360deg) scale(1)}}
.lvlup-overlay{position:fixed;inset:0;z-index:9998;display:flex;align-items:center;justify-content:center;pointer-events:none;background:radial-gradient(ellipse at center,rgba(250,204,21,.1) 0%,transparent 70%)}
.lvlup-overlay.lvlup-out{animation:lvlup-fade-out .7s ease forwards}
.lvlup-burst{text-align:center;animation:lvlup-burst-in .55s cubic-bezier(.2,-0.5,.3,1.2) forwards}
.lvlup-star{font-size:52px;animation:lvlup-star-spin 1s ease infinite;display:block;margin-bottom:4px}
.lvlup-title{font-size:20px;font-weight:900;letter-spacing:.15em;color:#fbbf24;text-shadow:0 0 30px #f59e0b;text-transform:uppercase}
.lvlup-num{font-size:96px;font-weight:900;color:#fff;line-height:1;text-shadow:0 0 40px #fbbf24,0 4px 0 #b45309;margin:0 0 8px}
.lvlup-sub{font-size:16px;font-weight:700;color:#fde68a;letter-spacing:.08em;text-transform:uppercase;opacity:.9}
#projects-view{overflow-y:auto;max-height:calc(100vh - 90px)}
.proj-wrap{padding:0 24px 24px}
.proj-hdr{display:flex;align-items:center;justify-content:space-between;padding:16px 0 12px}
.proj-hdr span{font-size:14px;font-weight:700;color:var(--text)}
.proj-open-btn{font-size:11px;color:var(--accent);cursor:pointer;padding:5px 10px;border:1px solid var(--accent);border-radius:6px;background:none;transition:background .15s}
.proj-open-btn:hover{background:var(--accent);color:#fff}
.proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}
.proj-card{background:var(--card-bg);border:1px solid var(--border);border-radius:10px;overflow:hidden}
.proj-card-hdr{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--bg2);border-bottom:1px solid var(--border)}
.proj-card-info{flex:1;min-width:0}
.proj-card-name{font-weight:600;font-size:13px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.proj-card-company{font-size:11px;color:var(--text3);margin-top:1px}
.proj-status-pill{font-size:10px;font-weight:700;padding:2px 8px;border-radius:99px;white-space:nowrap;flex-shrink:0}
.proj-card-body{padding:10px 14px}
.proj-progress-bar{height:6px;background:var(--bg3);border-radius:99px;overflow:hidden;margin-bottom:6px}
.proj-meta{display:flex;justify-content:space-between;font-size:11px;color:var(--text3)}
.proj-loading,.proj-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:60px 20px;text-align:center;color:var(--text3);font-size:13px}
.proj-spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}


/* Hamster variant — warm shadow instead of green to avoid hitbox illusion */
.gremlin.is-hamster .g-inner{filter:drop-shadow(0 3px 8px rgba(240,192,128,.6))}
.gremlin.is-hamster:hover .g-inner{filter:none!important}


/* Diablo 2-style bottom game HUD */
#game-bottom-hud{
  position:fixed;bottom:0;left:0;right:0;height:80px;z-index:2400;
  display:none;align-items:stretch;
  background:linear-gradient(to bottom,#1a0e06 0%,#0d0704 60%,#060302 100%);
  border-top:2px solid #8b4513;
  box-shadow:0 -4px 20px rgba(0,0,0,.7),0 -1px 0 #c87941 inset;
}
body.nrt-game-active #game-bottom-hud{display:flex}
.ghud-left-orb,.ghud-right-orb{
  width:160px;flex-shrink:0;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:4px;
  background:linear-gradient(180deg,#2d1500 0%,#1a0e06 100%);
  border-right:1px solid #5a2d0c;padding:8px 12px;
}
.ghud-right-orb{border-right:none;border-left:1px solid #5a2d0c;}
.ghud-orb-ring{
  width:50px;height:50px;border-radius:50%;
  background:radial-gradient(circle at 38% 35%,#8b4513,#3d1a06 60%,#1a0800 100%);
  border:2px solid #c87941;box-shadow:0 0 10px rgba(200,121,65,.4),inset 0 0 8px rgba(0,0,0,.6);
  display:flex;align-items:center;justify-content:center;
}
.ghud-orb-ring-r{
  background:radial-gradient(circle at 38% 35%,#1a3d8b,#061430 60%,#010408 100%);
  border-color:#4169e1;box-shadow:0 0 10px rgba(65,105,225,.4),inset 0 0 8px rgba(0,0,0,.6);
}
.ghud-orb-inner{display:flex;flex-direction:column;align-items:center;line-height:1}
.ghud-level-num{font-size:18px;font-weight:900;color:#f0c060;font-family:serif}
.ghud-level-lbl{font-size:7px;letter-spacing:.08em;color:#c87941;text-transform:uppercase;font-weight:700}
.ghud-total-xp{font-size:13px;font-weight:900;color:#a0b8ff;font-family:serif}
.ghud-stat-row{display:flex;flex-direction:column;align-items:center;margin-top:2px}
.ghud-stat-label{font-size:8px;color:#8b6343;text-transform:uppercase;letter-spacing:.06em}
.ghud-stat-val{font-size:14px;font-weight:700;color:#c87941}
.ghud-center{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  padding:8px 20px;
}
.ghud-mode-name{
  font-size:11px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;
  color:#c87941;font-family:serif;
}
.ghud-xp-track{width:92%;max-width:240px;height:26px;background:#0a0302;border:1.5px solid #7c3200;border-radius:4px;position:relative;overflow:hidden;box-shadow:inset 0 2px 8px rgba(0,0,0,.9),0 0 0 1px rgba(200,121,65,.1);flex-shrink:0;}
.ghud-xp-fill{position:absolute;inset:0;right:auto;width:0%;height:100%;background:linear-gradient(90deg,#7f1d1d 0%,#b91c1c 35%,#ef4444 70%,#fca5a5 95%,#fff 100%);transition:width .5s ease-out;border-radius:3px 0 0 3px;}
 60%,100%{left:120%}

.ghud-xp-label{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;letter-spacing:.1em;color:#fff;text-shadow:0 0 6px rgba(0,0,0,1),0 1px 2px rgba(0,0,0,.9);text-transform:uppercase;pointer-events:none;z-index:2;}
.ghud-title-name{
  font-size:10px;font-style:italic;color:#8b6343;letter-spacing:.04em;
}
.ghud-boss-btn{
  align-self:center;margin-top:4px;padding:4px 10px;background:#3d0000;border:1px solid #8b1a1a;
  border-radius:3px;color:#ff6b6b;font-size:10px;font-weight:700;cursor:pointer;
  letter-spacing:.06em;text-transform:uppercase;transition:background .15s;
}
.ghud-boss-btn:hover{background:#6b0000;border-color:#dc2626;}


.gremlin.is-hamster{padding:0}
.gremlin.is-hamster .g-inner{filter:none}
.gremlin.is-hamster svg{filter:drop-shadow(0 3px 8px rgba(240,192,128,.6))}
.gremlin.is-hamster:hover svg{filter:drop-shadow(0 3px 14px rgba(240,192,128,.9)) brightness(1.12)}

#reports-view{overflow-y:auto;max-height:calc(100vh - 90px)}
.rpt-wrap{padding:0 24px 32px}
.rpt-hdr{display:flex;align-items:center;justify-content:space-between;padding:16px 0 10px}
.rpt-hdr span:first-child{font-size:14px;font-weight:700;color:var(--text)}
.rpt-summary{display:flex;gap:12px;margin-bottom:14px;flex-wrap:wrap}
.rpt-stat{background:var(--card-bg);border:1px solid var(--border);border-radius:8px;padding:10px 16px;min-width:100px;flex:1}
.rpt-stat-num{font-size:20px;font-weight:700;color:var(--text)}
.rpt-stat-lbl{font-size:11px;color:var(--text4);margin-top:1px}
.rpt-stat-err .rpt-stat-num{color:#ef4444}
.rpt-stat-warn .rpt-stat-num{color:#f59e0b}
.rpt-stat-ok .rpt-stat-num{color:var(--live)}
.rpt-table{width:100%;border-collapse:collapse;font-size:12px}
.rpt-table th{text-align:left;padding:7px 12px;background:var(--bg2);color:var(--text3);font-weight:600;font-size:10px;text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);white-space:nowrap}
.rpt-table td{padding:7px 12px;border-bottom:1px solid rgba(255,255,255,.04);vertical-align:middle}
.rpt-row:hover td{background:rgba(255,255,255,.02)}
.rpt-cat{font-size:10px;font-weight:700;padding:2px 7px;border-radius:99px}
.rpt-cat-net{background:rgba(6,182,212,.15);color:#06b6d4}
.rpt-cat-ep{background:rgba(168,85,247,.15);color:#a855f7}
.rpt-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:99px;white-space:nowrap}

@keyframes ctf-flag-float{0%{transform:translateY(0)}100%{transform:translateY(-8px)}}
.ctf-gremlin{z-index:2250!important}.lp-gremlin{z-index:2120!important;outline:none}

/* ═══ MOBILE RESPONSIVE — @media max-width:700px ═══════════════════ */
@media (max-width: 768px) {

  /* Header */
  .hdr { padding:0 12px; height:50px; }
  .hdr-title { font-size:12px; }
  .hdr-sub   { display:none !important; }
  .hg-badge  { display:none; }
  #hdr-xp    { display:none; }
  .hdr-right { gap:6px; }
  .health-btn,.hdr-right button { width:30px; height:30px; font-size:12px; padding:0; }
  .user-btn  { width:28px; height:28px; font-size:11px; }

  /* Tab bar — horizontal scroll, no wrap */
  .tabs { padding:0 8px; overflow-x:auto; flex-wrap:nowrap;
          scrollbar-width:none; -webkit-overflow-scrolling:touch; }
  .tabs::-webkit-scrollbar { display:none; }
  .tab  { padding:8px 10px; font-size:11px; gap:4px; white-space:nowrap; flex-shrink:0; }
  .tab svg { display:none; }
  .tab-badge { font-size:9px; padding:1px 5px; }

  /* Page header */
  .page-hdr  { padding:12px 12px 0; flex-wrap:wrap; gap:6px; }
  .page-title{ font-size:15px; }
  .page-sub  { font-size:11px; display:none; }
  .page-hdr-right { padding-left:0; }
  .btn-refresh{ padding:6px 10px; font-size:12px; }
  #last-updated { display:none; }

  /* Stats — 2×2 grid */
  .stats-wrap { margin:10px 12px; }
  .stats-grid { grid-template-columns:repeat(2,1fr) !important; }
  .stat-val   { font-size:22px; }
  .stat-label { font-size:10px; }

  /* Filter bar */
  #filter-bar { padding:0 12px 8px; gap:4px; }
  .fchip      { padding:3px 8px; font-size:11px; }
  .search-input { width:100%; margin-left:0; margin-top:4px; }

  /* View toggle */
  #view-toggle-bar { padding:0 12px 6px; }

  /* Client table header — hide on mobile, info in row */
  .tbl-hdr    { display:none !important; }

  /* Client rows — 3-column card layout for mobile */
  .client-row {
    grid-template-columns: 40px 1fr auto !important;
    gap:8px !important;
    padding:10px 12px !important;
  }
  /* Hide sector tags and status text on mobile; show only dots */
  .client-row > div:nth-child(3),
  .client-row > .status-txt { display:none; }
  .client-name { font-size:13px; }
  .client-domain { font-size:11px; }
  .client-avatar { width:36px; height:36px; }
  .dots-wrap { gap:4px; justify-content:flex-end; }
  .dot { width:10px; height:10px; }

  /* Attention bar */
  .attention-bar { margin:0 12px 8px; padding:8px 10px; font-size:11px; }

  /* Network grid */
  .net-grid { grid-template-columns:1fr !important; padding:0 12px 16px; gap:10px; }
  .net-cfg-panel,.net-setup-banner { margin:8px 12px 0; }
  .net-wan-row { grid-template-columns:1fr 1fr; }

  /* Outages */
  .outage-cards { grid-template-columns:1fr !important; }
  .outage-section { padding:10px 12px 0; }
  .outage-log-row { grid-template-columns:70px 90px 60px 1fr; gap:6px; font-size:11px; }
  .outage-map-section { margin:0 12px 12px; }

  /* Reports */
  .rpt-wrap     { padding:0 12px 20px; }
  .rpt-summary  { gap:8px; }
  .rpt-stat     { min-width:80px; padding:8px 10px; }
  .rpt-stat-num { font-size:18px; }
  /* Reports table — horizontal scroll */
  .rpt-table-wrap, .rpt-wrap > div:last-child { overflow-x:auto; -webkit-overflow-scrolling:touch; }
  .rpt-table    { min-width:520px; }

  /* Endpoints */
  .ep-summary { padding:12px 12px 6px; gap:8px; }
  .ep-stat    { min-width:80px; }

  /* Projects */
  .proj-wrap    { padding:0 12px 16px; }
  .proj-grid    { grid-template-columns:1fr !important; }

  /* Modals — full width */
  .modal-sm,.modal-md,.modal-lg { width:calc(100vw - 24px) !important; max-width:100%; }
  .modal-body { padding:14px 16px; }
  .modal-hdr  { padding:14px 16px 12px; }
  .modal-footer { padding:12px 16px; }
  .cm-services { grid-template-columns:repeat(2,1fr) !important; }
  .cm-vars     { grid-template-columns:1fr !important; }

  /* User menu & panels */
  .user-menu  { width:calc(100vw - 16px); right:8px; }
  .theme-panel{ width:calc(100vw - 16px); right:8px; }

  /* Game HUD — compact */
  #game-bottom-hud { height:64px; }
  .ghud-left-orb,.ghud-right-orb { width:110px; padding:4px 8px; }
  .ghud-orb-ring { width:38px; height:38px; }
  .ghud-level-num { font-size:14px; }
  .ghud-stat-val  { font-size:12px; }
  .ghud-center    { padding:4px 10px; }
  .ghud-mode-name { font-size:9px; letter-spacing:.08em; }
  .ghud-xp-track  { height:12px; }
  .ghud-boss-btn  { font-size:9px; padding:3px 7px; margin-top:2px; }

  /* Toast — full bottom */
  #toast { bottom:12px; left:12px; right:12px; font-size:12px; }

  /* Matrix view */
  .svc-matrix { overflow-x:auto; -webkit-overflow-scrolling:touch; }

  /* Networks tab — config panel inputs stack */
  .net-cfg-row { flex-wrap:wrap; }
  .net-cfg-label { min-width:100%; }
  .net-cfg-input { flex:1 1 100%; }
}


  /* Horizontal overflow containment */
  .main { overflow-x:hidden; }
  .ep-table { overflow-x:auto; -webkit-overflow-scrolling:touch; }
  .ep-row   { min-width:380px; }
  .outage-log { overflow-x:auto; -webkit-overflow-scrolling:touch; }
  .outage-log-row { min-width:320px; }
  .svc-matrix { overflow-x:auto; -webkit-overflow-scrolling:touch; }
  /* Prevent fixed-width grids from pushing page width */
  .stats-wrap, #filter-bar, #view-toggle-bar, #attention-bar, #client-list,
  #outages-view, #networks-view, #endpoints-view, #reports-view, #projects-view {
    max-width:100vw; overflow-x:hidden;
  }

@media (max-width:480px) {
  .tab { padding:7px 8px; font-size:10px; }
  .ghud-left-orb,.ghud-right-orb { width:80px; }
  .ghud-stat-row,.ghud-stat-label { display:none; }
  .page-title { font-size:13px; }
}


/* Tablet mid-size — 769px to 1024px */
@media (min-width: 769px) and (max-width: 1024px) {
  .tabs { overflow-x:auto; flex-wrap:nowrap; scrollbar-width:none; }
  .tab  { padding:9px 12px; font-size:12px; white-space:nowrap; flex-shrink:0; }
  .stats-grid { grid-template-columns:repeat(2,1fr) !important; }
  .net-grid   { grid-template-columns:1fr !important; padding:0 16px 16px; }
  .client-row { grid-template-columns:44px 1fr 140px 70px 100px; gap:8px; padding:12px 16px; }
  .outage-cards { grid-template-columns:repeat(2,1fr) !important; }
  .proj-grid    { grid-template-columns:1fr !important; }
  .modal-lg { width:calc(100vw - 32px) !important; }
}


@supports (padding: env(safe-area-inset-bottom)) {
  #nrt-app { padding-bottom: env(safe-area-inset-bottom); }
  #game-bottom-hud { padding-bottom: env(safe-area-inset-bottom); height: calc(80px + env(safe-area-inset-bottom)); }
}


/* On-screen D-pad */
#game-dpad {
  position:fixed;bottom:90px;left:16px;z-index:2500;
  display:none;width:144px;height:144px;
}
body.nrt-game-active.touch-mode #game-dpad { display:block; }
.dpad-btn {
  position:absolute;width:44px;height:44px;border-radius:8px;
  background:rgba(34,197,94,.18);border:1.5px solid rgba(34,197,94,.5);
  color:var(--live);font-size:16px;cursor:pointer;touch-action:none;
  display:flex;align-items:center;justify-content:center;
  transition:background .1s;user-select:none;-webkit-user-select:none;
}
.dpad-btn:active,.dpad-btn.pressed{background:rgba(34,197,94,.45);border-color:var(--live);}
.dpad-up    {top:0;left:50px;}
.dpad-down  {top:100px;left:50px;}
.dpad-left  {top:50px;left:0;}
.dpad-right {top:50px;left:100px;}
.dpad-act   {top:50px;left:50px;font-size:11px;border-radius:50%;color:#f59e0b;
             background:rgba(245,158,11,.18);border-color:rgba(245,158,11,.5);}


body.nrt-ctf-active #nrt-app,
body.nrt-lp-active  #nrt-app { pointer-events:none; }

/* ── Game Mode Buttons ────────────────────────────────── */
.gm-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  padding:4px 0 8px;
}
.gm-btn {
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:3px;padding:10px 6px 8px;
  background:var(--bg2);border:1.5px solid var(--border);
  border-radius:10px;cursor:pointer;text-align:center;
  transition:background .15s,border-color .15s,transform .1s,box-shadow .15s;
  position:relative;overflow:hidden;
}
.gm-btn::before {
  content:'';position:absolute;inset:0;opacity:0;
  background:linear-gradient(135deg,rgba(255,255,255,.06) 0%,transparent 60%);
  transition:opacity .2s;pointer-events:none;
}
.gm-btn:hover { transform:translateY(-2px); }
.gm-btn:hover::before { opacity:1; }
.gm-btn:active { transform:translateY(0) scale(.97); }
.gm-icon { font-size:22px;line-height:1;display:block; }
.gm-name { font-size:11px;font-weight:700;color:var(--text);letter-spacing:.02em; }
.gm-desc { font-size:9px;color:var(--text4);letter-spacing:.03em; }

/* Off */
#gm-off                  { border-color:#374151; }
#gm-off:hover            { border-color:#6b7280;box-shadow:0 4px 12px rgba(107,114,128,.25); }
#gm-off.active           { background:rgba(107,114,128,.18);border-color:#6b7280;
                           box-shadow:0 0 0 2px rgba(107,114,128,.3); }
/* Chaos */
#gm-chaos                { border-color:#7f1d1d; }
#gm-chaos:hover          { border-color:#ef4444;box-shadow:0 4px 12px rgba(239,68,68,.3); }
#gm-chaos.active         { background:rgba(239,68,68,.15);border-color:#ef4444;
                           box-shadow:0 0 0 2px rgba(239,68,68,.35),0 0 18px rgba(239,68,68,.2); }
/* Maze 2D */
#gm-maze2                { border-color:#14532d; }
#gm-maze2:hover          { border-color:#22c55e;box-shadow:0 4px 12px rgba(34,197,94,.3); }
#gm-maze2.active         { background:rgba(34,197,94,.13);border-color:#22c55e;
                           box-shadow:0 0 0 2px rgba(34,197,94,.35),0 0 18px rgba(34,197,94,.2); }
/* Maze 3D */
#gm-maze3                { border-color:#0c4a6e; }
#gm-maze3:hover          { border-color:#06b6d4;box-shadow:0 4px 12px rgba(6,182,212,.3); }
#gm-maze3.active         { background:rgba(6,182,212,.13);border-color:#06b6d4;
                           box-shadow:0 0 0 2px rgba(6,182,212,.35),0 0 18px rgba(6,182,212,.2); }
/* CTF */
#gm-ctf                  { border-color:#78350f; }
#gm-ctf:hover            { border-color:#f59e0b;box-shadow:0 4px 12px rgba(245,158,11,.3); }
#gm-ctf.active           { background:rgba(245,158,11,.13);border-color:#f59e0b;
                           box-shadow:0 0 0 2px rgba(245,158,11,.35),0 0 18px rgba(245,158,11,.2); }
/* Gremlin Paintball */
#gm-lp                   { border-color:#4c1d95; }
#gm-lp:hover             { border-color:#a855f7;box-shadow:0 4px 12px rgba(168,85,247,.3); }
#gm-lp.active            { background:rgba(168,85,247,.13);border-color:#a855f7;
                           box-shadow:0 0 0 2px rgba(168,85,247,.35),0 0 18px rgba(168,85,247,.2); }

/* Spinning icon on active (subtle) */
#gm-chaos.active .gm-icon { animation:gm-spin-slow 4s linear infinite; }
@keyframes gm-spin-slow { to { transform:rotate(360deg); } }


/* ── Main game toggle button ──────────────────────────── */
#game-btn {
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  background:rgba(34,197,94,.07);
  border:1.5px solid rgba(34,197,94,.25);
  border-radius:9px;padding:5px 11px;
  cursor:pointer;color:var(--text2);
  font-size:12px;font-weight:600;letter-spacing:.03em;
  transition:background .2s,border-color .2s,box-shadow .2s,color .2s;
  position:relative;overflow:hidden;
  margin-right:4px;
}
#game-btn::before {
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(34,197,94,.1) 0%,transparent 70%);
  opacity:0;transition:opacity .2s;pointer-events:none;
}
#game-btn:hover { color:var(--live);border-color:var(--live);
  box-shadow:0 0 0 1px rgba(34,197,94,.2),0 4px 12px rgba(34,197,94,.2); }
#game-btn:hover::before { opacity:1; }
#game-btn:active { transform:scale(.96); }
#game-btn-icon { font-size:18px;line-height:1;display:inline-flex;align-items:center;justify-content:center;transition:transform .3s; }
#game-btn-label { font-size:11px;font-weight:700;line-height:1; }

/* Active game mode — button glows in the mode's colour */
/* Off */
body.nrt-game-active #game-btn[data-mode="0"] { border-color:#6b7280;box-shadow:0 0 0 1px #6b7280,0 0 8px rgba(107,114,128,.3); }
/* Chaos */
body.nrt-game-active[data-gmode="1"] #game-btn {
  background:rgba(239,68,68,.12);border-color:#ef4444;color:#ef4444;
  box-shadow:0 0 0 1px #ef4444,0 0 14px rgba(239,68,68,.35);
  animation:game-btn-pulse 2s ease-in-out infinite;
}
/* Maze 2D */
body.nrt-game-active[data-gmode="2"] #game-btn {
  background:rgba(34,197,94,.12);border-color:#22c55e;color:var(--live);
  box-shadow:0 0 0 1px #22c55e,0 0 14px rgba(34,197,94,.35);
  animation:game-btn-pulse 2s ease-in-out infinite;
}
/* Maze 3D */
body.nrt-game-active[data-gmode="3"] #game-btn {
  background:rgba(6,182,212,.12);border-color:#06b6d4;color:#06b6d4;
  box-shadow:0 0 0 1px #06b6d4,0 0 14px rgba(6,182,212,.35);
  animation:game-btn-pulse 2s ease-in-out infinite;
}
/* CTF */
body.nrt-game-active[data-gmode="4"] #game-btn {
  background:rgba(245,158,11,.12);border-color:#f59e0b;color:#f59e0b;
  box-shadow:0 0 0 1px #f59e0b,0 0 14px rgba(245,158,11,.35);
  animation:game-btn-pulse 2s ease-in-out infinite;
}
/* Gremlin Paintball */
body.nrt-game-active[data-gmode="5"] #game-btn {
  background:rgba(168,85,247,.12);border-color:#a855f7;color:#a855f7;
  box-shadow:0 0 0 1px #a855f7,0 0 14px rgba(168,85,247,.35);
  animation:game-btn-pulse 2s ease-in-out infinite;
}
@keyframes game-btn-pulse {
  0%,100% { box-shadow:0 0 0 1px currentColor,0 0 10px rgba(128,128,128,.3); }
  50%      { box-shadow:0 0 0 2px currentColor,0 0 22px rgba(128,128,128,.5); }
}
body.nrt-game-active #game-btn-icon { animation:game-icon-spin 3s linear infinite; }
@keyframes game-icon-spin {
  0%   { transform:rotate(0deg) scale(1); }
  45%  { transform:rotate(15deg) scale(1.15); }
  55%  { transform:rotate(-15deg) scale(1.15); }
  100% { transform:rotate(0deg) scale(1); }
}


@keyframes attention-in{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}

/* ── Game panel settings ──────────────────────────────── */
.gm-settings { display:flex;flex-direction:column;gap:6px;padding:6px 0 4px; }
.gm-setting  { display:flex;align-items:center;gap:8px; }
.gm-slbl     { font-size:10px;color:var(--text3);min-width:64px;font-weight:600;text-transform:uppercase;letter-spacing:.05em; }
.gm-opts     { display:flex;gap:4px;flex-wrap:wrap; }
.gm-opt {
  font-size:10px;padding:3px 8px;border-radius:5px;cursor:pointer;font-weight:600;
  background:var(--bg2);border:1px solid var(--border);color:var(--text3);
  transition:background .15s,border-color .15s,color .15s;
}
.gm-opt.active { background:rgba(34,197,94,.15);border-color:var(--live);color:var(--live); }
.gm-opt:hover:not(.active) { border-color:var(--text3);color:var(--text2); }
.gm-start-btn {
  width:100%;margin-top:10px;padding:9px;border-radius:8px;font-size:12px;font-weight:700;
  cursor:pointer;letter-spacing:.04em;
  background:linear-gradient(135deg,#166534 0%,#15803d 100%);
  border:1.5px solid #22c55e;color:#fff;
  box-shadow:0 2px 12px rgba(34,197,94,.3);
  transition:box-shadow .2s,transform .1s;
}
.gm-start-btn:hover { box-shadow:0 4px 20px rgba(34,197,94,.5);transform:translateY(-1px); }
.gm-start-btn:active { transform:scale(.97); }
/* Selected (not yet running) button gets amber ring */
.gm-btn.gm-selected:not(.active) {
  border-color:#f59e0b;
  box-shadow:0 0 0 2px rgba(245,158,11,.35);
  background:rgba(245,158,11,.08);
}


/* ── HUD improvements ─────────────────────────────────── */
#game-bottom-hud { justify-content:stretch; }
.ghud-center { padding:6px 16px; min-width:0; }
.ghud-mode-name { font-size:10px; margin-bottom:1px; }
.ghud-title-name { font-size:11px; margin-bottom:4px; }
.ghud-xp-track { position:relative; }
.ghud-boss-btn { font-size:10px; letter-spacing:.04em; }
/* Pulse orb rings when XP is earned */
@keyframes orb-pulse { 0%,100%{box-shadow:0 0 0 2px rgba(200,121,65,.2)} 50%{box-shadow:0 0 0 5px rgba(200,121,65,.5),0 0 18px rgba(200,121,65,.3)} }
body.nrt-game-active .ghud-orb-ring { animation:orb-pulse 3s ease-in-out infinite; }


.gm-setting-colors { align-items:flex-start; }
.gm-color-pickers { display:flex; gap:10px; }
.gm-cpick { display:flex; flex-direction:column; align-items:center; gap:3px; font-size:9px; color:var(--text3); cursor:pointer; }
.gm-cpick input[type=color] { width:28px; height:22px; border:1px solid var(--border); border-radius:4px; padding:1px; background:var(--bg3); cursor:pointer; }

.si-sidebar{padding:6px 4px;display:flex;flex-direction:column;gap:4px;height:100%;overflow-y:auto}
.si-sb-hdr{font-size:11px;font-weight:800;color:var(--text3);letter-spacing:.12em;text-transform:uppercase;text-align:center;padding:2px 0 6px}
.si-sb-div{border-top:1px solid var(--border);margin:4px 0}
.si-upg{display:flex;align-items:center;gap:6px;padding:4px 6px;border-radius:6px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06)}
.si-upg-dim{opacity:.35}
.si-upg-icon{font-size:20px;width:20px;text-align:center;flex-shrink:0}
.si-upg-info{flex:1;min-width:0}
.si-upg-name{font-size:11px;font-weight:700;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.si-pips{display:flex;gap:2px;margin-top:2px}
.si-pip{width:9px;height:5px;border-radius:2px;background:var(--border)}
.si-pip-on{background:#f59e0b}
.si-sb-stat{display:flex;align-items:center;justify-content:space-between;font-size:11px;color:var(--text3);padding:2px 4px;gap:4px;color:var(--text3);padding:2px 4px;gap:4px}
.si-bar{flex:1;height:6px;background:var(--border);border-radius:3px;overflow:hidden}
.si-bar-fill{height:100%;border-radius:3px;transition:width .3s}
.si-bar-shield{background:linear-gradient(90deg,#0891b2,#06b6d4)}
.si-bar-boss{background:linear-gradient(90deg,#7c3aed,#a855f7)}
.si-bomb-ct{font-weight:800;color:#f59e0b}
.si-boss-hp .si-sb-stat{flex-direction:column;align-items:flex-start;gap:2px}
.si-sb-hint{font-size:10px;color:var(--text4);text-align:center;line-height:1.6;padding:4px 0}

.ver-badge:hover .ver-tip{display:block!important}
.ver-badge:focus .ver-tip{display:block!important}

@keyframes xp-gain-flash{
}

#gm-si                   { border-color:#1e3a5f; }
#gm-si:hover             { border-color:#3b82f6;box-shadow:0 4px 12px rgba(59,130,246,.3); }
#gm-si.active            { background:rgba(59,130,246,.13);border-color:#3b82f6;box-shadow:0 0 0 2px rgba(59,130,246,.35),0 0 18px rgba(59,130,246,.2); }
