/* ============================================================
   monitor.css — Server Monitor page-specific styles
   Extracted from monitor.html (CODING_STANDARDS §5.1: file size).
   Loaded after css/pages.css via <link> in monitor.html.
   ============================================================ */

/* Monitor-specific overrides */
.m-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.5rem;margin-bottom:.75rem}
.m-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:.8rem .5rem;text-align:center;transition:border-color .2s,transform .15s}
.m-card:hover{border-color:var(--border2);transform:translateY(-1px)}
.m-label{font-size:.5rem;color:var(--mute);letter-spacing:.5px;margin-bottom:5px;text-transform:uppercase;font-weight:600}
.m-val{font-family:'JetBrains Mono',monospace;font-size:1rem;font-weight:700;display:block;line-height:1}
.m-val.good{color:var(--green)}.m-val.warn{color:var(--gold)}.m-val.bad{color:var(--red)}.m-val.dim{color:var(--cyan)}
.m-unit{font-size:.48rem;color:var(--mute);display:block;margin-top:4px;text-transform:uppercase;letter-spacing:.3px}

/* Latency indicator strip */
.lat-strip{display:flex;align-items:center;gap:.75rem;padding:.65rem 1rem;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--r-sm);margin-bottom:.75rem}
.lat-strip-label{font-family:'JetBrains Mono',monospace;font-size:.55rem;font-weight:700;color:var(--mute);letter-spacing:1.5px;text-transform:uppercase}
.lat-ind{font-family:'JetBrains Mono',monospace;font-size:.63rem;font-weight:700;padding:3px 10px;border-radius:20px;margin-left:auto}
.lat-ind.good{color:var(--green);background:rgba(52,211,153,.08);border:1px solid rgba(52,211,153,.18)}
.lat-ind.ok{color:var(--cyan);background:rgba(34,211,238,.07);border:1px solid rgba(34,211,238,.15)}
.lat-ind.warn{color:var(--gold);background:rgba(245,200,66,.07);border:1px solid rgba(245,200,66,.15)}
.lat-ind.bad{color:var(--red);background:rgba(248,113,113,.07);border:1px solid rgba(248,113,113,.15)}

/* Chart */
canvas{width:100%;border-radius:var(--r-sm);background:rgba(255,255,255,.012);border:1px solid var(--border)}

/* Diag items */
.diag-item{display:flex;align-items:flex-start;gap:10px;padding:9px 12px;border-radius:var(--r-xs);font-size:.72rem;line-height:1.55;margin-bottom:4px}
.diag-icon{flex-shrink:0;margin-top:1px;opacity:.85}
.diag-item.good{background:rgba(52,211,153,.05);border:1px solid rgba(52,211,153,.1);color:var(--green)}
.diag-item.warn{background:rgba(245,200,66,.05);border:1px solid rgba(245,200,66,.1);color:var(--gold)}
.diag-item.bad{background:rgba(248,113,113,.05);border:1px solid rgba(248,113,113,.1);color:var(--red)}
.diag-item.info{background:var(--surface);border:1px solid var(--border);color:var(--dim)}

/* Tip grid */
.tip-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}
.tip{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:.8rem .9rem;transition:border-color .2s}
.tip:hover{border-color:var(--border2)}
.tip-ico{margin-bottom:6px}.tip-ico svg{width:20px;height:20px}
.tip-title{font-family:'JetBrains Mono',monospace;font-size:.58rem;font-weight:700;color:var(--text);letter-spacing:.3px;margin-bottom:3px}
.tip-desc{font-size:.63rem;color:var(--dim);line-height:1.5}

/* Player count badge */
.pt-count{font-family:'JetBrains Mono',monospace;font-size:.6rem;color:var(--ac);
  background:rgba(168,85,247,.08);border:1px solid rgba(168,85,247,.18);border-radius:20px;padding:2px 9px}

@media(max-width:560px){
  .m-grid{grid-template-columns:repeat(3,1fr)}
  .tip-grid{grid-template-columns:1fr}
  .ent-grid{grid-template-columns:repeat(2,1fr)}
}
.mh-info{font-size:.58rem;color:var(--mute);margin-top:6px;text-align:center}
.mh-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:8px 10px;margin-bottom:4px;transition:border-color .2s}
.mh-row:hover{border-color:var(--border2)}
.mh-row:last-child{margin-bottom:0}
.mh-row-hd{display:flex;align-items:center;gap:6px;margin-bottom:4px}
.mh-row-dot{width:8px;height:8px;border-radius:2px;background:var(--mc);flex-shrink:0}
.mh-row-name{font-family:'JetBrains Mono',monospace;font-size:.5rem;font-weight:700;color:var(--dim);letter-spacing:.5px;text-transform:uppercase}
.mh-row-val{font-family:'JetBrains Mono',monospace;font-size:.72rem;font-weight:700;color:var(--mc);margin-left:auto}
.mh-row-cv{width:100%;height:32px;border-radius:4px;display:block}
.mh-row-range{display:flex;justify-content:space-between;margin-top:3px}
.mh-row-range span{font-family:'JetBrains Mono',monospace;font-size:.4rem;color:var(--mute)}

/* Fullscreen radar — all controls visible */
#player-details-card:fullscreen,#player-details-card:-webkit-full-screen{
  background:#060a0e;padding:10px 14px 10px;max-width:100vw;width:100vw;height:100vh;
  border:none;border-radius:0;display:flex;flex-direction:column;overflow:hidden;box-sizing:border-box;margin:0}
#player-details-card:fullscreen::before,#player-details-card:-webkit-full-screen::before{display:none}
#player-details-card:fullscreen>*,#player-details-card:-webkit-full-screen>*{flex-shrink:0}
#player-details-card:fullscreen #radar-wrap,#player-details-card:-webkit-full-screen #radar-wrap{
  flex:1 1 0;min-height:0;border-radius:6px;overflow:hidden}
#player-details-card:fullscreen #radar-canvas,#player-details-card:-webkit-full-screen #radar-canvas{
  display:block}
.dim-badge{font-family:'JetBrains Mono',monospace;font-size:.5rem;font-weight:700;background:rgba(168,85,247,.12);border-radius:8px;padding:1px 5px;margin-left:3px;min-width:14px;text-align:center;display:inline-block}

/* Health Index Gauge */
.health-wrap{text-align:center;margin-bottom:.75rem}
.health-gauge{display:inline-flex;align-items:center;gap:1rem;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:.9rem 1.5rem;position:relative;overflow:hidden}
.health-gauge::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(168,85,247,.18),transparent)}
.gauge-svg{width:60px;height:60px;transform:rotate(-90deg);flex-shrink:0}
.gauge-bg{fill:none;stroke:rgba(255,255,255,.06);stroke-width:4}
.gauge-fill{fill:none;stroke-width:4;stroke-linecap:round;transition:stroke-dashoffset .8s ease,stroke .5s}
.gauge-center{text-align:left}
.gauge-score{font-family:'JetBrains Mono',monospace;font-size:1.4rem;font-weight:700;line-height:1}
.gauge-label{font-size:.45rem;color:var(--mute);text-transform:uppercase;letter-spacing:1.5px;margin-top:2px;display:block}
.gauge-sub{font-size:.52rem;color:var(--dim);margin-top:3px;display:block}

/* TPS Trend Arrow */
.trend{font-size:.5rem;display:block;margin-top:2px;font-weight:700;letter-spacing:.3px}
.trend.up{color:var(--green)}.trend.flat{color:var(--dim)}.trend.down{color:var(--red)}

/* Uptime Bar */
.uptime-wrap{margin-bottom:.75rem}
.uptime-hd{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}
.uptime-pct{font-family:'JetBrains Mono',monospace;font-size:.68rem;font-weight:700}
.uptime-lbl{font-family:'JetBrains Mono',monospace;font-size:.48rem;color:var(--mute);text-transform:uppercase;letter-spacing:1.5px;font-weight:600}
.uptime-track{height:5px;background:var(--surface);border-radius:3px;display:flex;overflow:hidden;border:1px solid var(--border)}
.uptime-seg{height:100%;min-width:1px}.uptime-seg.on{background:var(--green)}.uptime-seg.off{background:var(--red)}
.uptime-times{display:flex;justify-content:space-between;margin-top:3px}
.uptime-times span{font-size:.4rem;color:var(--mute);font-family:'JetBrains Mono',monospace}

/* Notification Bell */
.notif-wrap{position:relative;display:inline-block;margin-left:6px;vertical-align:middle}
.notif-bell{background:none;border:1px solid var(--border);border-radius:var(--r-xs);padding:3px 8px;cursor:pointer;color:var(--mute);transition:all .2s;display:inline-flex;align-items:center;gap:3px;font-size:.45rem;font-family:'JetBrains Mono',monospace;letter-spacing:.5px}
.notif-bell:hover{border-color:var(--border2);color:var(--dim)}
.notif-bell.active{border-color:rgba(52,211,153,.3);color:var(--green)}
.notif-badge{position:absolute;top:-5px;right:-5px;background:var(--red);color:#fff;font-size:.38rem;font-weight:700;width:13px;height:13px;border-radius:50%;display:none;line-height:13px;text-align:center}
.notif-panel{display:none;position:absolute;top:calc(100% + 6px);right:-20px;width:240px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-sm);box-shadow:var(--shadow);z-index:50;max-height:260px;overflow-y:auto;scrollbar-width:thin}
.notif-panel.open{display:block}
.notif-hd{padding:7px 10px;border-bottom:1px solid var(--border);font-family:'JetBrains Mono',monospace;font-size:.48rem;font-weight:700;color:var(--dim);letter-spacing:1px;text-transform:uppercase;display:flex;justify-content:space-between;align-items:center}
.notif-clear{font-size:.42rem;color:var(--mute);cursor:pointer;border:none;background:none;font-family:inherit;padding:2px 6px;border-radius:3px}
.notif-clear:hover{color:var(--red)}
.notif-item{display:flex;gap:6px;padding:6px 10px;border-bottom:1px solid rgba(255,255,255,.02)}
.notif-item:last-child{border-bottom:none}
.notif-ico{flex-shrink:0;font-size:.65rem;line-height:1}
.notif-msg{color:var(--dim);font-size:.55rem;line-height:1.4}
.notif-ts{font-size:.42rem;color:var(--mute);margin-top:1px;font-family:'JetBrains Mono',monospace}

/* Heatmap Toggle */
.hm-chk{display:inline-flex;align-items:center;gap:4px;cursor:pointer;font-family:'JetBrains Mono',monospace;font-size:.48rem;color:var(--mute);transition:color .2s}
.hm-chk:hover{color:var(--dim)}
.hm-chk input{accent-color:var(--orange);width:11px;height:11px;cursor:pointer}

/* Peak Hours Bar */
.peak-wrap{position:relative}
.peak-desc{font-family:'JetBrains Mono',monospace;font-size:.48rem;color:var(--mute);margin-bottom:8px;line-height:1.6}
.peak-grid{display:flex;gap:1px;align-items:flex-end;height:56px;margin-top:6px;position:relative}
.peak-bar{flex:1;min-width:0;border-radius:2px 2px 0 0;transition:height .4s ease,opacity .15s;cursor:crosshair;position:relative}
.peak-bar:hover{opacity:.85}
.peak-labels{display:flex;gap:1px;margin-top:2px}
.peak-labels span{flex:1;text-align:center;font-family:'JetBrains Mono',monospace;font-size:.32rem;color:var(--mute)}
.peak-tip{position:absolute;display:none;background:var(--bg2);border:1px solid var(--border2);border-radius:var(--r-xs);padding:6px 10px;font-family:'JetBrains Mono',monospace;font-size:.48rem;color:var(--text);pointer-events:none;z-index:20;white-space:nowrap;box-shadow:var(--shadow);backdrop-filter:blur(6px);top:-4px;transform:translateY(-100%)}
.peak-tip::after{content:'';position:absolute;bottom:-4px;left:50%;transform:translateX(-50%);border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid var(--border2)}
.peak-legend{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.peak-legend-item{display:flex;align-items:center;gap:4px;font-family:'JetBrains Mono',monospace;font-size:.4rem;color:var(--mute)}
.peak-legend-dot{width:8px;height:4px;border-radius:1px;flex-shrink:0}
.peak-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-top:8px}
.peak-stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xs);padding:6px 8px;text-align:center}
.peak-stat-label{font-family:'JetBrains Mono',monospace;font-size:.38rem;color:var(--mute);text-transform:uppercase;letter-spacing:.5px;margin-bottom:3px}
.peak-stat-val{font-family:'JetBrains Mono',monospace;font-size:.62rem;font-weight:700;line-height:1}
@media(max-width:400px){.peak-stats{grid-template-columns:1fr}}

/* Export Buttons */
.exp-btns{display:flex;gap:4px;margin-left:auto}
.exp-btn{font-family:'JetBrains Mono',monospace;font-size:.42rem;font-weight:600;padding:3px 8px;border-radius:var(--r-xs);border:1px solid var(--border);background:var(--surface);color:var(--mute);cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:3px;letter-spacing:.3px}
.exp-btn:hover{border-color:var(--border2);color:var(--dim)}
.exp-btn svg{width:9px;height:9px;opacity:.5}

/* Theme Toggle */
.theme-btn{background:none;border:1px solid var(--border);border-radius:var(--r-xs);padding:3px 8px;cursor:pointer;color:var(--mute);transition:all .2s;display:inline-flex;align-items:center;gap:3px;font-size:.45rem;font-family:'JetBrains Mono',monospace;letter-spacing:.5px;margin-left:4px}
.theme-btn:hover{border-color:var(--border2);color:var(--dim)}
body.light{--bg:#f0f0f5;--bg2:#fff;--bg3:#e8e8f0;--surface:rgba(0,0,0,.03);--surface2:rgba(0,0,0,.05);--surface3:rgba(0,0,0,.08);--border:rgba(0,0,0,.08);--border2:rgba(0,0,0,.14);--border3:rgba(0,0,0,.22);--text:#1a1a2e;--dim:#555580;--mute:#8888aa}
body.light::before{background:radial-gradient(ellipse 700px 450px at 15% 5%,rgba(168,85,247,.06),transparent),radial-gradient(ellipse 500px 400px at 88% 90%,rgba(34,211,238,.04),transparent)}
body.light canvas{background:rgba(0,0,0,.015)}

/* Radar Search */
.radar-search{display:flex;gap:4px;margin-bottom:6px;flex-wrap:wrap}
.radar-search input{font-family:'JetBrains Mono',monospace;font-size:.52rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xs);color:var(--text);padding:4px 8px;outline:none;transition:border-color .2s}
.radar-search input:focus{border-color:var(--ac)}
.radar-search input::placeholder{color:var(--mute)}
.rs-name{flex:1;min-width:100px}
.rs-coord{width:60px}
.rs-btn{font-family:'JetBrains Mono',monospace;font-size:.45rem;font-weight:600;padding:4px 10px;border-radius:var(--r-xs);border:1px solid var(--border);background:var(--surface);color:var(--dim);cursor:pointer;transition:all .2s}
.rs-btn:hover{border-color:var(--ac);color:var(--ac)}

/* Metric comparison delta */
.mh-delta{font-family:'JetBrains Mono',monospace;font-size:.42rem;font-weight:600;margin-left:6px;padding:1px 5px;border-radius:3px}
.mh-delta.up{color:var(--green);background:rgba(52,211,153,.08)}
.mh-delta.down{color:var(--red);background:rgba(248,113,113,.08)}
.mh-delta.flat{color:var(--mute);background:var(--surface)}

/* Chart Tooltip */
.chart-tip{position:absolute;display:none;background:var(--bg2);border:1px solid var(--border2);border-radius:var(--r-xs);padding:5px 9px;font-family:'JetBrains Mono',monospace;font-size:.48rem;color:var(--text);pointer-events:none;z-index:10;white-space:nowrap;box-shadow:var(--shadow)}
.chart-tip-line{position:absolute;display:none;width:1px;background:rgba(168,85,247,.3);pointer-events:none;z-index:9;top:0;bottom:0}

/* Metric Sparkline Background */
.m-card{position:relative;overflow:hidden}
.m-spark{position:absolute;bottom:0;left:0;right:0;height:20px;opacity:.3;pointer-events:none}

/* Radar Mini-Map */
.radar-minimap{position:absolute;bottom:8px;left:8px;width:80px;height:80px;background:rgba(6,10,14,.85);border:1px solid var(--border);border-radius:var(--r-xs);z-index:3;display:none;backdrop-filter:blur(4px);overflow:hidden}
.radar-minimap canvas{width:100%;height:100%;display:block}

/* Measure Tool */
.measure-btn{font-family:'JetBrains Mono',monospace;font-size:.45rem;font-weight:600;padding:3px 8px;border-radius:var(--r-xs);border:1px solid var(--border);background:var(--surface);color:var(--mute);cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:3px}
.measure-btn:hover{border-color:var(--border2);color:var(--dim)}
.measure-btn.active{border-color:rgba(245,200,66,.3);color:var(--gold);background:rgba(245,200,66,.06)}
.measure-info{font-family:'JetBrains Mono',monospace;font-size:.45rem;color:var(--gold);margin-left:auto}
.radar-coord-tip{position:absolute;display:none;background:rgba(8,12,18,.88);border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:8px 12px;font-family:'JetBrains Mono',monospace;font-size:.5rem;line-height:1.6;color:rgba(255,255,255,.7);pointer-events:none;z-index:4;white-space:normal;max-width:min(280px,80vw);word-break:break-word;backdrop-filter:blur(12px) saturate(1.3);-webkit-backdrop-filter:blur(12px) saturate(1.3);box-shadow:0 4px 16px rgba(0,0,0,.3),0 0 0 1px rgba(0,0,0,.15);animation:coordFadeIn .18s ease}
.radar-coord-tip b{color:#fff;font-weight:600;font-size:.55rem}
.radar-coord-tip .tip-dim{color:rgba(255,255,255,.3);font-size:.42rem}
.radar-coord-tip .tip-warn{color:#fb923c;font-weight:600}
.radar-coord-tip .tip-crit{color:#f87171;font-weight:600}
.radar-coord-tip .tip-ok{color:#34d399;font-weight:500}
@keyframes coordFadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}

/* Land Expiry Table */
.exp-tbl{width:100%;border-collapse:collapse;font-family:'JetBrains Mono',monospace;font-size:.48rem}
.exp-tbl th{text-align:left;padding:5px 8px;color:var(--mute);font-weight:600;font-size:.4rem;letter-spacing:.5px;text-transform:uppercase;border-bottom:1px solid var(--border);white-space:nowrap}
.exp-tbl td{padding:5px 8px;color:var(--dim);border-bottom:1px solid rgba(255,255,255,.02);white-space:nowrap;vertical-align:middle}
.exp-tbl tr:hover td{background:rgba(255,255,255,.015);color:var(--text)}
.exp-tbl .exp-name{color:var(--text);font-weight:600;max-width:100px;overflow:hidden;text-overflow:ellipsis}
.exp-tbl .exp-owner{max-width:80px;overflow:hidden;text-overflow:ellipsis}
.exp-st{display:inline-block;padding:1px 6px;border-radius:3px;font-size:.4rem;font-weight:700;letter-spacing:.3px}
.exp-st.st-ok{color:#34d399;background:rgba(52,211,153,.08)}
.exp-st.st-warn{color:#fb923c;background:rgba(251,146,60,.08)}
.exp-st.st-crit{color:#f87171;background:rgba(248,113,113,.08)}
.exp-st.st-dead{color:#fff;background:rgba(248,113,113,.22)}
.exp-pos{color:var(--mute);font-size:.4rem}
#land-exp-body.collapsed{display:none}

/* Server Selector */
.srv-select{font-family:'JetBrains Mono',monospace;font-size:.65rem;font-weight:700;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xs);color:var(--text);padding:4px 24px 4px 8px;cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%238888aa' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 6px center;background-size:10px;transition:border-color .2s,box-shadow .2s;max-width:200px}
.srv-select:hover{border-color:var(--border2)}
.srv-select:focus{border-color:var(--ac);outline:none;box-shadow:0 0 0 2px rgba(168,85,247,.15)}
.srv-select option{background:var(--bg2);color:var(--text);padding:4px}
body.light .srv-select{background-color:rgba(0,0,0,.03);border-color:rgba(0,0,0,.1);color:#1a1a2e;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%23555580' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E")}
body.light .srv-select option{background:#fff;color:#1a1a2e}

/* Keyboard Shortcuts Bar */
.kbd-bar{display:flex;flex-wrap:wrap;gap:4px;justify-content:center;margin-top:6px}
.kbd{font-family:'JetBrains Mono',monospace;font-size:.38rem;color:var(--mute);border:1px solid var(--border);border-radius:3px;padding:1px 5px;background:var(--surface);display:inline-flex;gap:3px;align-items:center}
.kbd b{color:var(--dim);font-weight:700}

/* Light theme polish */
body.light .cd{background:rgba(255,255,255,.8);border-color:rgba(0,0,0,.06)}
body.light .tab{background:rgba(0,0,0,.03);border-color:rgba(0,0,0,.08);color:#555580}
body.light .tab.a{background:rgba(168,85,247,.08);border-color:rgba(168,85,247,.2);color:#7c3aed}
body.light .orb.on{background:radial-gradient(circle,#22c55e 0%,#15803d 100%)}
body.light .m-card{background:rgba(255,255,255,.7);border-color:rgba(0,0,0,.06)}
body.light .hd a{color:#555580}
body.light .notif-bell{border-color:rgba(0,0,0,.1);color:#555580}
body.light .theme-btn{border-color:rgba(0,0,0,.1);color:#555580}
body.light .measure-btn{border-color:rgba(0,0,0,.1);color:#555580;background:rgba(0,0,0,.02)}
body.light .rs-btn{border-color:rgba(0,0,0,.1);color:#555580;background:rgba(0,0,0,.02)}
body.light .radar-search input{background:rgba(0,0,0,.03);border-color:rgba(0,0,0,.08);color:#1a1a2e}
body.light .exp-btn{border-color:rgba(0,0,0,.1);color:#555580;background:rgba(0,0,0,.02)}
body.light .mh-row{background:rgba(0,0,0,.02);border-color:rgba(0,0,0,.06)}
body.light .info-row{border-color:rgba(0,0,0,.04)}
body.light .tip{background:rgba(255,255,255,.7);border-color:rgba(0,0,0,.06)}
body.light .ft{background:rgba(255,255,255,.5);border-color:rgba(0,0,0,.06)}
body.light .rb{background:rgba(168,85,247,.08);border-color:rgba(168,85,247,.2);color:#7c3aed}
body.light .diag-item{background:rgba(0,0,0,.02);border-color:rgba(0,0,0,.06)}
body.light .notif-panel{background:#fff;border-color:rgba(0,0,0,.1)}
body.light .chart-tip{background:#fff;border-color:rgba(0,0,0,.12);color:#1a1a2e}

/* Integrated health in status card */
.sc{justify-content:space-between}
.health-inline{display:none;align-items:center;gap:8px}
.health-inline .gauge-svg{width:44px;height:44px}
.health-inline .gauge-center{text-align:right}
.health-inline .gauge-score{font-size:1rem}
.health-inline .gauge-label{font-size:.38rem}
.health-inline .gauge-sub{font-size:.42rem}

/* ═══ Lag Prediction Banner ═══ */
.lag-predict{display:flex;align-items:flex-start;gap:12px;padding:10px 14px;border-radius:var(--r-sm);margin-bottom:.75rem;position:relative;animation:lagPredictPulse 3s ease-in-out infinite;transition:all .4s ease}
.lag-predict.level-warn{background:rgba(251,191,36,.06);border:1px solid rgba(251,191,36,.2)}
.lag-predict.level-crit{background:rgba(248,113,113,.06);border:1px solid rgba(248,113,113,.25)}
.lag-predict-icon{flex-shrink:0;width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center}
.lag-predict.level-warn .lag-predict-icon{background:rgba(251,191,36,.1);color:var(--gold)}
.lag-predict.level-crit .lag-predict-icon{background:rgba(248,113,113,.12);color:var(--red)}
.lag-predict-body{flex:1;min-width:0}
.lag-predict-title{font-family:'JetBrains Mono',monospace;font-size:.52rem;font-weight:700;letter-spacing:1px;margin-bottom:3px}
.lag-predict.level-warn .lag-predict-title{color:var(--gold)}
.lag-predict.level-crit .lag-predict-title{color:var(--red)}
.lag-predict-desc{font-size:.58rem;color:var(--dim);line-height:1.5;margin-bottom:6px}
.lag-predict-bar{height:4px;background:var(--surface);border-radius:2px;overflow:hidden;margin-bottom:6px}
.lag-predict-fill{height:100%;border-radius:2px;transition:width .6s ease,background .4s}
.lag-predict.level-warn .lag-predict-fill{background:linear-gradient(90deg,var(--gold),#fb923c)}
.lag-predict.level-crit .lag-predict-fill{background:linear-gradient(90deg,#fb923c,var(--red))}
.lag-predict-actions{font-family:'JetBrains Mono',monospace;font-size:.45rem;color:var(--mute);line-height:1.6}
.lag-predict-actions b{color:var(--dim);font-weight:600}
.lag-predict-close{position:absolute;top:6px;right:8px;background:none;border:none;color:var(--mute);font-size:.8rem;cursor:pointer;padding:2px 6px;line-height:1;opacity:.5;transition:opacity .2s}
.lag-predict-close:hover{opacity:1}
@keyframes lagPredictPulse{0%,100%{opacity:1}50%{opacity:.88}}
@media(prefers-reduced-motion:reduce){.lag-predict{animation:none}}

/* ═══ Entity Budget Gauge ═══ */
.ent-budget-row{display:flex;align-items:center;gap:8px;padding:5px 0}
.ent-budget-row+.ent-budget-row{border-top:1px solid rgba(255,255,255,.03)}
.ent-budget-label{font-family:'JetBrains Mono',monospace;font-size:.48rem;font-weight:600;color:var(--dim);width:70px;flex-shrink:0;letter-spacing:.3px}
.ent-budget-track{flex:1;height:6px;background:var(--surface);border-radius:3px;overflow:hidden;border:1px solid var(--border);position:relative}
.ent-budget-bar{height:100%;border-radius:3px;transition:width .6s ease,background .4s}
.ent-budget-bar.safe{background:linear-gradient(90deg,#34d399,#22d3ee)}
.ent-budget-bar.warn{background:linear-gradient(90deg,#fbbf24,#fb923c)}
.ent-budget-bar.crit{background:linear-gradient(90deg,#fb923c,#f87171)}
.ent-budget-val{font-family:'JetBrains Mono',monospace;font-size:.48rem;font-weight:700;width:80px;text-align:right;flex-shrink:0}
.ent-budget-val.safe{color:var(--green)}
.ent-budget-val.warn{color:var(--gold)}
.ent-budget-val.crit{color:var(--red)}
.ent-budget-tip{font-family:'JetBrains Mono',monospace;font-size:.42rem;color:var(--mute);margin-top:6px;line-height:1.5;text-align:center}
body.light .lag-predict.level-warn{background:rgba(251,191,36,.06);border-color:rgba(251,191,36,.18)}
body.light .lag-predict.level-crit{background:rgba(248,113,113,.06);border-color:rgba(248,113,113,.2)}
body.light .ent-budget-row+.ent-budget-row{border-color:rgba(0,0,0,.04)}
body.light .ent-budget-track{background:rgba(0,0,0,.04);border-color:rgba(0,0,0,.08)}

/* ═══ TPS Drop Correlation Chart ═══ */
.tps-corr-legend{display:flex;gap:12px;margin-top:6px;flex-wrap:wrap}
.tps-corr-legend-item{display:flex;align-items:center;gap:4px;font-family:'JetBrains Mono',monospace;font-size:.4rem;color:var(--mute)}
.tps-corr-dot{width:8px;height:3px;border-radius:1px;flex-shrink:0}

/* ═══ Lag Event Log ═══ */
#lag-log-body.collapsed{display:none}
.lag-log-empty{font-family:'JetBrains Mono',monospace;font-size:.48rem;color:var(--mute);text-align:center;padding:12px 0}
.lag-ev{display:flex;gap:8px;align-items:flex-start;padding:6px 8px;border-radius:var(--r-xs);margin-bottom:4px;font-family:'JetBrains Mono',monospace;font-size:.48rem;line-height:1.5}
.lag-ev:last-child{margin-bottom:0}
.lag-ev.sev-crit{background:rgba(248,113,113,.05);border:1px solid rgba(248,113,113,.12)}
.lag-ev.sev-warn{background:rgba(251,191,36,.04);border:1px solid rgba(251,191,36,.1)}
.lag-ev.sev-ok{background:rgba(52,211,153,.04);border:1px solid rgba(52,211,153,.1)}
.lag-ev-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;margin-top:4px}
.lag-ev.sev-crit .lag-ev-dot{background:var(--red)}
.lag-ev.sev-warn .lag-ev-dot{background:var(--gold)}
.lag-ev.sev-ok .lag-ev-dot{background:var(--green)}
.lag-ev-body{flex:1;min-width:0}
.lag-ev-title{font-weight:600;margin-bottom:2px}
.lag-ev.sev-crit .lag-ev-title{color:var(--red)}
.lag-ev.sev-warn .lag-ev-title{color:var(--gold)}
.lag-ev.sev-ok .lag-ev-title{color:var(--green)}
.lag-ev-detail{color:var(--mute);font-size:.42rem}
.lag-ev-time{font-size:.4rem;color:var(--mute);flex-shrink:0;text-align:right;min-width:40px}

/* ═══ Hotspot Recommendation Tooltip ═══ */
.hs-reco{position:absolute;display:none;background:rgba(8,12,18,.92);border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:10px 14px;font-family:'JetBrains Mono',monospace;font-size:.48rem;line-height:1.6;color:rgba(255,255,255,.7);pointer-events:none;z-index:5;white-space:normal;max-width:min(320px,85vw);word-break:break-word;backdrop-filter:blur(14px) saturate(1.3);-webkit-backdrop-filter:blur(14px) saturate(1.3);box-shadow:0 6px 24px rgba(0,0,0,.4),0 0 0 1px rgba(0,0,0,.15);animation:coordFadeIn .18s ease}
.hs-reco b{color:#fff;font-weight:600}
.hs-reco-title{font-size:.52rem;font-weight:700;color:#fff;margin-bottom:4px;display:flex;align-items:center;gap:6px}
.hs-reco-types{margin:4px 0 6px}
.hs-reco-type{display:inline-flex;align-items:center;gap:3px;padding:1px 6px;border-radius:3px;margin:1px 2px;font-size:.42rem;font-weight:600}
.hs-reco-type.hostile{background:rgba(248,113,113,.12);color:#f87171}
.hs-reco-type.passive{background:rgba(52,211,153,.1);color:#34d399}
.hs-reco-type.item{background:rgba(251,191,36,.1);color:#fbbf24}
.hs-reco-type.other{background:rgba(168,85,247,.1);color:#a855f7}
.hs-reco-actions{margin-top:6px;border-top:1px solid rgba(255,255,255,.06);padding-top:6px}
.hs-reco-cmd{display:flex;align-items:center;gap:4px;cursor:pointer;padding:2px 6px;border-radius:3px;transition:background .15s;font-size:.42rem;color:var(--cyan)}
.hs-reco-cmd:hover{background:rgba(34,211,238,.08)}
body.light .hs-reco{background:rgba(255,255,255,.95);border-color:rgba(0,0,0,.12);color:#555}
body.light .hs-reco b{color:#1a1a2e}
body.light .hs-reco-title{color:#1a1a2e}
body.light .lag-ev.sev-crit{background:rgba(248,113,113,.05);border-color:rgba(248,113,113,.1)}
body.light .lag-ev.sev-warn{background:rgba(251,191,36,.04);border-color:rgba(251,191,36,.08)}
body.light .lag-ev.sev-ok{background:rgba(52,211,153,.04);border-color:rgba(52,211,153,.08)}
