: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:hidden;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-events{
  color:var(--good);font-weight:600;
  border-color:rgba(109,199,123,.2);
  background:rgba(109,199,123,.06);
}
.tb-chip-events:empty{display:none}

/* 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-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}
.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}
#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);
}

/* === 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:3px;
  max-height:240px;min-height:120px;overflow:auto;
  background:var(--bg);border:1px solid var(--border-soft);
  border-radius:var(--r-sm);padding:8px 10px;font-size:12px;line-height:1.45;
}
.chat .msg .auth{color:var(--accent-hi);font-weight:600;margin-right:5px;font-size:10.5px}
.chat .msg.rust .auth{color:var(--info)}
.chat .msg .t{color:var(--muted);font-size:10px;margin-right:5px;font-variant-numeric:tabular-nums;font-family:ui-monospace,monospace}
.chatform{display:flex;gap:5px;margin-top:8px;align-items:center}
.chatform input[type="text"], .chatform input:not([type]){flex:1;padding:7px 10px;font-size:12px}
.chatform .bridgechk{font-size:10px;color:var(--muted);display:flex;gap:4px;align-items:center;cursor:pointer}
.chatform button{
  background:var(--accent-soft);border:1px solid var(--accent);color:var(--accent-hi);
  border-radius:var(--r-sm);padding:6px 12px;cursor:pointer;font-weight:600;font-size:11px;
}
.chatform button:hover{background:var(--accent);color:#fff}

/* === 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-popup{
  position:fixed;top:52px;right:12px;z-index:60;
  width:340px;
  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{position:relative}
.notepad-has-update::after{
  content:'';position:absolute;top:4px;right:4px;
  width:7px;height:7px;border-radius:50%;
  background:var(--accent,#d96b3e);
}

/* === 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 === */
@media (max-width:1024px){
  .layout{grid-template-columns:1fr}
  .sidebar{display:none}
  .sidebar.left.open,.sidebar.right.open{display:block;position:absolute;inset:52px 0 0 0;width:100%;z-index:4}
  .icon-grid{grid-template-columns:repeat(8,1fr)}
  .swatch-grid{grid-template-columns:repeat(11,1fr)}
}

/* === 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;
}

/* ─── 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}

.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)}
.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-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)}
.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)}

/* === 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{
  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-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: 7px;
  padding: 8px 13px 8px 10px;
  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;
  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, box-shadow .15s;
  letter-spacing: .03em;
}
.shop-search-fab:hover {
  border-color: rgba(255,255,255,.18);
  background: rgba(20,24,30,.95);
  color: var(--text, #c8d0d8);
  box-shadow: 0 4px 16px rgba(0,0,0,.6);
}
.shop-search-fab.active {
  border-color: rgba(217,107,62,.5);
  color: var(--accent-hi, #f08550);
  background: rgba(217,107,62,.1);
  box-shadow: 0 2px 12px rgba(217,107,62,.2);
}

.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-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{display:flex;flex-direction:column;gap:5px;padding:6px 10px 10px}
.sb-card{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.07);
  border-left:3px solid var(--sb-accent,var(--accent));
  border-radius:6px;overflow:hidden;
}
.sb-head{
  display:flex;align-items:center;gap:7px;
  padding:7px 10px 5px;
}
.sb-emoji{font-size:14px;line-height:1;flex-shrink:0}
.sb-name{flex:1;font-size:11.5px;font-weight:700;color:#d4cfc8}
.sb-badge{
  font-size:9px;font-weight:800;letter-spacing:.08em;
  padding:2px 7px;border-radius:10px;flex-shrink:0;
}
.sb-on{background:rgba(109,199,123,.15);color:#6dc77b;border:1px solid rgba(109,199,123,.25)}
.sb-off{background:rgba(255,255,255,.04);color:var(--dim);border:1px solid rgba(255,255,255,.08)}
.sb-rows{padding:0 10px 8px;display:flex;flex-direction:column;gap:2px}
.sb-row{
  display:flex;align-items:baseline;gap:6px;
  font-size:11px;
}
.sb-key{color:var(--dim);flex-shrink:0;min-width:80px}
.sb-val{color:var(--muted);font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10.5px}
.sb-none{font-size:10.5px;color:var(--dim);padding-top:2px}
.sb-timer{
  color:#ffb169;font-weight:700;
  font-family:'JetBrains Mono',ui-monospace,monospace;
}
.sb-avail{
  color:#6dc77b;font-weight:800;letter-spacing:.04em;
}
.sb-unlocked{
  color:var(--muted);font-style:italic;
}
.sb-icon-img{
  width:18px;height:18px;flex-shrink:0;object-fit:contain;
  filter:brightness(0) invert(0.8);
  opacity:.9;
}

/* ── 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 */
