:root{
  --bg:#0c0e10;
  --panel:#14171a;
  --panel-2:#181c20;
  --border:#23282d;
  --border-soft:#1c2025;
  --text:#d4d8db;
  --muted:#6c7480;
  --dim:#454c54;

  --accent:#d96b3e;       /* ember copper */
  --accent-hi:#f08550;
  --accent-soft:#3a201a;
  --good:#6dc77b;
  --bad:#d96b6b;
  --info:#6ba9d9;

  --shadow:0 8px 24px rgba(0,0,0,.45);
  --r:6px;
  --r-sm:3px;
}

*,*::before,*::after{box-sizing:border-box}
html,body{
  margin:0;height:100%;overflow:hidden;color:var(--text);
  font-family:system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  font-size:13px;
  background:
    radial-gradient(1100px 700px at 70% -10%, rgba(217,107,62,.06), transparent 55%),
    linear-gradient(180deg, rgba(10,12,14,.92), rgba(12,14,16,.88) 60%),
    url('/img/background-art.png') center/cover no-repeat fixed;
}
button,input,select,textarea{font-family:inherit;color:inherit;font-size:13px}

/* === TOPBAR === */
.topbar{
  display:flex;align-items:center;gap:0;
  height:52px;padding:0;
  background:linear-gradient(180deg,#13161b 0%,#0e1115 100%);
  border-bottom:1px solid rgba(217,107,62,.15);
  box-shadow:0 1px 0 rgba(217,107,62,.08), 0 4px 24px rgba(0,0,0,.5);
  position:relative;z-index:5;
  overflow:visible;white-space:nowrap;
}
.topbar::after{
  content:"";position:absolute;bottom:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(217,107,62,.4) 20%,rgba(240,133,80,.5) 50%,rgba(217,107,62,.4) 80%,transparent);
  pointer-events:none;
}

/* Logo */
.tb-logo{
  display:flex;align-items:center;gap:8px;
  padding:0 22px;height:100%;flex:0 0 auto;
  border-right:1px solid rgba(255,255,255,.055);
}
.tb-logo-mark{
  width:9px;height:9px;border-radius:3px;
  background:var(--accent);
  box-shadow:0 0 12px rgba(217,107,62,.8),0 0 24px rgba(217,107,62,.35);
  flex:0 0 auto;
}
.tb-logo-tea{
  font-family:'Rubik',sans-serif;font-size:18px;font-weight:800;
  color:var(--accent-hi);letter-spacing:.06em;line-height:1;
}
.tb-logo-rust{
  font-family:'Rubik',sans-serif;font-size:18px;font-weight:800;
  color:#ede4d8;letter-spacing:.06em;line-height:1;
}
.tb-logo-node{
  font-size:10px;color:var(--dim);letter-spacing:.12em;font-weight:500;
  text-transform:uppercase;padding:2px 7px;
  border:1px solid rgba(255,255,255,.07);border-radius:3px;
  background:rgba(255,255,255,.03);margin-left:2px;
}

/* Divider */
.tb-divider{width:1px;height:26px;background:rgba(255,255,255,.07);flex:0 0 auto;margin:0 4px}

/* Status chips */
.tb-stats{display:flex;align-items:center;gap:5px;padding:0 12px;flex:1;min-width:0;overflow:hidden}
.tb-chip{
  display:inline-flex;align-items:center;gap:0;
  padding:4px 10px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07);
  border-radius:5px;
  font-size:11px;color:var(--muted);
  letter-spacing:.05em;font-variant-numeric:tabular-nums;
  white-space:nowrap;flex:0 0 auto;
  transition:.15s;
}
.tb-chip-time{
  color:var(--accent-hi);font-weight:700;
  border-color:rgba(217,107,62,.2);
  background:rgba(217,107,62,.07);
}
.tb-chip-wipe{
  color:#9fb3c8;font-size:10px;
  border-color:rgba(159,179,200,.15);
  background:rgba(159,179,200,.05);
}
/* Secondary chips hidden by default, reveal on stats hover */
.tb-chip-server,.tb-chip-wipe{
  opacity:0;max-width:0;padding-left:0;padding-right:0;
  border-left-width:0;border-right-width:0;overflow:hidden;
  transition:opacity .2s,max-width .25s,padding .2s,border-width .2s;
}
.tb-stats:hover .tb-chip-server:not(.hidden),
.tb-stats:hover .tb-chip-wipe:not(.hidden){
  opacity:1;max-width:220px;padding-left:10px;padding-right:10px;
  border-left-width:1px;border-right-width:1px;
}

/* Wipe-preview toggle chip */
.tb-chip-preview{
  gap:5px;cursor:pointer;font-weight:700;
  font-family:'Rubik',sans-serif;
  color:#7ecf8a;
  border-color:rgba(126,207,138,.28);
  background:rgba(126,207,138,.08);
}
.tb-chip-preview:hover{background:rgba(126,207,138,.16);border-color:rgba(126,207,138,.45)}
.tb-chip-preview.active{
  color:#fff;background:rgba(126,207,138,.85);border-color:rgba(126,207,138,.9);
  box-shadow:0 0 12px rgba(126,207,138,.4);
}
.tb-chip-preview svg{flex:0 0 auto}

/* Wipe-preview seed/size dialog */
.wp-backdrop{
  position:fixed;inset:0;z-index:4000;
  background:rgba(0,0,0,.6);backdrop-filter:blur(5px);
  display:flex;align-items:center;justify-content:center;padding:16px;
}
.wp-backdrop[hidden]{display:none}
.wp-box{
  background:#0f1215;border:1px solid rgba(255,255,255,.1);
  border-radius:16px;padding:22px 20px 18px;width:100%;max-width:380px;
  box-shadow:0 18px 50px rgba(0,0,0,.7);
}
.wp-title{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:700;color:#7ecf8a;margin-bottom:8px}
.wp-sub{font-size:12.5px;color:var(--muted);line-height:1.55;margin-bottom:16px}
.wp-row{display:flex;gap:10px}
.wp-field{flex:1;display:flex;flex-direction:column;gap:5px}
.wp-field label{font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.07em}
.wp-inp{
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  border-radius:9px;color:var(--text);font-family:'Rubik',sans-serif;font-size:14px;
  padding:9px 11px;width:100%;transition:border-color .13s;
}
.wp-inp:focus{outline:none;border-color:rgba(126,207,138,.5)}
.wp-msg{font-size:12px;min-height:17px;margin:10px 0 4px;color:#7ecf8a}
.wp-msg.err{color:#ff7070}
.wp-btns{display:flex;gap:8px;margin-top:8px}
.wp-cancel{
  flex:1;padding:10px;border-radius:9px;background:rgba(255,255,255,.05);
  color:var(--text);border:1px solid rgba(255,255,255,.1);
  font-family:'Rubik',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:background .13s;
}
.wp-cancel:hover{background:rgba(255,255,255,.1)}
.wp-go{
  flex:1;padding:10px;border-radius:9px;background:rgba(90,160,90,.85);
  color:#fff;border:1px solid rgba(126,207,138,.5);
  font-family:'Rubik',sans-serif;font-size:13px;font-weight:700;cursor:pointer;transition:background .13s;
}
.wp-go:hover{background:rgba(100,175,100,.95)}
.wp-go:disabled{opacity:.5;cursor:default}

/* Right zone */
.tb-right{
  display:flex;align-items:center;gap:8px;
  padding:0 16px;height:100%;
  border-left:1px solid rgba(255,255,255,.055);
  flex:0 0 auto;
}
.tb-me{
  display:inline-flex;align-items:center;gap:7px;
  padding:5px 12px;
  background:rgba(217,107,62,.07);
  border:1px solid rgba(217,107,62,.18);
  border-radius:6px;
  font-size:11.5px;color:var(--accent-hi);font-weight:600;letter-spacing:.03em;
  white-space:nowrap;
}
.tb-me::before{
  content:"";width:6px;height:6px;border-radius:50%;
  background:var(--good);box-shadow:0 0 7px rgba(109,199,123,.8);
  flex:0 0 auto;
}
/* Nav button group — subtle shared background */
.tb-nav-group{
  display:flex;align-items:center;gap:2px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.07);
  border-radius:7px;
  padding:3px;
}
.tb-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:5px;
  padding:5px 11px;
  background:transparent;
  border:1px solid transparent;
  border-radius:5px;
  color:var(--muted);font-size:12px;font-weight:500;
  cursor:pointer;text-decoration:none;
  transition:.15s;white-space:nowrap;
}
.tb-btn:hover{
  border-color:rgba(255,255,255,.1);
  color:var(--text);
  background:rgba(255,255,255,.06);
}
.tb-btn:active{transform:scale(.97)}
.tb-btn-icon{width:28px;padding:5px;}
.tb-btn-menu{
  padding:5px 14px;gap:6px;
  border-color:rgba(217,107,62,.3);
  color:var(--accent-hi);
  box-shadow:0 0 10px rgba(217,107,62,.08);
}
.tb-btn-menu:hover{
  border-color:rgba(217,107,62,.6);
  background:rgba(217,107,62,.1);
  box-shadow:0 0 18px rgba(217,107,62,.22);
  color:var(--accent-hi);
}
.tb-btn-danger{
  padding:5px 12px;
  color:var(--muted);
  border:1px solid rgba(255,255,255,.07);
  border-radius:6px;
  background:transparent;
}
.tb-btn-danger:hover{border-color:rgba(217,107,107,.35);color:var(--bad);background:rgba(217,107,107,.07);}

/* legacy .btn kept for voice panel */
.btn{
  background:var(--panel);border:1px solid var(--border);
  border-radius:var(--r-sm);color:var(--text);
  padding:5px 10px;cursor:pointer;font-size:12px;font-weight:500;
  text-decoration:none;display:inline-flex;align-items:center;gap:5px;
  transition:.15s;
}
.btn:hover{border-color:var(--accent);color:var(--accent-hi);background:rgba(217,107,62,.1)}
.btn.ghost{background:transparent}

/* === LAYOUT === */
.layout{
  display:grid;
  grid-template-columns:minmax(0,280px) minmax(0,1fr) minmax(0,320px);
  height:calc(100vh - 52px);
  overflow:hidden;
}
.sidebar{
  background:var(--bg);border-right:1px solid var(--border);
  overflow-y:auto;overflow-x:hidden;padding:10px;min-width:0;
}
.sidebar.right{border-right:0;border-left:1px solid var(--border)}
.mapwrap{min-width:0}

/* === PANEL === */
.panel{
  background:var(--panel);border:1px solid var(--border);
  border-radius:var(--r);margin-bottom:10px;
  box-shadow:var(--shadow);
}
.panel h3{
  margin:0;padding:9px 12px;
  font-size:11px;letter-spacing:.10em;color:var(--muted);
  text-transform:uppercase;font-weight:600;
  border-bottom:1px solid var(--border-soft);
  display:flex;align-items:center;justify-content:space-between;
}
.panel > *:not(h3){padding:10px 12px}
.panel > h3 + *{padding-top:10px}
.badge{
  background:var(--accent-soft);color:var(--accent-hi);
  font-size:10px;padding:2px 7px;border-radius:10px;font-weight:600;
}

/* === FIELDS === */
.field-block{padding:10px 12px;border-bottom:1px solid var(--border-soft)}
.field-block:last-child{border-bottom:0}
.field-label{
  font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.10em;
  margin-bottom:8px;display:flex;justify-content:space-between;align-items:center;
}
.hint{color:var(--dim);font-weight:400;text-transform:none;letter-spacing:0;font-size:10px}

/* === TOOL GRID === */
.tool-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:4px}
.tool-btn{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  padding:8px 4px;border:1px solid var(--border);border-radius:var(--r-sm);
  background:var(--panel-2);color:var(--muted);cursor:pointer;
  transition:.12s;
}
.tool-btn:hover{
  color:var(--accent-hi);border-color:var(--accent);
  background:rgba(217,107,62,.1);
  box-shadow:0 0 8px rgba(217,107,62,.18);
  transform:translateY(-1px);
}
.tool-btn:active{transform:translateY(0)}
.tool-btn.active{
  background:rgba(217,107,62,.12);border-color:var(--accent);color:var(--accent-hi);
  box-shadow:inset 0 0 0 1px rgba(217,107,62,.2);
}
.tool-btn span{font-size:9.5px;letter-spacing:.04em;text-transform:uppercase;font-weight:600}

/* === ICON GRID === */
.icon-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.icon-btn{
  aspect-ratio:1;display:grid;place-items:center;
  border:1px solid var(--border);border-radius:var(--r-sm);
  background:var(--panel-2);color:var(--muted);cursor:pointer;
  transition:.12s;
}
.icon-btn:hover{
  color:var(--accent-hi);border-color:var(--accent);
  background:rgba(217,107,62,.1);
  box-shadow:0 0 8px rgba(217,107,62,.18);
}
.icon-btn.active{background:rgba(217,107,62,.18);border-color:var(--accent);color:var(--accent-hi)}

/* === SWATCHES === */
.swatch-grid{display:grid;grid-template-columns:repeat(11,1fr);gap:3px}
.swatch{
  aspect-ratio:1;border:1px solid rgba(255,255,255,.15);border-radius:var(--r-sm);
  cursor:pointer;padding:0;position:relative;
}
.swatch:hover{transform:scale(1.08)}
.swatch.active::after{
  content:"";position:absolute;inset:-2px;border:2px solid var(--accent);
  border-radius:var(--r-sm);
}
.swatch-custom{background:linear-gradient(135deg,#ff6b6b,#feca57,#48dbfb,#a55eea);padding:0;width:100%;border:1px solid var(--border)}

/* === SEGMENTED CONTROL === */
.seg-control{display:grid;grid-template-columns:repeat(3,1fr);gap:3px}
.seg-btn{
  display:flex;align-items:center;justify-content:center;gap:4px;
  padding:7px 4px;border:1px solid var(--border);border-radius:var(--r-sm);
  background:var(--panel-2);color:var(--muted);cursor:pointer;
  font-size:11px;font-weight:500;
  transition:.12s;
}
.seg-btn:hover{
  color:var(--accent-hi);border-color:var(--accent);
  background:rgba(217,107,62,.1);
  box-shadow:0 0 8px rgba(217,107,62,.18);
}
.seg-btn.active{background:rgba(217,107,62,.15);border-color:var(--accent);color:var(--accent-hi)}

/* === INPUTS === */
input[type="number"], input[type="text"], select{
  width:100%;background:var(--bg);border:1px solid var(--border);
  color:var(--text);border-radius:var(--r-sm);padding:7px 9px;
  outline:none;transition:.12s;
}
input:focus{border-color:var(--accent)}
.ttl-row input{margin-top:6px}

/* === SWITCHES (replace checkbox) === */
.layers{list-style:none;padding:10px 12px;margin:0;display:grid;gap:4px}
.layer-heat-row{display:flex;align-items:center;gap:6px;}
.layer-heat-row .switch{flex:1;}
.lyr-clear-btn{background:none;border:none;color:var(--muted);font-size:10px;cursor:pointer;padding:2px 5px;border-radius:3px;line-height:1;opacity:.6;}
.lyr-clear-btn:hover{background:rgba(255,255,255,.08);color:#f87171;opacity:1;}
.layer-heat-filter{padding:2px 6px 6px 6px;}
.heat-filter-hdr{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:none;color:var(--muted);font-size:10px;padding:4px 2px;cursor:pointer;letter-spacing:.03em;}
.heat-filter-hdr:hover{color:var(--text);}
.heat-filter-chevron{flex-shrink:0;transition:transform .2s;opacity:.6;}
.heat-filter-hdr.collapsed .heat-filter-chevron{transform:rotate(-90deg);}
.heat-pills{display:flex;flex-wrap:wrap;gap:5px;overflow:hidden;max-height:200px;transition:max-height .2s ease,opacity .15s;}
.heat-pills.collapsed{max-height:0;opacity:0;pointer-events:none;}
.heat-pill{display:flex;align-items:center;gap:5px;background:#141c28;border:1.5px solid #263040;border-radius:20px;padding:3px 10px 3px 4px;cursor:pointer;font-size:10.5px;font-weight:500;color:#9baabb;line-height:1;transition:border-color .15s,background .15s,color .15s;white-space:nowrap;}
.heat-pill img{width:20px;height:20px;border-radius:50%;object-fit:cover;flex-shrink:0;border:1.5px solid #2a3a50;}
.heat-pill:hover{background:#1a2535;border-color:#3a5070;color:#c8d8e8;}
.heat-pill--active{background:#1e1510;border-color:#d96b3e;color:#f5b090;}
.heat-pill--active img{border-color:#d96b3e;}
.switch{
  display:flex;align-items:center;gap:10px;cursor:pointer;
  padding:5px 0;font-size:12px;color:var(--text);
  position:relative;
}
.switch input{position:absolute;inset:0;width:100%;height:100%;opacity:0;pointer-events:none;margin:0}
.switch .track{
  width:30px;height:16px;background:var(--border);border-radius:8px;
  position:relative;transition:.15s;flex:0 0 auto;
}
.switch .track::after{
  content:"";position:absolute;top:2px;left:2px;
  width:12px;height:12px;background:var(--muted);border-radius:50%;
  transition:.15s;
}
.switch input:checked + .track{background:var(--accent-soft)}
.switch input:checked + .track::after{transform:translateX(14px);background:var(--accent-hi)}
.switch .lbl{flex:1;letter-spacing:.02em}
.switch:hover{color:var(--accent-hi)}

/* === SQUAD LIST === */
.team{list-style:none;padding:10px 12px;margin:0;display:grid;gap:4px}
.team li{
  display:flex;gap:8px;align-items:center;padding:6px 9px;
  background:var(--panel-2);border:1px solid var(--border-soft);
  border-radius:var(--r-sm);font-size:12px;
  transition:.12s;
}
.team li:hover{border-color:var(--accent);background:#1b1f24}
.team .dot{width:7px;height:7px;border-radius:50%;background:var(--dim);flex:0 0 auto}
.team .dot.online{background:var(--good);box-shadow:0 0 6px rgba(109,199,123,.5)}
.team .dot.dead{background:var(--bad);box-shadow:0 0 6px rgba(217,107,107,.5)}
.team .name{color:var(--text);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.team .coord{color:var(--muted);font-size:10px;font-variant-numeric:tabular-nums;letter-spacing:.04em;font-family:ui-monospace,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.team .crown{
  background:transparent;border:1px solid var(--border);
  border-radius:var(--r-sm);color:var(--muted);
  padding:3px 5px;cursor:pointer;display:grid;place-items:center;
  transition:.12s;flex:0 0 auto;
}
button.crown:hover{color:var(--accent-hi);border-color:var(--accent)}
.team .crown.is-leader{color:var(--accent-hi);border-color:var(--accent);background:rgba(217,107,62,.10);cursor:default}
.team .crown:disabled{opacity:.5;cursor:wait}

/* team member avatar layout */
.team-avatar-wrap{
  position:relative;flex:0 0 auto;cursor:pointer;
}
.team-avatar{
  width:36px;height:36px;border-radius:6px;
  background:var(--panel-2);border:1px solid var(--border-soft);
  object-fit:cover;display:block;
}
.team-avatar-init{
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:14px;color:var(--accent-hi);
}
.team-avatar-wrap .dot{
  position:absolute;right:-2px;bottom:-2px;
  border:2px solid var(--panel);
}
.team-avatar-wrap:hover .team-avatar{border-color:var(--accent)}
.team-info{
  flex:1;min-width:0;display:flex;flex-direction:column;gap:2px;cursor:pointer;
}
.team-info:hover .name{color:var(--accent-hi)}

/* === PROMOTE DIALOG === */
.pdlg-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.pdlg-avatar{
  width:48px;height:48px;border-radius:6px;flex:0 0 48px;
  background:var(--panel-2);border:1px solid var(--border-soft);
  display:flex;align-items:center;justify-content:center;
  font-size:20px;font-weight:700;color:var(--accent-hi);overflow:hidden;
}
.pdlg-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.pdlg-meta{display:flex;flex-direction:column;gap:4px}
.pdlg-title{font-size:11px;font-weight:700;color:var(--muted);letter-spacing:.08em;text-transform:uppercase}
.pdlg-name{font-size:15px;font-weight:700;color:#f0e6d2}
.pdlg-body{font-size:12px;color:var(--muted);margin:0 0 10px;line-height:1.5}
.pdlg-warn{
  background:rgba(217,107,62,.1);border:1px solid var(--accent-soft);
  border-radius:var(--r-sm);padding:9px 11px;
  font-size:12px;color:var(--accent-hi);margin-bottom:14px;line-height:1.55;
}
.pdlg-warn strong{color:#f08550}
.pdlg-actions{display:flex;gap:8px;justify-content:flex-end}
.pdlg-confirm{
  background:var(--accent);border:1px solid var(--accent);color:#0c0e10;
  border-radius:var(--r-sm);padding:7px 18px;cursor:pointer;font-weight:700;font-size:12px;
  transition:.12s;
}
.pdlg-confirm:hover{background:var(--accent-hi);border-color:var(--accent-hi)}

/* === MAP === */
.mapwrap{position:relative;background:#0b3a4a;overflow:hidden;border-top:1px solid var(--border-soft)}
#map{width:100%;height:100%;display:block;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none}
#map.dragging{cursor:grabbing}
#map.tool-drop{cursor:crosshair}
#map.tool-ruler{cursor:crosshair}
#map.tool-erase{cursor:not-allowed}
#map.tool-bump{cursor:cell}

.mapHud{
  position:absolute;left:12px;bottom:12px;
  background:rgba(20,23,26,.92);backdrop-filter:blur(8px);
  border:1px solid var(--border);padding:6px 12px;border-radius:var(--r-sm);
  font-size:11px;color:var(--text);
  display:flex;gap:14px;align-items:center;
  font-variant-numeric:tabular-nums;letter-spacing:.04em;font-family:ui-monospace,monospace;
  box-shadow:var(--shadow);
}
.mapHud .dot{width:7px;height:7px;border-radius:50%;background:var(--good);box-shadow:0 0 6px rgba(109,199,123,.5)}
.mapHud .dot.off{background:var(--bad);box-shadow:0 0 6px rgba(217,107,107,.5)}

.zoomctl{position:absolute;right:12px;bottom:12px;display:grid;gap:4px}
.zoomctl button{
  width:32px;height:32px;border-radius:var(--r-sm);
  border:1px solid var(--border);background:rgba(20,23,26,.92);backdrop-filter:blur(8px);
  color:var(--text);cursor:pointer;font-size:13px;font-weight:600;
  transition:.12s;
}
.zoomctl button:hover{
  border-color:var(--accent);color:var(--accent-hi);
  background:rgba(217,107,62,.12);
  box-shadow:0 0 10px rgba(217,107,62,.2);
}
#minimapBtn{display:flex;align-items:center;justify-content:center;}
#minimapBtn svg{display:block;flex-shrink:0;}

/* === MARKER PANEL === */
.empty{color:var(--muted);font-size:12px;padding:12px;text-align:center}
.markerView .head{display:flex;gap:8px;align-items:center;margin-bottom:8px}
.markerView .pin{width:14px;height:14px;border-radius:50%;border:2px solid var(--text);flex:0 0 auto}
.markerView strong{font-size:13px}
.markerView .meta{font-size:10.5px;color:var(--muted);margin-bottom:8px;letter-spacing:.04em}
.markerView .actions{display:flex;gap:6px;margin-bottom:10px}
.notes{display:grid;gap:6px;max-height:280px;overflow:auto}
.note{
  background:var(--panel-2);border:1px solid var(--border-soft);
  border-radius:var(--r-sm);padding:8px 10px;
}
.note .who{font-size:10px;color:var(--accent-hi);font-weight:600;letter-spacing:.04em;display:flex;justify-content:space-between}
.note .body{font-size:12px;margin-top:4px;white-space:pre-wrap;word-wrap:break-word;line-height:1.5}
.noteform{display:flex;gap:6px;margin-top:8px}
.noteform input{flex:1;padding:7px 10px}
.noteform button{
  background:var(--accent-soft);border:1px solid var(--accent);color:var(--accent-hi);
  border-radius:var(--r-sm);padding:7px 12px;cursor:pointer;font-weight:600;font-size:11px;
}
.noteform button:hover{background:var(--accent);color:#fff}

/* === CHAT === */
.chat{
  display:flex;flex-direction:column;gap:1px;
  max-height:280px;min-height:120px;overflow-y:auto;overflow-x:hidden;
  background:var(--bg);border:1px solid var(--border);
  border-radius:var(--r-sm);padding:6px 4px;
  scrollbar-width:thin;scrollbar-color:var(--border) transparent;
}
.chat::-webkit-scrollbar{width:4px}
.chat::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}
.chat::-webkit-scrollbar-track{background:transparent}
.chat .msg{
  display:flex;gap:8px;padding:5px 8px;border-radius:4px;
  transition:background .1s;
}
.chat .msg:hover{background:rgba(255,255,255,.04)}
.msg-avatar{
  width:28px;height:28px;border-radius:50%;flex-shrink:0;
  background:var(--accent-soft);border:1px solid var(--accent);
  color:var(--accent-hi);font-size:11px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  text-transform:uppercase;margin-top:1px;overflow:hidden;
}
.msg-avatar img{width:100%;height:100%;object-fit:cover;display:block;border-radius:50%}
.chat .msg.rust .msg-avatar{
  background:rgba(107,169,217,.12);border-color:var(--info);color:var(--info);
}
.msg-content{display:flex;flex-direction:column;gap:1px;min-width:0}
.msg-header{display:flex;gap:6px;align-items:baseline}
.msg-header .auth{color:var(--accent-hi);font-weight:600;font-size:11.5px}
.chat .msg.rust .msg-header .auth{color:var(--info)}
.chat .msg.alliance .msg-avatar{
  background:rgba(249,115,22,.15);border-color:#f97316;color:#f97316;
}
.chat .msg.alliance .msg-header .auth{color:#f97316;font-weight:700}
.chat .msg.alliance{border-left:2px solid #f97316;padding-left:6px;background:rgba(249,115,22,0.04)}
.msg-header .t{color:var(--muted);font-size:10px;font-variant-numeric:tabular-nums;font-family:ui-monospace,monospace}
.msg-body{font-size:12.5px;color:var(--text);line-height:1.4;word-break:break-word}
.chatform{display:flex;flex-direction:column;gap:6px;margin-top:8px}
.chatform .chat-input-row{display:flex;align-items:stretch;gap:0}
.chatform input[type="text"],.chatform input:not([type]){
  flex:1;padding:8px 12px;font-size:12.5px;
  background:var(--panel-2);border:1px solid var(--border);
  border-right:none;border-radius:var(--r-sm) 0 0 var(--r-sm);color:var(--text);
  outline:none;transition:border-color .15s;
}
.chatform input[type="text"]:focus,.chatform input:not([type]):focus{
  border-color:var(--accent);
}
.chatform input[type="text"]:focus + button,.chatform input:not([type]):focus + button{
  border-color:var(--accent);
}
.chatform button{
  background:var(--accent-soft);border:1px solid var(--accent);color:var(--accent-hi);
  border-radius:0 var(--r-sm) var(--r-sm) 0;padding:0 14px;cursor:pointer;font-weight:600;font-size:13px;
  transition:background .15s,color .15s;flex-shrink:0;
}
.chatform button:hover{background:var(--accent);color:#fff}
.chatform .bridgechk{
  display:flex;align-items:center;gap:5px;cursor:pointer;
  font-size:10.5px;color:var(--muted);user-select:none;
  padding:3px 2px;
}
.chatform .bridgechk input[type="checkbox"]{
  accent-color:var(--accent);width:12px;height:12px;cursor:pointer;
}
.chatform .bridgechk:hover{color:var(--text)}
.chat-tabs{display:flex;gap:4px;margin-bottom:6px}
.chat-tab{
  flex:1;padding:5px 0;font-size:11px;font-weight:600;cursor:pointer;
  background:var(--panel-2);border:1px solid var(--border);border-radius:var(--r-sm);
  color:var(--muted);transition:background .12s,color .12s,border-color .12s;
}
.chat-tab:hover{color:var(--text)}
.chat-tab-active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent-hi)}

/* === RUST+ NOTICE BANNER === */
.rp-notice{
  display:flex;align-items:center;gap:12px;
  background:#1a1208;border-bottom:1px solid #6b4c1e;
  padding:10px 16px;font-size:12.5px;color:var(--text);
  transition:max-height .25s ease,opacity .2s ease,padding .25s ease;
  max-height:80px;overflow:hidden;opacity:1;
}
.rp-notice-hidden{max-height:0;opacity:0;padding-top:0;padding-bottom:0;pointer-events:none;border:none}
.rp-notice-icon{color:#f0a050;flex:0 0 auto}
.rp-notice-body{flex:1;display:flex;flex-direction:column;gap:2px}
.rp-notice-body strong{color:#f0a050;font-size:13px}
.rp-notice-body span{color:var(--muted);font-size:11.5px}
.rp-notice-btn{
  flex:0 0 auto;background:var(--accent);color:#fff;border:none;
  border-radius:var(--r-sm);padding:6px 14px;cursor:pointer;font-weight:600;font-size:12px;
  white-space:nowrap;
}
.rp-notice-btn:hover{background:var(--accent-hi)}
.rp-notice-dismiss{
  flex:0 0 auto;background:none;border:none;color:var(--muted);
  cursor:pointer;font-size:14px;padding:4px 6px;line-height:1;
}
.rp-notice-dismiss:hover{color:var(--text)}
.rp-notice-preview{background:#091a10;border-bottom-color:#2a6640}
.cmds-heading{cursor:pointer;user-select:none}
.cmds-heading:hover{color:var(--accent-hi)}
.cmds-toggle-icon{font-size:10px;opacity:.6;margin-left:4px}
.cmds-panel{margin-top:6px}
.cmds-table{width:100%;border-collapse:collapse;font-size:11px}
.cmds-table td{padding:3px 4px;vertical-align:top}
.cmds-table td:first-child{white-space:nowrap;padding-right:10px}
.cmds-table code{color:var(--accent-hi);font-family:ui-monospace,monospace;font-size:10.5px}
.cmds-table td:last-child{color:var(--muted)}
.cmds-table tr:hover td{background:var(--accent-soft)}

/* === EVENTS === */
.events{list-style:none;padding:10px 12px;margin:0;display:grid;gap:4px;max-height:240px;overflow:auto}
.events li{
  font-size:11px;color:var(--text);
  background:var(--panel-2);border:1px solid var(--border-soft);
  border-radius:var(--r-sm);padding:5px 9px;
  display:flex;gap:6px;align-items:center;
}
.events li .t{color:var(--muted);font-variant-numeric:tabular-nums;font-size:10px;font-family:ui-monospace,monospace}
.events li b{color:var(--accent-hi);font-weight:600;font-size:10px;letter-spacing:.04em;text-transform:uppercase;font-style:normal}

/* ── Notepad ─────────────────────────────────────────── */
.notepad-fab{
  position:absolute;
  top:12px;right:12px;
  display:flex;align-items:center;gap:6px;
  padding:6px 11px 6px 9px;
  background:rgba(12,15,19,.88);
  border:1px solid rgba(255,255,255,.1);
  border-radius:8px;
  color:var(--muted,#6c7480);
  font-size:12px;font-weight:600;font-family:inherit;
  cursor:pointer;z-index:20;
  backdrop-filter:blur(8px);
  box-shadow:0 2px 12px rgba(0,0,0,.5);
  transition:border-color .15s,background .15s,color .15s;
}
.notepad-fab:hover{
  border-color:rgba(255,255,255,.18);
  background:rgba(20,24,30,.95);
  color:var(--text,#c8d0d8);
}
.notepad-popup{
  position:absolute;top:50px;right:12px;z-index:60;
  width:340px;max-height:calc(100% - 70px);
  background:var(--panel,#14171a);border:1px solid var(--border,#23282d);border-radius:12px;
  box-shadow:0 8px 32px rgba(0,0,0,.55);
  padding:0;display:flex;flex-direction:column;
}
.notepad-popup.hidden{display:none}
.notepad-popup-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 14px 8px;border-bottom:1px solid var(--border,#23282d);
}
.notepad-popup-title{
  display:flex;align-items:center;gap:7px;
  font-size:13px;font-weight:700;color:var(--text);
}
.notepad-popup-close{
  background:none;border:none;color:var(--muted);font-size:18px;cursor:pointer;
  line-height:1;padding:0 2px;
}
.notepad-popup-close:hover{color:var(--text)}
.notepad-area{
  width:100%;box-sizing:border-box;
  background:transparent;border:none;
  color:var(--text);font-size:12.5px;font-family:inherit;line-height:1.6;
  padding:12px 14px;resize:none;height:220px;
  outline:none;
}
.notepad-area::placeholder{color:var(--muted);font-size:11.5px}
.notepad-footer{
  display:flex;align-items:center;justify-content:space-between;
  padding:6px 12px 10px;gap:8px;border-top:1px solid var(--border,#23282d);
}
.notepad-hint{font-size:11px;color:var(--muted);flex:1}
.notepad-save-btn{
  background:var(--accent);color:#fff;border:none;border-radius:5px;
  padding:4px 12px;font-size:11px;font-weight:700;font-family:inherit;cursor:pointer;
}
.notepad-save-btn:hover{background:var(--accent-hi)}
.notepad-save-btn:disabled{opacity:.5;cursor:default}
.notepad-has-update::after{
  content:'';position:absolute;top:4px;right:4px;
  width:7px;height:7px;border-radius:50%;
  background:var(--accent,#d96b3e);
  box-shadow:0 0 6px rgba(217,107,62,.7);
}

/* Guest / locked state */
.notepad-fab.is-guest{opacity:.7;cursor:pointer}
.notepad-fab.is-guest .np-icon-edit{display:none}
.notepad-fab.is-guest .np-icon-lock{display:block !important}
.notepad-popup.is-guest .notepad-area,
.notepad-popup.is-guest .notepad-footer{display:none}
.notepad-popup.is-guest .notepad-locked{display:flex}
.notepad-locked{
  display:none;flex-direction:column;align-items:center;
  gap:10px;padding:28px 20px 24px;text-align:center;
}
.notepad-locked-title{
  font-size:13px;font-weight:700;color:var(--text);
}
.notepad-locked-desc{
  font-size:11.5px;color:var(--muted);line-height:1.55;max-width:240px;
}
.notepad-steam-btn{
  display:inline-flex;align-items:center;gap:7px;
  padding:7px 14px;margin-top:4px;
  background:#1b2838;border:1px solid rgba(255,255,255,.15);
  border-radius:6px;color:#c7d5e0;
  text-decoration:none;font-size:12px;font-weight:600;font-family:inherit;
  transition:background .15s,border-color .15s;
}
.notepad-steam-btn:hover{background:#2a475e;border-color:rgba(255,255,255,.28)}

/* === DIALOG === */
dialog{
  background:var(--panel);color:var(--text);
  border:1px solid var(--border);border-radius:var(--r);
  padding:18px;max-width:500px;box-shadow:0 30px 80px rgba(0,0,0,.7);
}
/* admin dialog overrides the base dialog styles */
dialog.admin-dlg{padding:0;max-width:540px;background:linear-gradient(180deg,#13161b,#0f1215);border:none}
dialog::backdrop{background:rgba(0,0,0,.7);backdrop-filter:blur(4px)}
dialog h2{color:var(--accent-hi);font-size:13px;letter-spacing:.06em;text-transform:uppercase;margin:0 0 12px;font-weight:600}
dialog ul{padding-left:20px;line-height:1.7;font-size:12px}
dialog li b{color:var(--accent-hi)}
.cdlg-title{font-size:13px;font-weight:700;color:var(--accent-hi);letter-spacing:.05em;text-transform:uppercase;margin-bottom:8px}
.cdlg-body{font-size:13px;color:var(--muted);line-height:1.55;margin-bottom:16px}
#helpDlg{padding:0;max-width:520px;width:calc(100vw - 32px);background:var(--panel);border:1px solid var(--border);border-radius:14px}
.help-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 14px;border-bottom:1px solid var(--border)}
.help-title{font-size:13px;font-weight:700;color:var(--accent-hi);letter-spacing:.06em;text-transform:uppercase}
.help-close{background:none;border:none;color:var(--muted);cursor:pointer;padding:4px;border-radius:6px;display:flex;align-items:center;transition:color .15s}
.help-close:hover{color:#e8e8e8}
.help-section-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);padding:14px 20px 8px}
.help-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border)}
.help-item{display:flex;gap:10px;align-items:flex-start;padding:12px 16px;background:var(--panel)}
.help-icon{font-size:16px;flex-shrink:0;margin-top:1px}
.help-name{display:block;font-size:12px;font-weight:600;color:#e8e8e8;margin-bottom:2px}
.help-desc{display:block;font-size:11px;color:var(--muted);line-height:1.55}
.help-roles{display:flex;flex-direction:column;gap:6px;padding:4px 20px 14px}
.help-role{display:flex;align-items:baseline;gap:10px;font-size:12px}
.help-role-badge{font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:2px 8px;border-radius:4px;flex-shrink:0}
.help-role-badge.guest{background:rgba(255,255,255,.07);color:var(--muted)}
.help-role-badge.member{background:rgba(99,179,237,.12);color:var(--accent-hi)}
.help-role-badge.leader{background:rgba(255,190,60,.12);color:#fbbe3c}
.help-role-desc{color:rgba(255,255,255,.55);line-height:1.5}
.help-ok{display:block;width:calc(100% - 40px);margin:0 20px 18px;padding:10px;background:var(--accent-soft);border:1px solid var(--accent);color:var(--accent-hi);border-radius:8px;cursor:pointer;font-weight:600;font-size:12px;transition:background .15s}
.help-ok:hover{background:rgba(99,179,237,.18)}
#promoteDlg button:not(.pdlg-confirm):not(.btn){
  background:var(--accent-soft);border:1px solid var(--accent);color:var(--accent-hi);
  border-radius:var(--r-sm);padding:7px 14px;cursor:pointer;font-weight:600;font-size:11px;
  margin-top:10px;
}

/* === VOICE PANEL === */
#voicePanel{padding:0}
#voicePanel .switch.big{
  padding:10px 12px;border-bottom:1px solid var(--border-soft);
  font-size:13px;font-weight:600;
}
#voicePanel .switch.sm{padding:3px 0;font-size:11.5px}
#voicePanel .switch.sm .track{width:24px;height:13px}
#voicePanel .switch.sm .track::after{width:9px;height:9px;top:2px;left:2px}
#voicePanel .switch.sm input:checked + .track::after{transform:translateX(11px)}
#voicePanel select{
  width:100%;background:var(--bg);border:1px solid var(--border);
  color:var(--text);border-radius:var(--r-sm);padding:6px 9px;font-size:11.5px;
}
#voicePanel input[type="range"]{
  width:100%;-webkit-appearance:none;appearance:none;
  height:4px;background:var(--border);border-radius:2px;outline:none;
}
#voicePanel input[type="range"]::-webkit-slider-thumb{
  -webkit-appearance:none;width:14px;height:14px;border-radius:50%;
  background:var(--accent);border:2px solid var(--panel);cursor:pointer;
}
#voicePanel input[type="range"]::-moz-range-thumb{
  width:14px;height:14px;border-radius:50%;
  background:var(--accent);border:2px solid var(--panel);cursor:pointer;
}
.voice-events{display:grid;gap:0}
.voice-actions{
  display:flex;gap:6px;padding:10px 12px;border-top:1px solid var(--border-soft);
}
.voice-actions .btn{flex:1;justify-content:center}

/* === SCROLLBARS === */
*::-webkit-scrollbar{width:8px;height:8px}
*::-webkit-scrollbar-track{background:transparent}
*::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
*::-webkit-scrollbar-thumb:hover{background:var(--accent-soft)}

/* === RESPONSIVE === */

/* Mobile drawer toggle bar — hidden on desktop, shown ≤1024px */
.mnav{display:none}
.mnav-backdrop{display:none}

@media (max-width:1024px){
  .layout{grid-template-columns:1fr}

  /* Map fills the viewport; sidebars become slide-in drawers */
  .sidebar{
    display:block;position:fixed;top:52px;bottom:0;width:min(86vw,360px);
    z-index:60;overflow-y:auto;-webkit-overflow-scrolling:touch;
    padding:10px 10px calc(10px + env(safe-area-inset-bottom));
    background:var(--bg);box-shadow:0 0 40px rgba(0,0,0,.6);
    transition:transform .22s cubic-bezier(.4,0,.2,1);
    will-change:transform;
  }
  .sidebar.left {left:0; transform:translateX(-105%);border-right:1px solid var(--border)}
  .sidebar.right{right:0;transform:translateX(105%); border-left:1px solid var(--border)}
  .sidebar.left.open,.sidebar.right.open{transform:translateX(0)}

  /* Dimmed backdrop behind an open drawer */
  .mnav-backdrop{
    display:block;position:fixed;inset:52px 0 0 0;z-index:55;
    background:rgba(0,0,0,.55);backdrop-filter:blur(2px);
    animation:mnavFade .18s ease-out;
  }
  .mnav-backdrop[hidden]{display:none}
  @keyframes mnavFade{from{opacity:0}to{opacity:1}}

  /* Toggle buttons, top-left over the map (notepad FAB is top-right) */
  .mnav{
    display:flex;gap:6px;position:absolute;top:10px;left:10px;z-index:25;
  }
  .mnav-btn{
    display:flex;align-items:center;gap:6px;
    padding:8px 12px 8px 10px;
    background:rgba(12,15,19,.9);border:1px solid rgba(255,255,255,.12);
    border-radius:8px;color:var(--text);font:600 12px/1 inherit;
    cursor:pointer;backdrop-filter:blur(8px);
    box-shadow:0 2px 12px rgba(0,0,0,.5);
    transition:border-color .15s,background .15s,color .15s;
  }
  .mnav-btn:active{transform:scale(.96)}
  .mnav-btn.active{
    border-color:rgba(217,107,62,.55);color:var(--accent-hi,#f08550);
    background:rgba(217,107,62,.12);
  }
  .mnav-btn svg{flex:0 0 auto}

  /* Stop the topbar from overflowing on narrow screens */
  .topbar{flex-wrap:wrap;height:auto;min-height:52px;row-gap:4px;padding:6px 10px}
  .tb-stats{display:none}

  /* Bigger touch targets for on-map controls */
  .zoomctl button{width:42px;height:42px;font-size:18px}
  .mapHud{font-size:12px}

  .icon-grid{grid-template-columns:repeat(8,1fr)}
  .swatch-grid{grid-template-columns:repeat(11,1fr)}
}

/* Phones: drawer covers the screen, single-column tool/swatch grids */
@media (max-width:560px){
  .sidebar{width:100%}
  .icon-grid{grid-template-columns:repeat(6,1fr)}
  .swatch-grid{grid-template-columns:repeat(8,1fr)}
}

/* Lock background scroll while a drawer is open */
body.mnav-lock{overflow:hidden}

/* === SHOP POPUP (vending machine) === */
.shop-popup{
  position:fixed;z-index:50;
  width:380px;max-width:calc(100vw - 16px);
  max-height:70vh;display:flex;flex-direction:column;
  background:linear-gradient(180deg,#15181c,#101316);
  border:1px solid var(--border);
  border-radius:var(--r);
  box-shadow:var(--shadow), 0 0 0 1px rgba(217,107,62,.08);
  color:var(--text);
  overflow:hidden;
  animation:shopFade .12s ease-out;
}
.shop-popup.hidden{display:none}
@keyframes shopFade{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}

.shop-head{
  display:grid;
  grid-template-columns:1fr auto;
  grid-template-rows:auto auto;
  gap:2px 8px;
  padding:9px 10px 8px 12px;
  background:linear-gradient(180deg,#181c20,#14171a);
  border-bottom:1px solid var(--border);
  position:relative;
}
.shop-title{display:flex;align-items:center;gap:7px;font-weight:700;font-size:13px;letter-spacing:.02em}
.shop-title-name{color:#f0e6d2;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;max-width:260px}
.shop-dot{width:7px;height:7px;border-radius:50%;background:#9bd3ff;box-shadow:0 0 6px rgba(155,211,255,.7)}
.shop-loc{grid-column:1 / span 2;color:var(--muted);font-size:11px;font-variant-numeric:tabular-nums;letter-spacing:.04em}
.shop-close{
  grid-row:1;grid-column:2;
  width:24px;height:24px;border-radius:var(--r-sm);
  background:transparent;border:1px solid transparent;
  color:var(--muted);font-size:18px;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
}
.shop-close:hover{color:var(--accent-hi);border-color:var(--border)}

.shop-body{
  overflow-y:auto;
  padding:6px;
  display:flex;flex-direction:column;gap:4px;
}
.shop-empty{padding:18px 12px;text-align:center;color:var(--muted);font-style:italic}

.shop-row{
  display:grid;
  grid-template-columns:1fr auto 1fr auto;
  align-items:center;
  gap:8px;
  padding:7px 8px;
  background:var(--panel-2);
  border:1px solid var(--border-soft);
  border-radius:var(--r-sm);
  transition:.12s;
}
.shop-row:hover{border-color:var(--accent-soft);background:#1c2025}
.shop-row.oos{opacity:.55}

.shop-cell{display:flex;align-items:center;gap:8px;min-width:0}
.shop-cost{justify-content:flex-end}
.shop-icon{
  width:36px;height:36px;flex:0 0 36px;
  border-radius:var(--r-sm);
  background:#0c0e10;
  border:1px solid var(--border-soft);
  image-rendering:pixelated;
  object-fit:contain;
}
.shop-icon-bp{filter:hue-rotate(180deg) saturate(1.2);border-color:#3a4a5a}
.shop-icon-fallback{
  display:flex;align-items:center;justify-content:center;
  color:var(--muted);font-size:14px;font-weight:700;
}
.shop-meta{min-width:0;display:flex;flex-direction:column;gap:1px}
.shop-name{
  font-size:12px;color:#e6e0d0;font-weight:600;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px;
}
.shop-cost .shop-name{text-align:right}
.shop-qty{font-size:11px;color:var(--muted);font-variant-numeric:tabular-nums}
.shop-cost .shop-qty{text-align:right}
.shop-bp{
  display:inline-block;font-size:9px;padding:1px 4px;
  border-radius:2px;background:rgba(107,169,217,.15);
  color:var(--info);font-weight:700;letter-spacing:.06em;margin-left:4px;
}
.shop-arrow{color:var(--accent);font-weight:700;font-size:14px}
.shop-stock{
  grid-column:1 / span 4;
  font-size:10px;color:var(--muted);
  text-align:right;letter-spacing:.04em;
  font-variant-numeric:tabular-nums;
  margin-top:2px;
}
.shop-row.oos .shop-stock{color:var(--bad)}

.shop-foot{
  padding:6px 12px;font-size:11px;color:var(--muted);
  border-top:1px solid var(--border);
  background:#101316;letter-spacing:.04em;
  display:flex;justify-content:space-between;
}
/* Shop tabs (Stock / History) */
.shop-tabs{
  display:flex;gap:0;border-bottom:1px solid var(--border);
  background:#101316;flex-shrink:0;
}
.shop-tab{
  flex:1;padding:7px 12px;font-size:10.5px;font-weight:700;
  letter-spacing:.05em;text-transform:uppercase;font-family:inherit;
  background:transparent;border:none;color:var(--muted);
  cursor:pointer;transition:color 100ms;border-bottom:2px solid transparent;
}
.shop-tab:hover{color:var(--text);}
.shop-tab--active{color:#92cd2c;border-bottom-color:#92cd2c;}
.shop-tab-pane--hidden{display:none;}
/* Ghost vending dot */
.shop-dot-ghost{background:#7a7670 !important;}
/* History timeline */
.shop-hist-list{display:flex;flex-direction:column;gap:0;padding:4px 0;}
.shop-hist-row{
  display:flex;align-items:flex-start;gap:10px;
  padding:7px 12px;font-size:11px;
  border-bottom:1px solid var(--border);
}
.shop-hist-row:last-child{border-bottom:none;}
.shop-hist-time{
  font-size:9px;font-family:ui-monospace,monospace;
  color:var(--muted);white-space:nowrap;flex-shrink:0;margin-top:2px;min-width:60px;
}
.shop-hist-label{font-weight:700;letter-spacing:.04em;font-size:10.5px;}
.shop-hist-placed .shop-hist-label{color:#92cd2c;}
.shop-hist-removed .shop-hist-label{color:#f08550;}
.shop-hist-sale{align-items:flex-start;}
.shop-hist-sales{display:flex;flex-direction:column;gap:2px;}
.shop-hist-sale-item{color:var(--text);font-size:11px;}
.shop-hist-remaining{color:var(--muted);font-size:10px;}

/* ─── Player popup ─── */
.player-popup{
  position:fixed;z-index:55;
  width:340px;max-width:calc(100vw - 16px);
  display:flex;flex-direction:column;
  background:linear-gradient(180deg,#15181c,#101316);
  border:1px solid var(--border);
  border-radius:var(--r);
  box-shadow:var(--shadow), 0 0 0 1px rgba(217,107,62,.08);
  color:var(--text);
  overflow:hidden;
  animation:shopFade .12s ease-out;
}
.player-popup.hidden{display:none}

.pp-head{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;
  background:linear-gradient(180deg,#181c20,#14171a);
  border-bottom:1px solid var(--border);
  position:relative;
}
.pp-head-l{position:relative;flex:0 0 auto}
.pp-avatar{
  width:48px;height:48px;border-radius:6px;
  background:#0c0e10;
  border:1px solid var(--border-soft);
  object-fit:cover;display:block;
}
.pp-avatar-fallback{
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:20px;color:var(--accent-hi);
}
.pp-status-dot{
  position:absolute;right:-3px;bottom:-3px;
  width:14px;height:14px;border-radius:50%;
  border:2px solid var(--panel);
  box-shadow:0 0 6px rgba(0,0,0,.6);
}
.pp-status-dot.pp-alive{background:var(--good);box-shadow:0 0 8px rgba(109,199,123,.6)}
.pp-status-dot.pp-asleep{background:var(--info);box-shadow:0 0 8px rgba(107,169,217,.5)}
.pp-status-dot.pp-dead{background:var(--bad);box-shadow:0 0 8px rgba(217,107,107,.6)}

.pp-head-r{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.pp-name{
  font-size:14px;font-weight:700;color:#f0e6d2;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.pp-persona{
  font-size:11px;color:var(--muted);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.pp-status{
  font-size:11px;color:var(--muted);letter-spacing:.02em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.pp-close{
  position:absolute;top:6px;right:6px;
  width:24px;height:24px;border-radius:var(--r-sm);
  background:transparent;border:1px solid transparent;
  color:var(--muted);font-size:18px;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
}
.pp-close:hover{color:var(--accent-hi);border-color:var(--border)}

.pp-body{padding:10px 12px 12px;display:flex;flex-direction:column;gap:10px}

.pp-stats{
  display:grid;grid-template-columns:1fr 1fr;gap:6px;
}
.pp-stat{
  display:flex;flex-direction:column;gap:2px;
  padding:7px 9px;
  background:var(--panel-2);
  border:1px solid var(--border-soft);
  border-radius:var(--r-sm);
}
.pp-stat-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.pp-stat-value{
  font-size:13px;color:#e6e0d0;font-weight:600;
  font-variant-numeric:tabular-nums;
}
.pp-stat.pp-alive .pp-stat-value{color:var(--good)}
.pp-stat.pp-online .pp-stat-value{color:var(--info)}
.pp-stat.pp-afk .pp-stat-value{color:var(--accent-hi)}
.pp-stat.pp-dead .pp-stat-value{color:var(--bad)}

.pp-loc{
  display:flex;justify-content:space-between;align-items:center;gap:8px;
  padding:7px 9px;
  background:var(--panel-2);
  border:1px solid var(--border-soft);
  border-radius:var(--r-sm);
  font-size:12px;
}
.pp-loc-label{color:var(--muted);text-transform:uppercase;font-size:10px;letter-spacing:.06em}
.pp-loc-value{color:#e6e0d0;font-variant-numeric:tabular-nums}

.pp-actions{display:flex;flex-wrap:wrap;gap:6px}
.pp-btn{
  flex:1;min-width:90px;text-align:center;
  padding:7px 10px;font-size:12px;font-weight:600;
  background:var(--accent);color:#0c0e10;
  border:1px solid var(--accent);
  border-radius:var(--r-sm);
  cursor:pointer;text-decoration:none;
  display:inline-flex;align-items:center;justify-content:center;
  transition:.12s;
}
.pp-btn:hover{background:var(--accent-hi);border-color:var(--accent-hi)}
.pp-btn-ghost{
  background:transparent;color:var(--text);
  border-color:var(--border);
}
.pp-btn-ghost:hover{background:var(--panel-2);color:var(--accent-hi);border-color:var(--accent)}
.pp-tts-row{display:flex;align-items:center;gap:8px;margin-top:8px;padding-top:8px;border-top:1px solid var(--border)}
.pp-tts-label{font-size:11px;color:var(--muted);white-space:nowrap;min-width:60px}
.pp-tts-input{
  flex:1;background:var(--panel-2);border:1px solid var(--border);border-radius:5px;
  color:var(--text);font-size:12px;padding:3px 7px;font-family:inherit;
  outline:none;
}
.pp-tts-input:focus{border-color:var(--accent)}
.pp-tts-input::placeholder{color:var(--muted)}
.pp-tts-save{
  background:var(--accent);color:#fff;border:none;border-radius:5px;
  padding:3px 8px;font-size:11px;font-weight:700;font-family:inherit;
  cursor:pointer;white-space:nowrap;flex-shrink:0;
}
.pp-tts-save:hover{background:var(--accent-hi)}

/* ── Marker popup ─────────────────────────────────────── */
.marker-popup{
  position:fixed;z-index:52;width:280px;
  background:#16191e;
  border:1px solid rgba(255,255,255,.1);
  border-radius:10px;
  box-shadow:0 8px 32px rgba(0,0,0,.65),0 0 0 1px rgba(0,0,0,.4);
  overflow:hidden;
}
.marker-popup.hidden{display:none}
.mp-head{
  display:flex;align-items:center;gap:9px;
  padding:11px 12px 10px;
  border-bottom:1px solid rgba(255,255,255,.07);
}
.mp-pin{
  width:13px;height:13px;border-radius:50%;flex-shrink:0;
  box-shadow:0 0 6px rgba(0,0,0,.5);
}
.mp-label{
  flex:1;font-size:13.5px;font-weight:700;color:#f0e6d2;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.mp-close{
  background:none;border:none;color:var(--dim);font-size:14px;
  cursor:pointer;padding:0 3px;line-height:1;flex-shrink:0;
}
.mp-close:hover{color:#f0e6d2}
.mp-meta{
  padding:7px 12px 6px;
  font-size:10.5px;color:var(--dim);
  border-bottom:1px solid rgba(255,255,255,.05);
}
.mp-cat{
  font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:9.5px;
  color:var(--muted);
}
.mp-exp{color:var(--dim);}
.mp-actions{
  display:flex;gap:6px;padding:8px 12px;
  border-bottom:1px solid rgba(255,255,255,.05);
}
.mp-btn{
  flex:1;padding:6px 10px;font-size:11px;font-weight:700;letter-spacing:.02em;
  border-radius:5px;cursor:pointer;transition:.12s;
  border:1px solid rgba(255,255,255,.1);
  background:rgba(255,255,255,.04);color:var(--muted);
}
.mp-btn:hover{color:#f0e6d2;border-color:rgba(255,255,255,.2);background:rgba(255,255,255,.08)}
.mp-btn.danger:hover{background:rgba(200,60,60,.15);border-color:rgba(200,60,60,.4);color:#ff8080}
.mp-notes-wrap{border-bottom:1px solid rgba(255,255,255,.05)}
.mp-notes-head{
  font-size:9.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--dim);padding:7px 12px 4px;
}
.mp-notes{max-height:150px;overflow-y:auto;padding:0 12px 8px}
.mp-note{
  padding:5px 0;border-bottom:1px solid rgba(255,255,255,.05);
  font-size:11.5px;
}
.mp-note:last-child{border-bottom:none}
.mp-note-who{font-size:10px;color:var(--muted);margin-bottom:2px;font-weight:600}
.mp-note-time{font-weight:400;color:var(--dim)}
.mp-note-body{color:#d4cfc8;line-height:1.4}
.mp-empty{font-size:11px;color:var(--dim);padding:4px 0 2px}
.mp-addnote{
  display:flex;gap:6px;padding:8px 12px 10px;
}
.mp-addnote input{
  flex:1;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  border-radius:5px;padding:5px 9px;font-size:12px;color:var(--fg);
  outline:none;
}
.mp-addnote input:focus{border-color:rgba(217,107,62,.5)}
.mp-addnote button{
  padding:5px 12px;background:var(--accent);border:none;
  border-radius:5px;font-size:11px;font-weight:700;color:#0c0e10;cursor:pointer;
  transition:.1s;flex-shrink:0;
}
.mp-addnote button:hover{background:var(--accent-hi)}

/* ── Marker Drop Popup ───────────────────────────────── */
.mdrop{
  position:fixed;z-index:60;width:330px;
  background:#16191e;
  border:1px solid rgba(255,255,255,.12);
  border-radius:12px;
  box-shadow:0 12px 40px rgba(0,0,0,.7),0 0 0 1px rgba(0,0,0,.5);
  overflow:hidden;
  animation:shopFade .1s ease-out;
}
.mdrop.hidden{display:none}
.mdrop-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:11px 14px 10px;
  border-bottom:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.02);
}
.mdrop-title{
  font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);
}
.mdrop-close{
  background:none;border:none;color:var(--dim);font-size:14px;
  cursor:pointer;padding:0 3px;line-height:1;
}
.mdrop-close:hover{color:#f0e6d2}
.mdrop-section{padding:9px 12px;border-bottom:1px solid rgba(255,255,255,.06)}
.mdrop-label-section{padding:8px 12px}
.mdrop-section-label{
  font-size:9.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--dim);margin-bottom:7px;
}
.mdrop-icons{display:grid;grid-template-columns:repeat(10,1fr);gap:3px}
.mdrop-icon-btn{
  aspect-ratio:1;display:grid;place-items:center;
  border:1px solid rgba(255,255,255,.08);border-radius:5px;
  background:rgba(255,255,255,.04);cursor:pointer;transition:.1s;padding:0;
}
.mdrop-icon-btn img{filter:brightness(0) invert(.7);transition:.1s}
.mdrop-icon-btn:hover img{filter:brightness(0) invert(1)}
.mdrop-icon-btn:hover{border-color:rgba(217,107,62,.4);background:rgba(217,107,62,.1)}
.mdrop-icon-btn.active{border-color:var(--accent);background:rgba(217,107,62,.2)}
.mdrop-icon-btn.active img{filter:brightness(0) invert(1)}
.mdrop-colors{display:grid;grid-template-columns:repeat(10,1fr);gap:3px;margin-bottom:7px}
.mdrop-swatch{
  aspect-ratio:1;border:1px solid rgba(255,255,255,.18);border-radius:4px;
  cursor:pointer;padding:0;position:relative;transition:.1s;
}
.mdrop-swatch:hover{transform:scale(1.12)}
.mdrop-swatch.active::after{
  content:"";position:absolute;inset:-3px;border:2px solid var(--accent);
  border-radius:5px;pointer-events:none;
}
.mdrop-custom-row{
  display:flex;align-items:center;gap:8px;
}
.mdrop-custom-lbl{font-size:9.5px;color:var(--dim);letter-spacing:.06em;flex-shrink:0}
.mdrop-custom-picker{
  width:34px;height:26px;padding:1px 2px;border-radius:5px;cursor:pointer;
  border:1px solid rgba(255,255,255,.15);background:transparent;flex-shrink:0;
}
.mdrop-custom-hex{
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:10.5px;color:var(--muted);letter-spacing:.04em;
}
.mdrop-cats{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}
.mdrop-cat-btn{
  display:flex;align-items:center;justify-content:center;gap:5px;
  padding:6px 4px;border:1px solid rgba(255,255,255,.08);border-radius:5px;
  background:rgba(255,255,255,.03);color:var(--muted);cursor:pointer;
  font-size:11px;font-weight:600;transition:.1s;
}
.mdrop-cat-btn:hover{color:var(--accent-hi);border-color:rgba(217,107,62,.4);background:rgba(217,107,62,.08)}
.mdrop-cat-btn.active{border-color:var(--accent);background:rgba(217,107,62,.15);color:var(--accent-hi)}
.mdrop-input{
  width:100%;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  border-radius:7px;padding:9px 12px;font-size:13px;color:#f0e6d2;
  outline:none;transition:.12s;box-sizing:border-box;
}
.mdrop-input:focus{border-color:rgba(217,107,62,.5);background:rgba(255,255,255,.08)}
.mdrop-footer{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px 12px;
}
.mdrop-ttl-wrap{
  display:flex;align-items:center;gap:7px;
  font-size:10px;color:var(--dim);white-space:nowrap;flex-shrink:0;
}
.mdrop-ttl-input{
  width:58px!important;padding:5px 7px!important;font-size:12px;
  background:rgba(255,255,255,.05)!important;border:1px solid rgba(255,255,255,.1)!important;
  border-radius:5px;color:var(--fg)!important;
}
.mdrop-confirm{
  flex:1;padding:9px 16px;
  background:var(--accent);border:none;border-radius:7px;
  font-size:12px;font-weight:800;letter-spacing:.04em;color:#0c0e10;
  cursor:pointer;transition:.12s;
}
.mdrop-confirm:hover{background:var(--accent-hi)}

/* === MONUMENT POPUP === */
.cargo-popup{
  position:fixed;z-index:52;width:280px;
  background:linear-gradient(180deg,#15181c,#101316);
  border:1px solid var(--border);border-radius:var(--r);
  box-shadow:var(--shadow);overflow:hidden;
  animation:shopFade .12s ease-out;
}
.cargo-popup-head{
  display:flex;align-items:center;gap:10px;
  padding:10px 10px 10px 12px;
  border-bottom:1px solid var(--border);
}
.cargo-popup-icon{width:32px;height:32px;object-fit:contain;flex-shrink:0}
.cargo-popup-title{font-size:13px;font-weight:700;color:var(--text)}
.cargo-popup-sub{font-size:10px;color:#7be3a1;margin-top:2px}
.cargo-popup-close{
  margin-left:auto;background:transparent;border:none;
  color:var(--dim);cursor:pointer;font-size:14px;padding:2px 4px;
  border-radius:4px;transition:color .12s;flex-shrink:0;
}
.cargo-popup-close:hover{color:var(--text)}
.cargo-popup-rows{padding:10px 12px;display:flex;flex-direction:column;gap:6px}
.cargo-popup-row{display:flex;justify-content:space-between;align-items:center}
.cargo-popup-label{font-size:10px;color:var(--dim);text-transform:uppercase;letter-spacing:.06em}
.cargo-popup-value{font-size:12px;font-weight:600;color:var(--text);font-family:ui-monospace,monospace}
.heli-popup{
  position:fixed;z-index:52;width:280px;
  background:linear-gradient(180deg,#15181c,#101316);
  border:1px solid var(--border);border-radius:var(--r);
  box-shadow:var(--shadow);overflow:hidden;
  animation:shopFade .12s ease-out;
}
.heli-popup-sub{color:#ff8b3d}
.cargo-popup-docked{color:#7be3a1}
.cargo-popup-at-sea{color:var(--dim);font-weight:500}
.cargo-popup-dock-title{font-size:9px;color:var(--dim);text-transform:uppercase;letter-spacing:.1em;padding-top:4px;border-top:1px solid var(--border);margin-top:2px}
.cargo-popup-dock-past{color:var(--dim);font-weight:500;font-size:11px}
.cargo-popup-footer{padding:8px 12px;border-top:1px solid var(--border)}
.cargo-popup-goto{
  width:100%;padding:6px 0;border:none;border-radius:5px;cursor:pointer;
  background:rgba(255,255,255,0.06);color:var(--text);font-size:11px;font-weight:600;
  letter-spacing:.04em;transition:background .12s;
}
.cargo-popup-goto:hover{background:rgba(255,255,255,0.12)}

.mon-popup{
  position:fixed;z-index:52;width:360px;
  background:linear-gradient(180deg,#15181c,#101316);
  border:1px solid var(--border);border-radius:var(--r);
  box-shadow:var(--shadow);overflow:hidden;
  animation:shopFade .12s ease-out;
}
.mon-head{
  display:flex;align-items:center;gap:6px;
  padding:8px 10px 7px 12px;
  background:linear-gradient(180deg,#181c20,#14171a);
  border-bottom:1px solid var(--border);
}
.mon-title{font-size:14px;font-weight:700;color:#f0e6d2;flex:1;line-height:1.2}
.mon-diff{font-size:11px;font-weight:700;letter-spacing:.06em;flex:0 0 auto}
.mon-close{
  width:22px;height:22px;border-radius:var(--r-sm);flex:0 0 auto;
  background:transparent;border:1px solid transparent;
  color:var(--muted);font-size:16px;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
}
.mon-close:hover{color:var(--accent-hi);border-color:var(--border)}
.mon-img-wrap{
  position:relative;width:100%;height:220px;
  background:#080a0c;display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.mon-img{width:100%;height:100%;object-fit:cover;display:block}
.mon-img-placeholder{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  color:var(--muted);font-size:11px;pointer-events:none;
}
.mon-img-wrap:not(.no-img) .mon-img-placeholder{display:none}
.mon-img-wrap.no-img .mon-img{display:none}
.mon-info{
  display:flex;gap:10px;flex-wrap:wrap;
  padding:7px 12px;border-top:1px solid var(--border-soft);
}
.mon-info-item{font-size:13px;color:var(--text)}
.mon-nav{
  position:absolute;top:50%;transform:translateY(-50%);
  background:rgba(0,0,0,.55);border:none;color:#fff;
  font-size:18px;line-height:1;padding:4px 8px;cursor:pointer;
  border-radius:3px;opacity:.8;z-index:2;
}
.mon-nav:hover{opacity:1;background:rgba(0,0,0,.8)}
.mon-prev{left:4px}
.mon-next{right:4px}
.mon-counter{
  position:absolute;bottom:4px;left:50%;transform:translateX(-50%);
  background:rgba(0,0,0,.55);color:#ddd;font-size:10px;
  padding:1px 6px;border-radius:3px;pointer-events:none;
}

/* === BATTLEMETRICS NEIGHBOURS === */
.bm-toolbar{padding:8px 10px 4px;border-bottom:1px solid var(--border-soft)}
.bm-toolbar input{width:100%;background:var(--bg);border:1px solid var(--border);
  color:var(--text);border-radius:var(--r-sm);padding:5px 8px;font-size:12px;outline:none}
.bm-toolbar input:focus{border-color:var(--accent)}
/* Neighbours dock panel (app-v2) — count badge + feed label ported from player-intel sidebar */
.v2-dock-panel[data-panel="neighbours"]{display:flex;flex-direction:column;min-height:0}
.pi-sidebar-count{font-size:11px;font-weight:700;font-family:'JetBrains Mono',monospace;color:var(--text);background:rgba(255,255,255,.06);border-radius:10px;padding:2px 8px}
.pi-sidebar-feed-label{font-size:8.5px;font-weight:800;text-transform:uppercase;letter-spacing:.15em;color:var(--dim);padding:8px 12px 4px;border-top:1px solid var(--border)}
.bm-list{list-style:none;margin:0;padding:4px 0;max-height:180px;overflow-y:auto}
.bm-list li{
  display:flex;align-items:center;gap:7px;
  padding:4px 12px;font-size:12px;color:var(--text);
  border-bottom:1px solid var(--border-soft);
  cursor:default;transition:.1s;
}
.bm-list li:last-child{border-bottom:0}
.bm-list li:hover{background:var(--panel-2)}
.bm-list li.watched{color:var(--accent-hi)}
.bm-dot{width:7px;height:7px;border-radius:50%;background:var(--good);flex-shrink:0}
.bm-dot.off{background:rgba(140,150,160,.45)}
.bm-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bm-time{font-size:10px;color:var(--muted);flex-shrink:0}
.bm-watch-btn{
  background:transparent;border:none;cursor:pointer;
  color:var(--dim);font-size:13px;padding:0 2px;line-height:1;
  transition:.1s;flex-shrink:0;
}
.bm-watch-btn:hover{color:var(--accent-hi)}
.bm-watch-btn.on{color:var(--accent-hi)}
/* Risk pills */
.bm-risk{
  flex-shrink:0;min-width:16px;height:16px;padding:0 4px;
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:8px;font-size:10px;font-weight:600;line-height:1;
  cursor:help;border:1px solid transparent;
}
.bm-risk-unknown{background:rgba(120,130,140,.18);color:var(--muted);border-color:rgba(120,130,140,.35)}
.bm-risk-low{background:rgba(80,180,110,.18);color:var(--good);border-color:rgba(80,180,110,.4)}
.bm-risk-medium{background:rgba(220,170,60,.18);color:#d9a93c;border-color:rgba(220,170,60,.4)}
.bm-risk-high{background:rgba(210,80,80,.2);color:var(--bad);border-color:rgba(210,80,80,.45)}
.bm-enrich-btn{
  background:transparent;border:1px solid var(--line,#333);cursor:pointer;
  color:var(--dim);font-size:11px;padding:3px 8px;border-radius:5px;
  line-height:1;transition:.1s;white-space:nowrap;
}
.bm-enrich-btn:hover{color:var(--accent-hi);border-color:var(--accent-hi)}

/* Server population sparkline (header trend) */
.bm-pop{padding:4px 10px 6px;display:flex;flex-direction:column;gap:4px}
.bm-pop-head{display:flex;align-items:center;gap:6px;font-size:9px}
.bm-pop-label{color:var(--dim);text-transform:uppercase;letter-spacing:.06em}
.bm-pop-range{display:flex;gap:3px}
.bm-pop-btn{background:transparent;border:1px solid var(--border);color:var(--muted);font-size:9px;padding:1px 5px;border-radius:4px;cursor:pointer;line-height:1.4}
.bm-pop-btn.on{color:var(--accent-hi);border-color:var(--accent-hi)}
.bm-pop-stats{margin-left:auto;color:var(--muted);font-size:10px;white-space:nowrap}
.bm-pop-spark{display:flex;align-items:flex-end;gap:1px;height:24px;background:var(--bg);border-radius:4px;padding:2px 3px}
.bm-pop-bar{flex:1;background:var(--accent);border-radius:1px 1px 0 0;min-height:3px;opacity:.85}
.bm-pop-na{font-size:10px;color:var(--muted);align-self:center;padding-left:2px}
.bm-feed{padding:4px 10px 8px;display:flex;flex-direction:column;gap:3px;max-height:110px;overflow-y:auto}
.bm-ev{font-size:11px;display:flex;gap:6px;align-items:baseline;padding:2px 0}
.bm-ev.join{color:var(--good)}
.bm-ev.leave{color:var(--bad)}
.bm-ev-time{color:var(--dim);font-size:10px;flex-shrink:0}
.bm-empty{padding:10px 12px;font-size:12px;color:var(--muted)}
.bm-active{background:var(--accent-soft) !important}
.bm-list li{cursor:pointer}

/* Detail panel */
/* Inline accordion card — mounted directly under the clicked player row */
.bm-detail{
  border:1px solid rgba(240,133,80,.28);border-radius:8px;
  background:rgba(255,255,255,.03);
  padding:10px 12px;margin:3px 2px 8px;
  display:flex;flex-direction:column;gap:8px;
  list-style:none;
}
.bm-detail-close{
  flex-shrink:0;width:20px;height:20px;line-height:1;padding:0;
  display:inline-flex;align-items:center;justify-content:center;
  background:transparent;border:1px solid rgba(255,255,255,.14);border-radius:5px;
  color:var(--muted);font-size:11px;cursor:pointer;
}
.bm-detail-close:hover{color:var(--text);border-color:rgba(255,255,255,.3)}
.bm-detail-loading{font-size:11px;color:var(--muted);padding:6px 0}
.bm-detail-head{display:flex;align-items:center;justify-content:space-between;gap:8px}
.bm-detail-name{font-size:12px;font-weight:700;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bm-detail-intel{font-size:10px;color:var(--accent-hi);text-decoration:none;flex-shrink:0}
.bm-detail-intel:hover{text-decoration:underline}
.bm-link-row{display:flex;gap:6px;margin:6px 0 2px}
.bm-link-input{
  flex:1;min-width:0;font-size:11px;color:var(--text);
  background:var(--bg);border:1px solid rgba(255,255,255,.12);border-radius:5px;
  padding:6px 8px;outline:none;
}
.bm-link-input:focus{border-color:var(--accent)}
.bm-link-btn{
  flex-shrink:0;font-size:11px;font-weight:700;cursor:pointer;
  color:#0c0f12;background:var(--accent);border:none;border-radius:5px;padding:6px 12px;
}
.bm-link-btn:disabled{opacity:.6;cursor:default}
.bm-link-hint{font-size:10px;color:var(--muted);line-height:1.5;margin-bottom:4px}
.bm-detail-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}
.bm-stat{display:flex;flex-direction:column;align-items:center;background:var(--bg);border-radius:4px;padding:5px 2px}
.bm-stat-val{font-size:12px;font-weight:700;color:var(--text);white-space:nowrap}
.bm-stat-label{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.bm-detail-section-label{font-size:9px;color:var(--dim);text-transform:uppercase;letter-spacing:.06em;margin-top:2px}

/* 24hr chart */
.bm-hour-chart{display:flex;align-items:flex-end;gap:1px;height:48px;padding-bottom:14px;position:relative}
.bm-hour-col{display:flex;flex-direction:column;align-items:center;flex:1;height:100%}
.bm-hour-bar{width:100%;background:var(--accent);border-radius:2px 2px 0 0;min-height:2px;margin-top:auto;transition:height .2s}
.bm-hour-label{font-size:7px;color:var(--dim);margin-top:2px;white-space:nowrap;position:absolute;bottom:0}

/* 12-week daily activity grid (GitHub-contributions style) */
.bm-daygrid{display:flex;gap:2px;padding:2px 0}
.bm-daycol{display:flex;flex-direction:column;gap:2px;flex:1}
.bm-daycell{width:100%;aspect-ratio:1;border-radius:2px;background:var(--panel);display:block}
.bm-daycell-l0{background:rgba(120,130,140,.12)}
.bm-daycell-l1{background:rgba(80,180,110,.30)}
.bm-daycell-l2{background:rgba(80,180,110,.50)}
.bm-daycell-l3{background:rgba(80,180,110,.72)}
.bm-daycell-l4{background:var(--good,#50b46e)}
.bm-daycell-future{background:transparent}
.bm-daygrid-legend{display:flex;align-items:center;gap:3px;font-size:9px;color:var(--dim)}
.bm-daygrid-legend .bm-daycell{width:9px;height:9px;aspect-ratio:auto;flex:none}

/* Session list */
.bm-sess-list{display:flex;flex-direction:column;gap:3px;max-height:120px;overflow-y:auto}
.bm-sess-empty{font-size:11px;color:var(--muted)}
.bm-sess-row{display:flex;align-items:center;gap:6px;font-size:11px}
.bm-sess-date{color:var(--dim);min-width:50px;flex-shrink:0}
.bm-sess-time{color:var(--muted);min-width:40px;flex-shrink:0}
.bm-sess-dur{color:var(--text);font-weight:600;margin-left:auto;display:flex;align-items:center;gap:4px}
.bm-sess-live{font-size:8px;background:var(--good);color:#000;border-radius:3px;padding:1px 4px;font-weight:700}

/* === BM CO-PRESENCE TAB === */
.bm-tabs{display:flex;gap:4px;padding:6px 10px 0}
.bm-tab{flex:1;background:var(--panel-2);border:1px solid var(--border);color:var(--muted);font-size:11px;font-weight:600;padding:5px 8px;border-radius:5px 5px 0 0;cursor:pointer}
.bm-tab:hover{color:var(--text)}
.bm-tab.on{background:var(--panel);color:var(--accent-hi);border-bottom-color:var(--panel)}
.bm-copresence{padding:8px 10px;display:flex;flex-direction:column;gap:10px;max-height:420px;overflow-y:auto}
.bm-cp-empty{font-size:11px;color:var(--muted);padding:8px 2px}
.bm-cp-section{display:flex;flex-direction:column;gap:5px}
.bm-cp-label{font-size:9px;color:var(--dim);text-transform:uppercase;letter-spacing:.06em}
.bm-cp-note{text-transform:none;letter-spacing:0;color:var(--muted)}
.bm-cp-hint{font-size:10px;color:var(--muted);line-height:1.4}
.bm-cp-vuln-row{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--muted)}
.bm-cp-vuln-row input{width:46px;background:var(--panel-2);border:1px solid var(--border);color:var(--text);border-radius:4px;padding:3px 5px;font-size:11px}
.bm-cp-btn{background:var(--panel-2);border:1px solid var(--border);color:var(--muted);font-size:11px;padding:3px 9px;border-radius:4px;cursor:pointer}
.bm-cp-btn:hover{color:var(--accent-hi);border-color:var(--accent-hi)}
.bm-cp-sortbar{display:flex;align-items:center;gap:5px;font-size:10px;color:var(--dim)}
.bm-cp-sort{background:transparent;border:1px solid var(--border);color:var(--muted);font-size:10px;padding:2px 7px;border-radius:4px;cursor:pointer}
.bm-cp-sort.on{color:var(--accent-hi);border-color:var(--accent-hi)}
.bm-cp-list{display:flex;flex-direction:column;gap:8px}
.bm-cp-row{background:var(--panel-2);border:1px solid var(--border);border-radius:6px;padding:7px 8px;display:flex;flex-direction:column;gap:5px}
.bm-cp-row-head{display:flex;align-items:center;justify-content:space-between;gap:6px}
.bm-cp-name{font-size:12px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bm-cp-total{font-size:11px;color:var(--muted);flex-shrink:0}
.bm-cp-spark{display:flex;align-items:flex-end;gap:1px;height:26px}
.bm-cp-spark-bar{flex:1;background:var(--accent);border-radius:1px 1px 0 0;min-height:3px;opacity:.85}
.bm-cp-bars{display:flex;flex-direction:column;gap:3px}
.bm-cp-bar-wrap{display:flex;align-items:center;gap:6px;font-size:10px}
.bm-cp-bar-label{color:var(--dim);min-width:34px;text-transform:uppercase;letter-spacing:.04em}
.bm-cp-bar{flex:1;height:8px;background:var(--panel);border-radius:4px;overflow:hidden}
.bm-cp-bar-fill{display:block;height:100%;border-radius:4px}
.bm-cp-bar-fill.vuln{background:#d9a93c}
.bm-cp-bar-fill.squad{background:var(--bad)}
.bm-cp-bar-val{color:var(--muted);min-width:30px;text-align:right}
.bm-cp-pairs{display:flex;flex-direction:column;gap:4px}
.bm-cp-pair{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:11px;background:var(--panel-2);border:1px solid var(--border);border-radius:5px;padding:5px 8px}
.bm-cp-pair-names{color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bm-cp-pair-amp{color:var(--dim)}
.bm-cp-pair-meta{color:var(--muted);flex-shrink:0}

/* === MAP EVENT STATUS OVERLAY === */
.map-ev-panel{
  position:absolute;
  top:10px;left:10px;
  z-index:20;
  display:flex;flex-direction:row;align-items:stretch;
  background:rgba(6,9,14,.88);
  border:1px solid rgba(255,255,255,.09);
  border-radius:12px;
  overflow:hidden;
  backdrop-filter:blur(18px);
  box-shadow:0 2px 20px rgba(0,0,0,.55),inset 0 1px 0 rgba(255,255,255,.06);
  pointer-events:none;
}
.mev-chip{
  display:flex;align-items:center;gap:6px;
  padding:8px 13px;
  position:relative;
  transition:background .22s;
  pointer-events:auto;
}
.mev-chip+.mev-chip::before{
  content:'';position:absolute;left:0;top:22%;bottom:22%;
  width:1px;background:rgba(255,255,255,.07);
}
.mev-chip.mev-on{
  background:color-mix(in srgb,var(--c) 11%,transparent);
}
.mev-icon{
  display:flex;align-items:center;flex-shrink:0;
  opacity:.22;
  transition:opacity .22s,filter .22s;
}
.mev-icon img{
  filter:grayscale(1) brightness(.5);
  transition:filter .22s;
}
.mev-icon svg{
  color:rgba(255,255,255,.4);
  transition:color .22s;
}
.mev-chip.mev-on .mev-icon{
  opacity:1;
  filter:drop-shadow(0 0 5px color-mix(in srgb,var(--c) 70%,transparent));
}
.mev-chip.mev-on .mev-icon img{
  filter:drop-shadow(0 0 5px color-mix(in srgb,var(--c) 70%,transparent));
}
.mev-chip.mev-on .mev-icon svg{color:var(--c)}
.mev-name{
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;
  color:rgba(255,255,255,.2);
  white-space:nowrap;
  transition:color .22s;
}
.mev-chip.mev-on .mev-name{color:var(--c)}
.mev-dot{
  width:5px;height:5px;border-radius:50%;
  background:var(--c);
  box-shadow:0 0 6px var(--c);
  flex-shrink:0;
}
.mev-time{
  font-size:9px;font-family:'JetBrains Mono',monospace;font-weight:600;
  color:rgba(255,255,255,.75);white-space:nowrap;
  background:rgba(0,0,0,.3);
  border:1px solid rgba(255,255,255,.1);
  padding:2px 5px;border-radius:5px;
}

/* === COUNTDOWN TIMERS === */
.cd-panel{display:flex;flex-direction:column;gap:3px;padding:8px 12px}
.cd-row{
  display:flex;align-items:center;gap:6px;
  padding:5px 8px;
  background:var(--panel-2);
  border:1px solid var(--border-soft);
  border-left:3px solid var(--cd-color,var(--accent));
  border-radius:var(--r-sm);
  font-size:11px;
  transition:.12s;
  cursor:default;
}
.cd-row.cd-urgent{
  border-color:var(--bad);border-left-color:var(--bad);
  background:rgba(217,107,107,.08);
  animation:cdPulse 1s infinite;
}
.cd-row.cd-ready{
  border-left-color:var(--good);
  background:rgba(109,199,123,.08);
}
@keyframes cdPulse{0%,100%{opacity:1}50%{opacity:.72}}
.cd-label{
  display:flex;align-items:center;gap:5px;
  font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:var(--cd-color,var(--accent));flex:0 0 auto;min-width:74px;
}
.cd-label svg{flex-shrink:0;}
.cd-time{
  font-variant-numeric:tabular-nums;font-family:ui-monospace,monospace;
  font-size:12px;font-weight:600;color:#e6e0d0;flex:1;text-align:right;
}
.cd-badge{
  font-size:9px;font-weight:700;letter-spacing:.08em;
  padding:2px 5px;border-radius:3px;
  background:rgba(109,199,123,.18);color:var(--good);
  border:1px solid rgba(109,199,123,.3);flex:0 0 auto;
}

/* === UTILITY === */
.hidden{display:none!important}

/* === ADMIN DIALOG === */
.admin-dlg{
  padding:0;width:540px;max-width:calc(100vw - 32px);
  background:linear-gradient(180deg,#13161b,#0f1215);
  border:1px solid rgba(255,255,255,.09);
  border-radius:10px;
  box-shadow:0 40px 100px rgba(0,0,0,.8), 0 0 0 1px rgba(217,107,62,.06);
  overflow:hidden;
}

/* Header */
.admin-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 18px 15px;
  background:linear-gradient(180deg,#1a1e24 0%,#141820 100%);
  border-bottom:1px solid rgba(255,255,255,.07);
  position:relative;
}
.admin-head::after{
  content:"";position:absolute;bottom:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(217,107,62,.35) 30%,rgba(240,133,80,.45) 55%,rgba(217,107,62,.35) 80%,transparent);
}
.admin-head-l{display:flex;align-items:center;gap:12px}
.admin-head-mark{
  width:32px;height:32px;border-radius:7px;flex:0 0 32px;
  background:linear-gradient(135deg,rgba(217,107,62,.25),rgba(217,107,62,.08));
  border:1px solid rgba(217,107,62,.35);
  box-shadow:0 0 18px rgba(217,107,62,.18);
  display:flex;align-items:center;justify-content:center;
  font-size:15px;line-height:1;
  position:relative;
}
.admin-head-mark::after{
  content:"⚙";position:absolute;
  font-size:14px;line-height:1;
  color:var(--accent-hi);opacity:.9;
}
.admin-title{
  font-size:14px;font-weight:800;color:#f0e8dc;
  letter-spacing:.06em;text-transform:uppercase;line-height:1;
}
.admin-subtitle{
  font-size:10px;color:var(--dim);letter-spacing:.08em;
  text-transform:uppercase;margin-top:3px;
}
.admin-close{
  width:28px;height:28px;border-radius:6px;
  background:transparent;border:1px solid transparent;
  color:var(--dim);font-size:20px;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:.12s;flex:0 0 auto;
}
.admin-close:hover{color:var(--text);border-color:rgba(255,255,255,.1);background:rgba(255,255,255,.06)}

/* Tabs */
.admin-tabs{
  display:flex;
  background:#0c0f12;
  border-bottom:1px solid rgba(255,255,255,.07);
  padding:0 6px;
  gap:2px;
}
.admin-tab{
  padding:11px 16px;font-size:12px;font-weight:600;letter-spacing:.04em;
  background:transparent;border:none;
  border-bottom:2px solid transparent;
  color:var(--dim);cursor:pointer;transition:.15s;
  margin-bottom:-1px;position:relative;
}
.admin-tab:hover{color:var(--muted)}
.admin-tab.active{
  color:var(--accent-hi);
  border-bottom-color:var(--accent);
}
.admin-tab.active::before{
  content:"";position:absolute;inset:0 0 -1px;
  background:linear-gradient(180deg,rgba(217,107,62,.06),transparent);
  pointer-events:none;
}

/* Body */
.admin-body{padding:18px}

/* Password grid */
.admin-pw-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:12px;
}
.admin-card{
  border-radius:8px;padding:14px;
  display:flex;flex-direction:column;gap:10px;
  border:1px solid rgba(255,255,255,.07);
  background:rgba(255,255,255,.03);
  position:relative;overflow:hidden;
}
.admin-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:2px;
  border-radius:8px 8px 0 0;
}
.admin-card-clan::before{background:linear-gradient(90deg,rgba(217,107,62,.6),rgba(240,133,80,.3))}
.admin-card-guest::before{background:linear-gradient(90deg,rgba(107,169,217,.5),rgba(107,169,217,.2))}
.admin-card-header{display:flex;align-items:center;justify-content:space-between;gap:8px}
.admin-card-badge{
  font-size:9px;font-weight:800;letter-spacing:.12em;
  padding:3px 7px;border-radius:4px;flex:0 0 auto;
}
.admin-card-badge-clan{
  background:rgba(217,107,62,.15);color:var(--accent-hi);
  border:1px solid rgba(217,107,62,.3);
}
.admin-card-badge-guest{
  background:rgba(107,169,217,.12);color:var(--info);
  border:1px solid rgba(107,169,217,.25);
}
.admin-card-status{
  font-size:10px;color:var(--dim);text-align:right;line-height:1.4;
  min-width:0;overflow:hidden;text-overflow:ellipsis;
}
.admin-card-label{
  font-size:10px;font-weight:700;color:var(--muted);
  letter-spacing:.08em;text-transform:uppercase;
}
.admin-pw-row{display:flex;gap:5px}
.admin-pw-row input{
  flex:1;padding:8px 10px;font-size:12px;
  background:rgba(0,0,0,.35);
  border:1px solid rgba(255,255,255,.09);
  color:var(--text);border-radius:5px;outline:none;
  min-width:0;transition:.12s;
}
.admin-pw-row input:focus{border-color:var(--accent);box-shadow:0 0 0 2px rgba(217,107,62,.12)}
.admin-pw-row input::placeholder{color:var(--dim)}
.admin-pw-row button{
  padding:8px 10px;font-size:11px;font-weight:600;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09);
  color:var(--muted);border-radius:5px;cursor:pointer;
  white-space:nowrap;transition:.12s;flex:0 0 auto;
}
.admin-pw-row button:hover{color:var(--text);background:rgba(255,255,255,.09)}
.admin-save-btn{
  width:100%;padding:9px 14px;font-size:12px;font-weight:700;
  border-radius:5px;cursor:pointer;transition:.12s;
  letter-spacing:.03em;
}
.admin-save-clan{
  background:rgba(217,107,62,.15);border:1px solid rgba(217,107,62,.35);
  color:var(--accent-hi);
}
.admin-save-clan:hover{background:var(--accent);border-color:var(--accent);color:#0c0e10}
.admin-save-guest{
  background:rgba(107,169,217,.1);border:1px solid rgba(107,169,217,.3);
  color:var(--info);
}
.admin-save-guest:hover{background:rgba(107,169,217,.25);border-color:var(--info);color:#fff}
.admin-save-btn:disabled{opacity:.45;cursor:not-allowed}

/* Sessions tab */
.admin-sessions-toolbar{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:12px;
}
.admin-sess-hint{font-size:10px;color:var(--dim);letter-spacing:.03em}
.admin-refresh-btn{
  padding:6px 12px;font-size:11px;font-weight:600;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);
  color:var(--muted);border-radius:5px;cursor:pointer;
  transition:.12s;
}
.admin-refresh-btn:hover{color:var(--accent-hi);border-color:rgba(217,107,62,.4);background:rgba(217,107,62,.08)}
.admin-sessions-list{
  list-style:none;margin:0;padding:0;
  display:flex;flex-direction:column;gap:5px;
  max-height:300px;overflow-y:auto;
}
.admin-sess-loading{
  font-size:12px;color:var(--dim);
  padding:24px 0;text-align:center;letter-spacing:.04em;
}
.admin-sess-row{
  display:flex;align-items:center;gap:11px;
  padding:10px 12px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.07);
  border-radius:7px;transition:.12s;
}
.admin-sess-row:hover{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.1)}
.admin-sess-avatar{
  width:36px;height:36px;border-radius:7px;flex:0 0 36px;
  object-fit:cover;border:1px solid rgba(255,255,255,.08);
  background:#0c0e10;
}
.admin-sess-avatar-init{
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:15px;color:var(--accent-hi);
  background:rgba(217,107,62,.1);
}
.admin-sess-info{flex:1;min-width:0;display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.admin-sess-name{
  font-size:13px;font-weight:600;color:#e8e0d4;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.admin-sess-role{
  display:inline-flex;align-items:center;
  font-size:9px;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;padding:2px 6px;border-radius:4px;
  flex:0 0 auto;
}
.admin-role-clan{background:rgba(217,107,62,.15);color:var(--accent-hi);border:1px solid rgba(217,107,62,.3)}
.admin-role-guest{background:rgba(107,169,217,.12);color:var(--info);border:1px solid rgba(107,169,217,.25)}
.admin-role-unknown{background:rgba(255,255,255,.06);color:var(--muted);border:1px solid rgba(255,255,255,.1)}
.admin-sess-steam{
  font-size:10px;color:var(--dim);
  font-family:ui-monospace,monospace;letter-spacing:.03em;
  flex:0 0 auto;
}
.admin-sess-guest{
  font-size:10px;color:var(--info,#6ba9d9);
  font-family:ui-monospace,monospace;letter-spacing:.03em;
  background:rgba(107,169,217,.1);border:1px solid rgba(107,169,217,.2);
  border-radius:4px;padding:1px 5px;flex:0 0 100%;
}
.admin-kick-btn{
  padding:6px 12px;font-size:11px;font-weight:600;
  background:rgba(217,107,107,.08);border:1px solid rgba(217,107,107,.25);
  color:var(--bad);border-radius:5px;cursor:pointer;
  white-space:nowrap;transition:.12s;flex:0 0 auto;
}
.admin-kick-btn:hover{background:rgba(217,107,107,.18);border-color:var(--bad);box-shadow:0 0 10px rgba(217,107,107,.15)}
.admin-kick-btn:disabled{opacity:.45;cursor:not-allowed}
.admin-sess-kicked{opacity:.35;pointer-events:none}
.admin-sess-actions{display:flex;align-items:center;gap:5px;flex-shrink:0}
.admin-promote-btn{
  padding:5px 10px;font-size:10px;font-weight:700;
  background:rgba(240,133,80,.1);border:1px solid rgba(240,133,80,.3);
  color:var(--accent-hi);border-radius:5px;cursor:pointer;
  white-space:nowrap;transition:.12s;flex:0 0 auto;
}
.admin-promote-btn:hover{background:rgba(240,133,80,.2);border-color:var(--accent-hi)}
.admin-promote-btn:disabled{opacity:.45;cursor:not-allowed}
.admin-demote-btn{
  padding:5px 10px;font-size:10px;font-weight:700;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  color:var(--muted);border-radius:5px;cursor:pointer;
  white-space:nowrap;transition:.12s;flex:0 0 auto;
}
.admin-demote-btn:hover{background:rgba(255,255,255,.09);border-color:rgba(255,255,255,.2);color:var(--text)}
.admin-demote-btn:disabled{opacity:.45;cursor:not-allowed}
.admin-sess-self{
  font-size:10px;font-weight:700;letter-spacing:.08em;
  padding:4px 9px;border-radius:5px;flex:0 0 auto;
  background:rgba(109,199,123,.08);border:1px solid rgba(109,199,123,.2);
  color:var(--good);
}

/* Squad-membership role chips (used by admin members list) */
.admin-role-leader{background:rgba(217,107,62,.15);color:var(--accent-hi);border:1px solid rgba(217,107,62,.3)}
.admin-role-member{background:rgba(107,169,217,.12);color:var(--info);border:1px solid rgba(107,169,217,.25)}

/* === ONBOARD PAGE === */
.onboard-wrap{
  min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:24px;
  background:
    radial-gradient(900px 600px at 70% 10%, rgba(217,107,62,.07), transparent 55%),
    var(--bg);
}
.onboard-logo{
  display:flex;align-items:center;gap:10px;margin-bottom:40px;
}
.onboard-logo-mark{
  width:10px;height:10px;border-radius:3px;
  background:var(--accent);box-shadow:0 0 14px rgba(217,107,62,.8);
}
.onboard-headline{
  font-family:'Rubik',sans-serif;font-size:24px;font-weight:800;
  color:#f0e6d2;margin-bottom:8px;text-align:center;
}
.onboard-sub{font-size:13px;color:var(--muted);text-align:center;margin-bottom:32px}
.onboard-steam{
  font-size:12px;color:var(--dim);margin-bottom:28px;
  padding:6px 14px;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);
  border-radius:20px;
}
.onboard-steam b{color:var(--accent-hi)}
.onboard-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:16px;
  width:100%;max-width:560px;
}
@media(max-width:640px){.onboard-grid{grid-template-columns:1fr}}
.onboard-card{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
  border-radius:10px;padding:22px;
  display:flex;flex-direction:column;gap:12px;
  position:relative;overflow:hidden;
}
.onboard-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:2px;border-radius:10px 10px 0 0;
}
.onboard-card-create::before{background:linear-gradient(90deg,rgba(217,107,62,.7),rgba(240,133,80,.3))}
.onboard-card-join::before{background:linear-gradient(90deg,rgba(107,169,217,.6),rgba(107,169,217,.2))}
.onboard-card-title{
  font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);
}
.onboard-card-body{font-size:12px;color:var(--dim);line-height:1.55}
.onboard-input{
  width:100%;padding:9px 11px;font-size:12px;
  background:rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.09);
  color:var(--text);border-radius:5px;outline:none;
  box-sizing:border-box;transition:.12s;
}
.onboard-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px rgba(217,107,62,.12)}
.onboard-input::placeholder{color:var(--dim)}
.onboard-btn-create{
  width:100%;padding:10px;font-size:12px;font-weight:700;
  background:var(--accent);border:1px solid var(--accent);color:#0c0e10;
  border-radius:5px;cursor:pointer;transition:.12s;
}
.onboard-btn-create:hover{background:var(--accent-hi);border-color:var(--accent-hi)}
.onboard-btn-join{
  width:100%;padding:10px;font-size:12px;font-weight:700;
  background:rgba(107,169,217,.12);border:1px solid rgba(107,169,217,.3);
  color:var(--info);border-radius:5px;cursor:pointer;transition:.12s;
}
.onboard-btn-join:hover{background:rgba(107,169,217,.22);border-color:var(--info)}

/* Squad button in topbar */
.tb-btn-squad{
  gap:6px;font-weight:600;font-size:12px;
  background:rgba(217,107,62,.08);
  border-color:rgba(217,107,62,.25);
  color:var(--accent-hi);
}
.tb-btn-squad:hover{
  background:rgba(217,107,62,.16);
  border-color:var(--accent);
  box-shadow:0 0 14px rgba(217,107,62,.2);
}
.tb-btn-squad svg{flex:0 0 auto;opacity:.85}

/* ── Invite tab redesign ─────────────────────────────────── */
.inv-squad-row{
  display:flex;align-items:center;gap:8px;
  padding:14px 18px 10px;
  border-bottom:1px solid var(--border-soft);
}
.inv-squad-label{
  font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--dim);
}
.inv-squad-name{
  flex:1;font-size:13px;font-weight:700;color:#f0e6d2;
}
.inv-member-count{
  font-size:10px;color:var(--muted);
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);
  border-radius:10px;padding:2px 9px;letter-spacing:.04em;
}

/* ── Invite short-code card ─────────────────────────────── */
.inv-code-card{
  margin:14px 18px 0;
  background:rgba(217,107,62,.07);
  border:1px solid rgba(217,107,62,.28);
  border-radius:10px;
  padding:16px 18px 14px;
  text-align:center;
}
.inv-code-label{
  font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--dim);margin-bottom:8px;
}
.inv-code-display{
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:26px;font-weight:800;letter-spacing:.3em;
  color:var(--accent-hi);
  text-shadow:0 0 18px rgba(217,107,62,.35);
  padding:6px 0 8px;user-select:all;cursor:text;
}
.inv-code-hint{
  font-size:11px;color:var(--dim);margin-bottom:12px;line-height:1.4;
}
.inv-code-hint b{color:var(--muted);}
.inv-code-actions{
  display:flex;gap:8px;justify-content:center;
}
.inv-code-actions .inv-copy-btn{flex:1;max-width:160px}

.inv-link-card{
  margin:14px 18px 0;
  background:rgba(0,0,0,.35);
  border:1px solid rgba(255,255,255,.08);
  border-radius:8px;overflow:hidden;
  position:relative;
}
.inv-link-label{
  display:flex;align-items:center;gap:5px;
  padding:8px 12px 7px;
  font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--dim);
  border-bottom:1px solid rgba(255,255,255,.06);
  background:rgba(255,255,255,.02);
}
.inv-link-label svg{flex:0 0 auto;opacity:.7}
.inv-url-box{
  display:flex;align-items:baseline;gap:0;
  padding:12px 14px 14px;
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:12.5px;line-height:1.4;
  cursor:text;user-select:all;
  overflow:hidden;
}
.inv-url-prefix{color:var(--dim);flex:0 0 auto}
.inv-url-path{color:var(--accent-hi);flex:1;word-break:break-all}

.inv-actions{
  display:flex;gap:8px;padding:10px 18px 0;
}
.inv-copy-btn{
  flex:1;display:flex;align-items:center;justify-content:center;gap:7px;
  padding:10px 16px;font-size:12px;font-weight:700;letter-spacing:.03em;
  background:var(--accent);border:1px solid var(--accent);
  color:#0c0e10;border-radius:6px;cursor:pointer;transition:.12s;
}
.inv-copy-btn:hover{background:var(--accent-hi);border-color:var(--accent-hi)}
.inv-copy-btn.copied{
  background:rgba(109,199,123,.2);border-color:rgba(109,199,123,.5);
  color:var(--good);
}
.inv-share-btn{
  width:40px;display:flex;align-items:center;justify-content:center;
  padding:10px;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  color:var(--muted);border-radius:6px;cursor:pointer;transition:.12s;flex:0 0 auto;
}
.inv-share-btn:hover{color:var(--accent-hi);border-color:rgba(217,107,62,.4);background:rgba(217,107,62,.08)}

.inv-rotate-row{
  display:flex;align-items:center;gap:10px;
  padding:10px 18px 18px;
  margin-top:6px;
}
.inv-rotate-note{
  flex:1;font-size:10.5px;color:var(--dim);line-height:1.4;letter-spacing:.02em;
}
.inv-rotate-btn{
  padding:6px 13px;font-size:11px;font-weight:700;letter-spacing:.04em;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);
  color:var(--muted);border-radius:5px;cursor:pointer;transition:.12s;
  white-space:nowrap;flex:0 0 auto;
}
.inv-rotate-btn:hover{color:var(--bad);border-color:rgba(217,107,107,.4);background:rgba(217,107,107,.07)}

/* ── Shop Search ─────────────────────────────────────── */
.shop-search-fab {
  position: absolute;
  bottom: 52px;
  left: 14px;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px 8px 11px;
  background: rgba(10,13,18,.9);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 22px;
  color: rgba(255,255,255,.35);
  font-size: 12px;
  font-weight: 400;
  cursor: text;
  z-index: 20;
  backdrop-filter: blur(12px);
  box-shadow: 0 2px 16px rgba(0,0,0,.55), inset 0 1px 0 rgba(255,255,255,.05);
  transition: border-color .15s, background .15s, color .15s, box-shadow .15s;
  white-space: nowrap;
}
.shop-search-fab:hover {
  border-color: rgba(255,255,255,.22);
  background: rgba(16,20,26,.95);
  color: rgba(255,255,255,.55);
  box-shadow: 0 4px 20px rgba(0,0,0,.65), inset 0 1px 0 rgba(255,255,255,.07);
}
.shop-search-fab.active {
  border-color: rgba(217,107,62,.5);
  color: var(--accent-hi, #f08550);
  background: rgba(217,107,62,.08);
  box-shadow: 0 2px 14px rgba(217,107,62,.2);
  cursor: pointer;
}
.ssf-text {
  font-style: italic;
  letter-spacing: .01em;
}

.ss-panel {
  position: absolute;
  bottom: 100px;
  left: 14px;
  width: 340px;
  max-height: calc(100% - 130px);
  background: rgba(10,13,18,.97);
  border: 1px solid #2a3540;
  border-radius: 14px;
  z-index: 25;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  box-shadow: 0 12px 40px rgba(0,0,0,.7), 0 0 0 1px rgba(255,255,255,.04);
  backdrop-filter: blur(10px);
  transition: opacity .15s, transform .15s;
}
.ss-hidden { display: none !important; }

.ss-panel-head {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 11px 14px;
  border-bottom: 1px solid #1e2a34;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--muted, #6c7480);
  flex-shrink: 0;
  background: rgba(0,0,0,.25);
}
.ss-close {
  margin-left: auto;
  width: 22px; height: 22px;
  background: none;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 5px;
  color: var(--dim, #454c54);
  font-size: 11px;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: color .1s, border-color .1s;
}
.ss-close:hover { color: #ff6060; border-color: rgba(255,80,80,.35); }

.ss-search-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border-bottom: 1px solid #1e2a34;
  flex-shrink: 0;
  color: var(--dim, #454c54);
}
.ss-input {
  flex: 1;
  background: none;
  border: none;
  outline: none;
  font-size: 13px;
  color: var(--text, #d4d8db);
  font-family: inherit;
}
.ss-input::placeholder { color: var(--dim, #454c54); }

.ss-list {
  overflow-y: auto;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 1px;
  padding: 6px 0;
}

.ss-hint {
  padding: 20px 16px;
  text-align: center;
  font-size: 11px;
  color: var(--dim, #454c54);
  font-style: italic;
}

/* Shop result block */
.ss-shop {
  padding: 10px 14px;
  border-bottom: 1px solid #171e25;
}
.ss-shop:last-child { border-bottom: none; }

.ss-shop-head {
  display: flex;
  align-items: center;
  gap: 7px;
  margin-bottom: 7px;
}
.ss-shop-name {
  font-size: 11px;
  font-weight: 700;
  color: var(--text, #d4d8db);
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ss-oos {
  font-size: 9px;
  font-weight: 700;
  color: var(--bad, #d96b6b);
  background: rgba(217,107,107,.1);
  border-radius: 3px;
  padding: 1px 5px;
  flex-shrink: 0;
}
.ss-dynamic {
  font-size: 9px;
  font-weight: 700;
  color: #f0a050;
  background: rgba(240,160,80,.12);
  border-radius: 3px;
  padding: 1px 5px;
  flex-shrink: 0;
  cursor: help;
}
.ss-goto {
  padding: 3px 9px;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: .06em;
  background: rgba(217,107,62,.12);
  border: 1px solid rgba(217,107,62,.3);
  border-radius: 4px;
  color: var(--accent-hi, #f08550);
  cursor: pointer;
  transition: background .12s, border-color .12s;
  flex-shrink: 0;
}
.ss-goto:hover { background: rgba(217,107,62,.22); border-color: rgba(217,107,62,.5); }

/* Order row */
.ss-order {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 5px 0;
  border-radius: 5px;
}
.ss-icon {
  width: 30px; height: 30px;
  object-fit: contain;
  border-radius: 5px;
  background: rgba(255,255,255,.04);
  flex-shrink: 0;
}
.ss-icon-sm {
  width: 20px; height: 20px;
  object-fit: contain;
  flex-shrink: 0;
}
.ss-order-info {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 1px;
  min-width: 0;
}
.ss-item-name {
  font-size: 11px;
  font-weight: 600;
  color: var(--text, #d4d8db);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.ss-item-qty {
  font-size: 9px;
  color: var(--dim, #454c54);
  font-family: 'JetBrains Mono', monospace;
}
.ss-cost {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-shrink: 0;
}
.ss-cost-val {
  font-size: 11px;
  font-weight: 700;
  font-family: 'JetBrains Mono', monospace;
  color: var(--accent-hi, #f08550);
}
.ss-stock {
  font-size: 9px;
  color: var(--good, #6dc77b);
  font-family: 'JetBrains Mono', monospace;
  white-space: nowrap;
}

/* ── Event Status Board ──────────────────────────────── */
/* ── Status board: event tile grid ──────────────────────────── */
.status-board{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:4px;
  padding:6px 8px 10px;
}
.sb-tile{
  display:flex;flex-direction:column;align-items:center;
  gap:3px;
  background:rgba(255,255,255,.02);
  border:1px solid rgba(255,255,255,.06);
  border-radius:8px;
  padding:8px 4px 7px;
  position:relative;
  overflow:hidden;
  transition:border-color .25s,background .25s,box-shadow .25s;
  min-width:0;
}
.sb-tile.sb-active{
  border-color:color-mix(in srgb,var(--c) 40%,transparent);
  background:color-mix(in srgb,var(--c) 9%,transparent);
  box-shadow:0 0 12px color-mix(in srgb,var(--c) 15%,transparent);
}
.sb-tile.sb-warn{
  border-color:color-mix(in srgb,var(--c) 22%,transparent);
  background:color-mix(in srgb,var(--c) 5%,transparent);
}
.sb-tile-icon{
  width:24px;height:24px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  color:var(--dim);
  transition:color .25s,filter .25s;
}
.sb-tile.sb-active .sb-tile-icon{
  color:var(--c);
  filter:drop-shadow(0 0 5px var(--c));
}
.sb-tile.sb-warn .sb-tile-icon{
  color:color-mix(in srgb,var(--c) 65%,var(--dim));
}
.sb-tile-img{
  width:100%;height:100%;object-fit:contain;
  filter:grayscale(1) brightness(.4);
  transition:filter .25s;
}
.sb-tile.sb-active .sb-tile-img{
  filter:brightness(1.15);
}
.sb-tile.sb-warn .sb-tile-img{
  filter:grayscale(0) brightness(.8);
}
.sb-tile-svg{
  width:100%;height:100%;
}
.sb-tile-name{
  font-size:8px;font-weight:800;text-transform:uppercase;letter-spacing:.07em;
  color:var(--dim);
  transition:color .25s;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;
  text-align:center;line-height:1.2;
}
.sb-tile.sb-active .sb-tile-name{color:var(--text)}
.sb-tile.sb-warn   .sb-tile-name{color:var(--muted)}
.sb-tile-status{
  font-size:8.5px;
  color:var(--dim);
  font-family:'JetBrains Mono',ui-monospace,monospace;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;
  text-align:center;line-height:1.2;
  transition:color .25s;
}
.sb-tile.sb-active .sb-tile-status{color:var(--c)}
.sb-tile.sb-warn   .sb-tile-status{color:color-mix(in srgb,var(--c) 70%,var(--dim))}
.sb-reset-btn{
  position:absolute;top:3px;right:3px;
  background:none;border:1px solid rgba(255,255,255,.1);border-radius:3px;
  color:var(--dim);font-size:9px;cursor:pointer;padding:0 3px;
  line-height:1.5;transition:.12s;
}
.sb-reset-btn:hover{color:var(--muted);border-color:rgba(255,255,255,.2);background:rgba(255,255,255,.05)}

/* ── Status board reset button + popup ──────────────── */
.sb-reset-btn{
  background:none;border:1px solid rgba(255,255,255,.1);border-radius:4px;
  color:var(--dim);font-size:11px;cursor:pointer;padding:1px 5px;
  margin-left:auto;flex-shrink:0;transition:.12s;line-height:1.4;
}
.sb-reset-btn:hover{color:var(--muted);border-color:rgba(255,255,255,.2);background:rgba(255,255,255,.05)}

.sb-reset-popup{
  position:fixed;z-index:300;width:270px;
  background:#1a1e24;
  border:1px solid rgba(255,255,255,.12);
  border-radius:10px;
  box-shadow:0 12px 40px rgba(0,0,0,.7);
  padding:0;overflow:hidden;
  animation:shopFade .1s ease-out;
}
.sb-rp-head{
  display:flex;align-items:center;gap:9px;
  padding:12px 14px 10px;
  border-bottom:1px solid rgba(255,255,255,.07);
  background:rgba(255,255,255,.02);
}
.sb-rp-icon{font-size:15px;color:var(--muted)}
.sb-rp-title{font-size:12px;font-weight:800;letter-spacing:.04em;color:#f0e6d2}
.sb-rp-body{
  margin:0;padding:12px 14px;
  font-size:11.5px;color:var(--muted);line-height:1.6;
  border-bottom:1px solid rgba(255,255,255,.07);
}
.sb-rp-actions{
  display:flex;gap:8px;padding:10px 14px 12px;
}
.sb-rp-cancel{
  flex:1;padding:7px 10px;font-size:11px;font-weight:700;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);
  border-radius:6px;color:var(--muted);cursor:pointer;transition:.1s;
}
.sb-rp-cancel:hover{background:rgba(255,255,255,.08);color:#f0e6d2}
.sb-rp-confirm{
  flex:2;padding:7px 10px;font-size:11px;font-weight:800;letter-spacing:.03em;
  background:rgba(217,107,62,.15);border:1px solid rgba(217,107,62,.35);
  border-radius:6px;color:var(--accent-hi);cursor:pointer;transition:.1s;
}
.sb-rp-confirm:hover{background:rgba(217,107,62,.25);border-color:var(--accent)}

/* ── Pair Rust+ modal ────────────────────────────────────────── */
.pm-hidden{display:none!important}
body.pm-open{overflow:hidden}
.pm-overlay{
  position:fixed;inset:0;z-index:1000;
  background:rgba(5,7,9,.82);
  backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;
  padding:20px;
  animation:pmFadeIn .18s ease;
}
@keyframes pmFadeIn{from{opacity:0}to{opacity:1}}
.pm-box{
  width:100%;max-width:980px;max-height:90vh;
  background:linear-gradient(180deg,#14181e 0%,#0e1115 100%);
  border:1px solid rgba(255,255,255,.1);
  border-radius:14px;
  box-shadow:0 32px 80px -20px rgba(0,0,0,.85),0 0 0 1px rgba(255,255,255,.05) inset;
  display:flex;flex-direction:column;
  overflow:hidden;
  animation:pmSlideIn .2s ease;
}
@keyframes pmSlideIn{from{transform:translateY(12px);opacity:0}to{transform:none;opacity:1}}
.pm-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 24px;
  border-bottom:1px solid rgba(255,255,255,.07);
  background:rgba(0,0,0,.2);
  flex:0 0 auto;
}
.pm-head-brand{display:flex;align-items:center;gap:10px}
.pm-head-title{
  font-family:'Rubik',sans-serif;font-size:17px;font-weight:800;
  color:#f0e6d2;letter-spacing:.02em;
}
.pm-head-sub{
  font-size:12px;color:var(--muted);
  border-left:1px solid rgba(255,255,255,.1);
  padding-left:12px;margin-left:2px;
}
.pm-close{
  width:32px;height:32px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  border-radius:7px;color:var(--muted);cursor:pointer;
  transition:.15s;flex:0 0 auto;
}
.pm-close:hover{background:rgba(255,255,255,.1);color:var(--text);border-color:rgba(255,255,255,.18)}
.pm-body{
  display:grid;grid-template-columns:1fr 300px;
  gap:0;overflow:hidden;flex:1;min-height:0;
}
.pm-steps-col{
  padding:20px 24px;
  overflow-y:auto;
  border-right:1px solid rgba(255,255,255,.06);
}
.pm-sidebar{
  padding:16px;
  overflow-y:auto;
  display:flex;flex-direction:column;gap:12px;
  background:rgba(0,0,0,.12);
}

/* ── Tools modal ─────────────────────────────────────────────── */
.tm-box{max-width:860px}
.tm-body{
  padding:28px 28px 32px;
  overflow-y:auto;
  background:radial-gradient(900px 500px at 50% -60px,rgba(217,107,62,.06),transparent 65%);
}
.tools-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:14px;
}
.tool-card{
  background:#0f1318;
  border:1px solid #1e2530;
  border-radius:14px;
  overflow:hidden;
  display:flex;flex-direction:column;
  transition:border-color .2s,transform .15s,box-shadow .2s;
  text-decoration:none;color:inherit;
  position:relative;
}
.tool-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,rgba(217,107,62,0));
  transition:background .2s;
}
.tool-card:not(.tool-card-locked):hover{
  border-color:var(--accent);
  transform:translateY(-3px);
  box-shadow:0 12px 40px rgba(0,0,0,.5),0 0 0 1px rgba(217,107,62,.15);
}
.tool-card:not(.tool-card-locked):hover::before{
  background:linear-gradient(90deg,transparent 5%,var(--accent) 40%,var(--accent-hi) 60%,transparent 95%);
}
.tool-card-locked{opacity:.45;cursor:not-allowed}
.tool-card-banner{
  height:130px;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(ellipse at 50% 60%,rgba(217,107,62,.10) 0%,transparent 70%),#0a0d12;
  border-bottom:1px solid #1a2028;
  position:relative;overflow:hidden;
}
.tool-card-banner img{
  width:80px;height:80px;object-fit:contain;
  filter:drop-shadow(0 4px 20px rgba(217,107,62,.4));
  transition:transform .2s,filter .2s;
}
.tool-card:not(.tool-card-locked):hover .tool-card-banner img{
  transform:scale(1.1) translateY(-4px);
  filter:drop-shadow(0 8px 28px rgba(217,107,62,.65));
}
.tool-card-body{padding:16px 18px 18px;display:flex;flex-direction:column;gap:6px;flex:1}
.tool-card-name{font-size:14px;font-weight:800;color:var(--text);letter-spacing:-.01em}
.tool-card-desc{font-size:11px;color:var(--muted);line-height:1.55;flex:1}
.tool-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:12px}
.tool-card-tag{
  font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;
  padding:3px 8px;border-radius:4px;
  background:rgba(217,107,62,.12);color:var(--accent);
}
.tool-card-tag.tag-soon{background:rgba(255,255,255,.04);color:var(--dim)}
.tool-card-open{
  font-size:10px;font-weight:700;color:var(--accent-hi);
  display:flex;align-items:center;gap:5px;transition:gap .15s;
}
.tool-card:not(.tool-card-locked):hover .tool-card-open{gap:8px}
.tool-card-open::after{content:'→';font-size:13px}
.tool-card-featured{grid-column:span 2}
.tool-card-featured .tool-card-banner{height:160px}
.tool-card-featured .tool-card-banner img{width:100px;height:100px}
.tool-card-banner-multi{display:flex;align-items:center;justify-content:center;gap:14px}
.tool-card-banner-multi img{width:52px!important;height:52px!important}
@media(max-width:600px){.tool-card-featured{grid-column:span 1}}

/* ── Tool viewer (iframe) modal ──────────────────────────────── */
.tv-box{
  width:96vw;max-width:1400px;
  height:94vh;max-height:94vh;
  display:flex;flex-direction:column;
}
.tv-body{flex:1;min-height:0;overflow:hidden;position:relative}
.tv-frame{position:absolute;inset:0;width:100%;height:100%;border:none;background:#060b10;display:block}
.tv-back-btn{
  display:inline-flex;align-items:center;gap:5px;
  padding:4px 10px;font-size:12px;font-weight:600;
  color:var(--muted);background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.09);border-radius:6px;
  cursor:pointer;transition:.15s;
}
.tv-back-btn:hover{color:var(--text);background:rgba(255,255,255,.08)}
.pm-head-sep{color:rgba(255,255,255,.18);font-size:14px;margin:0 4px}

/* ── Squad settings modal ────────────────────────────────── */
.sq-settings-box{width:100%;max-width:520px}
.sq-body{padding:24px;display:flex;flex-direction:column;gap:20px}
.sq-desc{margin:0;font-size:12px;color:var(--muted);line-height:1.5}
.sq-section{display:flex;flex-direction:column;gap:10px}
.sq-section-label{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.13em;color:var(--dim)}
.sq-row{display:flex;align-items:center;justify-content:space-between;gap:16px;
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);
  border-radius:8px;padding:12px 14px}
.sq-row-info{display:flex;flex-direction:column;gap:3px;flex:1;min-width:0}
.sq-row-title{font-size:12px;font-weight:600;color:var(--text)}
.sq-row-hint{font-size:11px;color:var(--dim);line-height:1.4}
.sq-row-control{display:flex;align-items:center;gap:10px;flex-shrink:0}
.sq-range{-webkit-appearance:none;appearance:none;width:120px;height:4px;
  background:rgba(255,255,255,.12);border-radius:2px;outline:none;cursor:pointer}
.sq-range::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;
  border-radius:50%;background:var(--accent-hi);cursor:pointer;transition:transform .1s}
.sq-range::-webkit-slider-thumb:hover{transform:scale(1.2)}
.sq-range-val{font-size:12px;font-weight:700;color:var(--accent-hi);
  min-width:42px;text-align:right;font-variant-numeric:tabular-nums}
.sq-footer{display:flex;align-items:center;justify-content:flex-end;gap:12px;padding-top:4px}
.sq-saved-msg{font-size:11px;color:var(--good);opacity:0;transition:opacity .3s}
.sq-saved-msg.show{opacity:1}
.sq-save-btn{padding:8px 20px;background:var(--accent);color:#fff;
  border:none;border-radius:7px;font-size:12px;font-weight:700;
  cursor:pointer;transition:background .15s}
.sq-save-btn:hover{background:var(--accent-hi)}
.sq-clear-btn{padding:8px 16px;background:transparent;color:var(--bad);
  border:1px solid rgba(217,107,107,.35);border-radius:7px;font-size:12px;font-weight:600;
  cursor:pointer;transition:background .15s,border-color .15s;margin-right:auto}
.sq-clear-btn:hover{background:rgba(217,107,107,.1);border-color:var(--bad)}

/* ═══════════════════════════════════════════════
   OWNER PANEL
═══════════════════════════════════════════════ */
.owner-settings-section{margin-top:4px}
.owner-settings-sep{height:1px;background:rgba(255,255,255,.07);margin:12px 0 14px}
.owner-settings-btn{
  display:flex;align-items:center;gap:7px;width:100%;
  padding:9px 14px;border-radius:7px;cursor:pointer;font-size:13px;font-weight:600;
  background:rgba(224,85,85,.09);border:1px solid rgba(224,85,85,.28);
  color:#e05555;transition:background .15s,border-color .15s,color .15s;
}
.owner-settings-btn:hover{
  background:rgba(224,85,85,.17);border-color:rgba(255,112,112,.5);color:#ff7070;
}

.owner-overlay{
  position:fixed;inset:0;z-index:9999;
  background:rgba(5,7,9,.82);backdrop-filter:blur(6px);
  display:flex;align-items:stretch;justify-content:center;
  padding:0;
}
.owner-hidden{display:none!important}

.owner-panel{
  display:flex;flex-direction:column;
  width:100%;max-width:1280px;
  background:linear-gradient(180deg,#10141a 0%,#0c0f13 100%);
  border-left:1px solid rgba(255,255,255,.06);
  border-right:1px solid rgba(255,255,255,.06);
  overflow:hidden;
}

.owner-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 22px;
  background:linear-gradient(180deg,#13171e 0%,#0e1218 100%);
  border-bottom:1px solid rgba(224,85,85,.2);
  flex-shrink:0;
}
.owner-head::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(224,85,85,.4) 30%,rgba(255,100,100,.5) 50%,rgba(224,85,85,.4) 70%,transparent);
}
.owner-head-l{display:flex;align-items:center;gap:14px}
.owner-head-mark{
  width:10px;height:10px;border-radius:50%;
  background:#e05555;
  box-shadow:0 0 10px rgba(224,85,85,.9),0 0 24px rgba(224,85,85,.4);
  flex-shrink:0;
}
.owner-title{font-size:15px;font-weight:700;color:#f0d0d0;letter-spacing:.03em}
.owner-subtitle{font-size:11px;color:var(--muted);margin-top:2px;font-variant-numeric:tabular-nums}
.owner-head-r{display:flex;align-items:center;gap:8px}
.owner-hbtn{
  padding:5px 13px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);color:var(--muted);
  transition:.15s;
}
.owner-hbtn:hover{background:rgba(255,255,255,.1);color:var(--text)}
.owner-close-btn{
  width:30px;height:30px;border-radius:7px;font-size:18px;line-height:1;
  background:rgba(224,85,85,.08);border:1px solid rgba(224,85,85,.2);
  color:#e05555;cursor:pointer;transition:.15s;
  display:flex;align-items:center;justify-content:center;
}
.owner-close-btn:hover{background:rgba(224,85,85,.2);border-color:rgba(224,85,85,.5)}

.owner-body{
  display:flex;flex:1;overflow:hidden;
  min-height:0;
}

/* Left column: squad cards */
.owner-squads-col{
  width:420px;flex-shrink:0;
  overflow-y:auto;
  padding:14px;
  display:flex;flex-direction:column;gap:8px;
  border-right:1px solid rgba(255,255,255,.06);
}
.owner-squads-col::-webkit-scrollbar{width:4px}
.owner-squads-col::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:2px}

.owner-loading{padding:20px;text-align:center;color:var(--dim);font-size:12px}

.owner-card{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.07);
  border-radius:10px;
  padding:12px 14px;
  cursor:pointer;
  transition:.15s;
}
.owner-card:hover{background:rgba(255,255,255,.055);border-color:rgba(255,255,255,.12)}
.owner-card.selected{
  background:rgba(224,85,85,.06);
  border-color:rgba(224,85,85,.3);
}
.owner-card-top{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:4px}
.owner-card-name{font-size:13px;font-weight:700;color:var(--text)}
.owner-squad-id{font-size:10px;color:var(--dim);font-weight:400}
.owner-card-server{font-size:11px;color:var(--muted);margin-bottom:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.owner-card-stats{
  display:flex;flex-wrap:wrap;gap:4px 12px;
  margin-bottom:10px;
}
.owner-stat{font-size:11px;color:var(--dim);font-variant-numeric:tabular-nums}
.owner-stat.stat-hi{color:var(--good)}
.owner-stat.stat-warn{color:#e0a055}
.osv-label{opacity:.7}
.owner-card-actions{display:flex;gap:6px}
.owner-act-btn{
  padding:4px 11px;border-radius:5px;font-size:11px;font-weight:600;cursor:pointer;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:var(--muted);
  transition:.15s;
}
.owner-act-btn:hover{background:rgba(255,255,255,.12);color:var(--text)}
.owner-act-map{border-color:rgba(109,199,123,.2);color:var(--good)}
.owner-act-map:hover{background:rgba(109,199,123,.1);border-color:rgba(109,199,123,.4)}

/* Connection badge */
.owner-conn-badge{
  display:inline-flex;align-items:center;gap:4px;
  font-size:10px;font-weight:700;letter-spacing:.05em;
  padding:2px 8px;border-radius:10px;flex-shrink:0;
}
.owner-conn-ok{background:rgba(109,199,123,.12);color:var(--good);border:1px solid rgba(109,199,123,.25)}
.owner-conn-ok::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--good);box-shadow:0 0 6px var(--good);flex-shrink:0}
.owner-conn-off{background:rgba(217,107,107,.1);color:var(--bad);border:1px solid rgba(217,107,107,.2)}
.owner-conn-none{background:rgba(255,255,255,.04);color:var(--dim);border:1px solid rgba(255,255,255,.07)}
.owner-retry-warn{font-size:9px;color:#e0a055;margin-left:4px;font-weight:500}

/* Right column: detail */
.owner-detail-col{
  flex:1;min-width:0;overflow-y:auto;padding:18px 20px;
  display:flex;flex-direction:column;gap:0;
}
.owner-detail-col::-webkit-scrollbar{width:4px}
.owner-detail-col::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:2px}

.owner-detail-head{
  display:flex;align-items:flex-start;justify-content:space-between;gap:12px;
  margin-bottom:14px;
}
.owner-detail-title{font-size:16px;font-weight:800;color:var(--text)}
.owner-detail-meta{font-size:11px;color:var(--dim);margin-top:3px}
.owner-detail-err{padding:20px;color:var(--bad);font-size:12px}

/* Map preview */
.owner-map-wrap{
  border-radius:10px;overflow:hidden;
  border:1px solid rgba(255,255,255,.08);
  margin-bottom:16px;max-height:300px;
  background:#090b0d;
  display:flex;align-items:center;justify-content:center;
}
.owner-map-img{width:100%;height:300px;object-fit:cover;display:block}

/* Detail sections */
.owner-dsec{
  border-top:1px solid rgba(255,255,255,.06);
  padding:12px 0;
}
.owner-dsec:first-of-type{border-top:none}
.owner-dsec-title{
  font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--dim);margin-bottom:8px;
}
.owner-server-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:4px}
.owner-srv-name{font-size:12px;color:var(--text);font-weight:600}
.owner-srv-pop{font-size:11px;color:var(--muted)}
.owner-srv-ip{font-size:11px;color:var(--dim);font-family:monospace;margin-top:2px}
.owner-retry-info{font-size:11px;color:#e0a055;margin-top:4px}

/* Lists */
.owner-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:3px}
.owner-team-row,.owner-dbm-row,.owner-death-row{
  display:flex;align-items:center;gap:8px;
  padding:5px 8px;border-radius:6px;
  background:rgba(255,255,255,.02);
  font-size:12px;
}
.owner-team-row:hover,.owner-dbm-row:hover,.owner-death-row:hover{background:rgba(255,255,255,.04)}
.owner-tname{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text)}
.owner-tstatus{font-size:10px;color:var(--dim);flex-shrink:0}
.owner-empty{padding:8px;font-size:11px;color:var(--dim)}
.owner-skull{font-size:11px;flex-shrink:0}

.owner-tdot{
  width:7px;height:7px;border-radius:50%;flex-shrink:0;
}
.tdot-on{background:var(--good);box-shadow:0 0 5px var(--good)}
.tdot-dead{background:var(--bad)}
.tdot-off{background:var(--dim)}

/* DB member avatars */
.owner-dbm-av{
  width:22px;height:22px;border-radius:50%;object-fit:cover;flex-shrink:0;
}
.owner-dbm-init{
  background:rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;
  font-size:10px;font-weight:700;color:var(--muted);
}
.owner-role-badge{
  font-size:9px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  padding:1px 6px;border-radius:3px;flex-shrink:0;
}
.role-leader{background:rgba(217,107,62,.15);color:var(--accent-hi);border:1px solid rgba(217,107,62,.3)}
.role-member{background:rgba(255,255,255,.06);color:var(--dim);border:1px solid rgba(255,255,255,.08)}
.role-guest{background:rgba(109,169,217,.1);color:var(--info);border:1px solid rgba(109,169,217,.2)}

/* Stats row */
.owner-stats-row{display:flex;gap:16px;flex-wrap:wrap;padding:4px 0}
.owner-stats-item{
  display:flex;flex-direction:column;align-items:center;gap:2px;
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);
  border-radius:8px;padding:10px 18px;min-width:70px;
}
.owner-stats-item>span:last-child{font-size:10px;color:var(--dim);text-transform:uppercase;letter-spacing:.07em}
.osv{font-size:20px;font-weight:800;color:var(--text);font-variant-numeric:tabular-nums}

/* Live Map button */
.owner-act-live{
  text-decoration:none;
  border-color:rgba(109,199,123,.25)!important;
  color:var(--good)!important;
  background:rgba(109,199,123,.07)!important;
  font-weight:700;
}
.owner-act-live:hover{
  background:rgba(109,199,123,.16)!important;
  border-color:rgba(109,199,123,.45)!important;
}

/* Steam profile link */
.owner-steam-link{
  display:inline-flex;align-items:center;gap:4px;
  padding:2px 7px;border-radius:4px;font-size:10px;font-weight:600;
  color:#7ba7d4;border:1px solid rgba(109,152,196,.2);
  background:rgba(109,152,196,.07);text-decoration:none;
  transition:.15s;flex-shrink:0;margin-left:auto;
}
.owner-steam-link:hover{
  color:#a8c8f0;border-color:rgba(109,152,196,.45);
  background:rgba(109,152,196,.15);
}
/* inline steam icon in live team — icon only, no text */
.owner-team-row .owner-steam-link{padding:2px 5px}

/* CSP note: Steam avatars use external domains — owner panel uses
   referrerpolicy="no-referrer" on img tags to avoid leaking referrer */

/* ── Entities panel ────────────────────────────────────── */
.ent-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:5px;}
.ent-empty{font-size:11px;color:var(--muted);line-height:1.6;padding:6px 2px;}
/* Card base */
.ent-card{display:flex;align-items:center;justify-content:space-between;gap:8px;
  padding:9px 10px;border-radius:8px;border:1px solid rgba(255,255,255,.07);
  background:rgba(255,255,255,.03);transition:border-color .2s;}
.ent-card-on{border-color:rgba(109,199,123,.25);background:rgba(109,199,123,.04);}
.ent-card-alert{border-color:rgba(248,113,113,.3);background:rgba(248,113,113,.05);}
/* Left side */
.ent-card-left{display:flex;align-items:center;gap:9px;min-width:0;flex:1;}
.ent-card-icon{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0;
  background:rgba(255,255,255,.07);color:var(--muted);}
.ent-switch .ent-card-icon{background:rgba(109,199,123,.12);color:#6dc77b;}
.ent-card-on .ent-card-icon{background:rgba(109,199,123,.22);color:#6dc77b;}
.ent-alarm .ent-card-icon{background:rgba(251,146,60,.1);color:#fb923c;}
.ent-card-alert .ent-card-icon{background:rgba(248,113,113,.2);color:#f87171;}
.ent-storage .ent-card-icon{background:rgba(96,165,250,.1);color:#60a5fa;}
.ent-card-info{min-width:0;}
.ent-card-name{font-size:12px;font-weight:600;color:var(--fg);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:110px;}
.ent-card-type{font-size:10px;color:var(--muted);margin-top:1px;}
/* Right side */
.ent-card-right{display:flex;align-items:center;gap:6px;flex-shrink:0;}
.ent-card-right-col{flex-direction:column;align-items:flex-end;gap:4px;}
/* Pills */
.ent-pill{font-size:10px;font-weight:700;padding:2px 7px;border-radius:20px;letter-spacing:.03em;}
.ent-pill-dim{background:rgba(255,255,255,.06);color:var(--muted);}
.ent-pill-on{background:rgba(109,199,123,.18);color:#6dc77b;}
.ent-pill-off{background:rgba(255,255,255,.07);color:var(--muted);}
.ent-pill-ok{background:rgba(109,199,123,.14);color:#6dc77b;}
.ent-pill-alert{background:rgba(248,113,113,.18);color:#f87171;animation:ent-pulse 1.4s ease infinite;}
@keyframes ent-pulse{0%,100%{opacity:1;}50%{opacity:.6;}}
/* Pill toggle (switch) */
.ent-pill-toggle{display:flex;align-items:center;gap:6px;background:none;border:none;cursor:pointer;padding:3px 0;}
.ent-pill-track{position:relative;width:30px;height:16px;border-radius:8px;background:rgba(255,255,255,.12);transition:.2s;flex-shrink:0;}
.ent-pill-toggle.on .ent-pill-track{background:#3d7a4a;}
.ent-pill-thumb{position:absolute;top:2px;left:2px;width:12px;height:12px;border-radius:50%;background:#888;transition:.2s;}
.ent-pill-toggle.on .ent-pill-thumb{left:16px;background:#6dc77b;}
.ent-pill-label{font-size:10px;font-weight:700;color:var(--muted);min-width:20px;}
.ent-pill-toggle.on .ent-pill-label{color:#6dc77b;}
.ent-pill-toggle:disabled,.ent-pill-toggle.ent-pill-busy{opacity:.5;cursor:default;}
/* Storage bar */
.ent-storage-row{display:flex;align-items:center;gap:6px;}
.ent-storage-count{font-size:11px;font-weight:600;color:var(--fg);}
.ent-tc{font-size:10px;font-weight:700;color:#6dc77b;}
.ent-tc.ent-tc-no{color:rgba(248,113,113,.7);}
.ent-bar-wrap{width:72px;height:4px;border-radius:2px;background:rgba(255,255,255,.08);}
.ent-bar{height:100%;border-radius:2px;transition:width .4s;}
/* Delete button */
.ent-del{display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:4px;
  background:transparent;border:none;color:rgba(255,255,255,.2);cursor:pointer;padding:0;flex-shrink:0;}
.ent-del:hover{color:#f87171;background:rgba(248,113,113,.1);}

/* ── Entity pair request dialog ────────────────────────── */
.pair-ent-dlg{border:1px solid rgba(255,255,255,.12);border-radius:12px;background:#1a1c22;padding:0;width:340px;max-width:90vw;box-shadow:0 8px 40px rgba(0,0,0,.6);}
.pair-ent-dlg::backdrop{background:rgba(0,0,0,.5);backdrop-filter:blur(3px);}
.pair-ent-header{display:flex;align-items:center;gap:12px;padding:18px 20px 12px;}
.pair-ent-ping{font-size:26px;animation:pair-ping 1s ease infinite alternate;}
@keyframes pair-ping{from{opacity:.5;transform:scale(.95);}to{opacity:1;transform:scale(1.05);}}
.pair-ent-title{font-size:14px;font-weight:700;color:var(--fg);}
.pair-ent-sub{font-size:11px;color:var(--muted);margin-top:2px;}
.pair-ent-body{padding:0 20px 16px;}
.pair-ent-label{display:block;font-size:10px;font-weight:600;color:var(--muted);letter-spacing:.05em;text-transform:uppercase;margin-bottom:6px;}
.pair-ent-input{width:100%;box-sizing:border-box;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:6px;color:var(--fg);font-size:13px;padding:8px 10px;outline:none;}
.pair-ent-input:focus{border-color:rgba(109,199,123,.5);background:rgba(255,255,255,.09);}
.pair-ent-actions{display:flex;gap:8px;padding:0 20px 18px;justify-content:flex-end;}
.pair-ent-btn{padding:7px 16px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;border:none;}
.pair-ent-btn-ghost{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);color:var(--muted);}
.pair-ent-btn-ghost:hover{background:rgba(255,255,255,.12);color:var(--fg);}
.pair-ent-btn-primary{background:#3d7a4a;color:#fff;border:1px solid rgba(109,199,123,.3);}
.pair-ent-btn-primary:hover{background:#4a9459;}
.pair-ent-btn-primary:disabled{opacity:.5;cursor:default;}
.pair-ent-dlg{width:400px;}
.pair-ent-label-icon{margin-top:12px;}
.pair-ent-opt{font-weight:400;text-transform:none;letter-spacing:0;color:rgba(255,255,255,.3);font-size:9px;margin-left:4px;}
.pair-ent-icon-search-row{display:flex;align-items:center;gap:8px;margin-bottom:6px;}
.pair-ent-icon-sel{flex-shrink:0;width:34px;height:34px;border-radius:6px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;overflow:hidden;}
.pair-ent-icon-sel img{width:28px;height:28px;object-fit:contain;}
.pair-ent-icon-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:4px;max-height:140px;overflow-y:auto;padding-right:2px;}
.pair-ent-icon-grid::-webkit-scrollbar{width:4px;}
.pair-ent-icon-grid::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:2px;}
.pair-ent-icon-item{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:5px;padding:3px;cursor:pointer;display:flex;align-items:center;justify-content:center;aspect-ratio:1;transition:background .12s,border-color .12s;}
.pair-ent-icon-item:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2);}
.pair-ent-icon-item.selected{background:rgba(109,199,123,.15);border-color:rgba(109,199,123,.5);}
.pair-ent-icon-item img{width:100%;height:100%;object-fit:contain;}
.ent-item-icon{width:22px;height:22px;object-fit:contain;}
.ent-icon-edit{background:none;border:none;padding:2px;cursor:pointer;color:var(--muted);opacity:.5;display:flex;align-items:center;justify-content:center;border-radius:3px;transition:opacity .15s,color .15s;}
.ent-icon-edit:hover{opacity:1;color:var(--fg);background:rgba(255,255,255,.08);}

/* === UPDATE OVERLAY === */
.update-overlay{position:fixed;inset:0;z-index:9999;background:rgba(8,10,12,.88);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;}
.update-overlay.hidden{display:none;}
.update-overlay-box{display:flex;flex-direction:column;align-items:center;gap:16px;padding:40px 48px;background:#14171a;border:1px solid rgba(255,255,255,.1);border-radius:16px;box-shadow:0 24px 80px rgba(0,0,0,.7);max-width:360px;text-align:center;}
.update-overlay-spinner{width:36px;height:36px;border:3px solid rgba(255,255,255,.08);border-top-color:var(--accent-hi);border-radius:50%;animation:uo-spin .9s linear infinite;}
@keyframes uo-spin{to{transform:rotate(360deg)}}
.update-overlay-title{font-size:16px;font-weight:700;color:#f0e6d2;letter-spacing:.02em;}
.update-overlay-sub{font-size:12.5px;color:var(--muted);line-height:1.6;}
.update-overlay-dots{display:flex;gap:6px;}
.update-overlay-dots span{width:6px;height:6px;border-radius:50%;background:var(--accent);opacity:.3;animation:uo-dot 1.2s ease-in-out infinite;}
.update-overlay-dots span:nth-child(2){animation-delay:.2s;}
.update-overlay-dots span:nth-child(3){animation-delay:.4s;}
@keyframes uo-dot{0%,80%,100%{opacity:.2;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}

/* === CAMERA POPUP === */
.cam-backdrop{
  position:fixed;inset:0;z-index:599;
  background:rgba(0,0,0,.6);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
}
.cam-popup{
  position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);
  z-index:600;width:min(920px,calc(100vw - 24px));
  background:#0e1114;border:1px solid #1f2428;
  border-radius:8px;box-shadow:0 20px 60px rgba(0,0,0,.7),0 0 0 1px rgba(255,255,255,.03);
  display:flex;flex-direction:column;overflow:hidden;
}
.cam-hidden{display:none}

/* Header */
.cam-hdr{
  display:flex;align-items:center;gap:10px;
  padding:11px 14px;border-bottom:1px solid #1a1e22;
  flex-shrink:0;
}
.cam-hdr-left{display:flex;align-items:center;gap:8px;min-width:0}
.cam-dot{
  width:8px;height:8px;border-radius:50%;flex-shrink:0;
  background:#2d3339;border:1px solid #3a4148;
  transition:background .3s,box-shadow .3s;
}
.cam-dot--connecting{
  background:#c8941a;border-color:#c8941a;
  animation:cam-pulse 1s ease-in-out infinite;
}
.cam-dot--live{
  background:#3dba6a;border-color:#3dba6a;
  box-shadow:0 0 6px #3dba6a80;
}
@keyframes cam-pulse{0%,100%{opacity:1}50%{opacity:.35}}
.cam-hdr-title{
  font-size:11px;font-weight:700;letter-spacing:.1em;
  color:#5a6370;text-transform:uppercase;flex-shrink:0;
}
.cam-hdr-camname{
  font-size:12px;font-weight:600;color:var(--accent-hi);
  font-family:ui-monospace,monospace;letter-spacing:.05em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.cam-hdr-hint{font-size:10px;color:#3e4750;font-style:italic;flex:1;text-align:center}
.cam-hdr-close{
  background:none;border:none;color:#3e4750;cursor:pointer;
  font-size:13px;padding:3px 5px;border-radius:4px;line-height:1;
  transition:color .15s,background .15s;flex-shrink:0;
}
.cam-hdr-close:hover{color:#c8cdd2;background:rgba(255,255,255,.06)}

/* Saved cameras */
.cam-saved-list{
  display:flex;align-items:center;gap:6px;
  padding:8px 12px;border-bottom:1px solid #1a1e22;
  overflow-x:auto;flex-shrink:0;scrollbar-width:none;
}
.cam-saved-list:empty,.cam-saved-list[hidden]{display:none}
.cam-saved-list::-webkit-scrollbar{display:none}
.cam-chip{
  display:flex;align-items:stretch;flex-shrink:0;
  border-radius:5px;overflow:hidden;
  border:1px solid #252b31;background:#141820;
  transition:border-color .15s;
}
.cam-chip:hover{border-color:#2e353d}
.cam-chip-btn{
  padding:5px 11px;background:transparent;color:#8d9aa6;
  border:none;cursor:pointer;font-size:11px;font-family:ui-monospace,monospace;
  letter-spacing:.04em;font-weight:500;
  transition:color .12s,background .12s;white-space:nowrap;
}
.cam-chip-btn:hover{color:#f08550;background:rgba(240,133,80,.07)}
.cam-chip-rm{
  display:flex;align-items:center;padding:0 7px;background:transparent;color:#2e353d;
  border:none;border-left:1px solid #1e2428;cursor:pointer;font-size:9px;
  transition:color .12s,background .12s;
}
.cam-chip-rm:hover{color:#d96b6b;background:rgba(217,107,107,.12)}

/* Viewport */
.cam-viewport{
  position:relative;background:#000;aspect-ratio:16/9;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;flex-shrink:0;
}
.cam-viewport::after{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:2;
  background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(0,0,0,.06) 3px,rgba(0,0,0,.06) 4px);
}
.cam-img{display:block;width:100%;height:100%;object-fit:contain;image-rendering:pixelated;position:relative;z-index:1}
.cam-msg{
  display:flex;flex-direction:column;align-items:center;gap:10px;
  color:#2d353e;text-align:center;padding:24px;pointer-events:none;
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  z-index:3;width:100%;
}
.cam-msg[hidden]{display:none}
.cam-msg span{font-size:12px;color:#3a4450;letter-spacing:.02em}
.cam-msg-err span{color:#a05050}
.cam-hud{
  position:absolute;bottom:10px;left:12px;z-index:4;
  display:flex;gap:8px;pointer-events:none;
}
.cam-hud-fps,.cam-hud-dims{
  font-size:10px;font-family:ui-monospace,monospace;
  color:rgba(255,255,255,.35);background:rgba(0,0,0,.4);
  padding:2px 6px;border-radius:3px;letter-spacing:.04em;
}
.cam-mouse-active{cursor:crosshair}
.cam-dragging{cursor:grabbing!important}

/* Bottom bar */
.cam-bar{
  display:flex;align-items:center;gap:6px;
  padding:10px 12px;border-top:1px solid #1a1e22;flex-shrink:0;
}
.cam-bar input{
  flex:1;padding:8px 12px;font-size:12px;
  background:#0a0d10;border:1px solid #1e2428;
  border-radius:5px;color:#c8cdd2;outline:none;
  transition:border-color .15s;font-family:ui-monospace,monospace;
  letter-spacing:.04em;
}
.cam-bar input:focus{border-color:#3a4450}
.cam-bar-save{
  height:34px;padding:0 10px;gap:5px;display:flex;align-items:center;justify-content:center;
  background:#0a0d10;border:1px solid #1e2428;border-radius:5px;
  color:#3a4450;cursor:pointer;flex-shrink:0;font-size:11px;white-space:nowrap;
  transition:border-color .15s,color .15s,background .15s;
}
.cam-bar-save:hover{border-color:var(--accent);color:var(--accent-hi);background:var(--accent-soft)}
.cam-bar-save--saved{border-color:#3dba6a!important;color:#3dba6a!important;background:rgba(61,186,106,.1)!important}
.cam-bar-connect{
  padding:0 18px;height:34px;
  background:var(--accent-soft);border:1px solid var(--accent);color:var(--accent-hi);
  border-radius:5px;cursor:pointer;font-weight:600;font-size:11.5px;
  transition:background .15s,color .15s;white-space:nowrap;flex-shrink:0;
}
.cam-bar-connect:hover{background:var(--accent);color:#fff}
.cam-bar-connect:disabled{opacity:.4;cursor:default}
.cam-bar-disc{
  padding:0 14px;height:34px;
  background:rgba(217,107,107,.1);border:1px solid #5a2828;color:#a05050;
  border-radius:5px;cursor:pointer;font-size:11px;font-weight:600;
  transition:background .15s,border-color .15s,color .15s;white-space:nowrap;flex-shrink:0;
}
.cam-bar-disc:hover{background:rgba(217,107,107,.25);border-color:var(--bad);color:var(--bad)}

/* Sidebar "Cameras" button */
.btn-camera{
  background:none;border:1px solid var(--border);color:var(--muted);
  border-radius:var(--r-sm);padding:2px 8px;cursor:pointer;font-size:10px;
  margin-left:auto;transition:border-color .15s,color .15s;
}
.btn-camera:hover{border-color:var(--accent);color:var(--accent-hi)}

/* ── Twitch Drops map overlay ──────────────────────────────── */
.drops-overlay {
  position: absolute;
  top: 12px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 120;
  display: flex;
  align-items: center;
  background: rgba(20, 8, 40, 0.92);
  border: 1px solid #9146ff66;
  border-radius: 24px;
  backdrop-filter: blur(8px);
  box-shadow: 0 4px 24px rgba(145, 70, 255, 0.2), 0 1px 0 rgba(255,255,255,.04) inset;
  white-space: nowrap;
  overflow: hidden;
}

.drops-content {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 10px 7px 14px;
  text-decoration: none;
  color: #c9b3f5;
  font-size: 12px;
  transition: color .15s;
}
.drops-content:hover { color: #e4d6ff; }

.drops-live-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: #9146ff;
  box-shadow: 0 0 7px #9146ff;
  animation: dropsP 1.6s ease-in-out infinite;
  flex-shrink: 0;
}
@keyframes dropsP {
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.5;transform:scale(.8)}
}

.drops-twitch-icon { color: #9146ff; flex-shrink: 0; }

.drops-text { color: #e0d0ff; }
.drops-text b { color: #bf94ff; }

.drops-countdown {
  font-variant-numeric: tabular-nums;
  font-weight: 700;
  color: #9146ff;
  font-size: 11px;
  min-width: 70px;
}

.drops-cta-pill {
  background: #9146ff;
  color: #fff;
  font-weight: 700;
  font-size: 11px;
  padding: 3px 10px;
  border-radius: 12px;
  transition: background .15s;
}
.drops-content:hover .drops-cta-pill { background: #a970ff; }

.drops-x {
  background: none;
  border: none;
  border-left: 1px solid #9146ff33;
  color: #6040a0;
  font-size: 13px;
  padding: 0 12px;
  cursor: pointer;
  align-self: stretch;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color .15s, background .15s;
}
.drops-x:hover { color: #c9b3f5; background: rgba(145,70,255,.1); }


/* ══════════════════════════════════════════════════════════════
   TOOL APP SHELL — shared design system for all tool iframes
   (raid, breeder, recycler, cameras). Active when .modal-frame
   is on <html>. Keeps tool pages visually consistent and makes
   them feel like a native app inside the tv-viewer modal.
   ══════════════════════════════════════════════════════════════ */

.modal-frame{
  --ts-bg:#0a0d12;
  --ts-surface:#10151c;
  --ts-surface-hi:#141a22;
  --ts-border:#1e2530;
  --ts-border-hi:#2a3645;
  --ts-text:#e2e6ea;
  --ts-muted:#8c95a3;
  --ts-dim:#5a6373;
  --ts-accent:#d96b3e;
  --ts-accent-hi:#f08550;
  --ts-good:#6dc77b;
}

.modal-frame html,
.modal-frame body{
  background:var(--ts-bg)!important;
  color:var(--ts-text);
  font-family:'Rubik',sans-serif;
}

/* Unify all tool shells to fill the iframe edge-to-edge */
.modal-frame .raid-shell,
.modal-frame .breeder-shell,
.modal-frame .rec-shell,
.modal-frame .cam-page{
  max-width:none!important;
  margin:0!important;
  height:100%;
  padding:20px 24px 32px!important;
  background:var(--ts-bg);
}
.modal-frame .breeder-shell{padding:16px 20px!important;}

/* Shared section heading band — replaces inconsistent per-tool labels */
.modal-frame .section-label,
.modal-frame .card-title,
.modal-frame .b-title{
  font-family:'Rubik',sans-serif;
  font-size:9.5px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.16em;
  color:var(--ts-dim);
}

/* Unified panel cards across all 4 tools */
.modal-frame .raid-card,
.modal-frame .rec-card,
.modal-frame .b-card,
.modal-frame .exp-section,
.modal-frame .type-section{
  background:var(--ts-surface);
  border:1px solid var(--ts-border);
  border-radius:12px;
}

.modal-frame .card-head,
.modal-frame .b-head{
  background:rgba(0,0,0,.18);
  border-bottom:1px solid var(--ts-border);
  padding:10px 16px;
}

/* Hero number (raid result count) — make it pop more */
.modal-frame .res-big{
  font-size:3.6rem;
  color:var(--ts-accent-hi);
  text-shadow:0 0 38px rgba(240,133,80,.45),0 2px 12px rgba(0,0,0,.65);
}

/* Camera chip — bigger touch target, mono font, copy hint */
.modal-frame .cam-chip{
  padding:8px 14px;
  background:var(--ts-surface);
  border:1px solid var(--ts-border);
  border-radius:8px;
}
.modal-frame .cam-chip:hover{
  border-color:var(--ts-accent);
  background:var(--ts-surface-hi);
}
.modal-frame .cam-chip-code{font-size:13px;}

/* Search inputs — unify */
.modal-frame .cam-search-input,
.modal-frame .plant-textarea,
.modal-frame .b-select,
.modal-frame .b-num,
.modal-frame .score-input{
  background:var(--ts-bg);
  border:1px solid var(--ts-border);
  color:var(--ts-text);
}
.modal-frame .cam-search-input:focus,
.modal-frame .plant-textarea:focus,
.modal-frame .b-select:focus,
.modal-frame .b-num:focus,
.modal-frame .score-input:focus{
  border-color:var(--ts-accent);
  box-shadow:0 0 0 2px rgba(217,107,62,.15);
}

/* Explosive selector + recycler type — bigger active glow */
.modal-frame .exp-btn.active,
.modal-frame .type-btn.active{
  border-color:var(--ts-accent);
  background:rgba(217,107,62,.12);
  box-shadow:0 0 0 1px rgba(240,133,80,.3) inset,0 0 28px rgba(217,107,62,.12);
}

/* Result rows — tighter, more uniform */
.modal-frame .res-row,
.modal-frame .sel-row{
  background:var(--ts-surface-hi);
  border:1px solid var(--ts-border);
}

/* Scrollbars across all tool iframes */
.modal-frame *::-webkit-scrollbar{width:8px;height:8px;}
.modal-frame *::-webkit-scrollbar-track{background:transparent;}
.modal-frame *::-webkit-scrollbar-thumb{background:var(--ts-border);border-radius:4px;}
.modal-frame *::-webkit-scrollbar-thumb:hover{background:var(--ts-border-hi);}

/* Hide redundant page-style hero (cameras) inside modal */
.modal-frame .cam-hero{
  margin-bottom:14px;
  padding-bottom:14px;
  border-bottom:1px solid var(--ts-border);
}
.modal-frame .cam-hero-label{display:none;}
.modal-frame .cam-hero-title{font-size:18px;letter-spacing:.01em;}
.modal-frame .cam-hero-sub{font-size:12px;margin-top:4px;}

/* Subtle hover lift on interactive items */
.modal-frame .sc-btn:hover,
.modal-frame .item-btn:hover,
.modal-frame .cam-chip:hover{
  transform:translateY(-2px);
  transition:transform .15s,border-color .15s,background .15s;
}

/* === PHONE ALERTS — topbar NEW badge + modal === */
.tb-new-badge{
  position:absolute;top:-6px;right:-7px;
  background:linear-gradient(180deg,#f0995a,#d96b3e);
  color:#1a0e07;font-size:8.5px;font-weight:800;letter-spacing:.06em;
  padding:2px 5px;border-radius:7px;line-height:1;
  border:1.5px solid #0c0e10;
  box-shadow:0 0 8px rgba(217,107,62,.7);
  animation:pulse 1.6s infinite;
}
.tb-new-badge.is-hidden{display:none}

.alerts-box{max-width:560px}
.alerts-head{
  background:linear-gradient(180deg,rgba(217,107,62,.16),rgba(217,107,62,.03));
}
.alerts-free-tag{
  margin-left:8px;font-size:9.5px;font-weight:800;letter-spacing:.08em;
  color:#0c0e10;background:linear-gradient(180deg,#7ddc8e,#46b563);
  padding:3px 7px;border-radius:6px;
}
.alerts-intro{
  background:rgba(217,107,62,.06);border:1px solid rgba(217,107,62,.16);
  border-radius:10px;padding:11px 13px;margin:0 0 14px;
  color:var(--text);line-height:1.55;
}
.alerts-link-card{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  margin-top:16px;padding:14px;border-radius:12px;
  background:linear-gradient(180deg,#15191e,#101316);
  border:1px solid var(--border);
}
.alerts-link-title{font-weight:700;font-size:13px;color:var(--text);margin-bottom:3px}
.alerts-link-card .sq-save-btn{flex:0 0 auto;white-space:nowrap}
.alerts-note{
  margin:10px 2px 0;font-size:11px;color:var(--muted);font-style:italic;
}
.alerts-box .sq-row-control input:disabled + .track{opacity:.45;cursor:not-allowed}

.alerts-tabs{display:flex;gap:4px;padding:14px 16px 0;border-bottom:1px solid var(--border)}
.alerts-tab{flex:1;padding:8px 10px;border-radius:8px 8px 0 0;border:1px solid transparent;border-bottom:none;background:transparent;color:var(--muted);font-size:12.5px;font-weight:600;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:6px}
.alerts-tab:hover{color:var(--text);background:rgba(255,255,255,.04)}
.alerts-tab.active{background:#0d1117;border-color:var(--border);color:var(--text);margin-bottom:-1px;padding-bottom:9px}
.dc-status-card{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:10px;background:linear-gradient(180deg,#15191e,#101316);border:1px solid var(--border);margin-bottom:14px}
.dc-status-dot{width:9px;height:9px;border-radius:50%;background:#57f287;flex-shrink:0;box-shadow:0 0 6px rgba(87,242,135,.5)}
.dc-status-dot.off{background:var(--muted);box-shadow:none}
.dc-status-info{flex:1;min-width:0}
.dc-status-name{font-size:13px;font-weight:700;color:var(--text)}
.dc-status-sub{font-size:11px;color:var(--muted);margin-top:2px}
.dc-invite-btn{flex:0 0 auto;padding:8px 14px;border-radius:8px;border:none;background:#5865f2;color:#fff;font-size:12px;font-weight:700;cursor:pointer;text-decoration:none;white-space:nowrap;transition:background .15s}
.dc-invite-btn:hover{background:#4752c4}
.dc-code-card{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:13px 14px;border-radius:10px;background:rgba(88,101,242,.07);border:1px solid rgba(88,101,242,.22);margin-bottom:14px}
.dc-code-label{font-size:11px;color:var(--muted);margin-bottom:4px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.dc-code-val{font-family:'JetBrains Mono',monospace;font-size:20px;font-weight:800;color:#7289da;letter-spacing:.06em}
.dc-code-hint{font-size:11px;color:var(--muted);margin-top:4px}
.dc-code-hint code{background:rgba(255,255,255,.07);padding:2px 5px;border-radius:4px;font-size:11px}
.dc-channels-badge{flex:0 0 auto;font-size:11px;color:var(--muted);background:rgba(255,255,255,.06);border:1px solid var(--border);padding:4px 9px;border-radius:6px;white-space:nowrap;align-self:center}
.dc-channels-badge.linked{color:#57f287;border-color:rgba(87,242,135,.25);background:rgba(87,242,135,.06)}

/* =========================================================
   TOPBAR DROPDOWN MENU
   ========================================================= */
.tb-menu-wrap{position:relative}
.tb-menu-trigger.active{background:rgba(217,107,62,.15);border-color:rgba(217,107,62,.5);color:var(--accent-hi)}

.tb-dropdown{
  position:absolute;top:calc(100% + 8px);right:0;
  background:#131619;border:1px solid var(--border);
  border-radius:12px;padding:5px;min-width:168px;
  box-shadow:0 12px 40px rgba(0,0,0,.65);
  z-index:9000;
  animation:ddFadeIn .12s ease;
}
@keyframes ddFadeIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}

.tb-drop-item{
  display:flex;align-items:center;gap:9px;
  width:100%;background:none;border:none;
  color:var(--text);font-size:13px;font-weight:500;
  padding:8px 10px;border-radius:8px;cursor:pointer;
  text-decoration:none;white-space:nowrap;
  transition:background .12s,color .12s;
}
.tb-drop-item:hover{background:rgba(255,255,255,.07);color:#fff}
.tb-drop-item svg{flex-shrink:0;opacity:.7}
.tb-drop-item:hover svg{opacity:1}
.tb-drop-item-danger{color:#e05252}
.tb-drop-item-danger:hover{background:rgba(224,82,82,.12);color:#e05252}

.tb-drop-sep{
  height:1px;background:var(--border);
  margin:4px 0;
}
.tb-drop-label{
  padding:6px 10px 2px;
  font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:var(--dim);pointer-events:none;user-select:none;
}

/* =========================================================
   LEADERBOARD MODAL
   ========================================================= */
.lb-dialog{
  background:#0d1014;color:var(--text);
  border:1px solid rgba(255,255,255,.09);border-radius:18px;
  padding:0;width:min(98vw,1500px);max-width:min(98vw,1500px);max-height:88vh;
  overflow:hidden;
  box-shadow:0 32px 100px rgba(0,0,0,.8);
}
dialog[open].lb-dialog{display:flex;flex-direction:column}
.lb-dialog::backdrop{background:rgba(0,0,0,.72)}

/* Header */
.lb-header{
  display:flex;align-items:center;gap:10px;padding:14px 20px 0;flex-shrink:0;
  border-bottom:1px solid rgba(255,255,255,.07);
  background:linear-gradient(180deg,#131720,#0d1014);
}
.lb-title{margin:0 0 12px;font-size:17px;font-weight:800;letter-spacing:.02em;white-space:nowrap}
.lb-tabs{display:flex;gap:2px;flex:1}
.lb-tab{
  background:none;border:none;border-bottom:3px solid transparent;
  color:var(--muted);font-size:13px;font-weight:600;
  padding:7px 16px 11px;cursor:pointer;transition:color .13s,border-color .13s;white-space:nowrap;
}
.lb-tab:hover{color:var(--text)}
.lb-tab.active{color:#7ddc8e;border-bottom-color:#7ddc8e}
.lb-close{
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  border-radius:8px;color:var(--muted);cursor:pointer;
  font-size:15px;line-height:1;padding:6px 10px;margin-bottom:12px;flex-shrink:0;
  transition:background .13s,color .13s;
}
.lb-close:hover{background:rgba(255,255,255,.11);color:#fff}

/* Body */
.lb-body{
  overflow-y:auto;overflow-x:hidden;padding:18px 22px 24px;flex:1;min-height:0;
  scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent;
}

/* Shared states */
.lb-loading,.lb-empty,.lb-error{text-align:center;padding:48px 20px;color:var(--muted);font-size:13px}
.lb-error{color:#e05252}
.lb-warn{color:#f0995a;font-weight:600}
.lb-danger{color:#e05252;font-weight:600}
.lb-good{color:#7ddc8e;font-weight:600}

/* Wipe info strip */
.lbv-strip{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  font-size:12px;color:var(--muted);margin-bottom:18px;
  padding:9px 14px;background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.07);border-radius:10px;
}
.lbv-strip strong{color:var(--text);font-weight:700}
.lbv-dot{opacity:.3}
.lbv-partial{
  color:#f0a04b;font-weight:600;
  background:rgba(240,160,75,.1);border:1px solid rgba(240,160,75,.25);
  border-radius:5px;padding:1px 7px;font-size:11px;
}

/* Horizontal bar */
.lbv-bar{
  height:5px;background:rgba(255,255,255,.07);border-radius:3px;
  overflow:hidden;margin:8px 0;
}
.lbv-bar-fill{height:100%;border-radius:3px;transition:width .4s cubic-bezier(.4,0,.2,1)}

/* ── Podium ─────────────────── */
.lbv-podium{display:flex;gap:14px;margin-bottom:22px}
.lbv-pod{
  flex:1;min-width:0;
  background:linear-gradient(145deg,rgba(255,255,255,.04),rgba(255,255,255,.01));
  border:1px solid rgba(255,255,255,.08);border-radius:14px;
  padding:18px 16px 14px;position:relative;overflow:hidden;
  transition:transform .15s;
}
.lbv-pod::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--mc);border-radius:14px 14px 0 0;
}
.lbv-pod:hover{transform:translateY(-2px)}
.lbv-pod-medal{
  font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  color:var(--mc);margin-bottom:12px;
}
.lbv-pod-av{width:52px;height:52px;border-radius:50%;overflow:hidden;margin-bottom:10px;border:2px solid var(--mc);box-shadow:0 0 14px color-mix(in srgb,var(--mc) 40%,transparent)}
.lbv-pod-av img{width:100%;height:100%;object-fit:cover}
.lbv-pod-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.06);font-size:20px;font-weight:800;color:var(--mc)}
.lbv-pod-name{font-size:14px;font-weight:700;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lbv-pod-dist{font-size:22px;font-weight:800;color:var(--mc);letter-spacing:-.5px;margin-bottom:4px}
.lbv-chips{display:flex;flex-wrap:wrap;gap:5px;margin-top:10px}

/* Stat chips */
.lbv-chip{
  display:flex;flex-direction:column;align-items:center;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);
  border-radius:7px;padding:4px 8px;min-width:44px;
}
.lbv-chip-val{font-size:12px;font-weight:700;color:var(--text);line-height:1.2}
.lbv-chip-lbl{font-size:9px;color:var(--muted);letter-spacing:.04em;text-transform:uppercase;line-height:1.2}
.lbv-chip-warn{border-color:rgba(240,153,90,.3);background:rgba(240,153,90,.08)}
.lbv-chip-warn .lbv-chip-val{color:#f0995a}
.lbv-chip-danger{border-color:rgba(224,82,82,.3);background:rgba(224,82,82,.08)}
.lbv-chip-danger .lbv-chip-val{color:#e05252}

/* ── Table ──────────────────── */
.lbv-tbl{width:100%;border-collapse:collapse;font-size:13px}
.lbv-tbl th{
  text-align:left;padding:8px 12px;
  color:var(--muted);font-size:10.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
  border-bottom:1px solid rgba(255,255,255,.07);white-space:nowrap;
}
.lbv-tbl td{padding:8px 12px;border-bottom:1px solid rgba(255,255,255,.04);vertical-align:middle}
.lbv-tbl tbody tr:last-child td{border-bottom:none}
.lbv-tbl tbody tr:hover td{background:rgba(255,255,255,.03)}
.lbv-tbl-sm td,.lbv-tbl-sm th{padding:5px 10px;font-size:12px}
.lbv-rank{color:var(--muted);font-weight:700;width:32px}
.lbv-bar-cell{width:120px}
.lbv-player{display:flex;align-items:center;gap:8px;min-width:0}
.lbv-player span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.lbv-av{width:26px;height:26px;border-radius:50%;object-fit:cover;border:1px solid rgba(255,255,255,.12);flex-shrink:0}
.lbv-av-ph{width:26px;height:26px;border-radius:50%;background:rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;flex-shrink:0}
.lbv-row-danger td{background:rgba(224,82,82,.07)}
.lbv-row-danger:hover td{background:rgba(224,82,82,.12)}

/* ── Zones ──────────────────── */
.lbv-zones{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:14px}
.lbv-zone-card{
  background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.07);
  border-radius:12px;overflow:hidden;
}
.lbv-zone-hero{
  display:flex;align-items:center;gap:14px;
  padding:14px 16px;position:relative;
}
.lbv-zone-ico{
  width:44px;height:44px;flex-shrink:0;
  border-radius:10px;padding:8px;
  background:rgba(0,0,0,.25);
  filter:drop-shadow(0 2px 6px rgba(0,0,0,.5));
}
.lbv-zone-hero-info{flex:1;min-width:0}
.lbv-zone-name{font-weight:700;font-size:14px;color:#fff;line-height:1.3}
.lbv-zone-meta{font-size:11px;color:rgba(255,255,255,.65);margin-top:3px}
.lbv-zone-card .lbv-tbl{margin:0}
.lbv-safe{
  display:inline-block;font-size:9px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;
  color:#7ddc8e;background:rgba(125,220,142,.15);border:1px solid rgba(125,220,142,.3);
  border-radius:4px;padding:1px 5px;margin-left:6px;vertical-align:middle;
}
.lbv-mon-ico{display:inline-block;vertical-align:middle}

/* ── Timeline ───────────────── */
.lbv-tl-summary{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap}
.lbv-tl-stat{
  display:flex;flex-direction:column;align-items:center;
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);
  border-radius:10px;padding:12px 18px;min-width:100px;
}
.lbv-tl-stat-danger{border-color:rgba(224,82,82,.3) !important;background:rgba(224,82,82,.07) !important}
.lbv-tl-stat-val{font-size:24px;font-weight:800;line-height:1}
.lbv-tl-stat-lbl{font-size:10px;color:var(--muted);margin-top:5px;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}
.lbv-day-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));
  gap:6px;margin-bottom:22px;
}
.lbv-day-cell{
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);
  border-radius:8px;padding:9px 6px;text-align:center;
}
.lbv-day-hot{border-color:rgba(255,60,60,.55) !important;box-shadow:0 0 10px rgba(255,60,60,.15)}
.lbv-day-num{font-size:10px;font-weight:700;color:var(--muted);margin-bottom:5px;letter-spacing:.03em}
.lbv-day-visits{font-size:18px;font-weight:800;line-height:1;color:#fff}
.lbv-day-deaths{font-size:10px;margin-top:4px;color:#e05252;font-weight:600}
.lbv-day-clean{color:var(--dim) !important;font-weight:400}
.lbv-tl-deaths{margin-bottom:18px}
.lbv-tl-prow{display:grid;grid-template-columns:140px 1fr 36px;align-items:center;gap:10px;margin-bottom:7px}
.lbv-tl-prow .lbv-bar{margin:0}
.lbv-tl-pname{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lbv-tl-pval{font-size:12px;font-weight:700;text-align:right}
.lbv-tbl-scroll{overflow-x:auto}

/* ── Social ─────────────────── */
.lbv-social{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.lbv-social-col{}
.lbv-sec-hdr{font-size:11px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.07)}
.lbv-pair{margin-bottom:12px}
.lbv-pair-names{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:5px}
.lbv-pair-bar-row{display:flex;align-items:center;gap:8px}
.lbv-pair-bar-row .lbv-bar{flex:1;margin:0}
.lbv-pair-time{font-size:11px;color:var(--muted);white-space:nowrap}
.lbv-amp{color:var(--muted);margin:0 4px}
.lbv-fv-list{display:flex;flex-direction:column;gap:8px}
.lbv-fv-row{display:flex;align-items:center;gap:10px;padding:7px 10px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:8px}
.lbv-fv-info{flex:1;min-width:0}
.lbv-fv-zone{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lbv-fv-player{font-size:11px;color:var(--muted);margin-top:2px}
.lbv-fv-time{color:var(--dim)}

/* === SHOP ALERT TOAST === */
.shop-alert-toast{
  position:fixed;bottom:80px;right:16px;
  background:#1a2a1a;border:1px solid #4ade80;
  color:#fff;padding:10px 16px;border-radius:8px;
  font-size:13px;max-width:320px;z-index:9999;
  opacity:0;transform:translateY(8px);
  transition:opacity .3s,transform .3s;
  pointer-events:none;
}
.shop-alert-toast--show{opacity:1;transform:translateY(0)}

/* === SHOP WATCH BUTTON === */
.ss-watch-btn{
  display:block;width:100%;margin-bottom:8px;
  background:rgba(74,222,128,.08);
  border:1px solid rgba(74,222,128,.3);
  color:#4ade80;padding:6px 12px;border-radius:6px;
  font-size:12px;font-weight:600;cursor:pointer;
  transition:background .15s,border-color .15s;
  text-align:left;
}
.ss-watch-btn:hover{background:rgba(74,222,128,.15);border-color:rgba(74,222,128,.5)}
.ss-watch-btn--on{
  background:rgba(74,222,128,.18);
  border-color:#4ade80;
}
