/* ══════════════════════════════════════════════════════════
   GALAXIE — STARGATE COMMAND GALAXY INTERFACE
   ══════════════════════════════════════════════════════════ */

.gal-layout {
  display:grid; grid-template-rows:auto 1fr; height:100%;
  position:relative; overflow:hidden; z-index:1;
}

/* ── Topbar ── */
.gal-topbar {
  display:flex; align-items:center; gap:10px; padding:10px 18px;
  background:linear-gradient(180deg, rgba(6,12,28,0.95), rgba(4,8,18,0.98));
  border-bottom:2px solid rgba(var(--accent-rgb),0.20);
  backdrop-filter:blur(10px); z-index:2; position:relative;
  overflow:hidden; min-width:0;
  box-shadow:0 4px 20px rgba(0,0,0,0.4);
}
/* ── Topbar HUD grid lines ── */
.gal-topbar::before {
  content:''; position:absolute; inset:0; pointer-events:none;
  background:repeating-linear-gradient(90deg,
    transparent, transparent 120px,
    rgba(var(--accent-rgb),0.04) 120px, rgba(var(--accent-rgb),0.04) 121px);
}
.gal-topbar::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg, transparent, rgba(var(--accent-rgb),0.3), transparent);
}
.gal-coord-label {
  font-family:'Orbitron',monospace; font-size:12px; letter-spacing:3px;
  color:var(--accent); text-shadow:0 0 10px rgba(var(--accent-rgb),0.3);
  font-weight:700;
}
.gal-coord-sep { color:var(--textsoft); font-size:14px; }
.gal-coord-input {
  background:rgba(4,8,20,0.8); border:1px solid rgba(var(--accent-rgb),0.25);
  border-radius:6px; color:var(--textbright);
  font-family:'Orbitron',monospace; font-size:14px; font-weight:700;
  padding:6px 10px; text-align:center; width:60px;
  transition:all 0.2s; outline:none;
}
.gal-coord-input:focus {
  border-color:var(--accent); box-shadow:0 0 12px rgba(var(--accent-rgb),0.3);
}
.gal-nav-btn {
  font-family:'Orbitron',monospace; font-size:11px; font-weight:700; letter-spacing:1.5px;
  padding:8px 16px; border:1px solid rgba(var(--accent-rgb),0.35);
  border-radius:6px; background:linear-gradient(135deg, rgba(var(--accent-rgb),0.10), rgba(var(--accent-rgb),0.04));
  color:var(--accent); cursor:pointer; transition:all 0.25s;
  text-shadow:0 0 8px rgba(var(--accent-rgb),0.2);
  position:relative; overflow:hidden;
}
.gal-nav-btn::after {
  content:''; position:absolute; top:0; left:-100%; width:100%; height:100%;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,0.06), transparent);
  transition:left 0.5s;
}
.gal-nav-btn:hover::after { left:100%; }
.gal-nav-btn:hover {
  background:linear-gradient(135deg, rgba(var(--accent-rgb),0.20), rgba(var(--accent-rgb),0.08));
  box-shadow:0 0 14px rgba(var(--accent-rgb),0.2); border-color:rgba(var(--accent-rgb),0.5);
  transform:translateY(-1px);
}
.gal-coord-display {
  font-family:'Share Tech Mono',monospace; font-size:13px;
  color:var(--textmid); margin-left:8px; white-space:nowrap;
  overflow:hidden; text-overflow:ellipsis; min-width:0;
  letter-spacing:0.5px;
}
.gal-arrow-btn {
  width:34px; height:34px; font-size:14px;
  border:1px solid rgba(var(--accent-rgb),0.25); border-radius:6px;
  background:linear-gradient(135deg, rgba(var(--accent-rgb),0.08), rgba(var(--accent-rgb),0.03));
  color:var(--accent); cursor:pointer; transition:all 0.25s;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.gal-arrow-btn:hover {
  background:linear-gradient(135deg, rgba(var(--accent-rgb),0.18), rgba(var(--accent-rgb),0.08));
  border-color:rgba(var(--accent-rgb),0.5); box-shadow:0 0 10px rgba(var(--accent-rgb),0.15);
}

/* ── Body layout ── */
.gal-body { display:grid; grid-template-columns:1fr 380px; overflow:hidden; min-height:0; }
.gal-map-panel { overflow-y:auto; overflow-x:hidden; position:relative; z-index:1; min-width:0; }

/* ── Scanline radar effect ── */
@keyframes galScanline {
  0%   { top:0; opacity:0; }
  10%  { opacity:1; }
  90%  { opacity:1; }
  100% { top:100%; opacity:0; }
}
.gal-map-panel::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg, transparent 10%, rgba(var(--accent-rgb),0.4), transparent 90%);
  animation:galScanline 4s ease-in-out infinite;
  z-index:10; pointer-events:none;
  box-shadow:0 0 15px 3px rgba(var(--accent-rgb),0.15);
}

/* ── Detail panel (right) ── */
.gal-detail-panel {
  background:linear-gradient(180deg, rgba(4,8,18,0.96), rgba(6,12,28,0.98));
  border-left:2px solid rgba(var(--accent-rgb),0.20); padding:18px;
  overflow-y:auto; overflow-x:hidden; z-index:1;
  backdrop-filter:blur(10px); min-width:0; position:relative;
}
.gal-detail-panel::before {
  content:''; position:absolute; top:0; left:0; right:0; bottom:0;
  background:repeating-linear-gradient(0deg, transparent 0px, transparent 3px, rgba(var(--accent-rgb),0.012) 3px, rgba(var(--accent-rgb),0.012) 4px);
  pointer-events:none; z-index:0;
}
.gal-detail-panel > * { position:relative; z-index:1; }
.gal-detail-panel * { word-break:break-word; overflow-wrap:break-word; }
.gal-det-name {
  font-family:'Orbitron',monospace; font-size:17px; font-weight:700;
  color:var(--textbright); letter-spacing:1px;
  text-shadow:0 0 12px rgba(var(--accent-rgb),0.3);
}
.gal-det-type {
  font-family:'Share Tech Mono',monospace; font-size:12px;
  letter-spacing:2.5px; color:var(--textmid); margin-top:5px;
  text-transform:uppercase;
}
.gal-det-desc { font-size:14px; color:var(--textmid); line-height:1.7; }

/* ── Table ── */
.gal-table { width:100%; border-collapse:separate; border-spacing:0 2px; }
.gal-th {
  padding:12px 16px; font-family:'Orbitron',monospace; font-size:10px;
  letter-spacing:2.5px; color:rgba(var(--accent-rgb),0.7);
  border-bottom:1px solid rgba(var(--accent-rgb),0.15);
  text-transform:uppercase; position:sticky; top:0; z-index:1;
  background:rgba(6,12,28,0.98); backdrop-filter:blur(8px);
  text-align:left;
}
/* ── Row stagger animation ── */
@keyframes galRowEnter {
  from { opacity:0; transform:translateX(-12px); }
  to   { opacity:1; transform:translateX(0); }
}
.gal-tr {
  transition:all 0.2s ease; cursor:pointer;
  background:rgba(255,255,255,0.015);
  opacity:0; position:relative; overflow:hidden;
}
.gal-tr.gal-visible { animation:galRowEnter 0.3s ease-out forwards; }
.gal-tr:nth-child(odd) { background:rgba(255,255,255,0.025); }

/* ── Row hover glow + shine sweep ── */
.gal-tr::after {
  content:''; position:absolute; top:0; left:-100%; width:60%;
  height:100%; pointer-events:none; z-index:1;
  background:linear-gradient(90deg, transparent, rgba(var(--accent-rgb),0.07), transparent);
  transition:left 0.6s ease;
}
.gal-tr:hover::after { left:120%; }
.gal-tr:hover {
  background:rgba(var(--accent-rgb),0.08) !important;
  box-shadow:inset 3px 0 12px rgba(var(--accent-rgb),0.15),
             0 0 20px rgba(var(--accent-rgb),0.05);
}
.gal-tr.mine  { background:rgba(var(--accent-rgb),0.10) !important; }
.gal-tr.mine .gal-pos  { border-left:3px solid var(--accent); }
.gal-tr.mine:hover { background:rgba(var(--accent-rgb),0.15) !important; }
.gal-tr.enemy { background:rgba(224,80,80,0.06) !important; }
.gal-tr.enemy .gal-pos { border-left:3px solid rgba(224,80,80,0.5); }
.gal-tr.ally  { background:rgba(46,204,136,0.06) !important; }
.gal-tr.ally .gal-pos  { border-left:3px solid rgba(46,204,136,0.5); }
.gal-tr.npc { background:rgba(var(--accent-rgb),0.04) !important; }
.gal-tr.npc .gal-pos   { border-left:3px solid rgba(var(--accent-rgb),0.3); }
.gal-tr.empty { opacity:0.35; cursor:default; }
.gal-tr.empty:hover { background:rgba(255,255,255,0.025) !important; opacity:0.5; }
/* ── Selected row — breathing glow pulse ── */
@keyframes galSelectedPulse {
  0%,100% { box-shadow:inset 3px 0 10px rgba(var(--accent-rgb),0.1), 0 0 8px rgba(var(--accent-rgb),0.05); }
  50%     { box-shadow:inset 3px 0 18px rgba(var(--accent-rgb),0.25), 0 0 16px rgba(var(--accent-rgb),0.12); }
}
.gal-tr.selected {
  background:rgba(var(--accent-rgb),0.12) !important;
  outline:1px solid rgba(var(--accent-rgb),0.5);
  animation:galSelectedPulse 2s ease-in-out infinite;
}
.gal-tr.selected .gal-pos { border-left:3px solid var(--accent); }
.gal-td {
  padding:10px 14px; color:var(--text); vertical-align:middle;
  font-family:'Share Tech Mono',monospace; font-size:13px;
  border-bottom:1px solid rgba(255,255,255,0.03);
}
/* ── Coordinates glow ── */
.gal-pos {
  font-family:'Share Tech Mono',monospace; font-size:12px; font-weight:400;
  color:rgba(var(--accent-rgb),0.6); white-space:nowrap; padding-left:14px;
  text-shadow:0 0 8px rgba(var(--accent-rgb),0.25);
  transition:color 0.2s, text-shadow 0.2s;
}
.gal-tr:hover .gal-pos {
  color:var(--accent);
  text-shadow:0 0 12px rgba(var(--accent-rgb),0.5);
}
/* ── Planet hover animation ── */
.gal-planet-ico { filter:drop-shadow(0 2px 4px rgba(0,0,0,0.4)); line-height:1; }
.gal-planet-ico svg { transition:transform 0.3s ease, filter 0.3s ease; }
.gal-tr:hover .gal-planet-ico svg {
  transform:scale(1.25);
  filter:drop-shadow(0 0 8px rgba(var(--accent-rgb),0.5)) brightness(1.15);
}
.gal-orbit-ring { animation:orbitSpin 8s linear infinite; transform-origin:16px 16px; }
.gal-planet-name {
  font-family:'Rajdhani',sans-serif; font-size:15px; font-weight:700;
  color:var(--textbright); letter-spacing:0.3px;
}
.gal-player { font-size:13px; }
.gal-player.mine  { color:var(--accent); font-weight:700; }
.gal-player.enemy { color:var(--danger); font-weight:600; }
.gal-player.ally  { color:var(--success); font-weight:600; }
.gal-player.empty { color:var(--textsoft); font-style:italic; font-size:12px; }
.gal-alliance { font-family:'Orbitron',monospace; font-size:11px; color:var(--textmid); letter-spacing:1px; }

/* ── Action buttons (table) — neon glow ── */
.gal-actions { display:flex; gap:4px; flex-wrap:wrap; justify-content:flex-end; }
.gal-act-btn {
  padding:5px 10px; font-family:'Share Tech Mono',monospace; font-size:11px; font-weight:700;
  border:1px solid; border-radius:4px; cursor:pointer;
  background:transparent; transition:all 0.2s;
  white-space:nowrap; letter-spacing:0.5px;
  position:relative; overflow:hidden;
  text-shadow:0 0 6px currentColor;
}
.gal-act-btn::after {
  content:''; position:absolute; top:0; left:-100%; width:100%; height:100%;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,0.12), transparent);
  transition:left 0.4s; pointer-events:none;
}
.gal-act-btn:hover::after { left:100%; }
.gal-act-btn:hover { transform:translateY(-1px); filter:brightness(1.2); }
.gal-act-btn.spy {
  border-color:rgba(155,89,182,0.4); color:#b39ddb;
  background:rgba(155,89,182,0.06);
}
.gal-act-btn.spy:hover { background:rgba(155,89,182,0.15); box-shadow:0 0 8px rgba(155,89,182,0.2); }
.gal-act-btn.attack {
  border-color:rgba(224,80,80,0.4); color:#ef9a9a;
  background:rgba(224,80,80,0.06);
}
.gal-act-btn.attack:hover { background:rgba(224,80,80,0.15); box-shadow:0 0 8px rgba(224,80,80,0.2); }
.gal-act-btn.colonize {
  border-color:rgba(46,204,136,0.4); color:var(--success);
  background:rgba(46,204,136,0.06);
}
.gal-act-btn.colonize:hover { background:rgba(46,204,136,0.15); box-shadow:0 0 8px rgba(46,204,136,0.2); }
.gal-act-btn.reinforce {
  border-color:rgba(46,204,136,0.4); color:var(--success);
  background:rgba(46,204,136,0.06);
}
.gal-act-btn.reinforce:hover { background:rgba(46,204,136,0.15); box-shadow:0 0 8px rgba(46,204,136,0.2); }

/* ── Action buttons (detail panel) ── */
.gal-action-btn {
  width:100%; padding:14px; font-family:'Orbitron',monospace; font-size:12px;
  font-weight:700; letter-spacing:2px; border:2px solid; border-radius:8px;
  cursor:pointer; text-transform:uppercase; transition:all 0.25s;
  position:relative; overflow:hidden;
  background:transparent;
}
.gal-action-btn::after {
  content:''; position:absolute; top:0; left:-100%; width:100%; height:100%;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,0.06), transparent);
  transition:left 0.5s;
}
.gal-action-btn:hover:not(:disabled)::after { left:100%; }
.gal-action-btn:hover:not(:disabled) { transform:translateY(-2px); }
.gal-action-btn:disabled { opacity:0.4; cursor:not-allowed; }
.gal-action-btn.colonize {
  border-color:rgba(212,146,10,0.5); color:var(--gold);
  background:linear-gradient(135deg, rgba(212,146,10,0.08), transparent);
  text-shadow:0 0 10px rgba(212,146,10,0.3);
}
.gal-action-btn.colonize:hover:not(:disabled) { box-shadow:0 0 20px rgba(212,146,10,0.2); }
.gal-action-btn.attack {
  border-color:rgba(224,80,80,0.5); color:var(--danger);
  background:linear-gradient(135deg, rgba(224,80,80,0.08), transparent);
  text-shadow:0 0 10px rgba(224,80,80,0.3);
}
.gal-action-btn.attack:hover:not(:disabled) { box-shadow:0 0 20px rgba(224,80,80,0.2); }
.gal-action-btn.reinforce {
  border-color:rgba(46,204,136,0.5); color:var(--success);
  background:linear-gradient(135deg, rgba(46,204,136,0.08), transparent);
  text-shadow:0 0 10px rgba(46,204,136,0.3);
}
.gal-action-btn.reinforce:hover:not(:disabled) { box-shadow:0 0 20px rgba(46,204,136,0.2); }
.gal-action-btn.spy {
  border-color:rgba(155,89,182,0.5); color:var(--purple);
  background:linear-gradient(135deg, rgba(155,89,182,0.08), transparent);
  text-shadow:0 0 10px rgba(155,89,182,0.3);
}
.gal-action-btn.spy:hover:not(:disabled) { box-shadow:0 0 20px rgba(155,89,182,0.2); }

/* Prereq + unlock display */
.gs { position:absolute; border-radius:50%; background:white; }

#sf_galaxy { display:none; position:relative; }
#sf_galaxy.active { display:flex; flex-direction:column; }
#sf_galaxy .gal-layout { flex:1; min-height:0; }

/* ══════════════════════════════════════════════════════════
   SYSTEM OVERVIEW (right panel)
   ══════════════════════════════════════════════════════════ */
.gal-sys-overview {
  padding:12px 14px; display:flex; flex-direction:column; gap:12px;
  overflow-y:auto; max-height:100%;
}
.gal-sys-header {
  font-family:'Orbitron',monospace; font-size:15px; font-weight:700;
  color:var(--textbright); letter-spacing:1.5px;
  border-bottom:2px solid rgba(var(--accent-rgb),0.25); padding-bottom:10px;
  text-shadow:0 0 12px rgba(var(--accent-rgb),0.25);
  display:flex; align-items:center; gap:8px;
}
.gal-sys-header::before {
  content:''; width:4px; height:16px; background:var(--accent);
  border-radius:2px; box-shadow:0 0 10px rgba(var(--accent-rgb),0.5);
}
.gal-sys-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:5px; }
.gal-sys-slot {
  height:34px; border-radius:5px; display:flex; align-items:center; justify-content:center;
  font-size:14px; cursor:default;
  border:1px solid rgba(255,255,255,0.06); transition:all 0.2s;
}
.gal-sys-slot.clickable { cursor:pointer; }
.gal-sys-slot.clickable:hover { transform:scale(1.12); border-color:rgba(255,255,255,0.30); box-shadow:0 0 8px rgba(255,255,255,0.08); }
.gal-sys-slot.empty   { background:rgba(255,255,255,0.03); }
.gal-sys-slot.mine    { background:rgba(var(--accent-rgb),0.20); border-color:rgba(var(--accent-rgb),0.45); box-shadow:0 0 8px rgba(var(--accent-rgb),0.15); }
.gal-sys-slot.player  { background:rgba(255,60,60,0.16); border-color:rgba(255,80,80,0.40); box-shadow:0 0 6px rgba(255,60,60,0.1); }
.gal-sys-slot.npc1    { background:rgba(46,204,136,0.14); border-color:rgba(46,204,136,0.35); box-shadow:0 0 6px rgba(46,204,136,0.1); }
.gal-sys-slot.npc2    { background:rgba(243,156,18,0.14); border-color:rgba(243,156,18,0.35); box-shadow:0 0 6px rgba(243,156,18,0.1); }
.gal-sys-slot.npc3    { background:rgba(255,60,60,0.20); border-color:rgba(255,80,80,0.45); box-shadow:0 0 8px rgba(255,60,60,0.12); }
.gal-sys-section {
  font-family:'Orbitron',monospace; font-size:11px; letter-spacing:2px;
  color:var(--accent); margin-bottom:4px;
  display:flex; align-items:center; gap:6px;
  text-shadow:0 0 8px rgba(var(--accent-rgb),0.2);
}
.gal-sys-section::before {
  content:''; width:3px; height:10px; background:rgba(var(--accent-rgb),0.4);
  border-radius:2px;
}
.gal-sys-stats { display:flex; flex-direction:column; gap:3px; }
.gal-sys-stat {
  display:flex; justify-content:space-between; align-items:center;
  padding:6px 10px; border-radius:5px; transition:all 0.2s;
  background:linear-gradient(90deg, rgba(255,255,255,0.03), rgba(255,255,255,0.01));
  border-left:2px solid transparent;
}
.gal-sys-stat:hover { background:rgba(var(--accent-rgb),0.06); border-left-color:rgba(var(--accent-rgb),0.3); }
.gal-sys-stat-lbl { font-family:'Share Tech Mono',monospace; font-size:12px; color:var(--textmid); }
.gal-sys-stat-val { font-family:'Orbitron',monospace; font-size:12px; font-weight:700; color:var(--textbright); }
.gal-sys-row {
  display:flex; align-items:center; gap:8px;
  padding:7px 10px; border-radius:6px; margin-bottom:3px;
  background:linear-gradient(90deg, rgba(255,255,255,0.03), transparent);
  border:1px solid rgba(255,255,255,0.04); cursor:pointer; transition:all 0.2s;
}
.gal-sys-row:hover {
  background:linear-gradient(90deg, rgba(var(--accent-rgb),0.08), rgba(var(--accent-rgb),0.02));
  border-color:rgba(var(--accent-rgb),0.15); transform:translateX(3px);
}
.gal-sys-row-name { font-family:'Share Tech Mono',monospace; font-size:12px; font-weight:600; flex:1; }
.gal-sys-row-action { font-size:12px; opacity:0.7; transition:opacity 0.2s; }
.gal-sys-row:hover .gal-sys-row-action { opacity:1; }

/* ══════════════════════════════════════════════════════════
   SPY HISTORY
   ══════════════════════════════════════════════════════════ */
.spy-hist-panel {
  padding:14px 16px; display:flex; flex-direction:column; gap:10px;
  overflow-y:auto; max-height:100%;
}
.spy-hist-title {
  font-family:'Orbitron',monospace; font-size:13px; font-weight:700;
  color:var(--purple,#9b59b6); letter-spacing:2px;
  border-bottom:2px solid rgba(155,89,182,0.25); padding-bottom:8px;
  display:flex; align-items:center; justify-content:space-between;
  text-shadow:0 0 10px rgba(155,89,182,0.3);
}
.spy-hist-item {
  background:linear-gradient(135deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01));
  border:1px solid rgba(255,255,255,0.08); border-radius:8px;
  padding:10px 12px; transition:all 0.2s;
}
.spy-hist-item:hover { background:rgba(255,255,255,0.06); transform:translateY(-1px); }
.spy-hist-item.success { border-left:4px solid rgba(46,204,136,0.6); }
.spy-hist-item.caught  { border-left:4px solid rgba(255,80,80,0.6); }
.spy-hist-target {
  font-family:'Orbitron',monospace; font-size:13px; font-weight:700;
  color:var(--textbright); letter-spacing:0.5px;
}
.spy-hist-meta { font-family:'Share Tech Mono',monospace; font-size:12px; color:var(--textsoft); margin:3px 0; }
.spy-hist-res {
  font-family:'Share Tech Mono',monospace; font-size:13px;
  color:var(--gold2); font-weight:700;
  text-shadow:0 0 6px rgba(212,146,10,0.2);
}
.spy-hist-btns { display:flex; gap:6px; margin-top:8px; }
.spy-hist-btn {
  flex:1; padding:7px; font-family:'Orbitron',monospace; font-size:10px;
  font-weight:700; letter-spacing:1.5px; border-radius:6px;
  border:1px solid; cursor:pointer; background:transparent;
  transition:all 0.2s; text-transform:uppercase;
}
.spy-hist-btn:hover { transform:translateY(-1px); }
.spy-hist-btn.re-spy {
  border-color:rgba(46,204,136,0.4); color:var(--success);
  background:rgba(46,204,136,0.06);
}
.spy-hist-btn.re-spy:hover { background:rgba(46,204,136,0.12); box-shadow:0 0 10px rgba(46,204,136,0.15); }
.spy-hist-btn.re-atk {
  border-color:rgba(255,80,80,0.4); color:var(--danger);
  background:rgba(255,80,80,0.06);
}
.spy-hist-btn.re-atk:hover { background:rgba(255,80,80,0.12); box-shadow:0 0 10px rgba(255,80,80,0.15); }

/* ══════════════════════════════════════════════════════════
   EVENT BANNER (galaxy view)
   ══════════════════════════════════════════════════════════ */
.gal-evt-banner {
  display:flex; align-items:center; gap:12px; margin:10px 12px;
  padding:12px 16px; border-radius:10px; cursor:pointer; transition:all 0.25s;
  background:linear-gradient(135deg, rgba(192,57,43,0.12), rgba(255,140,0,0.05));
  border:1px solid rgba(255,140,0,0.45); position:relative; overflow:hidden;
  box-shadow:0 4px 16px rgba(0,0,0,0.3);
}
.gal-evt-banner::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg, rgba(255,140,0,0.5), transparent 60%);
}
.gal-evt-banner:hover {
  background:linear-gradient(135deg, rgba(192,57,43,0.20), rgba(255,140,0,0.10));
  transform:translateY(-2px); box-shadow:0 6px 24px rgba(0,0,0,0.4);
}
.gal-evt-icon  { font-size:26px; flex-shrink:0; filter:drop-shadow(0 0 4px rgba(255,140,0,0.3)); }
.gal-evt-info  { flex:1; min-width:0; }
.gal-evt-name  {
  font-family:'Orbitron',monospace; font-size:13px; font-weight:700;
  letter-spacing:2px; color:var(--event-orange); margin-bottom:6px;
  text-shadow:0 0 12px rgba(255,140,0,0.4);
}
.gal-evt-hp-wrap {
  height:8px; background:rgba(255,255,255,0.08); border-radius:4px;
  overflow:hidden; box-shadow:inset 0 1px 3px rgba(0,0,0,0.3);
}
.gal-evt-hp-fill {
  height:100%; border-radius:4px;
  background:linear-gradient(90deg,#ff4444,#ff8800);
  transition:width 0.4s; position:relative;
  box-shadow:0 0 10px rgba(255,80,0,0.4);
}
.gal-evt-hp-fill::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.25) 50%, transparent 100%);
  background-size:200% 100%;
  animation:evtHpShimmer 2.5s linear infinite;
}
@keyframes evtHpShimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }
.gal-evt-stats {
  font-family:'Share Tech Mono',monospace; font-size:12px;
  color:var(--textmid); margin-top:4px;
}
.gal-evt-atk-btn {
  font-family:'Orbitron',monospace; font-size:11px; font-weight:700;
  letter-spacing:1.5px; padding:9px 18px;
  background:linear-gradient(135deg, rgba(192,57,43,0.20), rgba(255,120,0,0.10));
  border:2px solid rgba(255,120,0,0.6); border-radius:6px;
  color:var(--event-orange); cursor:pointer; flex-shrink:0;
  white-space:nowrap; transition:all 0.25s;
  text-shadow:0 0 8px rgba(255,140,0,0.3);
  animation:evtAtkPulse 2.5s ease-in-out infinite;
}
@keyframes evtAtkPulse {
  0%,100% { box-shadow:0 0 10px rgba(255,120,0,0.15); }
  50%     { box-shadow:0 0 24px rgba(255,120,0,0.35); }
}
.gal-evt-atk-btn:hover {
  background:linear-gradient(135deg, rgba(192,57,43,0.35), rgba(255,120,0,0.18));
  transform:translateY(-2px);
}

/* ══════════════════════════════════════════════════════════
   GLOBAL EVENT CARD (overview)
   ══════════════════════════════════════════════════════════ */
.ev-gbl-card {
  background:linear-gradient(135deg, rgba(192,57,43,0.10), rgba(255,140,0,0.05));
  border:1px solid rgba(255,140,0,0.35); border-radius:10px;
  border-left:4px solid rgba(255,140,0,0.7);
  padding:14px 18px; margin-bottom:12px; cursor:pointer;
  box-shadow:0 4px 20px rgba(0,0,0,0.3);
  transition:all 0.25s; position:relative; overflow:hidden;
}
.ev-gbl-card::before {
  content:''; position:absolute; top:0; left:4px; right:0; height:2px;
  background:linear-gradient(90deg, rgba(255,140,0,0.4), transparent 50%);
}
.ev-gbl-card:hover {
  background:rgba(192,57,43,0.16); transform:translateY(-2px);
  box-shadow:0 6px 24px rgba(0,0,0,0.4), 0 0 20px rgba(255,140,0,0.08);
}
.ev-gbl-title {
  font-family:'Orbitron',monospace; font-size:13px; font-weight:700;
  letter-spacing:2.5px; color:var(--event-orange); margin-bottom:10px;
  display:flex; align-items:center; gap:8px;
  text-shadow:0 0 14px rgba(255,140,0,0.4);
}
.ev-gbl-hp-bar {
  height:8px; background:rgba(255,255,255,0.06); border-radius:4px;
  margin-bottom:6px; overflow:hidden;
  box-shadow:inset 0 1px 3px rgba(0,0,0,0.3);
}
.ev-gbl-hp-fill {
  height:100%; border-radius:4px;
  background:linear-gradient(90deg,#ff4444,#ff8800); transition:width 0.4s;
  box-shadow:0 0 10px rgba(255,80,0,0.5); position:relative;
}
.ev-gbl-hp-fill::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.25) 50%, transparent 100%);
  background-size:200% 100%;
  animation:evtHpShimmer 2.5s linear infinite;
}

/* ── Event attack modal rows ── */
.ev-troop-row {
  display:flex; align-items:center; gap:10px;
  padding:9px 0; border-bottom:1px solid rgba(255,255,255,0.06);
  transition:background 0.15s;
}
.ev-troop-row:hover { background:rgba(255,255,255,0.03); }
.ev-troop-name { font-family:'Share Tech Mono',monospace; font-size:14px; color:var(--textbright); flex:1; }
.ev-troop-have { font-family:'Share Tech Mono',monospace; font-size:14px; color:var(--textmid); width:70px; text-align:right; }
.ev-troop-atk  { font-family:'Share Tech Mono',monospace; font-size:14px; color:var(--danger); width:65px; text-align:right; font-weight:700; }
.ev-troop-input {
  width:75px; background:rgba(4,8,20,0.8);
  border:1px solid rgba(var(--accent-rgb),0.20); border-radius:6px;
  color:var(--textbright); font-family:'Orbitron',monospace; font-size:14px;
  font-weight:700; padding:6px 8px; text-align:center;
  transition:all 0.2s; outline:none;
}
.ev-troop-input:focus { border-color:var(--accent); box-shadow:0 0 10px rgba(var(--accent-rgb),0.3); }
