/* ============================================
   HACKER // ONLINE - CRT Cyberpunk Aesthetic
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Share+Tech+Mono&family=Press+Start+2P&display=swap');

:root {
  --bg-dark: #0b0e14;
  --bg-panel: #111820;
  --bg-panel-hover: #1a2230;
  --border-dim: #2a3a50;
  --border-glow: #00ff41;
  --neon-green: #00ff41;
  --neon-cyan: #00d4ff;
  --neon-magenta: #ff0080;
  --neon-amber: #ffb000;
  --neon-red: #ff2d2d;
  --neon-purple: #bf5fff;
  --text-dim: #6a7a90;
  --text-normal: #a8bdd4;
  --text-bright: #d4dde8;
  --text-white: #edf2f7;
  --font-body: 'Share Tech Mono', 'Courier New', monospace;
  --font-heading: 'Press Start 2P', monospace;
  --glow-green: 0 0 10px rgba(0,255,65,0.3), 0 0 20px rgba(0,255,65,0.1);
  --glow-cyan: 0 0 10px rgba(0,212,255,0.3), 0 0 20px rgba(0,212,255,0.1);
  --glow-magenta: 0 0 10px rgba(255,0,128,0.3), 0 0 20px rgba(255,0,128,0.1);
  /* Player colors */
  --player-green: #00ff41;
  --player-blue: #00d4ff;
  --player-purple: #bf5fff;
  --player-yellow: #ffdd00;
  --player-orange: #ff8c00;
  --player-red: #ff2d2d;
}

* { margin: 0; padding: 0; box-sizing: border-box; }

html, body {
  width: 100%; height: 100%;
  overflow: hidden;
  background: var(--bg-dark);
  color: var(--text-normal);
  font-family: var(--font-body);
  font-size: 15px;
  line-height: 1.45;
}

/* === CRT EFFECTS === */
#crt-overlay {
  position: fixed; top: 0; left: 0; right: 0; bottom: 0;
  pointer-events: none; z-index: 9999;
  background: radial-gradient(ellipse at center, transparent 50%, rgba(0,0,0,0.4) 100%);
}

#scanlines {
  position: fixed; top: 0; left: 0; right: 0; bottom: 0;
  pointer-events: none; z-index: 9998;
  background: repeating-linear-gradient(
    0deg,
    transparent,
    transparent 2px,
    rgba(0,0,0,0.08) 2px,
    rgba(0,0,0,0.08) 4px
  );
}

/* === SCREENS === */
.screen { display: none; width: 100%; height: 100%; }
.screen.active { display: flex; }

/* === SCROLLBAR === */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--bg-dark); }
::-webkit-scrollbar-thumb { background: var(--border-dim); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--neon-green); }

/* === PANELS === */
.panel {
  background: var(--bg-panel);
  border: 1px solid var(--border-dim);
  border-radius: 4px;
  padding: 12px;
  position: relative;
}
.panel::before {
  content: '';
  position: absolute; top: -1px; left: 10px; right: 10px; height: 1px;
  background: linear-gradient(90deg, transparent, var(--neon-green), transparent);
  opacity: 0.4;
}
.panel h2, .panel h3 {
  font-family: var(--font-heading);
  font-size: 11px;
  color: var(--neon-green);
  text-shadow: var(--glow-green);
  margin-bottom: 10px;
  letter-spacing: 1px;
}
/* Bottom-bar panels get more padding */
#bottom-bar .panel { padding: 14px 18px; }
#bottom-bar .panel h3 { margin-bottom: 10px; font-size: 12px; }

/* === BUTTONS === */
.neon-btn {
  font-family: var(--font-body);
  font-size: 14px;
  padding: 10px 24px;
  background: transparent;
  color: var(--neon-green);
  border: 1px solid var(--neon-green);
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: 2px;
  transition: all 0.2s;
  position: relative;
  overflow: hidden;
}
.neon-btn:hover {
  background: rgba(0,255,65,0.1);
  box-shadow: var(--glow-green);
  text-shadow: var(--glow-green);
}
.neon-btn:active {
  background: rgba(0,255,65,0.2);
  transform: scale(0.98);
}
.neon-btn.secondary {
  color: var(--neon-cyan);
  border-color: var(--neon-cyan);
}
.neon-btn.secondary:hover {
  background: rgba(0,212,255,0.1);
  box-shadow: var(--glow-cyan);
}
.neon-btn.danger {
  color: var(--neon-red);
  border-color: var(--neon-red);
}
.neon-btn.danger:hover {
  background: rgba(255,45,45,0.1);
  box-shadow: 0 0 10px rgba(255,45,45,0.3);
}
.neon-btn.small {
  padding: 4px 12px;
  font-size: 12px;
}
.neon-btn:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}

/* === INPUTS === */
input[type="text"], select {
  font-family: var(--font-body);
  font-size: 14px;
  padding: 8px 12px;
  background: rgba(0,0,0,0.5);
  color: var(--neon-green);
  border: 1px solid var(--border-dim);
  outline: none;
  width: 100%;
  transition: border-color 0.2s;
}
input[type="text"]:focus, select:focus {
  border-color: var(--neon-green);
  box-shadow: 0 0 5px rgba(0,255,65,0.2);
}
input[type="text"]::placeholder {
  color: var(--text-dim);
  font-style: italic;
}
select {
  cursor: pointer;
}
select option {
  background: var(--bg-dark);
  color: var(--text-normal);
}
input[type="checkbox"] {
  accent-color: var(--neon-green);
  cursor: pointer;
}

.form-group {
  margin-bottom: 12px;
}
.form-group label {
  display: block;
  font-size: 11px;
  color: var(--neon-cyan);
  margin-bottom: 4px;
  text-transform: uppercase;
  letter-spacing: 1px;
}
.checkbox-group {
  display: flex;
  gap: 16px;
}
.checkbox-group label {
  display: flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  color: var(--text-normal);
}

/* === LOBBY SCREEN === */
#lobby-screen {
  justify-content: center;
  align-items: center;
}
.lobby-container {
  max-width: 900px;
  width: 100%;
  padding: 20px;
}
.logo-container {
  text-align: center;
  margin-bottom: 30px;
}
.logo {
  width: 200px;
  height: auto;
  margin-bottom: 10px;
  filter: drop-shadow(0 0 20px rgba(0,255,65,0.3));
  animation: float 3s ease-in-out infinite;
}
@keyframes float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-8px); }
}

/* Glitch text effect */
.glitch-text {
  font-family: var(--font-heading);
  font-size: 20px;
  color: var(--neon-green);
  text-shadow: var(--glow-green);
  position: relative;
  animation: glitch-skew 4s infinite linear alternate-reverse;
}
.glitch-text::before,
.glitch-text::after {
  content: attr(data-text);
  position: absolute;
  top: 0; left: 0; right: 0;
  overflow: hidden;
}
.glitch-text::before {
  color: var(--neon-cyan);
  animation: glitch-1 2s infinite linear alternate-reverse;
  clip-path: polygon(0 0, 100% 0, 100% 45%, 0 45%);
}
.glitch-text::after {
  color: var(--neon-magenta);
  animation: glitch-2 3s infinite linear alternate-reverse;
  clip-path: polygon(0 60%, 100% 60%, 100% 100%, 0 100%);
}
@keyframes glitch-1 {
  0%, 90% { transform: translate(0); }
  92% { transform: translate(-2px, 1px); }
  94% { transform: translate(2px, -1px); }
  96% { transform: translate(-1px, 2px); }
  98% { transform: translate(1px); }
}
@keyframes glitch-2 {
  0%, 85% { transform: translate(0); }
  87% { transform: translate(2px, -1px); }
  90% { transform: translate(-2px, 1px); }
  93% { transform: translate(1px, -2px); }
  96% { transform: translate(-1px); }
}
@keyframes glitch-skew {
  0%, 95% { transform: skew(0deg); }
  96% { transform: skew(0.5deg); }
  97% { transform: skew(-0.3deg); }
  98% { transform: skew(0.2deg); }
  99% { transform: skew(0deg); }
}

.subtitle {
  font-family: var(--font-body);
  color: var(--text-dim);
  font-size: 12px;
  letter-spacing: 4px;
  margin-top: 8px;
}

.lobby-panels {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-bottom: 20px;
}

/* Game list */
.game-list {
  max-height: 200px;
  overflow-y: auto;
  margin-bottom: 12px;
}
.scanning {
  color: var(--text-dim);
  font-style: italic;
  animation: blink 1.5s infinite;
}
@keyframes blink {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.3; }
}
.game-list-item {
  padding: 8px 12px;
  border: 1px solid var(--border-dim);
  margin-bottom: 4px;
  cursor: pointer;
  transition: all 0.2s;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.game-list-item:hover {
  border-color: var(--neon-cyan);
  background: rgba(0,212,255,0.05);
}
.game-list-item .game-host { color: var(--neon-cyan); }
.game-list-item .game-players { color: var(--text-dim); font-size: 12px; }

/* Waiting Room */
#waiting-room {
  max-width: 500px;
  margin: 0 auto;
}
.game-code {
  text-align: center;
  font-family: var(--font-heading);
  font-size: 24px;
  color: var(--neon-amber);
  text-shadow: 0 0 20px rgba(255,176,0,0.5);
  padding: 15px;
  border: 1px dashed var(--neon-amber);
  margin-bottom: 20px;
  letter-spacing: 6px;
}
.player-list {
  margin-bottom: 20px;
}
.player-entry {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  border-bottom: 1px solid var(--border-dim);
}
.player-color-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  flex-shrink: 0;
}
.player-entry .player-name { color: var(--text-bright); flex: 1; }
.player-entry .player-role {
  font-size: 10px;
  color: var(--neon-amber);
  font-family: var(--font-heading);
}
.waiting-actions {
  display: flex;
  gap: 12px;
  justify-content: center;
}

/* === GAME SCREEN === */
#game-screen { overflow: hidden; }
.game-layout {
  display: grid;
  grid-template-areas:
    "topbar topbar topbar"
    "net net sidebar"
    "bottom bottom sidebar";
  grid-template-rows: 56px 1fr 340px;
  grid-template-columns: 1fr 1fr 360px;
  width: 100%;
  height: 100vh;
  gap: 2px;
  padding: 2px;
}

/* Top Bar */
#top-bar {
  grid-area: topbar;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 16px;
  padding: 0 0 0 12px;
  background: var(--bg-panel);
  border-bottom: 1px solid var(--border-dim);
}
#top-bar #player-stats {
  justify-content: center;
}

/* Forfeit button — Windows-style X in the top-right corner */
#btn-forfeit {
  align-self: stretch;
  width: 52px;
  height: 100%;
  border: none;
  border-left: 1px solid var(--border-dim);
  background: transparent;
  color: var(--text-dim);
  font-family: var(--font-body);
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
  display: flex;
  align-items: center;
  justify-content: center;
}
#btn-forfeit:hover {
  background: var(--neon-red);
  color: #fff;
  box-shadow: inset 0 0 24px rgba(255,45,45,0.4);
}

/* Victory banner shown in the GAME OVER modal */
.victory-banner {
  font-family: var(--font-heading);
  font-size: 32px;
  color: var(--neon-green);
  letter-spacing: 8px;
  text-shadow:
    0 0 10px rgba(0,255,65,0.8),
    0 0 24px rgba(0,255,65,0.4);
  margin-bottom: 14px;
}
.victory-names {
  font-size: 18px;
  color: var(--text-bright);
  margin-bottom: 6px;
  font-weight: bold;
}
.victory-sub {
  color: var(--text-dim);
  font-size: 13px;
  letter-spacing: 2px;
}

/* End-of-game statistics table */
.endgame-stats { padding: 4px; }
.endgame-stats .eg-head {
  text-align: center;
  margin-bottom: 14px;
}
.endgame-stats .eg-trophy {
  font-size: 40px;
  line-height: 1;
  filter: drop-shadow(0 0 14px rgba(255,221,0,0.7));
  margin-bottom: 6px;
}
.endgame-stats .eg-title {
  font-family: var(--font-heading);
  font-size: 14px;
  color: var(--neon-green);
  letter-spacing: 4px;
  text-shadow: var(--glow-green);
}
.endgame-stats .eg-scroll {
  max-height: 60vh;
  overflow: auto;
}
.endgame-stats .eg-table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--font-body);
  font-size: 12px;
}
.endgame-stats .eg-table th {
  font-family: var(--font-heading);
  font-size: 9px;
  color: var(--neon-cyan);
  letter-spacing: 0.8px;
  text-align: center;
  padding: 8px 6px;
  border-bottom: 1px solid var(--border-dim);
  background: rgba(0,212,255,0.05);
  position: sticky;
  top: 0;
  text-transform: uppercase;
  white-space: nowrap;
}
.endgame-stats .eg-table td {
  padding: 8px 6px;
  border-bottom: 1px dashed rgba(42,58,80,0.5);
  vertical-align: middle;
}
.endgame-stats .eg-table td.num {
  text-align: center;
  color: var(--text-bright);
  font-variant-numeric: tabular-nums;
  font-size: 13px;
}
.endgame-stats .eg-table td.num .pct {
  display: block;
  font-size: 10px;
  color: var(--text-dim);
  margin-top: 1px;
}
.endgame-stats .eg-table tr.stat-row.is-winner td {
  background: rgba(0,255,65,0.06);
}
.endgame-stats .eg-table tr.stat-row:hover td {
  background: rgba(255,255,255,0.03);
}
.endgame-stats .sr-player {
  display: flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
}
.endgame-stats .sr-name { font-weight: bold; }
.endgame-stats .stat-dot {
  display: inline-block;
  width: 10px; height: 10px;
  border-radius: 50%;
}
.endgame-stats .stat-badge {
  display: inline-block;
  font-family: var(--font-heading);
  font-size: 8px;
  padding: 2px 6px;
  border-radius: 2px;
  letter-spacing: 1px;
  margin-left: 4px;
}
.endgame-stats .stat-badge.winner {
  background: rgba(0,255,65,0.15);
  border: 1px solid var(--neon-green);
  color: var(--neon-green);
}
.endgame-stats .stat-badge.forfeit {
  background: rgba(255,176,0,0.12);
  border: 1px solid var(--neon-amber);
  color: var(--neon-amber);
}
.endgame-stats .stat-badge.eliminated {
  background: rgba(255,45,45,0.12);
  border: 1px solid var(--neon-red);
  color: var(--neon-red);
}
/* Wider modal when it contains the stats table */
#modal-content:has(.endgame-stats) { max-width: 900px !important; }

/* Forfeit confirmation modal */
.forfeit-modal { text-align: center; padding: 4px; }
.forfeit-modal .forfeit-title {
  font-family: var(--font-heading);
  font-size: 14px;
  color: var(--neon-red);
  letter-spacing: 3px;
  text-shadow: 0 0 10px rgba(255,45,45,0.7);
  margin-bottom: 14px;
}
.forfeit-modal .forfeit-body {
  font-size: 14px;
  color: var(--text-bright);
  line-height: 1.6;
  margin-bottom: 10px;
}
.forfeit-modal .forfeit-warn {
  font-size: 13px;
  color: var(--neon-amber);
  margin-top: 12px;
  padding: 8px 10px;
  border: 1px dashed var(--neon-amber);
  border-radius: 3px;
  background: rgba(255,176,0,0.06);
}
#turn-info {
  display: flex;
  align-items: center;
  gap: 16px;
}
#current-player {
  font-family: var(--font-heading);
  font-size: 12px;
}
.phase-badge {
  background: rgba(0,255,65,0.1);
  border: 1px solid var(--neon-green);
  color: var(--neon-green);
  padding: 4px 12px;
  font-size: 13px;
  letter-spacing: 1px;
}
#hacks-remaining {
  color: var(--neon-amber);
  font-size: 14px;
}
#player-stats {
  display: flex;
  gap: 12px;
}
.player-stat {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 14px;
  padding: 5px 12px;
  border: 1px solid var(--border-dim);
  border-radius: 3px;
  background: rgba(255,255,255,0.02);
}
.player-stat .stat-dot {
  width: 10px; height: 10px;
  border-radius: 50%;
}
.player-stat .stat-name { color: var(--text-normal); }
.player-stat .stat-count { color: var(--text-white); font-weight: bold; }
.player-stat.is-current { border-color: var(--neon-green); background: rgba(0,255,65,0.05); }

/* Net Container */
#net-container {
  grid-area: net;
  background: var(--bg-dark);
  overflow: hidden;
  position: relative;
  border: 1px solid var(--border-dim);
}
#net-canvas {
  width: 100%;
  height: 100%;
  cursor: crosshair;
}
.tooltip {
  position: absolute;
  background: rgba(13,17,23,0.95);
  border: 1px solid var(--neon-cyan);
  padding: 8px 12px;
  font-size: 12px;
  z-index: 100;
  pointer-events: none;
  max-width: 250px;
  box-shadow: var(--glow-cyan);
}

/* Sidebar */
#sidebar {
  grid-area: sidebar;
  display: flex;
  flex-direction: column;
  gap: 2px;
  overflow-y: auto;
}
#action-panel { flex: 0 0 auto; }
#dice-panel { flex: 0 0 auto; }
#info-panel { flex: 1; overflow-y: auto; }

#action-buttons {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.action-btn {
  font-family: var(--font-body);
  font-size: 15px;
  padding: 12px 16px;
  background: rgba(255,255,255,0.02);
  color: var(--neon-cyan);
  border: 1px solid var(--border-dim);
  cursor: pointer;
  text-align: left;
  transition: all 0.15s;
}
.action-btn:hover {
  border-color: var(--neon-cyan);
  background: rgba(0,212,255,0.05);
}
.action-btn.primary {
  border-color: var(--neon-green);
  color: var(--neon-green);
}
.action-btn.primary:hover {
  background: rgba(0,255,65,0.1);
}
.action-btn:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}
.action-btn.backup-btn {
  border-color: var(--neon-amber);
  color: var(--neon-amber);
  font-size: 13px;
  padding: 8px 12px;
  margin-bottom: 6px;
}
.action-btn.backup-btn:hover:not(:disabled) {
  background: rgba(255,176,0,0.08);
  box-shadow: 0 0 10px rgba(255,176,0,0.3);
}
.action-btn.backup-btn:disabled {
  border-color: var(--border-dim);
  color: var(--text-dim);
  opacity: 0.55;
}

/* Dice */
#dice-display {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 8px 0;
}
.dice {
  width: 56px; height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-heading);
  font-size: 22px;
  color: var(--text-white);
  background: var(--bg-dark);
  border: 2px solid var(--neon-cyan);
  border-radius: 6px;
}
.dice.rolling {
  animation: dice-spin 0.1s infinite;
  border-color: var(--neon-amber);
}
@keyframes dice-spin {
  0% { transform: rotate(0deg) scale(1); }
  25% { transform: rotate(5deg) scale(1.05); }
  50% { transform: rotate(-3deg) scale(0.95); }
  75% { transform: rotate(2deg) scale(1.02); }
}
.dice.success { border-color: var(--neon-green); color: var(--neon-green); }
.dice.failure { border-color: var(--neon-red); color: var(--neon-red); }
#dice-total {
  font-size: 24px;
  font-weight: bold;
  color: var(--text-dim);
  min-width: 36px;
  text-align: center;
}
#dice-result {
  text-align: center;
  font-size: 14px;
  min-height: 20px;
}

/* System Info */
#system-details .dim { color: var(--text-normal); font-style: italic; }
#system-details { font-size: 14px; }
.sys-name { color: var(--neon-cyan); font-size: 17px; font-weight: bold; margin-bottom: 4px; }
.sys-security { color: var(--neon-amber); font-size: 15px; }
.sys-ice { color: var(--neon-red); font-size: 15px; }
.sys-net { color: var(--neon-purple); font-size: 15px; }
.sys-type { color: var(--text-bright); font-size: 14px; }
.sys-accounts { margin-top: 6px; }

/* Bottom Bar */
#bottom-bar {
  grid-area: bottom;
  display: grid;
  grid-template-columns: 340px 1fr var(--log-width, 340px);
  gap: 2px;
  position: relative;
}
#log-resize-handle {
  position: absolute;
  top: 0; bottom: 0; left: -4px;
  width: 8px;
  cursor: ew-resize;
  z-index: 20;
  background: transparent;
  transition: background 0.15s;
}
#log-resize-handle:hover,
#log-resize-handle.dragging {
  background: rgba(0, 212, 255, 0.4);
  box-shadow: 0 0 12px rgba(0,212,255,0.5);
}
#log-chat-panel { position: relative; }

/* Localhost name (renamable) */
.localhost-name {
  cursor: pointer;
  transition: color 0.2s;
  border-bottom: 1px dashed rgba(0,255,65,0.3);
  padding-bottom: 1px;
}
.localhost-name:hover {
  color: var(--neon-cyan);
  border-bottom-color: var(--neon-cyan);
}
.localhost-name-input {
  font-family: var(--font-heading);
  font-size: 10px;
  color: var(--neon-green);
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--neon-green);
  outline: none;
  width: 120px;
  letter-spacing: 1px;
}

/* Console (localhost) */
#console-panel {
  overflow: visible; /* allow hover-zoom to pop out */
}
#console-display {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.console-slot {
  flex: 1;
  text-align: center;
  padding: 14px 10px;
  border: 1px solid var(--border-dim);
  border-radius: 4px;
  font-size: 14px;
  background: rgba(255,255,255,0.02);
  transition: all 0.25s ease;
  position: relative;
  cursor: default;
  min-height: 86px;
}
.console-slot.modem { border-top: 3px solid var(--player-yellow); }
.console-slot.system { border-top: 3px solid var(--neon-cyan); }
.console-slot.expansion { border-top: 3px solid var(--neon-red); }
.console-slot .slot-label {
  font-size: 11px;
  color: var(--text-normal);
  text-transform: uppercase;
  margin-bottom: 8px;
  letter-spacing: 1px;
}
.console-slot .slot-value {
  color: var(--text-white);
  font-size: 15px;
  font-weight: bold;
}
.console-slot.empty .slot-value { color: var(--text-dim); font-style: italic; font-weight: normal; }
.console-slot .slot-detail {
  font-size: 11px;
  color: var(--neon-green);
  margin-top: 5px;
  opacity: 0.75;
}
.console-slot.empty .slot-detail { color: var(--text-dim); opacity: 0.5; }

/* Console slot hover zoom */
.console-slot:hover {
  transform: scale(1.15) translateY(-8px);
  z-index: 20;
  background: var(--bg-panel-hover);
  border-color: var(--neon-cyan);
  box-shadow: 0 8px 24px rgba(0,0,0,0.6), var(--glow-cyan);
}
.console-slot.modem:hover { border-color: var(--player-yellow); box-shadow: 0 8px 24px rgba(0,0,0,0.6), 0 0 10px rgba(255,221,0,0.3); }
.console-slot.expansion:hover { border-color: var(--neon-red); box-shadow: 0 8px 24px rgba(0,0,0,0.6), 0 0 10px rgba(255,45,45,0.3); }

/* Hand — flexbox with cards on left, preview box on right */
#hand-panel {
  display: flex;
  flex-direction: column;
  position: relative;
}
#hand-cards {
  display: flex;
  gap: 6px;
  overflow-x: auto;
  padding: 4px;
  align-items: stretch;
  flex: 1;
}
#hand-count { color: var(--text-normal); font-family: var(--font-body); }

/* Card preview box (right side of hand area) */
.hand-preview-box {
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  width: 230px;
  background: var(--bg-panel-hover);
  border-left: 1px solid var(--border-dim);
  padding: 12px;
  overflow-y: auto;
  font-size: 14px;
  z-index: 5;
}
.hpb-name {
  color: var(--neon-cyan);
  font-size: 16px;
  font-weight: bold;
  margin-bottom: 8px;
}
.hpb-stats { margin-bottom: 4px; }

/* Mini hand cards — uniform small size */
.hand-card-mini {
  flex-shrink: 0;
  width: 110px;
  height: 88px;
  padding: 8px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border-dim);
  border-radius: 4px;
  cursor: pointer;
  transition: all 0.15s ease;
  font-size: 11px;
  overflow: hidden;
  position: relative;
}
.hand-card-mini:hover {
  border-color: var(--neon-cyan);
  background: rgba(0,212,255,0.06);
}
.hand-card-mini .hcm-name {
  color: var(--text-bright);
  font-size: 11px;
  font-weight: bold;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-bottom: 4px;
}
.hand-card-mini .hcm-stats {
  display: flex;
  gap: 8px;
  font-size: 11px;
}
.hand-card-mini .hcm-sec { color: var(--neon-amber); }
.hand-card-mini .hcm-ice { color: var(--neon-red); }
.hand-card-mini .hcm-type {
  position: absolute;
  bottom: 3px;
  right: 5px;
  font-size: 8px;
  color: var(--text-dim);
  font-weight: bold;
}

/* Draggable cards (setup + drawn) */
.hand-card-draggable {
  border-color: var(--neon-green) !important;
  background: rgba(0,255,65,0.08) !important;
  cursor: grab !important;
  animation: pulse-border 1.5s ease-in-out infinite;
}
.hand-card-draggable:hover {
  border-color: var(--neon-green) !important;
  background: rgba(0,255,65,0.14) !important;
  box-shadow: 0 0 8px rgba(0,255,65,0.3);
}
.hand-card-draggable:active { cursor: grabbing !important; }
.hand-card-draggable .hcm-name { color: var(--neon-green); }

/* Link indicator SVG on hand cards */
.hcm-link-ind {
  position: absolute;
  bottom: 3px;
  left: 5px;
  opacity: 0.85;
}

/* Modal canvas card preview */
#modal-card-canvas {
  border: 1px solid var(--border-dim);
  border-radius: 4px;
  background: #0b0e14;
}

/* Pending placement overlay buttons on the net */
#pending-placement-controls {
  position: absolute;
  display: flex;
  gap: 6px;
  z-index: 100;
  pointer-events: auto;
  transform: translate(-50%, 0);
}
.pending-btn {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: bold;
  padding: 6px 14px;
  background: rgba(11, 14, 20, 0.95);
  border: 2px solid;
  border-radius: 4px;
  cursor: pointer;
  letter-spacing: 1px;
  transition: all 0.15s;
  text-transform: uppercase;
}
.pending-btn.confirm {
  color: var(--neon-green);
  border-color: var(--neon-green);
  box-shadow: 0 0 10px rgba(0,255,65,0.4);
}
.pending-btn.confirm:hover {
  background: rgba(0,255,65,0.15);
  box-shadow: 0 0 16px rgba(0,255,65,0.7);
}
.pending-btn.undo {
  color: var(--neon-red);
  border-color: var(--neon-red);
  box-shadow: 0 0 10px rgba(255,45,45,0.4);
}
.pending-btn.undo:hover {
  background: rgba(255,45,45,0.15);
  box-shadow: 0 0 16px rgba(255,45,45,0.7);
}

.pending-btn.undo-soft {
  color: var(--neon-amber);
  border-color: var(--neon-amber);
  box-shadow: 0 0 8px rgba(255,176,0,0.3);
}
.pending-btn.undo-soft:hover {
  background: rgba(255,176,0,0.15);
  box-shadow: 0 0 12px rgba(255,176,0,0.6);
}

/* Net Ninja indicators */
.ninja-star {
  color: var(--neon-amber);
  font-size: 14px;
  text-shadow: 0 0 8px rgba(255,176,0,0.8), 0 0 16px rgba(255,176,0,0.4);
  animation: ninja-pulse 1.8s ease-in-out infinite;
  margin-right: 2px;
}
.player-stat.is-ninja {
  border-color: var(--neon-amber);
  background: rgba(255,176,0,0.06);
  box-shadow: 0 0 8px rgba(255,176,0,0.3);
}
@keyframes ninja-pulse {
  0%, 100% { text-shadow: 0 0 8px rgba(255,176,0,0.8), 0 0 16px rgba(255,176,0,0.4); }
  50%      { text-shadow: 0 0 14px rgba(255,176,0,1), 0 0 24px rgba(255,176,0,0.7); }
}

/* Net Ninja badge on the player's own localhost panel */
.ninja-badge {
  position: absolute;
  top: 8px;
  right: 10px;
  padding: 3px 9px;
  background: linear-gradient(90deg, rgba(255,176,0,0.2), rgba(255,176,0,0.08));
  border: 1px solid var(--neon-amber);
  border-radius: 3px;
  font-family: var(--font-heading);
  font-size: 9px;
  color: var(--neon-amber);
  text-shadow: 0 0 8px rgba(255,176,0,0.7);
  letter-spacing: 1.5px;
  animation: ninja-pulse 1.8s ease-in-out infinite;
  z-index: 5;
}
.ninja-badge .nb-star { margin-right: 4px; font-size: 10px; }

/* Upgrade Store modal */
#modal-content { max-width: 700px !important; }
.store-container { font-size: 12px; }
.store-heading {
  font-family: var(--font-heading);
  font-size: 10px;
  color: var(--neon-green);
  text-shadow: var(--glow-green);
  margin: 12px 0 6px;
  letter-spacing: 2px;
}
.store-console { margin-bottom: 14px; }
.store-slots-row {
  display: flex; gap: 8px;
  padding: 8px; background: rgba(255,255,255,0.02);
  border: 1px solid var(--border-dim); border-radius: 4px;
}
.store-slot-current {
  flex: 1; text-align: center; padding: 8px 6px;
  background: rgba(0,212,255,0.04);
  border: 1px solid var(--border-dim); border-radius: 3px;
}
.store-slot-current.empty { opacity: 0.5; }
.store-slot-current .ssc-label {
  font-size: 9px; color: var(--text-dim); text-transform: uppercase;
  letter-spacing: 1px; margin-bottom: 4px;
}
.store-slot-current .ssc-value {
  font-size: 12px; color: var(--text-white); font-weight: bold;
}
.store-shelves { max-height: 450px; overflow-y: auto; }
.store-shelf {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 10px; margin-bottom: 12px;
}
.store-item {
  background: rgba(255,255,255,0.03);
  border: 2px solid var(--border-dim);
  border-radius: 4px;
  padding: 10px;
  position: relative;
  transition: all 0.15s ease;
  cursor: pointer;
}
.store-item.available:hover {
  background: rgba(0,255,65,0.08);
  transform: translateY(-2px);
  box-shadow: 0 4px 14px rgba(0,0,0,0.5), 0 0 10px rgba(0,255,65,0.25);
}
.store-item.unavailable {
  opacity: 0.45;
  cursor: not-allowed;
  filter: grayscale(0.5);
}
.store-item .si-name {
  font-weight: bold; font-size: 13px; margin-bottom: 2px;
}
.store-item .si-slot {
  font-size: 9px; color: var(--text-dim);
  letter-spacing: 1.5px; margin-bottom: 6px;
}
.store-item .si-desc {
  font-size: 11px; color: var(--text-normal); line-height: 1.3; margin-bottom: 6px;
}
.store-item .si-req {
  font-size: 10px; color: var(--neon-amber); margin-bottom: 4px;
}
.store-item .si-stock {
  font-size: 10px; color: var(--neon-green); font-weight: bold;
}
.store-item .si-stock.out { color: var(--neon-red); }
.store-item .si-blocked {
  font-size: 10px; color: var(--neon-red); margin-top: 4px;
  font-style: italic;
}

/* Path mode overlay banner */
#path-mode-overlay {
  position: absolute;
  top: 12px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 100;
  pointer-events: auto;
}
.path-banner {
  background: rgba(11, 14, 20, 0.95);
  border: 2px solid;
  border-radius: 6px;
  padding: 10px 18px;
  min-width: 340px;
  text-align: center;
}
.path-banner .path-title {
  font-family: var(--font-heading);
  font-size: 11px;
  letter-spacing: 2px;
  margin-bottom: 4px;
}
.path-banner .path-info {
  font-family: var(--font-body);
  font-size: 11px;
  color: var(--text-normal);
  margin-bottom: 8px;
}
.path-banner .path-btns {
  display: flex;
  gap: 8px;
  justify-content: center;
}

/* v2 path banner — step-driven selection UI */
.path-banner-v2 {
  background: rgba(11, 14, 20, 0.96);
  border: 2px solid var(--neon-red);
  border-radius: 6px;
  padding: 12px 22px;
  min-width: 360px;
  max-width: 520px;
  text-align: center;
  box-shadow: 0 0 20px rgba(255,45,45,0.35),
              0 4px 14px rgba(0,0,0,0.6);
}
.path-banner-v2 .path-banner-step {
  font-family: var(--font-heading);
  font-size: 9px;
  letter-spacing: 2px;
  color: var(--neon-red);
  text-shadow: 0 0 8px rgba(255,45,45,0.6);
  margin-bottom: 5px;
}
.path-banner-v2 .path-banner-main {
  font-family: var(--font-body);
  font-size: 15px;
  color: var(--text-white);
  margin-bottom: 4px;
  letter-spacing: 0.5px;
}
.path-banner-v2 .path-banner-main b {
  color: var(--neon-red);
  letter-spacing: 1.5px;
}
.path-banner-v2 .path-banner-sub {
  font-size: 12px;
  color: var(--text-dim);
  letter-spacing: 0.3px;
}

/* DIAL / CANCEL overlay pinned beneath the hack target */
#hack-target-controls {
  position: absolute;
  display: flex;
  gap: 8px;
  z-index: 120;
  pointer-events: auto;
  transform: translate(-50%, 0);
}
#hack-target-controls .pending-btn {
  font-size: 13px;
  padding: 8px 18px;
  font-weight: bold;
}
#hack-target-controls .pending-btn[disabled] {
  box-shadow: none;
}

@keyframes pulse-border {
  0%, 100% { border-color: var(--neon-green); }
  50% { border-color: rgba(0,255,65,0.4); }
}

/* Log / Chat */
#log-chat-panel {
  display: flex;
  flex-direction: column;
}
.tab-bar {
  display: flex;
  gap: 2px;
  margin-bottom: 8px;
}
.tab {
  font-family: var(--font-heading);
  font-size: 9px;
  padding: 6px 14px;
  background: rgba(255,255,255,0.02);
  color: var(--text-normal);
  border: 1px solid var(--border-dim);
  cursor: pointer;
  transition: all 0.2s;
}
.tab.active {
  color: var(--neon-green);
  border-color: var(--neon-green);
  background: rgba(0,255,65,0.05);
}
.tab-content { display: none; flex: 1; overflow-y: auto; }
.tab-content.active { display: block; }

#game-log, #chat-messages {
  font-size: 12px;
  line-height: 1.6;
  max-height: 200px;
  overflow-y: auto;
}
.log-entry { padding: 2px 0; border-bottom: 1px solid rgba(255,255,255,0.04); color: var(--text-normal); }
.log-entry.system { color: var(--neon-amber); }
.log-entry.phase { color: var(--neon-cyan); }
.log-entry.hack { color: var(--neon-green); }
.log-entry.danger { color: var(--neon-red); }
.log-entry.turn { color: var(--neon-magenta); font-weight: bold; margin-top: 6px; }
.log-entry.info { color: var(--text-bright); }
.log-time { color: var(--text-dim); font-size: 11px; margin-right: 6px; }

.chat-input {
  display: flex;
  gap: 4px;
  margin-top: 6px;
}
.chat-input input { flex: 1; }
.chat-msg { padding: 2px 0; }
.chat-msg .chat-name { font-weight: bold; }

/* Modal */
#modal-overlay {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.8);
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
}
#modal-content {
  max-width: 500px;
  width: 90%;
  max-height: 80vh;
  overflow-y: auto;
}
#modal-actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  margin-top: 16px;
}

/* Notifications */
#notification-container {
  position: fixed;
  top: 20px;
  right: 20px;
  z-index: 5000;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.notification {
  padding: 10px 16px;
  background: var(--bg-panel);
  border-left: 3px solid var(--neon-green);
  font-size: 12px;
  animation: notif-in 0.3s ease-out;
  max-width: 350px;
}
.notification.error { border-color: var(--neon-red); color: var(--neon-red); }
.notification.warning { border-color: var(--neon-amber); color: var(--neon-amber); }
@keyframes notif-in {
  from { opacity: 0; transform: translateX(50px); }
  to { opacity: 1; transform: translateX(0); }
}

/* Bust tokens (handcuffs) — pinned to the bottom-left of the net so
 * they're always visible but don't crowd the console panel. */
.bust-tokens {
  position: absolute;
  left: 12px;
  bottom: 12px;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 5px 12px 5px 10px;
  background: linear-gradient(180deg, #2a0606 0%, #140303 100%);
  border: 1px solid var(--neon-red);
  border-radius: 3px;
  box-shadow: 0 0 10px rgba(255,45,45,0.5), 0 2px 6px rgba(0,0,0,0.6);
  z-index: 15;
  font-family: var(--font-heading);
}
.bust-tokens .bust-label {
  font-size: 9px;
  color: var(--neon-red);
  letter-spacing: 1.5px;
  text-shadow: 0 0 6px rgba(255,45,45,0.8);
}
.bust-tokens .bust-row { display: flex; gap: 2px; }
.bust-tokens .bust-cuff {
  font-size: 18px;
  line-height: 1;
  filter: drop-shadow(0 0 4px rgba(255,45,45,0.7));
}
.bust-tokens .bust-cuff.empty { opacity: 0.18; filter: grayscale(1); }
.bust-tokens .bust-count {
  font-size: 10px;
  color: var(--neon-red);
  letter-spacing: 1px;
  font-weight: bold;
}

/* Raid defense cards list inside the RAIDED modal */
.raid-defense-head {
  font-family: var(--font-heading);
  font-size: 10px;
  color: var(--neon-cyan);
  letter-spacing: 2px;
  margin: 14px 0 6px;
  text-align: center;
}
.raid-defense-list {
  display: flex; flex-direction: column; gap: 4px;
  max-height: 200px; overflow: auto;
}
.raid-defense-btn {
  display: block;
  width: 100%;
  text-align: left;
  padding: 8px 12px;
  background: rgba(0,212,255,0.06);
  color: var(--text-bright);
  border: 1px solid var(--border-dim);
  border-left: 3px solid var(--neon-cyan);
  border-radius: 2px;
  cursor: pointer;
  font-family: var(--font-body);
  transition: background 0.15s, border-color 0.15s;
}
.raid-defense-btn:hover {
  background: rgba(0,212,255,0.14);
  border-color: var(--neon-cyan);
}
.raid-defense-btn .rd-name {
  display: block;
  color: var(--neon-cyan);
  font-weight: bold;
  font-size: 13px;
  margin-bottom: 2px;
}
.raid-defense-btn .rd-desc {
  display: block;
  color: var(--text-normal);
  font-size: 11px;
  line-height: 1.4;
}

/* Chat mentions + unread tab pulse */
.chat-mention {
  background: rgba(255,176,0,0.14);
  border-radius: 2px;
  padding: 0 4px;
  font-weight: bold;
}
.tab.has-unread {
  color: var(--neon-red);
  border-color: var(--neon-red);
  animation: chat-pulse 0.9s ease-in-out infinite;
}
@keyframes chat-pulse {
  0%, 100% { box-shadow: 0 0 0 rgba(255,45,45,0.0); }
  50%      { box-shadow: 0 0 14px rgba(255,45,45,0.7), inset 0 0 6px rgba(255,45,45,0.4); }
}

/* @mention autocomplete popup */
#chat-mention-popup {
  position: fixed;
  display: none;
  z-index: 2050;
  min-width: 180px;
  background: rgba(11,14,20,0.98);
  border: 1px solid var(--neon-cyan);
  border-radius: 4px;
  padding: 4px;
  box-shadow: 0 0 14px rgba(0,212,255,0.35), 0 4px 14px rgba(0,0,0,0.6);
  font-family: var(--font-body);
}
#chat-mention-popup .cm-row {
  display: flex; align-items: center; gap: 8px;
  padding: 4px 8px; border-radius: 2px;
  font-size: 13px; cursor: pointer;
}
#chat-mention-popup .cm-row.sel { background: rgba(0,212,255,0.14); }
#chat-mention-popup .cm-row:hover { background: rgba(0,212,255,0.1); }
#chat-mention-popup .cm-dot {
  width: 10px; height: 10px; border-radius: 50%;
}
#chat-mention-popup .cm-name { font-weight: bold; }

/* Your-turn popup */
.your-turn-modal { text-align: center; padding: 4px; }
.your-turn-modal .yt-glyph {
  font-size: 50px;
  line-height: 1;
  color: var(--neon-green);
  text-shadow: 0 0 20px rgba(0,255,65,0.8);
  margin-bottom: 8px;
}
.your-turn-modal .yt-title {
  font-family: var(--font-heading);
  font-size: 18px;
  color: var(--neon-green);
  letter-spacing: 4px;
  text-shadow: 0 0 12px rgba(0,255,65,0.8), 0 0 24px rgba(0,255,65,0.3);
  margin-bottom: 6px;
}
.your-turn-modal .yt-sub {
  color: var(--text-dim);
  font-size: 13px;
  letter-spacing: 1px;
}

/* Rig flyout (hover over player-stats entry) */
#rig-flyout {
  position: fixed;
  display: none;
  z-index: 2000;
  min-width: 240px;
  max-width: 320px;
  background: rgba(11, 14, 20, 0.98);
  border: 1px solid var(--neon-cyan);
  border-radius: 4px;
  padding: 10px 12px;
  box-shadow: 0 0 14px rgba(0,212,255,0.35), 0 6px 20px rgba(0,0,0,0.6);
  animation: rf-slide 0.18s ease-out;
  font-family: var(--font-body);
}
@keyframes rf-slide {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}
#rig-flyout .rf-head {
  display: flex; align-items: center; gap: 6px;
  padding-bottom: 6px;
  border-bottom: 1px dashed var(--border-dim);
  margin-bottom: 8px;
}
#rig-flyout .rf-name { font-weight: bold; font-size: 14px; }
#rig-flyout .rf-tag {
  margin-left: auto; font-family: var(--font-heading); font-size: 8px;
  color: var(--neon-red); border: 1px solid var(--neon-red);
  padding: 1px 5px; border-radius: 2px; letter-spacing: 1px;
}
#rig-flyout .rf-body { display: flex; flex-direction: column; gap: 3px; }
#rig-flyout .rf-row {
  display: flex; justify-content: space-between; gap: 10px;
  font-size: 12px;
}
#rig-flyout .rf-slot { color: var(--text-dim); text-transform: uppercase; letter-spacing: 1px; }
#rig-flyout .rf-val { color: var(--text-bright); font-weight: bold; }
#rig-flyout .rf-hidden { color: var(--neon-amber); letter-spacing: 2px; }
#rig-flyout .rf-foot {
  margin-top: 8px; padding-top: 6px;
  border-top: 1px dashed var(--border-dim);
  font-size: 11px; color: var(--text-dim);
}
#rig-flyout .rf-busts { color: var(--neon-red); }
#rig-flyout .rf-hidden-note {
  margin-top: 4px;
  font-size: 10px;
  color: var(--neon-amber);
  font-style: italic;
}

/* Log-entry card-reference tooltip */
.card-ref {
  color: var(--neon-cyan);
  border-bottom: 1px dashed rgba(0,212,255,0.4);
  cursor: help;
  padding: 0 2px;
}
.card-ref:hover {
  color: #dff7ff;
  background: rgba(0,212,255,0.08);
  border-bottom-color: var(--neon-cyan);
}
#card-ref-tooltip {
  position: fixed;
  display: none;
  z-index: 2100;
  min-width: 220px;
  max-width: 340px;
  background: rgba(11, 14, 20, 0.98);
  border: 1px solid var(--neon-cyan);
  border-radius: 4px;
  padding: 10px 12px;
  box-shadow: 0 0 14px rgba(0,212,255,0.35), 0 4px 14px rgba(0,0,0,0.6);
  pointer-events: none;
  font-family: var(--font-body);
  font-size: 13px;
}
#card-ref-tooltip .cref-name {
  font-family: var(--font-heading);
  font-size: 11px;
  color: var(--neon-cyan);
  letter-spacing: 1.5px;
  margin-bottom: 4px;
}
#card-ref-tooltip .cref-meta {
  font-size: 10px;
  color: var(--text-dim);
  letter-spacing: 1px;
  margin-bottom: 4px;
}
#card-ref-tooltip .cref-stats {
  font-size: 11px;
  color: var(--neon-amber);
  margin-bottom: 6px;
}
#card-ref-tooltip .cref-desc {
  font-size: 12px;
  color: var(--text-bright);
  line-height: 1.4;
  white-space: pre-wrap;
}

/* Raid-target picker modal */
.raid-pick { padding: 4px; }
.raid-pick .raid-pick-title {
  font-family: var(--font-heading);
  font-size: 13px;
  color: var(--neon-red);
  letter-spacing: 2px;
  margin-bottom: 6px;
}
.raid-pick .raid-pick-desc {
  font-size: 12px;
  color: var(--text-bright);
  margin-bottom: 10px;
  line-height: 1.4;
}
.raid-pick .raid-pick-sub {
  font-size: 11px;
  color: var(--text-dim);
  letter-spacing: 1px;
  margin-bottom: 6px;
}
.raid-pick .raid-pick-list {
  display: flex; flex-direction: column; gap: 4px;
}
.raid-pick .raid-pick-row {
  display: flex; align-items: center; gap: 10px;
  padding: 6px 10px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border-dim);
  border-radius: 3px;
  cursor: pointer;
  font-size: 13px;
}
.raid-pick .raid-pick-row:hover { background: rgba(255,45,45,0.08); }
.raid-pick .raid-color { width: 12px; height: 12px; border-radius: 50%; }
.raid-pick .raid-busts {
  margin-left: auto;
  font-size: 10px; color: var(--neon-amber);
}

/* Nark modal */
.nark-modal { text-align: center; padding: 4px; }
.nark-modal .nark-title {
  font-family: var(--font-heading);
  font-size: 13px;
  letter-spacing: 3px;
  color: var(--neon-amber);
  text-shadow: 0 0 10px rgba(255,176,0,0.7);
  margin-bottom: 10px;
}
.nark-modal .nark-glyph {
  font-size: 40px;
  line-height: 1;
  color: var(--neon-amber);
  text-shadow: 0 0 14px rgba(255,176,0,0.9);
  margin-bottom: 12px;
}
.nark-modal .nark-desc {
  font-size: 13px;
  color: var(--text-bright);
  margin-bottom: 12px;
  line-height: 1.5;
}
.nark-rules {
  background: rgba(255,176,0,0.06);
  border: 1px dashed var(--neon-amber);
  border-radius: 3px;
  padding: 10px 14px;
  font-size: 13px;
  text-align: left;
}
.nark-rules .nr-row {
  display: flex;
  justify-content: space-between;
  padding: 3px 0;
}
.nark-rules .nr-good { color: var(--neon-green); font-weight: bold; }
.nark-rules .nr-bad  { color: var(--neon-red);   font-weight: bold; }
.nark-rules .nr-warn { color: var(--neon-amber); font-weight: bold; }
.nark-rules .nr-ok   { color: var(--text-dim); }

/* Houseclean modals */
.hc-modal { text-align: center; padding: 4px; }
.hc-modal .hc-title {
  font-family: var(--font-heading);
  font-size: 13px;
  letter-spacing: 3px;
  color: var(--neon-amber);
  text-shadow: 0 0 8px rgba(255,176,0,0.5);
  margin-bottom: 10px;
}
.hc-modal .hc-desc {
  font-size: 13px;
  color: var(--text-bright);
  line-height: 1.6;
  margin-bottom: 12px;
}
.hc-modal .hc-sub {
  font-size: 12px;
  color: var(--text-normal);
  margin-bottom: 8px;
  letter-spacing: 1px;
}
.hc-modal .hc-empty {
  font-size: 13px;
  color: var(--text-dim);
  padding: 14px;
  border: 1px dashed var(--border-dim);
  border-radius: 3px;
}
.hc-modal .hc-list {
  display: flex;
  flex-direction: column;
  gap: 4px;
  max-height: 320px;
  overflow-y: auto;
  text-align: left;
}
.hc-modal .hc-row {
  display: grid;
  grid-template-columns: 22px 14px 1fr auto auto;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border-dim);
  border-radius: 3px;
  cursor: pointer;
  font-size: 13px;
}
.hc-modal .hc-row:hover { background: rgba(255,255,255,0.06); }
.hc-modal .hc-color {
  width: 12px; height: 12px; border-radius: 50%;
}
.hc-modal .hc-name { font-weight: bold; }
.hc-modal .hc-level {
  font-family: var(--font-heading);
  font-size: 9px;
  letter-spacing: 1px;
  padding: 2px 5px;
  border-radius: 2px;
}
.hc-modal .hc-level.root { color: var(--neon-red); border: 1px solid var(--neon-red); }
.hc-modal .hc-level.reg  { color: var(--text-dim); border: 1px solid var(--text-dim); }
.hc-modal .hc-dice { color: var(--neon-cyan); font-size: 11px; font-family: var(--font-body); }

/* Houseclean result */
.hc-result { text-align: center; padding: 4px; }
.hc-result .hcr-title {
  font-family: var(--font-heading);
  font-size: 13px;
  letter-spacing: 3px;
  color: var(--neon-amber);
  margin-bottom: 4px;
}
.hc-result .hcr-target {
  font-size: 14px;
  color: var(--neon-cyan);
  margin-bottom: 10px;
}
.hc-result .hcr-list {
  display: flex; flex-direction: column; gap: 4px;
  text-align: left;
}
.hc-result .hcr-row {
  display: grid;
  grid-template-columns: 1fr auto auto auto;
  gap: 10px;
  padding: 6px 10px;
  border-left: 3px solid;
  border-radius: 2px;
  background: rgba(255,255,255,0.03);
  font-size: 13px;
}
.hc-result .hcr-row.kept   { border-left-color: var(--neon-green); }
.hc-result .hcr-row.kicked { border-left-color: var(--neon-red); }
.hc-result .hcr-row.skipped { border-left-color: var(--text-dim); opacity: 0.6; }
.hc-result .hcr-level { color: var(--text-dim); text-transform: uppercase; font-size: 11px; }
.hc-result .hcr-roll  { color: var(--neon-amber); font-family: var(--font-body); }
.hc-result .hcr-outcome { font-weight: bold; font-family: var(--font-heading); font-size: 10px; letter-spacing: 1px; }
.hc-result .hcr-row.kept .hcr-outcome { color: var(--neon-green); }
.hc-result .hcr-row.kicked .hcr-outcome { color: var(--neon-red); }

/* Houseclean message entry */
.hc-msg { padding: 4px; }
.hc-msg .hcm-head {
  font-size: 14px;
  color: var(--text-bright);
  margin-bottom: 4px;
}
.hc-msg .hcm-sub {
  font-size: 12px;
  color: var(--text-dim);
  margin-bottom: 10px;
}
.hc-msg .hcm-text {
  width: 100%;
  height: 90px;
  padding: 10px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border-dim);
  border-radius: 3px;
  color: var(--text-bright);
  font-family: var(--font-body);
  font-size: 14px;
  resize: vertical;
  outline: none;
  transition: border-color 0.15s;
}
.hc-msg .hcm-text:focus { border-color: var(--neon-cyan); }

/* Houseclean inbox (victim side) */
.hc-inbox { padding: 4px; }
.hc-inbox .hci-head {
  font-size: 14px;
  color: var(--text-bright);
  margin-bottom: 10px;
}
.hc-inbox .hci-msg {
  padding: 14px 16px;
  background: rgba(0,212,255,0.06);
  border-left: 3px solid var(--neon-cyan);
  border-radius: 2px;
  color: var(--text-white);
  font-size: 14px;
  line-height: 1.5;
  white-space: pre-wrap;
}

/* CRASH confirmation modal */
.crash-modal { text-align: center; padding: 4px; }
.crash-modal .crash-title {
  font-family: var(--font-heading);
  font-size: 14px;
  color: var(--neon-red);
  letter-spacing: 3px;
  text-shadow: 0 0 10px rgba(255,45,45,0.8);
  margin-bottom: 10px;
}
.crash-modal .crash-glyph {
  font-size: 48px;
  line-height: 1;
  color: var(--neon-amber);
  text-shadow: 0 0 14px rgba(255,176,0,0.9), 0 0 30px rgba(255,176,0,0.5);
  margin-bottom: 12px;
  animation: crash-zap 0.8s ease-in-out infinite;
}
@keyframes crash-zap {
  0%, 100% { transform: scale(1);    opacity: 1;    }
  50%      { transform: scale(1.12); opacity: 0.7;  }
}
.crash-modal .crash-desc {
  font-size: 13px;
  color: var(--text-bright);
  margin-bottom: 12px;
  line-height: 1.5;
}
.crash-modal .crash-risk {
  font-size: 13px;
  color: var(--neon-red);
  padding: 10px;
  background: rgba(255,45,45,0.08);
  border: 1px dashed var(--neon-red);
  border-radius: 3px;
  line-height: 1.6;
}
.crash-modal .crash-noice {
  font-size: 13px;
  color: var(--neon-green);
  padding: 10px;
  background: rgba(0,255,65,0.06);
  border: 1px dashed var(--neon-green);
  border-radius: 3px;
}
.crash-modal .crash-dim { color: var(--text-dim); font-size: 11px; }

/* RAIDED modal */
.raid-modal { text-align: center; padding: 6px 4px 4px; }
.raid-modal .raid-title {
  font-family: var(--font-heading);
  font-size: 44px;
  color: var(--neon-red);
  letter-spacing: 10px;
  text-shadow:
    0 0 12px rgba(255,45,45,1),
    0 0 30px rgba(255,45,45,0.7),
    0 0 60px rgba(255,45,45,0.4);
  margin-bottom: 14px;
  animation: raid-flash 0.45s steps(2, end) infinite;
}
@keyframes raid-flash {
  0%, 100% { opacity: 1; }
  50%      { opacity: 0.55; }
}
.raid-modal .raid-handcuffs {
  font-size: 60px;
  line-height: 1;
  margin: 0 0 14px;
  filter: drop-shadow(0 0 12px rgba(255,45,45,0.9));
}
.raid-modal .raid-reason {
  font-size: 14px;
  color: var(--neon-amber);
  margin-bottom: 6px;
  letter-spacing: 1px;
}
.raid-modal .raid-detail {
  font-size: 13px;
  color: var(--text-normal);
  margin-bottom: 14px;
}
.raid-modal .raid-rule {
  font-size: 13px;
  color: var(--text-bright);
  padding: 10px;
  background: rgba(255,45,45,0.06);
  border: 1px dashed var(--neon-red);
  border-radius: 3px;
  line-height: 1.6;
}
.raid-modal .raid-rule b { color: var(--neon-red); }

/* Hack bonus tooltip */
#hack-tooltip {
  position: fixed;
  background: rgba(8, 12, 18, 0.97);
  border: 1px solid var(--neon-cyan);
  border-radius: 4px;
  padding: 10px 14px;
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--text-bright);
  z-index: 2000;
  pointer-events: none;
  box-shadow: 0 0 20px rgba(0,212,255,0.35), 0 4px 16px rgba(0,0,0,0.6);
  min-width: 220px;
  max-width: 320px;
  letter-spacing: 0.4px;
}
#hack-tooltip .ht-title {
  font-family: var(--font-heading);
  font-size: 11px;
  color: var(--neon-cyan);
  text-shadow: var(--glow-cyan);
  letter-spacing: 1.5px;
  margin-bottom: 8px;
  padding-bottom: 6px;
  border-bottom: 1px dashed rgba(0,212,255,0.4);
}
#hack-tooltip .ht-target {
  color: var(--neon-amber);
  font-weight: bold;
  margin-bottom: 6px;
}
#hack-tooltip .ht-mode {
  color: var(--neon-purple);
  font-weight: bold;
  text-transform: uppercase;
  letter-spacing: 1px;
  font-size: 12px;
  margin-bottom: 6px;
}
#hack-tooltip .ht-row {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  padding: 2px 0;
}
#hack-tooltip .ht-row .ht-label { color: var(--text-normal); }
#hack-tooltip .ht-row .ht-val { color: var(--neon-green); font-weight: bold; }
#hack-tooltip .ht-row .ht-val.neg { color: var(--neon-red); }
#hack-tooltip .ht-bonuses {
  margin-top: 6px;
  padding-top: 6px;
  border-top: 1px dashed rgba(255,255,255,0.12);
}
#hack-tooltip .ht-bonus {
  display: flex;
  justify-content: space-between;
  font-size: 12px;
  padding: 1px 0;
  color: var(--text-normal);
}
#hack-tooltip .ht-bonus .b-val { color: var(--neon-amber); font-weight: bold; }
#hack-tooltip .ht-total {
  margin-top: 6px;
  padding-top: 6px;
  border-top: 1px solid var(--neon-cyan);
  display: flex;
  justify-content: space-between;
  font-weight: bold;
  color: var(--neon-cyan);
  font-size: 13px;
}
#hack-tooltip .ht-hint {
  margin-top: 6px;
  color: var(--text-dim);
  font-size: 11px;
  font-style: italic;
}

/* Utility */
.neon-text { color: var(--neon-green); text-shadow: var(--glow-green); }
.dim { color: var(--text-normal); }
.hidden { display: none !important; }

/* Color helpers for player colors */
.color-green { color: var(--player-green); }
.color-blue { color: var(--player-blue); }
.color-purple { color: var(--player-purple); }
.color-yellow { color: var(--player-yellow); }
.color-orange { color: var(--player-orange); }
.color-red { color: var(--player-red); }
.bg-green { background-color: var(--player-green); }
.bg-blue { background-color: var(--player-blue); }
.bg-purple { background-color: var(--player-purple); }
.bg-yellow { background-color: var(--player-yellow); }
.bg-orange { background-color: var(--player-orange); }
.bg-red { background-color: var(--player-red); }
