/* ============================================================
   LIGA MASTER — Modo carrera
   Layout: menú en lista a la izquierda, panel/cancha a la derecha.
   Fase 0: esqueleto.
   ============================================================ */

#page-ligamaster.active { display: block; }

.lm-layout {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 16px;
  max-width: 1600px;
  margin: 0 auto;
  padding: 24px 24px;
  min-height: calc(100vh - 58px);
  align-items: start;
}
@media (max-width: 720px) {
  .lm-layout { grid-template-columns: 1fr; }
}

/* ── Menú lateral ── */
.lm-menu {
  background: var(--bg-surface);
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  position: sticky;
  top: 16px;
}
.dark .lm-menu { border-color: rgba(255,255,255,0.1); }

.lm-menu-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px;
  background: linear-gradient(135deg, #059669, #047857);
  color: #fff;
}
.lm-menu-title {
  font-family: var(--font-title, 'Inter', sans-serif);
  font-weight: 800;
  letter-spacing: 0.08em;
  font-size: 0.95rem;
}
.lm-menu-close {
  background: rgba(255,255,255,0.18);
  border: none;
  color: #fff;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  cursor: pointer;
  font-size: 0.85rem;
  transition: background 0.15s ease;
}
.lm-menu-close:hover { background: rgba(255,255,255,0.32); }
.lm-menu-header-btns { display: flex; gap: 4px; align-items: center; }
.lm-menu-toggle {
  background: rgba(255,255,255,0.18);
  border: none;
  color: #fff;
  width: 26px;
  height: 26px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1;
  transition: background 0.15s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}
.lm-menu-toggle:hover { background: rgba(255,255,255,0.32); }
.lm-icon { display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.lm-icon svg { width: 16px; height: 16px; stroke: currentColor; display: block; }

/* Sidebar mini (colapsada) */
.lm-layout.lm-mini { grid-template-columns: 52px 1fr !important; }
.lm-menu.lm-mini .lm-menu-title { display: none; }
.lm-menu.lm-mini .lm-menu-close { display: none; }
.lm-menu.lm-mini .lm-menu-header { padding: 10px 4px; justify-content: center; }
.lm-menu.lm-mini .lm-menu-header-btns { width: 100%; justify-content: center; }
.lm-menu.lm-mini .lm-text { display: none; }
.lm-menu.lm-mini .lm-menu-item { padding: 10px 6px; justify-content: center; font-size: 1.1rem; gap: 0; }
.lm-menu.lm-mini .lm-icon svg { width: 20px; height: 20px; }
.lm-menu.lm-mini .lm-menu-toggle { font-size: 0.9rem; }

.lm-menu-list {
  display: flex;
  flex-direction: column;
  padding: 8px;
  gap: 2px;
}
.lm-menu-item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  text-align: left;
  padding: 11px 14px;
  border: none;
  background: transparent;
  border-radius: 8px;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text-dim);
  cursor: pointer;
  transition: background 0.15s ease, color 0.15s ease;
}
.lm-menu-item:hover { background: rgba(5,150,105,0.08); color: var(--text-bright); }
.lm-menu-item.active {
  background: rgba(5,150,105,0.14);
  color: #059669;
}
.dark .lm-menu-item.active { color: #34d399; background: rgba(52,211,153,0.16); }

/* ── Panel derecho ── */
.lm-panel {
  background: var(--bg-surface);
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  min-height: 420px;
  padding: 24px;
}
.dark .lm-panel { border-color: rgba(255,255,255,0.1); }

/* ── Placeholder "en construcción" (Fase 0) ── */
.lm-construccion {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 14px;
  min-height: 360px;
  padding: 24px;
}
.lm-construccion-emoji { font-size: 3rem; line-height: 1; }
.lm-construccion-title {
  font-family: var(--font-title, 'Inter', sans-serif);
  font-size: 1.4rem;
  font-weight: 800;
  color: var(--text-bright);
  margin: 0;
}
.lm-construccion-desc {
  font-size: 0.9rem;
  color: var(--text-muted);
  line-height: 1.6;
  max-width: 440px;
  margin: 0;
}

/* ── Selector de liga / club ── */
.lm-selector { padding: 8px 4px; }
.lm-sel-title { font-family: var(--font-title,'Inter',sans-serif); font-size: 1.5rem; font-weight: 800; color: var(--text-bright); margin: 0 0 6px; }
.lm-sel-sub { font-size: 0.88rem; color: var(--text-muted); margin: 0 0 18px; line-height: 1.5; }
.lm-liga-list { display: flex; flex-direction: column; gap: 8px; margin-bottom: 18px; }
.lm-liga-badge { object-fit: contain; display: block; flex-shrink: 0; }
.lm-liga-badge-gen { display: inline-flex; align-items: center; justify-content: center; font-size: 1.2rem; }
/* Etiqueta del próximo compromiso por competición + hint en secciones de copa. */
.lm-comp-liga { color: var(--text-muted); }
.lm-comp-copa { color: #d97706; }
.lm-comp-intl { color: #7c3aed; }
.lm-proximo-label.lm-comp-liga, .lm-proximo-label.lm-comp-copa, .lm-proximo-label.lm-comp-intl { font-weight: 800; }
/* B7: Clásico, finales y partidos especiales */
.lm-proximo-label.lm-comp-clasico    { color: #f87171; }
.lm-proximo-label.lm-comp-final-copa { color: #fbbf24; font-weight: 800; }
.lm-proximo-label.lm-comp-final-intl { color: #a78bfa; font-weight: 800; }
/* B7: Bordes de la card por tipo de partido */
.lm-proximo:has(.lm-comp-clasico)    { border-left: 3px solid #f87171; }
.lm-proximo:has(.lm-comp-intl)       { border-left: 3px solid #818cf8; }
.lm-proximo:has(.lm-comp-copa)       { border-left: 3px solid #f59e0b; }
.lm-proximo:has(.lm-comp-final-copa),
.lm-proximo:has(.lm-comp-final-intl) { border-left: 3px solid #a78bfa; animation: pulse-border 1.5s ease-in-out infinite; }

@keyframes pulse-border {
  0%, 100% { border-left-color: #a78bfa; }
  50% { border-left-color: #7c3aed; }
}
.lm-comp-hint { background: rgba(99,102,241,0.10); border: 1px solid rgba(99,102,241,0.25); color: var(--text-bright); border-radius: 10px; padding: 10px 12px; font-size: 0.9rem; margin: 8px 0; }
/* Lista de clasificados reales a las copas (agrupados por país). */
.lm-clf { margin-top: 12px; background: var(--card-bg, rgba(255,255,255,0.03)); border: 1px solid rgba(255,255,255,0.08); border-radius: 12px; padding: 6px 14px; }
.lm-clf summary { cursor: pointer; font-weight: 700; color: var(--text-bright); padding: 6px 0; font-size: 0.92rem; }
.lm-clf-body { padding: 6px 0 10px; display: flex; flex-direction: column; gap: 10px; }
.lm-clf-pais { font-size: 0.74rem; text-transform: uppercase; letter-spacing: 0.5px; color: var(--text-dim, #94a3b8); margin-bottom: 4px; font-weight: 700; }
.lm-clf-items { display: flex; flex-wrap: wrap; gap: 6px; }
.lm-clf-item { display: inline-flex; align-items: center; gap: 5px; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.07); border-radius: 999px; padding: 3px 9px 3px 5px; font-size: 0.82rem; }
.lm-clf-item small { color: var(--text-dim, #94a3b8); font-weight: 700; }
.lm-clf-item.mio { background: rgba(37,99,235,0.18); border-color: rgba(37,99,235,0.5); }
/* Escudo real (img) con el SVG generado por detrás como fallback. */
.lm-badge-wrap { position: relative; display: inline-flex; flex-shrink: 0; vertical-align: middle; }
.lm-badge-wrap .lm-badge-fb { position: absolute; inset: 0; display: inline-flex; align-items: center; justify-content: center; }
.lm-badge-wrap .lm-escudo-img { position: relative; z-index: 1; width: 100%; height: 100%; object-fit: contain; }
.lm-sel-clubtitle { font-size: 0.95rem; font-weight: 700; color: var(--text-bright); margin: 10px 0 10px; }
.lm-club-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 8px; }
.lm-club-opt {
  display: flex; flex-direction: row; align-items: center; gap: 10px; padding: 11px 13px; border-radius: 9px;
  border: 1.5px solid rgba(0,0,0,0.1); background: var(--bg-surface); cursor: pointer;
  text-align: left; transition: all 0.15s ease;
}
.lm-club-opt:hover { border-color: #059669; transform: translateY(-1px); box-shadow: var(--shadow-sm); }
.dark .lm-club-opt { border-color: rgba(255,255,255,0.12); }
.lm-club-info { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.lm-club-name { font-weight: 700; font-size: 0.88rem; color: var(--text-bright); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lm-club-rep { font-size: 0.7rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.05em; }

/* ── Inicio: layout 2 columnas ── */
.lm-inicio { display: flex; flex-direction: column; gap: 12px; }

.lm-inicio-top {
  display: grid;
  grid-template-columns: 1fr minmax(230px, 280px);
  gap: 16px;
  align-items: start;
}
@media (max-width: 720px) {
  .lm-inicio-top { grid-template-columns: 1fr; }
}
.lm-inicio-left { display: flex; flex-direction: column; gap: 10px; }
.lm-inicio-right { display: flex; flex-direction: column; gap: 0; }

.lm-resumen { text-align: center; padding: 4px 0 4px; min-width: 0; }
.lm-resumen-club { font-family: var(--font-title,'Inter',sans-serif); font-size: 1.45rem; font-weight: 800; color: var(--text-bright); line-height: 1; }
.lm-resumen-liga { font-size: 0.78rem; color: var(--text-muted); margin-top: 3px; }
.lm-resumen-stats { display: flex; justify-content: center; gap: 16px; margin-top: 10px; }
.lm-rstat { display: flex; flex-direction: column; align-items: center; }
.lm-rstat b { font-family: var(--font-title,'Inter',sans-serif); font-size: 1.25rem; font-weight: 800; color: var(--text-bright); line-height: 1; }
.lm-rstat span { font-size: 0.66rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.06em; margin-top: 3px; }

.lm-card { background: var(--bg-elevated, rgba(0,0,0,0.03)); border: 1px solid rgba(0,0,0,0.07); border-radius: 12px; padding: 14px 16px; }
.dark .lm-card { background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.08); }
.lm-ultimo-label, .lm-proximo-label { font-size: 0.68rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-muted); margin-bottom: 6px; }
.lm-ultimo-score { font-size: 1.1rem; font-weight: 700; color: var(--text-bright); display: flex; align-items: center; justify-content: center; gap: 12px; }
.lm-ms-goles { display: inline-block; padding: 2px 12px; border-radius: 6px; background: rgba(0,0,0,0.06); font-weight: 800; }
.dark .lm-ms-goles { background: rgba(255,255,255,0.1); }
.lm-ms-team { display: inline-flex; align-items: center; gap: 7px; }
.lm-ms-vs { color: var(--text-muted); font-weight: 700; font-size: 0.9rem; }
.lm-ultimo-goles { font-size: 0.78rem; color: var(--text-muted); margin-top: 8px; text-align: center; }
.lm-ultimo.win { border-left: 3px solid var(--green,#27ae60); }
.lm-ultimo.loss { border-left: 3px solid var(--red,#e74c3c); }
.lm-ultimo.draw { border-left: 3px solid var(--text-muted); }
.lm-proximo-match { font-size: 1.05rem; font-weight: 700; color: var(--text-bright); display: flex; align-items: center; justify-content: center; gap: 12px; }
.lm-fin { font-size: 1.1rem; font-weight: 700; text-align: center; color: var(--text-bright); }

/* ── Columna derecha de inicio: simular + controles ── */
.lm-acciones-row {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.lm-btn-jugar {
  width: 100%;
  padding: 10px 16px; font-size: 0.88rem; font-weight: 800; letter-spacing: 0.04em;
  background: linear-gradient(135deg, #059669, #047857); color: #fff; border: none;
  border-radius: 10px; cursor: pointer; transition: filter 0.15s ease; white-space: nowrap;
  text-transform: uppercase;
}
.lm-btn-jugar:hover { filter: brightness(1.08); }
.lm-btn-jugar:disabled { opacity: 0.5; cursor: not-allowed; }

.lm-acciones-right {
  display: flex;
  flex-direction: column;
  gap: 7px;
  background: var(--bg-surface);
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 10px;
  padding: 10px 11px;
}
.dark .lm-acciones-right { border-color: rgba(255,255,255,0.08); background: rgba(255,255,255,0.04); }

.lm-aux-controls {
  display: flex;
  gap: 6px;
}
.lm-aux-btn {
  flex: 1;
  padding: 6px 8px;
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 8px;
  background: var(--bg-elevated, rgba(255,255,255,0.04));
  color: var(--text-dim);
  font-size: 0.72rem;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.12s ease;
  white-space: nowrap;
}
.lm-aux-btn:hover { background: rgba(5,150,105,0.10); color: #059669; border-color: rgba(5,150,105,0.25); }
.lm-aux-btn.active { background: rgba(5,150,105,0.15); color: #059669; }
.dark .lm-aux-btn { border-color: rgba(255,255,255,0.08); background: rgba(255,255,255,0.04); }
.dark .lm-aux-btn:hover { color: #34d399; background: rgba(52,211,153,0.14); border-color: rgba(52,211,153,0.35); }
.dark .lm-aux-btn.active { color: #34d399; background: rgba(52,211,153,0.22); }

.lm-inicio-right .lm-aux-btn { font-size: 0.7rem; padding: 6px 4px; }
.lm-inicio-right .csp-btn { font-size: 0.65rem; padding: 4px 2px; letter-spacing: -0.01em; }
.lm-inicio-right .lm-live-toggle { justify-content: center; font-size: 0.72rem; margin-top: 2px; }

@media (max-width: 720px) {
  .lm-aux-controls { flex-direction: column; gap: 4px; }
  .lm-aux-btn,
  .lm-inicio-right .lm-aux-btn { width: 100%; padding: 8px; font-size: 0.78rem; }
  .csp-group { flex-wrap: wrap; }
  .csp-btn { flex: 1 1 45%; min-width: 60px; padding: 6px 4px; font-size: 0.68rem; }
}

.csp-group {
  display: flex;
  gap: 2px;
  background: rgba(0,0,0,0.06);
  border-radius: 8px;
  padding: 2px;
  width: 100%;
}
.dark .csp-group { background: rgba(255,255,255,0.06); }
.csp-btn {
  flex: 1;
  padding: 4px 8px;
  border: none;
  border-radius: 6px;
  background: transparent;
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--text-dim);
  cursor: pointer;
  transition: background 0.12s, color 0.12s;
  white-space: nowrap;
}
.csp-btn.active {
  background: #fff;
  color: #059669;
  box-shadow: 0 1px 3px rgba(0,0,0,0.15);
}
.dark .csp-btn.active {
  background: rgba(5,150,105,0.25);
  color: #34d399;
  box-shadow: none;
}

/* ── Mini tabla ── */
.lm-mini-tabla, .lm-tabla, .lm-plantel, .lm-fixture { font-size: 0.85rem; }
.lm-mt-head, .lm-mt-row { display: grid; grid-template-columns: 28px 1fr 32px 36px; align-items: center; padding: 5px 8px; }
.lm-mt-head { font-size: 0.66rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--text-muted); border-bottom: 1px solid rgba(0,0,0,0.08); }
.lm-mt-row { border-bottom: 1px solid rgba(0,0,0,0.04); }
.lm-mt-row.mio { background: rgba(5,150,105,0.1); font-weight: 700; border-radius: 6px; }
.lm-mt-pts { font-weight: 800; text-align: right; }
.lm-mt-pj { text-align: right; color: var(--text-muted); }
.lm-mt-sep { text-align: center; color: var(--text-muted); padding: 2px; }

/* ── Secciones (tabla, plantel, fixture) ── */
.lm-seccion-title { font-family: var(--font-title,'Inter',sans-serif); font-size: 1.3rem; font-weight: 800; color: var(--text-bright); margin: 0 0 14px; }
.lm-tb-head, .lm-tb-row { display: grid; grid-template-columns: 28px 1fr repeat(8, 30px); align-items: center; padding: 6px 8px; text-align: center; }
.lm-tb-head { font-size: 0.62rem; text-transform: uppercase; color: var(--text-muted); border-bottom: 1.5px solid rgba(0,0,0,0.1); }
.lm-tb-row { border-bottom: 1px solid rgba(0,0,0,0.04); }
.lm-tb-name, .lm-tb-head span:nth-child(2) { text-align: left; }
.lm-tb-row.mio { background: rgba(5,150,105,0.12); font-weight: 700; }
.lm-tb-row.desc { box-shadow: inset 3px 0 0 var(--red,#e74c3c); }
.lm-tb-pts { font-weight: 800; }
.lm-tb-pos { color: var(--text-muted); }
@media (max-width: 560px) {
  .lm-tb-head, .lm-tb-row { grid-template-columns: 22px 1fr 24px 24px 24px 24px 28px; font-size: 0.7rem; overflow: hidden; white-space: nowrap; }
  .lm-tb-head span:nth-child(n+7):not(:last-child), .lm-tb-row span:nth-child(n+7):not(:last-child) { display: none; }
  /* Plantel mobile: 2 filas — datos arriba, acciones abajo */
  .lm-pl-head { display: none; }
  .lm-pl-row { grid-template-columns: 1fr; padding: 8px 8px 6px; gap: 0; }
  .lm-pl-data { display: grid; grid-template-columns: auto 1fr auto auto; align-items: center; gap: 4px 6px; padding-bottom: 4px; }
  .lm-pl-data .lm-pl-pos { grid-column: 1; }
  .lm-pl-data .lm-pl-name { grid-column: 2; font-size: 0.82rem; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .lm-pl-data .lm-pl-nac, .lm-pl-data .lm-pl-edad { display: none; }
  .lm-pl-data .lm-pl-rat { grid-column: 3; font-size: 0.82rem; font-weight: 800; }
  .lm-pl-data .lm-pl-val { grid-column: 4; font-size: 0.72rem; color: var(--text-muted); }
  .lm-pl-data .lm-pl-ctr-cell { display: none; }
  .lm-pl-act-row { padding-top: 4px; border-top: 1px solid rgba(255,255,255,0.04); }
  .lm-pl-act-cell { gap: 6px; justify-content: flex-start; }
  .lm-pl-renovar { font-size: 0.62rem; padding: 2px 6px; }
  .lm-pl-badge.cedido { font-size: 0.58rem; padding: 1px 5px; }
}

/* ── Top jugadores liga externa ── */
.lm-top-jugs-ext { margin-top: 16px; }
.lm-top-jug-row { display: grid; grid-template-columns: 42px 1fr auto 36px; align-items: center; gap: 8px; padding: 6px 4px; border-bottom: 1px solid rgba(255,255,255,0.04); font-size: 0.83rem; }
.lm-top-jug-name { font-weight: 600; color: var(--text-bright); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lm-top-jug-club { color: var(--text-muted); font-size: 0.72rem; }
.lm-top-jug-rat { font-weight: 800; color: var(--text-bright); text-align: right; }

/* ── Plantel ── */
/* Columnas: Pos | Nombre | Nac | Edad | Media | Valor | Contrato | Acciones */
.lm-pl-head { display: grid; grid-template-columns: 46px 1fr 38px 46px 52px 64px 82px auto; align-items: center; padding: 6px 10px; gap: 4px; }
.lm-pl-head { font-size: 0.62rem; text-transform: uppercase; color: var(--text-muted); border-bottom: 1.5px solid rgba(0,0,0,0.1); }
.lm-pl-head span { font-weight: 600; font-size: 0.62rem; color: var(--text-muted); }
.lm-pl-row { display: grid; grid-template-columns: 1fr auto; align-items: center; padding: 6px 10px; gap: 4px; border-bottom: 1px solid rgba(0,0,0,0.06); }
.lm-pl-row:nth-child(even) { background: rgba(255,255,255,0.028); }
.lm-pl-row:hover { background: rgba(16,185,129,0.07) !important; }
.lm-pl-data { display: grid; grid-template-columns: 46px 1fr 38px 46px 52px 64px 82px; align-items: center; gap: 4px; }
.lm-pl-act-row { display: flex; align-items: center; justify-content: flex-end; gap: 4px; }
.lm-pl-pos { font-size: 0.68rem; font-weight: 700; color: var(--azul,#0038a8); }
.dark .lm-pl-pos { color: #60a5fa; }
.lm-pl-name { font-weight: 600; color: var(--text-bright); }
.lm-pl-nac, .lm-pl-edad { font-size: 0.72rem; color: var(--text-muted); text-align: center; }
.lm-pl-rat { font-weight: 800; text-align: center; }
.lm-pl-val { font-size: 0.76rem; color: var(--text-muted); text-align: right; }
.lm-pl-ctr-cell { text-align: center; }
.lm-pl-act-cell { display: flex; align-items: center; gap: 4px; justify-content: flex-end; }
.lm-pl-head .lm-pl-act-cell, .lm-pl-head [style*="text-align:right"] { text-align: right; }
.lm-pl-ctr { font-size: 0.72rem; font-weight: 700; }
.lm-pl-ctr.ctr-alerta { color: #f59e0b; }
.lm-pl-ctr.ctr-vencido { color: #ef4444; }
.lm-pl-renovar { padding: 2px 8px; border-radius: 5px; border: 1px solid rgba(255,255,255,0.2); background: transparent; color: var(--text-muted); font-size: 0.68rem; font-weight: 700; cursor: pointer; white-space: nowrap; }
.lm-pl-renovar:hover { background: rgba(5,150,105,0.3); border-color: #059669; color: #10b981; }

/* ── Fixture ── */
.lm-fx-header { display: flex; align-items: baseline; justify-content: space-between; flex-wrap: wrap; gap: 8px; margin-bottom: 10px; }
.lm-fx-header .lm-seccion-title { margin: 0; }
.lm-fx-resumen { display: flex; align-items: center; gap: 14px; font-size: 0.8rem; }
.lm-fx-prog { color: var(--text-muted); font-weight: 600; }
.lm-fx-record { color: var(--text-dim); font-weight: 600; }
.lm-fx-record b { font-weight: 800; }
.lm-fx-record b.win { color: var(--green,#27ae60); }
.lm-fx-record b.draw { color: var(--text-muted); }
.lm-fx-record b.loss { color: var(--red,#e74c3c); }

/* Contenedor scrolleable: posicionado en la próxima */
.lm-fixture-scroll {
  position: relative; max-height: 55vh; overflow-y: auto;
}
.lm-fixture-scroll .lm-intl-fix-fecha { margin-bottom: 0; }
.lm-fixture-scroll .lm-intl-fix-row { border-bottom: 1px solid rgba(0,0,0,0.04); }
.lm-fixture-scroll .lm-intl-fix-row.mia { background: rgba(5,150,105,0.08); border-radius: 6px; }
.lm-fixture-scroll .lm-intl-fix-row.win .lm-intl-fix-score { color: var(--green,#27ae60); }
.lm-fixture-scroll .lm-intl-fix-row.loss .lm-intl-fix-score { color: var(--red,#e74c3c); }
.lm-fixture-scroll .lm-intl-fix-row.next { background: rgba(5,150,105,0.1); box-shadow: inset 3px 0 0 #059669; }
.lm-fx-pillcell { text-align: center; margin-left: 6px; }
.lm-fx-pill { display: inline-flex; align-items: center; justify-content: center; width: 20px; height: 20px; border-radius: 50%; font-size: 0.65rem; font-weight: 800; color: #fff; }
.lm-fx-pill.win { background: var(--green,#27ae60); }
.lm-fx-pill.draw { background: #9ca3af; }
.lm-fx-pill.loss { background: var(--red,#e74c3c); }

/* ── Fixture responsive mobile ── */
@media (max-width: 560px) {
  .lm-fx-header { flex-direction: column; align-items: flex-start; gap: 4px; }
  .lm-fx-resumen { gap: 10px; font-size: 0.72rem; }
  .lm-fixture-scroll .lm-intl-fix-row { padding: 5px 8px; font-size: 0.74rem; }
  .lm-fixture-scroll .lm-intl-fix-score { min-width: 36px; }
}

/* ── Fin de temporada ── */
.lm-fin-temp { display: flex; flex-direction: column; gap: 14px; }

.lm-fin-header { text-align: center; padding: 8px 0 14px; }
.lm-fin-liga { font-size: 0.8rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 10px; }
.lm-fin-campeon { font-family: var(--font-title,'Inter',sans-serif); font-size: 1.7rem; font-weight: 800; color: #d97706; line-height: 1.1; }
.lm-fin-campeon-otro { font-size: 1rem; color: var(--text-bright); }
.lm-fin-campeon-otro b { color: #d97706; }

.lm-fin-tu { padding: 14px 16px; }
.lm-fin-tu.campeon { border-left: 3px solid #d97706; background: rgba(217,119,6,0.07); }
.lm-fin-tu.loss    { border-left: 3px solid var(--red,#e74c3c); background: rgba(231,76,60,0.06); }
.lm-fin-tu.win     { border-left: 3px solid var(--green,#27ae60); background: rgba(39,174,96,0.06); }
.dark .lm-fin-tu.campeon { background: rgba(217,119,6,0.13); }
.dark .lm-fin-tu.loss    { background: rgba(231,76,60,0.11); }
.dark .lm-fin-tu.win     { background: rgba(39,174,96,0.11); }
.lm-fin-tu-title { font-weight: 700; font-size: 1rem; color: var(--text-bright); margin-bottom: 4px; }
.lm-fin-tu-stats { font-size: 0.82rem; color: var(--text-muted); }

.lm-ft-section-title {
  font-size: 0.64rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.08em; color: var(--text-muted); margin-bottom: 10px;
}

/* Tabla de promedios (4 cols: #, nombre, pts/pj, promedio) */
.lm-prom-head, .lm-prom-row {
  display: grid; grid-template-columns: 28px 1fr 72px 60px;
  align-items: center; padding: 5px 8px;
}
.lm-prom-head {
  font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.05em;
  color: var(--text-muted); border-bottom: 1px solid rgba(0,0,0,0.08);
}
.lm-prom-row { border-bottom: 1px solid rgba(0,0,0,0.04); font-size: 0.82rem; }
.lm-prom-row.mio  { background: rgba(5,150,105,0.12); font-weight: 700; border-radius: 4px; }
.lm-prom-row.desc { box-shadow: inset 3px 0 0 var(--red,#e74c3c); background: rgba(231,76,60,0.05); }
.lm-prom-row.mio.desc { background: rgba(231,76,60,0.14); box-shadow: inset 3px 0 0 var(--red,#e74c3c); }
.dark .lm-prom-row.desc { background: rgba(231,76,60,0.1); }
.lm-prom-ratio { text-align: right; font-size: 0.76rem; color: var(--text-muted); }
.lm-prom-val   { text-align: right; font-weight: 800; }

.lm-ft-movimientos { padding: 12px 16px; display: flex; flex-direction: column; gap: 6px; }
.lm-ft-desc b      { font-weight: 700; }
.lm-ft-desc        { color: var(--red,#e74c3c); font-size: 0.88rem; font-weight: 600; }
.lm-ft-asc-pending { color: var(--text-muted); font-size: 0.82rem; }

/* Historial de temporadas anteriores */
.lm-log-row {
  display: grid; grid-template-columns: 1fr 32px 1fr auto;
  gap: 8px; align-items: center; padding: 5px 0;
  border-bottom: 1px solid rgba(0,0,0,0.04); font-size: 0.8rem;
}
.lm-log-t    { font-weight: 600; color: var(--text-dim); }
.lm-log-pos  { font-weight: 800; text-align: center; }
.lm-log-camp { color: var(--text-muted); font-size: 0.77rem; }
.lm-log-desc { color: var(--red,#e74c3c); font-size: 0.74rem; text-align: right; white-space: nowrap; }

.lm-btn-siguiente-temp {
  width: 100%; padding: 15px; font-size: 1.05rem; font-weight: 800;
  letter-spacing: 0.03em; background: linear-gradient(135deg, #059669, #047857);
  color: #fff; border: none; border-radius: 12px; cursor: pointer;
  transition: filter 0.15s ease; margin-top: 4px;
}
.lm-btn-siguiente-temp:hover { filter: brightness(1.08); }

/* ── Mercado de pases ── */
.lm-mercado { display: flex; flex-direction: column; gap: 14px; }

.lm-mk-head {
  display: grid; grid-template-columns: 1fr auto auto auto; gap: 18px; align-items: center;
  background: var(--bg-elevated, rgba(0,0,0,0.03)); border: 1px solid rgba(0,0,0,0.07);
  border-radius: 12px; padding: 14px 18px;
}
.dark .lm-mk-head { background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.08); }
.lm-mk-club { display: flex; align-items: center; gap: 10px; min-width: 0; }
.lm-mk-clubname { font-family: var(--font-title,'Inter',sans-serif); font-weight: 800; font-size: 1.05rem; color: var(--text-bright); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lm-mk-stat { display: flex; flex-direction: column; gap: 2px; text-align: right; }
.lm-mk-stat-label { font-size: 0.64rem; text-transform: uppercase; letter-spacing: 0.07em; color: var(--text-muted); }
.lm-mk-stat-val { font-family: var(--font-title,'Inter',sans-serif); font-size: 1.4rem; font-weight: 800; color: var(--text-bright); line-height: 1; }
.lm-mk-stat-val.budget { color: #059669; }
.dark .lm-mk-stat-val.budget { color: #34d399; }
.lm-mk-max { font-size: 0.85rem; font-weight: 600; color: var(--text-muted); }
.lm-mk-estado { text-align: right; font-size: 0.82rem; font-weight: 700; white-space: nowrap; }
.lm-mk-open { color: #059669; }
.dark .lm-mk-open { color: #34d399; }
.lm-mk-closed { color: var(--red,#e74c3c); }
@media (max-width: 640px) { .lm-mk-head { grid-template-columns: 1fr 1fr; } .lm-mk-estado { grid-column: 1 / -1; text-align: left; } }

.lm-mk-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items: start; }
@media (max-width: 720px) { .lm-mk-cols { grid-template-columns: 1fr; } }
.lm-mk-col { display: flex; flex-direction: column; }
.lm-mk-coltitle { display: flex; align-items: center; gap: 7px; font-size: 0.82rem; font-weight: 800; color: var(--text-bright); margin: 0 0 10px; }
.lm-mk-dot { width: 9px; height: 9px; border-radius: 50%; display: inline-block; flex-shrink: 0; }
.lm-mk-dot.in  { background: #059669; }
.lm-mk-dot.out { background: var(--red,#e74c3c); }

.lm-mk-filtros { display: flex; flex-wrap: wrap; gap: 5px; margin-bottom: 10px; }
.lm-mk-filtro {
  padding: 4px 11px; border-radius: 999px; border: 1px solid rgba(0,0,0,0.14);
  background: transparent; font-size: 0.74rem; font-weight: 700; color: var(--text-dim);
  cursor: pointer; transition: all 0.12s ease;
}
.dark .lm-mk-filtro { border-color: rgba(255,255,255,0.16); }
.lm-mk-filtro:hover { border-color: #059669; color: var(--text-bright); }
.lm-mk-filtro.active { background: #059669; border-color: #059669; color: #fff; }

/* Encabezado de columnas + filas alineadas (mismas plantillas) */
.lm-mk-colhead, .lm-mk-row {
  display: grid; grid-template-columns: 42px 1fr 28px 36px 64px 130px;
  align-items: center; gap: 8px;
}
.lm-mk-colhead {
  padding: 4px 6px; font-size: 0.62rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.05em; color: var(--text-muted); border-bottom: 1.5px solid rgba(0,0,0,0.1);
}
.dark .lm-mk-colhead { border-bottom-color: rgba(255,255,255,0.12); }
.lm-mk-colhead span:nth-child(3), .lm-mk-colhead span:nth-child(4) { text-align: center; }
.lm-mk-colhead span:nth-child(5) { text-align: right; }

/* Las dos listas con la MISMA altura fija → columnas simétricas */
.lm-mk-list { display: flex; flex-direction: column; height: 430px; overflow-y: auto; }
.lm-mk-row {
  padding: 8px 6px; border-bottom: 1px solid rgba(0,0,0,0.05); font-size: 0.9rem;
}
.dark .lm-mk-row { border-bottom-color: rgba(255,255,255,0.06); }
.lm-mk-row:hover { background: rgba(5,150,105,0.05); }
.lm-mk-pos {
  font-size: 0.66rem; font-weight: 800; color: #fff; background: var(--azul,#0038a8);
  border-radius: 5px; padding: 2px 0; text-align: center; letter-spacing: 0.02em;
}
.dark .lm-mk-pos { background: #2563eb; }
.lm-mk-name { font-weight: 700; color: var(--text-bright); display: flex; flex-direction: column; line-height: 1.25; overflow: hidden; }
.lm-mk-from { font-size: 0.68rem; font-weight: 600; color: var(--text-dim); display: inline-flex; align-items: center; gap: 4px; }
.lm-mk-age { font-size: 0.82rem; color: var(--text-dim); text-align: center; }
.lm-mk-rat { font-weight: 800; text-align: center; font-size: 0.95rem; color: var(--text-bright); }
.lm-mk-price { font-size: 0.82rem; font-weight: 800; text-align: right; color: var(--text-bright); }
.lm-mk-price.venta { color: #059669; }
.dark .lm-mk-price.venta { color: #34d399; }
.lm-mk-btn {
  padding: 5px 10px; border-radius: 7px; border: none; font-size: 0.76rem; font-weight: 800;
  cursor: pointer; transition: filter 0.12s ease, opacity 0.12s ease;
}
.lm-mk-btn.fichar { background: #059669; color: #fff; }
.lm-mk-btn.vender { background: rgba(231,76,60,0.16); color: var(--red,#e74c3c); }
.dark .lm-mk-btn.vender { color: #f87171; }
.lm-mk-btn:hover:not(:disabled) { filter: brightness(1.08); }
.lm-mk-btn:disabled { opacity: 0.3; cursor: not-allowed; }
.lm-mk-empty { padding: 26px 8px; text-align: center; font-size: 0.85rem; color: var(--text-muted); }

.lm-mk-logwrap { border-top: 1px solid rgba(0,0,0,0.08); padding-top: 14px; }
.dark .lm-mk-logwrap { border-top-color: rgba(255,255,255,0.1); }
.lm-mk-log { display: flex; flex-direction: column; gap: 1px; }
.lm-mk-logrow { display: grid; grid-template-columns: 22px 1fr auto; gap: 8px; align-items: center; padding: 6px 4px; font-size: 0.84rem; border-bottom: 1px solid rgba(0,0,0,0.04); }
.dark .lm-mk-logrow { border-bottom-color: rgba(255,255,255,0.05); }
.lm-mk-logico { text-align: center; }
.lm-mk-logtxt { color: var(--text-dim); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lm-mk-logtxt b { color: var(--text-bright); font-weight: 700; }
.lm-mk-lograt { font-weight: 800; color: var(--azul,#0038a8); font-size: 0.78rem; }
.dark .lm-mk-lograt { color: #60a5fa; }
.lm-mk-logarrow { color: var(--text-muted); }
.lm-mk-logmonto { font-weight: 800; font-size: 0.82rem; }
.lm-mk-logrow.in  .lm-mk-logmonto { color: #059669; }
.dark .lm-mk-logrow.in .lm-mk-logmonto { color: #34d399; }
.lm-mk-logrow.out .lm-mk-logmonto { color: var(--red,#e74c3c); }
.dark .lm-mk-logrow.out .lm-mk-logmonto { color: #f87171; }
.lm-mk-logrow.ia  .lm-mk-logmonto { color: var(--text-muted); }

/* ── Escudos integrados (Liga Master) ── */
.lm-title-conescudo { display: flex; align-items: center; gap: 10px; }
.lm-resumen-escudo { display: flex; justify-content: center; margin-bottom: 4px; }
.lm-mt-name, .lm-tb-name { display: flex; align-items: center; gap: 7px; min-width: 0; text-align: left; }
.lm-mt-name > span, .lm-tb-name > span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lm-fx-local { display: flex; align-items: center; justify-content: flex-end; gap: 8px; }
.lm-fx-visit { display: flex; align-items: center; justify-content: flex-start; gap: 8px; }
.lm-fx-tn { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.badge-img-wrap, .lm-mt-name svg, .lm-tb-name svg, .lm-fx-row svg { flex-shrink: 0; }

/* ── Controles de orden / filtro (plantel, mercado) ── */
.lm-posb { display: inline-block; min-width: 36px; text-align: center; padding: 2px 5px; border-radius: 5px; font-size: 0.62rem; font-weight: 800; color: #fff; letter-spacing: 0.02em; }
.lm-controls { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; margin-bottom: 10px; }
.lm-ctl-group { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.lm-ctl-label { font-size: 0.64rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-muted); font-weight: 700; }
.lm-ctl-btn { padding: 5px 12px; border-radius: 8px; border: 1px solid rgba(0,0,0,0.12); background: transparent; font-size: 0.78rem; font-weight: 700; color: var(--text-dim); cursor: pointer; transition: all 0.12s ease; }
.dark .lm-ctl-btn { border-color: rgba(255,255,255,0.14); }
.lm-ctl-btn:hover { border-color: #059669; color: var(--text-bright); }
.lm-ctl-btn.active { background: #059669; border-color: #059669; color: #fff; }
.lm-chips { display: flex; flex-wrap: wrap; gap: 5px; margin-bottom: 12px; }
.lm-chip { padding: 4px 11px; border-radius: 999px; border: 1px solid rgba(0,0,0,0.14); background: transparent; font-size: 0.72rem; font-weight: 700; color: var(--text-dim); cursor: pointer; transition: all 0.12s ease; }
.dark .lm-chip { border-color: rgba(255,255,255,0.16); }
.lm-chip:hover { border-color: #059669; color: var(--text-bright); }
.lm-chip.active { background: #059669; border-color: #059669; color: #fff; }
.lm-pl-pos { display: flex; align-items: center; }
.lm-mk-orden { display: flex; flex-wrap: wrap; gap: 5px; margin-bottom: 8px; }
.lm-ctl-btn.sm { padding: 3px 10px; font-size: 0.7rem; border-radius: 7px; }

/* ── Once / formación (Bloque A) ── */
.lm-once-hint { font-size: 0.8rem; color: var(--text-muted); margin: 0 0 6px; }
.lm-esq-row { flex-wrap: nowrap !important; overflow-x: auto; scrollbar-width: thin; scrollbar-color: rgba(255,255,255,0.12) transparent; padding-bottom: 2px; }
.lm-esq-select { appearance: none; -webkit-appearance: none; background: rgba(5,150,105,0.15) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2310b981' stroke-width='1.8' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat right 10px center; border: 1.5px solid #059669; border-radius: 8px; color: #10b981; font-size: 1rem; font-weight: 800; padding: 6px 34px 6px 14px; cursor: pointer; min-width: 120px; }
.lm-esq-select:focus { outline: none; border-color: #10b981; box-shadow: 0 0 0 2px rgba(16,185,129,0.25); }
.lm-esq-select option, .lm-esq-select optgroup { background: #0f172a; color: #e2e8f0; }
.lm-once-main { display: flex; gap: 14px; align-items: flex-start; margin-top: 8px; }
.lm-once-pitch { width: 320px; max-width: 360px; flex-shrink: 0; }
.lm-once-right { flex: 1; min-width: 0; }

.lm-pitch { position: relative; width: 100%; padding-bottom: 142%; border-radius: 10px; overflow: hidden; box-shadow: var(--shadow-sm); }
.lm-pitch-svg { position: absolute; inset: 0; width: 100%; height: 100%; display: block; }
.lm-token { position: absolute; width: 68px; transform: translate(-50%, -50%); display: flex; flex-direction: column; align-items: center; cursor: pointer; z-index: 2; transition: transform 0.12s ease, z-index 0s; }
.lm-token:hover { transform: translate(-50%, -50%) scale(1.08); z-index: 10; }
.lm-token-top { position: relative; width: 52px; height: 58px; display: flex; justify-content: center; align-items: flex-end; }
.lm-token-rat { position: absolute; top: -7px; right: -8px; min-width: 24px; height: 24px; display: flex; align-items: center; justify-content: center; background: rgba(0,0,0,0.92); color: #fff; border-radius: 50%; font-size: 0.72rem; font-weight: 800; border: 2px solid rgba(255,255,255,0.92); z-index: 3; line-height: 1; }
.lm-token-pen { position: absolute; top: -7px; left: -8px; min-width: 22px; height: 22px; display: flex; align-items: center; justify-content: center; background: #f97316; color: #fff; border-radius: 50%; font-size: 0.62rem; font-weight: 800; z-index: 3; box-shadow: 0 1px 3px rgba(0,0,0,0.4); }
.lm-token-name { margin-top: 3px; font-size: 0.68rem; font-weight: 700; color: #fff; text-align: center; line-height: 1.1; max-width: 82px; padding: 2px 6px; background: rgba(0,0,0,0.82); border-radius: 4px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.lm-token.sel .lm-token-rat { border-color: #fbbf24; box-shadow: 0 0 0 2px #fbbf24; background: rgba(30,20,0,0.95); }
.lm-token.sel .lm-token-name { background: rgba(120,80,0,0.88); outline: 1.5px solid #fbbf24; }
.lm-token.fuera .lm-shirt-svg { filter: drop-shadow(0 0 5px #f97316); }
.lm-token.fuera .lm-token-name { background: rgba(249,115,22,0.88); }

.lm-once-suplentes { display: flex; flex-direction: column; gap: 3px; max-height: 220px; overflow-y: auto; }
.lm-once-reservas { max-height: 160px; opacity: 0.7; }
.lm-once-reserva { color: var(--text-muted) !important; }
.lm-once-reserva:hover { opacity: 1; background: rgba(100,100,120,0.08) !important; }
.lm-once-reserva.sel { border-color: #93c5fd !important; background: rgba(147,197,253,0.1) !important; opacity: 1; }
.lm-banco-count { font-size: 0.7rem; font-weight: 600; color: var(--text-muted); padding: 1px 6px; border-radius: 8px; background: rgba(255,255,255,0.06); }
.lm-reservas-title { margin-top: 10px; }
.lm-once-supl { display: grid; grid-template-columns: 42px 1fr 32px; align-items: center; gap: 8px; padding: 8px; border: 1px solid transparent; border-radius: 8px; background: transparent; cursor: pointer; text-align: left; transition: background 0.12s ease, border-color 0.12s ease; }
.lm-once-supl:hover { background: rgba(5,150,105,0.07); }
.lm-once-supl.sel { border-color: #fbbf24; background: rgba(251,191,36,0.13); }
.lm-once-supl-name { font-weight: 600; color: var(--text-bright); font-size: 0.86rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lm-once-supl-rat { font-weight: 800; text-align: center; color: var(--text-bright); }

/* ── Toggle "ver en vivo" ── */
.lm-live-toggle { display: flex; align-items: center; gap: 6px; font-size: 0.75rem; color: var(--text-muted); cursor: pointer; }
.lm-live-toggle input { width: 14px; height: 14px; accent-color: #059669; cursor: pointer; flex-shrink: 0; }

/* ── Partido en vivo (Bloque C) ── */
.lm-pt-overlay { position: fixed; inset: 0; z-index: 9000; background: rgba(8,12,20,0.82); backdrop-filter: blur(4px); display: flex; align-items: center; justify-content: center; padding: 16px; }
.lm-pt-card { width: 100%; max-width: 560px; background: var(--bg-surface); border-radius: 18px; box-shadow: 0 20px 60px rgba(0,0,0,0.4); overflow: hidden; display: flex; flex-direction: column; max-height: 92vh; }
.dark .lm-pt-card { background: #131a2a; }
.lm-pt-scoreboard { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 10px; padding: 20px 18px 8px; }
.lm-pt-team { display: flex; flex-direction: column; align-items: center; gap: 6px; font-weight: 700; font-size: 0.86rem; color: var(--text-bright); text-align: center; }
.lm-pt-score { display: flex; align-items: center; gap: 8px; font-family: var(--font-title,'Inter',sans-serif); font-size: 2.6rem; font-weight: 800; color: var(--text-bright); }
.lm-pt-score .lm-pt-sep { font-size: 1.6rem; color: var(--text-muted); }
.lm-pt-min { text-align: center; font-weight: 800; color: #059669; font-size: 0.95rem; padding-bottom: 8px; }
.dark .lm-pt-min { color: #34d399; }
.lm-pt-feed { flex: 1; overflow-y: auto; padding: 10px 18px; display: flex; flex-direction: column; gap: 4px; min-height: 200px; border-top: 1px solid rgba(0,0,0,0.06); border-bottom: 1px solid rgba(0,0,0,0.06); }
.dark .lm-pt-feed { border-color: rgba(255,255,255,0.08); }
.lm-pt-ev { display: grid; grid-template-columns: 32px 22px 1fr; align-items: center; gap: 8px; padding: 6px 8px; border-radius: 8px; font-size: 0.86rem; color: var(--text-dim); }
.lm-pt-ev.gol { background: rgba(5,150,105,0.1); color: var(--text-bright); }
.lm-pt-ev.gol.rival { background: rgba(231,76,60,0.1); }
.lm-pt-ev-min { font-weight: 800; color: var(--text-muted); font-size: 0.78rem; }
.lm-pt-ev-ico { text-align: center; }
.lm-pt-banco { color: #059669; font-size: 0.72rem; font-weight: 700; }
.lm-pt-controls { padding: 12px 18px 18px; display: flex; flex-wrap: wrap; gap: 8px; align-items: center; justify-content: center; }
.lm-pt-ctl { padding: 9px 14px; border-radius: 9px; border: 1px solid rgba(0,0,0,0.12); background: transparent; font-size: 0.84rem; font-weight: 700; color: var(--text-bright); cursor: pointer; transition: all 0.12s ease; }
.dark .lm-pt-ctl { border-color: rgba(255,255,255,0.16); }
.lm-pt-ctl:hover:not(:disabled) { border-color: #059669; }
.lm-pt-ctl:disabled { opacity: 0.4; cursor: not-allowed; }
.lm-pt-ctl.cambios { background: rgba(5,150,105,0.12); border-color: transparent; color: #059669; }
.dark .lm-pt-ctl.cambios { color: #34d399; }
.lm-pt-btn-cont { width: 100%; padding: 14px; font-size: 1rem; font-weight: 800; background: linear-gradient(135deg, #059669, #047857); color: #fff; border: none; border-radius: 12px; cursor: pointer; }
.lm-pt-btn-cont:hover { filter: brightness(1.08); }
/* Panel de cambios */
.lm-pt-cambios { width: 100%; }
.lm-pt-cambios-head { font-size: 0.8rem; font-weight: 700; color: var(--text-bright); margin-bottom: 10px; text-align: center; }
.lm-pt-cambios-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; max-height: 38vh; overflow-y: auto; margin-bottom: 10px; }
.lm-pt-cambios-tit { font-size: 0.64rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-muted); font-weight: 700; margin-bottom: 6px; }
.lm-pt-cj { display: grid; grid-template-columns: 38px 1fr 28px; align-items: center; gap: 6px; width: 100%; padding: 7px 6px; border: 1px solid transparent; border-radius: 8px; background: transparent; cursor: pointer; text-align: left; margin-bottom: 3px; transition: all 0.12s ease; }
.lm-pt-cj:hover { background: rgba(5,150,105,0.07); }
.lm-pt-cj.sel { border-color: #fbbf24; background: rgba(251,191,36,0.13); }
.lm-pt-cj-n { font-size: 0.82rem; font-weight: 600; color: var(--text-bright); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lm-pt-cj-r { font-weight: 800; text-align: center; color: var(--text-bright); font-size: 0.82rem; }
.lm-pt-cj-sal { font-size: 0.7rem; text-align: center; color: var(--text-muted); }
.lm-pt-cj-sust { display: grid; grid-template-columns: 38px 1fr 28px 20px; opacity: 0.4; cursor: default; pointer-events: none; }

/* ── B6-LESIONES-VIVO: Panel de cambio por expulsión/lesión ── */
.lm-pt-panel-cambio { position: fixed; inset: 0; z-index: 9100; background: rgba(8,12,20,0.88); backdrop-filter: blur(6px); display: flex; align-items: center; justify-content: center; padding: 16px; }
.lm-pt-pc-card { width: 100%; max-width: 420px; background: var(--bg-surface); border-radius: 16px; box-shadow: 0 20px 60px rgba(0,0,0,0.5); padding: 20px; display: flex; flex-direction: column; max-height: 80vh; overflow: hidden; }
.dark .lm-pt-pc-card { background: #131a2a; }
.lm-pt-pc-titulo { font-size: 1rem; font-weight: 800; color: var(--text-bright); text-align: center; margin-bottom: 4px; }
.lm-pt-pc-sub { font-size: 0.76rem; color: var(--text-muted); text-align: center; margin-bottom: 14px; }
.lm-pt-pc-lista { display: flex; flex-direction: column; gap: 4px; max-height: 48vh; overflow-y: auto; margin-bottom: 12px; padding-right: 4px; }
.lm-pt-pc-item { display: grid; grid-template-columns: 42px 1fr 36px; align-items: center; gap: 8px; width: 100%; padding: 9px 10px; border: 1px solid rgba(0,0,0,0.08); border-radius: 10px; background: transparent; cursor: pointer; text-align: left; transition: all 0.12s ease; }
.lm-pt-pc-item:hover { background: rgba(5,150,105,0.10); border-color: rgba(5,150,105,0.30); }
.dark .lm-pt-pc-item { border-color: rgba(255,255,255,0.06); }
.dark .lm-pt-pc-item:hover { background: rgba(5,150,105,0.16); border-color: rgba(5,150,105,0.35); }
.lm-pt-pc-pos { font-size: 0.72rem; font-weight: 700; color: var(--text-muted); text-align: center; }
.lm-pt-pc-nom { font-size: 0.86rem; font-weight: 600; color: var(--text-bright); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lm-pt-pc-rat { font-size: 0.88rem; font-weight: 800; color: var(--azul,#0038a8); text-align: center; }
.dark .lm-pt-pc-rat { color: #60a5fa; }
.lm-pt-pc-empty { font-size: 0.82rem; color: var(--text-muted); text-align: center; padding: 20px 0; }
.lm-pt-pc-cancel { width: 100%; padding: 10px; border: 1px solid rgba(231,76,60,0.3); border-radius: 10px; background: rgba(231,76,60,0.08); color: var(--red,#e74c3c); font-weight: 700; font-size: 0.84rem; cursor: pointer; transition: all 0.12s ease; }
.lm-pt-pc-cancel:hover { background: rgba(231,76,60,0.16); }

/* ── Ofertas / transferibles (Bloque B) ── */
.lm-mk-name-row { flex-direction: row !important; align-items: center; gap: 6px; }
.lm-mk-flag { border: none; background: transparent; cursor: pointer; font-size: 0.85rem; padding: 0; opacity: 0.35; filter: grayscale(1); transition: opacity 0.12s ease, filter 0.12s ease; flex-shrink: 0; }
.lm-mk-flag:hover { opacity: 0.7; }
.lm-mk-flag.on { opacity: 1; filter: none; }
.lm-mk-pactado { font-size: 0.62rem; font-weight: 800; color: var(--red,#e74c3c); text-transform: uppercase; letter-spacing: 0.04em; }
.lm-mk-row.pactado { opacity: 0.6; }

.lm-of-seccion { background: rgba(5,150,105,0.06); border: 1px solid rgba(5,150,105,0.18); border-radius: 12px; padding: 12px 14px; margin-bottom: 4px; }
.dark .lm-of-seccion { background: rgba(5,150,105,0.1); }
.lm-of-list { display: flex; flex-direction: column; gap: 8px; }
.lm-of-card { display: grid; grid-template-columns: 1fr auto auto; align-items: center; gap: 12px; background: var(--bg-surface); border: 1px solid rgba(0,0,0,0.07); border-radius: 10px; padding: 10px 12px; }
.dark .lm-of-card { background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.08); }
.lm-of-info { display: flex; align-items: center; gap: 10px; min-width: 0; }
.lm-of-txt { min-width: 0; }
.lm-of-jug { font-weight: 700; color: var(--text-bright); font-size: 0.9rem; display: flex; align-items: center; gap: 6px; }
.lm-of-rat { font-weight: 800; color: var(--azul,#0038a8); }
.dark .lm-of-rat { color: #60a5fa; }
.lm-of-club { font-size: 0.74rem; color: var(--text-muted); }
.lm-of-monto { font-family: var(--font-title,'Inter',sans-serif); font-size: 1.2rem; font-weight: 800; color: #059669; white-space: nowrap; }
.dark .lm-of-monto { color: #34d399; }
.lm-of-acts { display: flex; gap: 6px; }
.lm-of-ok, .lm-of-no { padding: 6px 12px; border-radius: 8px; border: none; font-size: 0.76rem; font-weight: 800; cursor: pointer; transition: filter 0.12s ease; }
.lm-of-ok { background: #059669; color: #fff; }
.lm-of-no { background: rgba(231,76,60,0.14); color: var(--red,#e74c3c); }
.lm-of-ok:hover, .lm-of-no:hover { filter: brightness(1.08); }
.lm-of-pactadas { margin-top: 10px; display: flex; flex-direction: column; gap: 4px; }
.lm-of-pact-tit { font-size: 0.72rem; font-weight: 700; color: var(--text-muted); }
.lm-of-pact { font-size: 0.8rem; color: var(--text-dim); }

.lm-notif-ofertas { cursor: pointer; background: rgba(5,150,105,0.12) !important; border-color: rgba(5,150,105,0.3) !important; color: var(--text-bright); font-size: 0.88rem; text-align: center; transition: filter 0.12s ease; }
.lm-notif-ofertas:hover { filter: brightness(1.05); }
.lm-notif-ofertas b { color: #059669; }
.dark .lm-notif-ofertas b { color: #34d399; }
.lm-mk-ayuda { font-size: 0.68rem; color: var(--text-muted); margin: 0 0 8px; line-height: 1.3; min-height: 18px; }
.lm-mk-enventa { font-size: 0.56rem; font-weight: 800; color: #059669; background: rgba(5,150,105,0.14); padding: 1px 5px; border-radius: 4px; text-transform: uppercase; letter-spacing: 0.03em; white-space: nowrap; }
.dark .lm-mk-enventa { color: #34d399; }

/* ── Nueva carrera ── */
.lm-nueva-carrera { display: block; margin: 6px auto 0; padding: 8px 14px; background: transparent; border: 1px solid rgba(0,0,0,0.12); border-radius: 8px; font-size: 0.78rem; font-weight: 600; color: var(--text-muted); cursor: pointer; transition: all 0.12s ease; }
.dark .lm-nueva-carrera { border-color: rgba(255,255,255,0.14); }
.lm-nueva-carrera:hover { border-color: var(--red,#e74c3c); color: var(--red,#e74c3c); }

/* ── Controles AUTO / velocidad (inicio) ── */
.lm-aux-controls { display: flex; align-items: center; gap: 4px; }
.lm-aux-btn { flex: 1; padding: 5px 8px; border-radius: 8px; border: 1px solid rgba(0,0,0,0.12); background: transparent; font-size: 0.73rem; font-weight: 700; color: var(--text-bright); cursor: pointer; transition: all 0.12s ease; white-space: nowrap; text-align: center; }
.dark .lm-aux-btn { border-color: rgba(255,255,255,0.16); }
.lm-aux-btn:hover:not(:disabled) { border-color: #059669; }
.lm-aux-btn.active { background: #059669; border-color: #059669; color: #fff; }
.lm-aux-btn:disabled { opacity: 0.4; cursor: not-allowed; }

/* ── Fase A: Stats, noticias, palmarés ── */
.lm-stats-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; align-items: start; }
@media (max-width: 720px) { .lm-stats-cols { grid-template-columns: 1fr; } }
.lm-stats-col { min-width: 0; }
.lm-gol-head, .lm-gol-row { display: grid; grid-template-columns: 26px 24px 1fr 32px; align-items: center; gap: 8px; padding: 6px 6px; }
.lm-gol-head { font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--text-muted); border-bottom: 1.5px solid rgba(0,0,0,0.1); }
.dark .lm-gol-head { border-bottom-color: rgba(255,255,255,0.12); }
.lm-gol-row { border-bottom: 1px solid rgba(0,0,0,0.05); font-size: 0.86rem; }
.dark .lm-gol-row { border-bottom-color: rgba(255,255,255,0.06); }
.lm-gol-row.mio { background: rgba(5,150,105,0.1); border-radius: 6px; font-weight: 700; }
.lm-gol-pos { font-weight: 700; color: var(--text-muted); text-align: center; }
.lm-gol-name { font-weight: 600; color: var(--text-bright); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lm-gol-num { font-weight: 800; text-align: center; color: var(--text-bright); }
.lm-gol-list, .lm-forma-list { display: flex; flex-direction: column; max-height: 460px; overflow-y: auto; }
.lm-forma-row { display: grid; grid-template-columns: 26px 1fr auto; align-items: center; gap: 8px; padding: 6px 6px; border-bottom: 1px solid rgba(0,0,0,0.05); font-size: 0.84rem; }
.dark .lm-forma-row { border-bottom-color: rgba(255,255,255,0.06); }
.lm-forma-row.mio { background: rgba(5,150,105,0.1); border-radius: 6px; font-weight: 700; }
.lm-racha { display: inline-flex; gap: 3px; }
.lm-racha-dot { display: inline-flex; align-items: center; justify-content: center; width: 17px; height: 17px; border-radius: 4px; font-size: 0.6rem; font-weight: 800; color: #fff; }
.lm-racha-dot.win { background: var(--green,#27ae60); }
.lm-racha-dot.draw { background: #9ca3af; }
.lm-racha-dot.loss { background: var(--red,#e74c3c); }
.lm-noticias { display: flex; flex-direction: column; gap: 4px; }
.lm-noticias-tit { font-size: 0.66rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.07em; color: var(--text-muted); margin-bottom: 4px; }
.lm-noticia { font-size: 0.83rem; color: var(--text-dim); display: flex; align-items: baseline; gap: 6px; padding: 4px 8px; border-radius: 6px; }
.lm-noticia-ico { flex-shrink: 0; font-size: 0.88rem; }
.lm-noticia.win { background: rgba(39,174,96,0.08); color: var(--text); }
.dark .lm-noticia.win { background: rgba(52,211,153,0.1); }
.lm-noticia.loss { background: rgba(231,76,60,0.07); }
.dark .lm-noticia.loss { background: rgba(248,113,113,0.1); }
.lm-noticia.goleada { background: rgba(217,119,6,0.08); }
.lm-noticia.retiro { background: rgba(245,158,11,0.1); color: var(--text); font-weight: 500; }
.dark .lm-noticia.retiro { background: rgba(252,211,77,0.1); }
.lm-noticia.contrato { background: rgba(239,68,68,0.09); color: var(--text); font-weight: 500; }
.dark .lm-noticia.contrato { background: rgba(248,113,113,0.1); }
.lm-noticia.aviso { background: rgba(245,158,11,0.08); color: var(--text-dim); }
.lm-noticia.lesion { background: rgba(59,130,246,0.08); color: var(--text-dim); }
.dark .lm-noticia.lesion { background: rgba(96,165,250,0.1); }
.lm-noticia.suspension { background: rgba(239,68,68,0.08); color: var(--text-dim); }
.dark .lm-noticia.suspension { background: rgba(248,113,113,0.1); }
.lm-club-stats { display: flex; flex-wrap: wrap; justify-content: space-around; gap: 14px; padding: 8px 0; }
.lm-palm-list { display: flex; flex-direction: column; gap: 2px; margin-top: 8px; }
.lm-palm-row { display: grid; grid-template-columns: 28px 1fr auto; align-items: center; gap: 8px; padding: 7px 4px; border-bottom: 1px solid rgba(0,0,0,0.05); font-size: 0.85rem; }
.dark .lm-palm-row { border-bottom-color: rgba(255,255,255,0.06); }
.lm-palm-ico { text-align: center; font-size: 1rem; }
.lm-palm-txt { color: var(--text-dim); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lm-palm-txt b { color: var(--text-bright); }
.lm-palm-temp { font-size: 0.72rem; font-weight: 700; color: var(--text-muted); }

/* ── Fuera de posición (FF2) ── */
.lm-once-warn { color: #f97316; font-weight: 700; }
.lm-once-token.fuera circle { animation: lmFueraPulse 1.6s ease-in-out infinite; }
@keyframes lmFueraPulse { 0%,100% { opacity: 1; } 50% { opacity: 0.62; } }

/* ── Progresión de rating (FF3) ── */
.lm-pl-rat { display: inline-flex; align-items: center; gap: 4px; justify-content: center; }
.lm-pl-delta { font-size: 0.6rem; font-weight: 800; }
.lm-pl-delta.up { color: var(--green,#27ae60); }
.lm-pl-delta.down { color: var(--red,#e74c3c); }

/* ── Estados: lesiones/suspensiones (FF5) ── */
.lm-indisp { font-size: 0.62rem; font-weight: 800; color: var(--red,#e74c3c); white-space: nowrap; }
.lm-pl-row.indisp { opacity: 0.62; }
.lm-once-supl.indisp { opacity: 0.5; cursor: not-allowed; }
.lm-once-supl.indisp .lm-once-supl-name { color: var(--text-muted); }
.lm-pt-ev.grave { background: rgba(231,76,60,0.1); }
.dark .lm-pt-ev.grave { background: rgba(231,76,60,0.14); }

/* ── Listar venta/cesión (FF6) ── */
.lm-mk-listar { display: flex; gap: 3px; justify-content: flex-end; align-items: center; }
.lm-mk-listar .lm-mk-flag { font-size: 0.95rem; }
.lm-mk-encesion { font-size: 0.56rem; font-weight: 800; color: #2563eb; background: rgba(37,99,235,0.14); padding: 1px 5px; border-radius: 4px; text-transform: uppercase; letter-spacing: 0.03em; white-space: nowrap; }
.dark .lm-mk-encesion { color: #60a5fa; }

/* ── Objetivos del presidente + cantera (FF9) ── */
.lm-obj-inicio { display: flex; align-items: center; gap: 8px; font-size: 0.88rem; flex-wrap: wrap; }
.lm-obj-inicio b { color: var(--text-bright); }
.lm-obj-tit { font-size: 0.66rem; text-transform: uppercase; letter-spacing: 0.07em; color: var(--text-muted); margin-bottom: 4px; }
.lm-obj-txt { font-size: 1rem; font-weight: 700; color: var(--text-bright); }
.lm-obj-warn { font-size: 0.78rem; color: var(--red,#e74c3c); margin-top: 6px; }
.lm-obj-fin.cumplido { border-left: 3px solid var(--green,#27ae60); background: rgba(39,174,96,0.07); }
.lm-obj-fin.fallido { border-left: 3px solid var(--red,#e74c3c); background: rgba(231,76,60,0.06); }
.dark .lm-obj-fin.cumplido { background: rgba(39,174,96,0.12); }
.dark .lm-obj-fin.fallido { background: rgba(231,76,60,0.1); }
.lm-obj-fin-tit { font-weight: 700; color: var(--text-bright); margin-bottom: 4px; }
.lm-obj-fin-res { font-size: 0.85rem; color: var(--text-dim); }
.lm-cant-list { display: flex; flex-direction: column; gap: 3px; }
.lm-cant-row { display: grid; grid-template-columns: 40px 1fr 36px auto; align-items: center; gap: 8px; padding: 7px 4px; border-bottom: 1px solid rgba(0,0,0,0.05); }
.dark .lm-cant-row { border-bottom-color: rgba(255,255,255,0.06); }
.lm-cant-name { font-weight: 600; color: var(--text-bright); font-size: 0.86rem; }
.lm-cant-name small { color: var(--text-muted); font-weight: 500; }
.lm-cant-rat { font-weight: 800; text-align: center; }
.lm-cant-btn { padding: 5px 12px; border-radius: 8px; border: none; background: #059669; color: #fff; font-size: 0.76rem; font-weight: 800; cursor: pointer; }
.lm-cant-btn:hover:not(:disabled) { filter: brightness(1.08); }
.lm-cant-btn:disabled { opacity: 0.4; cursor: not-allowed; }

/* ── Copa Argentina (FF8) ── */
.lm-copa-estado { font-size: 0.95rem; font-weight: 700; color: var(--text-bright); }
.lm-copa-estado.campeon { color: #d97706; }
.lm-copa-estado.out { color: var(--red,#e74c3c); }
.lm-copa-estado.vivo { color: #059669; }
.dark .lm-copa-estado.vivo { color: #34d399; }
.lm-copa-bracket { display: flex; flex-direction: column; gap: 16px; margin-top: 14px; }
.lm-copa-ronda-tit { font-size: 0.66rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.07em; color: var(--text-muted); margin-bottom: 8px; }
.lm-copa-llave { display: grid; grid-template-columns: 1fr 70px 1fr; align-items: center; gap: 8px; padding: 7px 8px; border-bottom: 1px solid rgba(0,0,0,0.05); font-size: 0.84rem; }
.dark .lm-copa-llave { border-bottom-color: rgba(255,255,255,0.06); }
.lm-copa-llave.mia { background: rgba(5,150,105,0.1); border-radius: 6px; }
.lm-copa-team { display: flex; align-items: center; gap: 6px; min-width: 0; }
.lm-copa-team:last-child { justify-content: flex-end; }
.lm-copa-team span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lm-copa-team.gana span { font-weight: 800; color: var(--text-bright); }
.lm-copa-team.pierde { opacity: 0.5; }
.lm-copa-res { text-align: center; font-weight: 800; font-size: 0.82rem; padding: 2px 4px; border-radius: 6px; background: rgba(0,0,0,0.05); }
.dark .lm-copa-res { background: rgba(255,255,255,0.08); }
.lm-copa-res small { font-weight: 600; color: var(--text-muted); }

/* ── IA-1: Copas Internacionales — Hero + Mini Cards ── */
.lm-intl-hero { display: flex; align-items: center; gap: 16px; padding: 20px 22px; border-radius: 14px; margin-bottom: 18px; border: 1px solid rgba(255,255,255,0.08); }
.lm-intl-hero--sin-copa { background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.12); border-left: 4px solid rgba(255,255,255,0.15); border-radius: 14px; padding: 20px 22px; margin-bottom: 18px; }
.lm-intl-hero-icon { font-size: 2.4rem; flex-shrink: 0; }
.lm-intl-hero-info { flex: 1; min-width: 0; }
.lm-intl-hero-title { font-size: 1.25rem; font-weight: 800; margin: 0 0 4px; letter-spacing: -0.02em; }
.lm-intl-hero-sub { font-size: 0.83rem; opacity: 0.8; }
.lm-intl-hero-badge { flex-shrink: 0; opacity: 0.85; }
.lm-intl-copas-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 14px; margin-top: 18px; }
.lm-intl-copa-card { border-radius: 10px; overflow: hidden; border: 1px solid rgba(255,255,255,0.07); background: rgba(255,255,255,0.02); }
.lm-intl-copa-card-header { display: flex; justify-content: space-between; align-items: center; gap: 8px; padding: 10px 14px; font-weight: 700; }
.lm-intl-copa-emoji { font-size: 1.1rem; }
.lm-intl-copa-nombre { font-size: 0.9rem; flex: 1; }
.lm-intl-copa-count { font-size: 0.72rem; opacity: 0.7; }
.lm-intl-copa-body { padding: 10px 14px 12px; }
.lm-intl-clf-liga { margin-bottom: 8px; }
.lm-intl-clf-pais { font-size: 0.7rem; font-weight: 700; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.06em; display: block; margin-bottom: 4px; }
.lm-intl-clf-items { display: flex; flex-wrap: wrap; gap: 4px 8px; }
.lm-intl-clf-item { display: inline-flex; align-items: center; gap: 5px; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.07); border-radius: 999px; padding: 2px 8px 2px 4px; font-size: 0.78rem; }
.lm-intl-clf-item small { color: var(--text-muted); font-size: 0.68rem; }
.lm-intl-clf-item.mio { font-weight: 700; color: #34d399; background: rgba(52,211,153,0.10); border-color: rgba(52,211,153,0.30); }

/* ── IA-4: Tabs de copas ajenas (modo espectador) ── */
.lm-intl-tabs { display: flex; gap: 4px; flex-wrap: wrap; margin-bottom: 16px; }
.lm-intl-tab { padding: 6px 14px; border-radius: 20px; border: 1px solid rgba(255,255,255,0.10); background: transparent; color: var(--text-muted); font-size: 0.8rem; cursor: pointer; transition: all 0.15s; font-weight: 600; }
.lm-intl-tab:hover { background: rgba(255,255,255,0.05); color: var(--text-bright); }
.lm-intl-tab.active { background: rgba(5,150,105,0.15); border-color: #059669; color: #34d399; font-weight: 700; }
.lm-intl-ajena { margin-top: 8px; }
.lm-intl-ajena-header { display: flex; align-items: center; gap: 8px; }

/* ════════════════════════════════════════════════
   FF10 — Responsive / mobile
   ════════════════════════════════════════════════ */
@media (max-width: 720px) {
  .lm-layout { gap: 10px; padding: 10px 8px; min-height: calc(100vh - 50px); }
  /* Menú: mantener columna vertical en mobile (iconos apilados) */
  .lm-menu { position: static; top: auto; }
  .lm-menu-header { padding: 10px 14px; }
  .lm-menu-title { font-size: 0.85rem; }
  .lm-menu-list { flex-direction: column; gap: 2px; padding: 6px; }
  .lm-menu-item { white-space: nowrap; padding: 8px 12px; font-size: 0.8rem; }
  .lm-panel { padding: 14px 11px; min-height: 0; }
  .lm-seccion-title { font-size: 1.15rem; }
  /* Alturas de listas más cortas para no comerse la pantalla */
  .lm-mk-list { height: 340px; }
  .lm-once-suplentes { max-height: 160px; }
  .lm-once-reservas { max-height: 100px; }
  .lm-gol-list, .lm-forma-list { max-height: 340px; }
  .lm-inicio-top { grid-template-columns: 1fr; }
  .lm-inicio-right { order: -1; }
  .lm-resumen-club { font-size: 1.25rem; }
  .lm-resumen-stats { gap: 14px; }
  .lm-once-pitch { width: 260px; max-width: 280px; }
  .lm-once-main { flex-direction: column; align-items: stretch; }
  .lm-once-right { min-width: 0; width: 100%; }
  .lm-once-suplentes { max-height: none; }
  .lm-token { transform: translate(-50%, -50%) scale(0.88); }
  /* IA-1: Copas internacionales responsive */
  .lm-intl-hero { flex-wrap: wrap; padding: 16px; }
  .lm-intl-hero--sin-copa { padding: 16px; }
  .lm-intl-copas-grid { grid-template-columns: 1fr; }
  .lm-intl-hero-title { font-size: 1.1rem; }
}

/* ── Tabs mobile del mercado (ocultos en desktop) ── */
.lm-mk-tabs { display: none; }
.lm-mk-toggle-rangos { display: none; }

/* ── MERCADO MOBILE: breakpoint 640px ── */
@media (max-width: 640px) {
  /* Cortar overflow horizontal en el panel */
  .lm-panel { overflow-x: hidden; }

  /* Tabs Tu plantel / Comprás */
  .lm-mk-tabs {
    display: flex;
    border-bottom: 1.5px solid rgba(0,0,0,0.09);
    margin-bottom: 12px;
  }
  .dark .lm-mk-tabs { border-bottom-color: rgba(255,255,255,0.09); }
  .lm-mk-tab {
    flex: 1; padding: 10px 6px; border: none; background: transparent;
    font-size: 0.79rem; font-weight: 700; color: var(--text-dim); cursor: pointer;
    border-bottom: 2px solid transparent; margin-bottom: -1.5px;
    transition: color 0.13s, border-color 0.13s;
  }
  .lm-mk-tab.active { color: #059669; border-bottom-color: #059669; }
  .dark .lm-mk-tab.active { color: #34d399; border-bottom-color: #34d399; }

  /* Ocultar col no-activa en mobile */
  [data-mkcol] { display: none; }
  [data-mkcol].lm-mk-col-active { display: flex; }

  /* Filtros rango: colapsable */
  .lm-mk-toggle-rangos {
    display: flex; align-items: center; gap: 6px;
    padding: 6px 12px; margin-bottom: 6px;
    border: 1px solid rgba(0,0,0,0.12); border-radius: 8px;
    background: transparent; font-size: 0.74rem; font-weight: 700;
    color: var(--text-dim); cursor: pointer;
    width: 100%; box-sizing: border-box;
  }
  .dark .lm-mk-toggle-rangos { border-color: rgba(255,255,255,0.14); }
  .lm-mk-toggle-rangos.tiene-filtros { color: #059669; border-color: #059669; }
  .dark .lm-mk-toggle-rangos.tiene-filtros { color: #34d399; border-color: #34d399; }
  .lm-mk-rangos { display: none !important; }
  .lm-mk-rangos.open { display: flex !important; }

  /* Selects liga/club en columna */
  .lm-mk-filtros-liga { flex-direction: column; gap: 6px; }
  .lm-mk-liga-sel, .lm-mk-club-sel { width: 100%; min-width: 0; max-width: 100%; box-sizing: border-box; }

  /* Orden y chips: scroll horizontal interno (sin overflow de página) */
  .lm-mk-orden { flex-wrap: nowrap; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; padding-bottom: 2px; }
  .lm-mk-orden::-webkit-scrollbar { display: none; }
  .lm-mk-filtros { flex-wrap: nowrap; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; padding-bottom: 2px; }
  .lm-mk-filtros::-webkit-scrollbar { display: none; }
  .lm-mk-filtros .lm-chip { flex-shrink: 0; }
  .lm-mk-ayuda { display: none; }

  /* ── FILAS mobile: 2 líneas, todo visible ── */
  .lm-mk-colhead { display: none; }

  /* Lista: block para que las filas no se compriman */
  .lm-mk-list { display: block; height: auto; max-height: 58vh; overflow-y: auto; overflow-x: visible; }

  .lm-mk-row {
    display: grid !important;
    grid-template-columns: auto 1fr auto auto;
    grid-template-rows: auto auto;
    gap: 1px 4px;
    padding: 7px 4px;
    align-items: center;
  }
  /* Posición: ambas filas */
  .lm-mk-row .lm-mk-pos { grid-column: 1; grid-row: 1 / 3; justify-self: center; width: 28px; font-size: 0.6rem; }
  /* Nombre: fila 1 */
  .lm-mk-row .lm-mk-name { grid-column: 2; grid-row: 1; font-size: 0.82rem; line-height: 1.2;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .lm-mk-row .lm-mk-name > span { }
  .lm-mk-row .lm-mk-from { font-size: 0.64rem; }
  /* Media: fila 1, derecha */
  .lm-mk-row .lm-mk-rat { grid-column: 3; grid-row: 1; font-size: 0.88rem; font-weight: 700; }
  /* Edad: oculta en mobile */
  .lm-mk-row .lm-mk-age { display: none !important; }
  /* Valor: fila 2 */
  .lm-mk-row .lm-mk-price { grid-column: 2; grid-row: 2; font-size: 0.7rem; font-weight: 800; white-space: nowrap; }
  /* Acciones (comprás): fila 2, columna 3-4 */
  .lm-mk-row .lm-mk-acciones { grid-column: 3 / 5; grid-row: 2; display: flex; flex-direction: row; gap: 4px; align-items: center; justify-content: flex-end; }
  /* Listar (tu plantel): fila 2, columna 3-4 */
  .lm-mk-row .lm-mk-listar { grid-column: 3 / 5; grid-row: 2; display: flex; flex-direction: row; gap: 3px; justify-content: flex-end; }
  .lm-mk-row .lm-mk-cerrado { grid-column: 2 / 5; grid-row: 2; font-size: 0.6rem; text-align: right; color: var(--text-muted); }

  /* Etiquetas EN VENTA / CESIÓN / vendido */
  .lm-mk-enventa, .lm-mk-encesion, .lm-mk-pactado { font-size: 0.52rem !important; display: inline-block; margin-left: 4px; }

  /* Botones de acción compactos */
  .lm-mk-clausula { font-size: 0.6rem; padding: 3px 5px; max-width: 80px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .lm-mk-ofertar { font-size: 0.68rem; padding: 4px 8px; text-align: center; white-space: nowrap; }
  .lm-mk-flag { font-size: 0.9rem; padding: 3px 4px; }

  .lm-mk-pag { padding: 6px 0; gap: 6px; }
  .lm-mk-pag .lm-ctl-btn { padding: 5px 10px; font-size: 0.72rem; }
  .lm-mk-pag-lbl { font-size: 0.7rem; }
}

@media (max-width: 480px) {
  .lm-panel { padding: 12px 9px; }
  .lm-seccion-title { font-size: 1.05rem; }
  .lm-mk-stat-val { font-size: 1.1rem; }
  .lm-mk-clubname { font-size: 0.9rem; }
  .lm-mk-btn { padding: 5px 7px; font-size: 0.7rem; }
  /* Partido en vivo */
  .lm-pt-overlay { padding: 8px; }
  .lm-pt-scoreboard { padding: 14px 12px 6px; gap: 6px; }
  .lm-pt-score { font-size: 2rem; }
  .lm-pt-team { font-size: 0.76rem; }
  .lm-pt-feed { padding: 8px 12px; min-height: 160px; }
  .lm-pt-controls { padding: 10px 12px 14px; gap: 6px; }
  .lm-pt-ctl { padding: 8px 11px; font-size: 0.78rem; }
  .lm-pt-cambios-cols { grid-template-columns: 1fr; }
  /* Copa: nombres más compactos */
  .lm-copa-llave { grid-template-columns: 1fr 58px 1fr; gap: 5px; font-size: 0.78rem; }
  .lm-copa-team { gap: 4px; }
  /* Once: medias y cancha */
  .lm-once-med b { font-size: 1.2rem; }
  .lm-once-pitch { width: 210px; max-width: 220px; }
  .lm-token { transform: translate(-50%, -50%) scale(0.78); }
  /* Resumen del inicio */
  .lm-resumen-club { font-size: 1.25rem; }
  .lm-rstat b { font-size: 1.25rem; }
  /* Controles que envuelven bien */
  .lm-aux-controls { gap: 7px; }
  .lm-ctl-btn { padding: 5px 10px; font-size: 0.74rem; }
}

/* ── Menú: oculto sin carrera activa (Fase 4) ── */
.lm-menu-oculto { display: none !important; }
/* Cuando el menú está oculto, el grid solo tiene 1 columna */
.lm-layout.lm-layout-sin-menu { grid-template-columns: 1fr !important; }

/* ── Selector 2 columnas (Fase 4) ── */
.lm-sel-2col {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 12px;
  margin-top: 14px;
  align-items: start;
}
@media (max-width: 680px) { .lm-sel-2col { grid-template-columns: 1fr; } }

.lm-sel-ligas {
  max-height: 480px;
  overflow-y: auto;
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: var(--radius);
  background: var(--bg-surface);
  padding: 6px;
  display: flex;
  flex-direction: column;
  gap: 2px;
  scrollbar-width: thin;
}
.dark .lm-sel-ligas { border-color: rgba(255,255,255,0.1); }

.lm-sel-pais { display: flex; flex-direction: column; }
.lm-sel-pais-nombre {
  font-size: 0.67rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-dim);
  padding: 8px 10px 3px;
}
.lm-liga-opt {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  text-align: left;
  padding: 8px 10px;
  border: none;
  background: transparent;
  border-radius: 7px;
  font-size: 0.86rem;
  font-weight: 600;
  color: var(--text-dim);
  cursor: pointer;
  transition: background 0.12s, color 0.12s;
}
.lm-liga-opt:hover { background: rgba(5,150,105,0.08); color: var(--text-bright); }
.lm-liga-opt.active { background: rgba(5,150,105,0.15); color: #059669; }
.dark .lm-liga-opt.active { color: #34d399; background: rgba(52,211,153,0.14); }
.lm-liga-opt > * { pointer-events: none; }

.lm-sel-clubes {
  max-height: 480px;
  overflow-y: auto;
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: var(--radius);
  background: var(--bg-surface);
  padding: 12px;
  scrollbar-width: thin;
}
.dark .lm-sel-clubes { border-color: rgba(255,255,255,0.1); }
.lm-sel-clubes-hint {
  color: var(--text-dim);
  font-size: 0.9rem;
  text-align: center;
  padding: 40px 16px;
}
.lm-sel-loading { color: var(--text-dim); text-align: center; padding: 20px; font-size: 0.9rem; }

.lm-sel-volver {
  display: none;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 8px;
  background: var(--bg-elevated, rgba(255,255,255,0.04));
  color: var(--text-dim);
  font-size: 0.78rem;
  font-weight: 700;
  margin-bottom: 10px;
  cursor: pointer;
  transition: all 0.12s ease;
}
.lm-sel-volver:hover { background: rgba(5,150,105,0.08); color: #059669; border-color: rgba(5,150,105,0.25); }
.dark .lm-sel-volver { border-color: rgba(255,255,255,0.1); }

@media (max-width: 680px) {
  .lm-sel-2col { grid-template-columns: 1fr; }
  .lm-sel-ligas,
  .lm-sel-clubes { max-height: none; }
  .lm-sel-clubes { display: none; }
  .lm-sel-clubes.lm-sel-visible { display: block; }
  .lm-sel-ligas.lm-sel-hidden { display: none; }
  .lm-sel-volver { display: inline-flex; }
  .lm-selector { padding: 8px 0; }
  .lm-club-grid { grid-template-columns: 1fr; }
  .lm-club-opt { padding: 12px 14px; }
  .lm-club-name { font-size: 0.95rem; }
}

.lm-loading-overlay {
  position: absolute;
  inset: 0;
  background: var(--bg-surface, rgba(255,255,255,0.92));
  border-radius: inherit;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 14px;
  z-index: 50;
}
.dark .lm-loading-overlay { background: rgba(19,26,42,0.92); }
.lm-loading-spinner {
  width: 36px;
  height: 36px;
  border: 3.5px solid rgba(0,0,0,0.1);
  border-top-color: #059669;
  border-radius: 50%;
  animation: lm-spin 0.7s linear infinite;
}
.dark .lm-loading-spinner { border-color: rgba(255,255,255,0.12); border-top-color: #34d399; }
.lm-loading-text { font-size: 0.88rem; font-weight: 600; color: var(--text-muted); }
@keyframes lm-spin { to { transform: rotate(360deg); } }
.lm-sel-clubtitle { font-size: 0.85rem; font-weight: 700; color: var(--text-dim); margin: 0 0 10px; text-transform: uppercase; letter-spacing: 0.05em; }

/* ── B2: Gestión plantel — acciones T/C y badge CEDIDO ── */
.lm-pl-acts { display: flex; gap: 3px; justify-content: center; }
.lm-pl-act { padding: 3px 9px; border-radius: 5px; border: 1px solid rgba(255,255,255,0.2); background: transparent; color: var(--text-muted); font-size: 0.67rem; font-weight: 700; cursor: pointer; transition: all 0.12s ease; white-space: nowrap; }
.lm-pl-act:hover { border-color: rgba(5,150,105,0.5); color: var(--text-bright); }
.lm-pl-act.active { background: rgba(5,150,105,0.3); border-color: #059669; color: #10b981; }
.lm-pl-badge.cedido { font-size: 0.67rem; font-weight: 700; color: #f59e0b; border: 1px solid #f59e0b; border-radius: 4px; padding: 2px 7px; white-space: nowrap; }

/* ── B3: Sección dedicada de ofertas ── */
.lm-oferta-card { background: var(--card-bg); border: 1px solid var(--border, rgba(0,0,0,0.07)); border-radius: 10px; padding: 14px; display: flex; flex-direction: column; gap: 10px; margin-bottom: 10px; }
.dark .lm-oferta-card { background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.08); }
.lm-oferta-jugador { display: flex; align-items: center; gap: 10px; }
.lm-oferta-info { display: flex; flex-direction: column; gap: 2px; }
.lm-oferta-info b { font-size: 0.95rem; color: var(--text-bright); }
.lm-oferta-info span { font-size: 0.78rem; color: var(--text-muted); }
.lm-oferta-detalle { display: flex; justify-content: space-between; align-items: center; font-size: 0.85rem; }
.lm-oferta-club { display: flex; align-items: center; gap: 6px; }
.lm-oferta-monto { font-weight: 800; color: var(--text-bright); display: flex; align-items: center; gap: 6px; }
.of-ind { font-size: 0.72rem; font-weight: 700; padding: 1px 6px; border-radius: 4px; }
.of-ind.alta { background: rgba(16,185,129,0.2); color: #10b981; }
.of-ind.baja { background: rgba(239,68,68,0.2); color: #f87171; }
.of-ind.justa { background: rgba(245,158,11,0.2); color: #f59e0b; }
.lm-oferta-btns { display: flex; gap: 8px; }
.lm-oferta-btns .btn-sm { padding: 6px 14px; border-radius: 8px; border: none; font-size: 0.78rem; font-weight: 800; cursor: pointer; transition: filter 0.12s ease; }
.lm-oferta-btns .btn-accept { background: #059669; color: #fff; }
.lm-oferta-btns .btn-reject { background: rgba(231,76,60,0.14); color: var(--red, #e74c3c); }
.lm-oferta-btns .btn-sm:hover { filter: brightness(1.08); }

/* Badge en el menú lateral */
.lm-menu-badge { background: #ef4444; color: #fff; font-size: 0.6rem; font-weight: 800; border-radius: 999px; padding: 1px 5px; margin-left: 4px; vertical-align: middle; line-height: 1; }

/* ── Tabla navegable (Fase 5) ── */
.lm-tabla-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
  flex-wrap: wrap;
}
.lm-tabla-sel {
  padding: 6px 10px;
  border: 1px solid rgba(0,0,0,0.14);
  border-radius: 8px;
  font-size: 0.85rem;
  font-weight: 600;
  background: var(--bg-surface);
  color: var(--text-bright);
  cursor: pointer;
  max-width: 280px;
}
.dark .lm-tabla-sel {
  border-color: rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.05);
}
.lm-tabla-nombre { font-weight: 600; font-size: 0.9rem; color: var(--text-bright); }
.lm-tabla-proyeccion {
  font-size: 0.74rem;
  color: var(--text-dim);
  font-style: italic;
  background: rgba(5,150,105,0.08);
  padding: 3px 8px;
  border-radius: 20px;
}

/* ── Mercado: filtros de liga + club (Fase 3) ── */
.lm-mk-filtros-liga {
  display: flex;
  gap: 6px;
  margin-bottom: 8px;
  flex-wrap: wrap;
}
.lm-mk-liga-sel, .lm-mk-club-sel {
  padding: 5px 8px;
  border: 1px solid rgba(0,0,0,0.12);
  border-radius: 7px;
  font-size: 0.8rem;
  font-weight: 600;
  background: var(--bg-surface);
  color: var(--text-bright);
  cursor: pointer;
  flex: 1;
  min-width: 120px;
  max-width: 220px;
}
.dark .lm-mk-liga-sel, .dark .lm-mk-club-sel {
  border-color: rgba(255,255,255,0.15);
  background: rgba(255,255,255,0.05);
}
.dark .lm-mk-liga-sel option, .dark .lm-mk-club-sel option {
  background: var(--bg-surface);
  color: var(--text-bright);
}
.dark .lm-tabla-sel option {
  background: var(--bg-surface);
  color: var(--text-bright);
}

/* ── Copa internacional: tabla de grupo (FF7) ── */
.lm-grp-table { display: flex; flex-direction: column; margin-top: 4px; }
.lm-grp-head, .lm-grp-row { display: grid; grid-template-columns: 28px 1fr 32px 36px; align-items: center; gap: 8px; padding: 7px 6px; }
.lm-grp-head { font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--text-muted); border-bottom: 1.5px solid rgba(0,0,0,0.1); }
.dark .lm-grp-head { border-bottom-color: rgba(255,255,255,0.12); }
.lm-grp-row { border-bottom: 1px solid rgba(0,0,0,0.05); font-size: 0.86rem; }
.dark .lm-grp-row { border-bottom-color: rgba(255,255,255,0.06); }
.lm-grp-row.mio { background: rgba(5,150,105,0.1); font-weight: 700; }
.lm-grp-row.clasif { box-shadow: inset 3px 0 0 #059669; }
.lm-grp-pts { font-weight: 800; text-align: center; }

/* ── League Phase: tabla completa de 36 equipos ── */
.lm-lp-table { display: flex; flex-direction: column; margin-top: 4px; max-height: 70vh; overflow-y: auto; }
.lm-lp-head { display: grid; grid-template-columns: 28px 1fr 32px 32px 32px 32px 32px 32px 36px 36px; align-items: center; gap: 6px; padding: 7px 6px; font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--text-muted); border-bottom: 1.5px solid rgba(0,0,0,0.1); position: sticky; top: 0; background: var(--bg, #fff); z-index: 1; }
.dark .lm-lp-head { border-bottom-color: rgba(255,255,255,0.12); background: var(--bg, #1a1a2e); }
.lm-lp-row { display: grid; grid-template-columns: 28px 1fr 32px 32px 32px 32px 32px 32px 36px 36px; align-items: center; gap: 6px; padding: 6px; border-bottom: 1px solid rgba(0,0,0,0.05); font-size: 0.82rem; }
.dark .lm-lp-row { border-bottom-color: rgba(255,255,255,0.06); }
.lm-lp-row.mio { background: rgba(5,150,105,0.1); font-weight: 700; }
.lm-lp-row.top8 { box-shadow: inset 3px 0 0 #059669; }
.lm-lp-row.playoff { box-shadow: inset 3px 0 0 #d97706; }
.lm-lp-row.elim { opacity: 0.5; box-shadow: inset 3px 0 0 #dc2626; }
.lm-lp-pts { font-weight: 800; text-align: center; }

/* ── League Phase: zonas preview ── */
.lm-lp-zones { display: flex; flex-direction: column; gap: 12px; margin-top: 12px; }
.lm-lp-zone { background: var(--card-bg, rgba(255,255,255,0.03)); border: 1px solid rgba(255,255,255,0.08); border-radius: 12px; padding: 8px 12px; }
.lm-lp-zone-title { font-size: 0.68rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 6px; padding: 3px 0; }
.lm-lp-zone-title.direct { color: #059669; }
.lm-lp-zone-title.playoff { color: #d97706; }
.lm-lp-zone-title.elim { color: #dc2626; }
.lm-lp-zone-row { display: flex; align-items: center; gap: 8px; padding: 4px 6px; font-size: 0.82rem; border-bottom: 1px solid rgba(0,0,0,0.04); }
.dark .lm-lp-zone-row { border-bottom-color: rgba(255,255,255,0.04); }
.lm-lp-zone-row.mio { background: rgba(5,150,105,0.1); font-weight: 700; border-radius: 6px; }
.lm-lp-zone-row.elim { opacity: 0.5; }

/* ── B11: Resultados de la jornada (bloque en Inicio) ── */
.lm-jornada-block { margin-top: 20px; }
.lm-jornada-grid { display: flex; flex-direction: column; gap: 2px; }
.lm-jornada-row { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 10px; padding: 6px 8px; border-radius: 6px; font-size: 0.8rem; background: var(--card-bg, rgba(255,255,255,0.03)); }
.lm-jornada-row.mio { background: rgba(5,150,105,0.08); font-weight: 700; }
.lm-jornada-home { text-align: right; color: var(--text-bright); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lm-jornada-away { text-align: left; color: var(--text-bright); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lm-jornada-score { font-weight: 800; color: var(--text-bright); white-space: nowrap; text-align: center; min-width: 40px; }

/* ── Mercado: filtros de rango + paginación ── */
.lm-mk-rangos { display: flex; flex-direction: column; gap: 5px; margin-bottom: 8px; }
.lm-mk-range-pair { display: flex; align-items: center; gap: 5px; }
.lm-mk-range-label { font-size: 0.68rem; font-weight: 700; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.06em; min-width: 38px; flex-shrink: 0; }
.lm-mk-range-sep { font-size: 0.8rem; color: var(--text-muted); flex-shrink: 0; }
.lm-mk-range-sel { padding: 4px 6px; border-radius: 8px; border: 1px solid rgba(0,0,0,0.12); background: transparent; font-size: 0.74rem; font-weight: 600; color: var(--text-dim); cursor: pointer; flex: 1; min-width: 60px; transition: border-color 0.12s; }
.lm-mk-range-sel:focus { outline: none; border-color: #059669; }
.dark .lm-mk-range-sel { border-color: rgba(255,255,255,0.14); background: rgba(255,255,255,0.05); color: var(--text-bright); }
.dark .lm-mk-range-sel option { background: var(--bg-surface); color: var(--text-bright); }
.lm-mk-pag { display: flex; align-items: center; gap: 8px; padding: 4px 0 6px; }
.lm-mk-pag-lbl { font-size: 0.72rem; color: var(--text-muted); flex: 1; }
.lm-mk-pag .lm-ctl-btn[disabled] { opacity: 0.3; cursor: not-allowed; }

/* ── Ofertas: tipo badge (venta / préstamo) ── */
.of-tipo { display: inline-flex; align-items: center; gap: 3px; padding: 2px 7px; border-radius: 12px; font-size: 0.66rem; font-weight: 700; white-space: nowrap; margin-left: auto; flex-shrink: 0; }
.of-tipo.cesion { background: rgba(251,191,36,0.12); color: #d97706; border: 1px solid rgba(217,119,6,0.25); }
.of-tipo.venta  { background: rgba(5,150,105,0.1);  color: #059669; border: 1px solid rgba(5,150,105,0.25); }
.dark .of-tipo.cesion { background: rgba(251,191,36,0.15); color: #fbbf24; border-color: rgba(251,191,36,0.3); }
.dark .of-tipo.venta  { background: rgba(52,211,153,0.1);  color: #34d399; border-color: rgba(52,211,153,0.3); }

/* ── Internacional: sub-tabs (tabla / fixture) dentro de copa activa ── */
.lm-intl-subtabs { display: flex; gap: 4px; margin: 10px 0 12px; }
.lm-intl-subtab { padding: 5px 18px; border-radius: 8px; border: 1px solid rgba(0,0,0,0.1); background: transparent; font-size: 0.78rem; font-weight: 600; color: var(--text-dim); cursor: pointer; transition: all 0.12s; }
.dark .lm-intl-subtab { border-color: rgba(255,255,255,0.1); }
.lm-intl-subtab:hover { color: var(--text-bright); border-color: rgba(0,0,0,0.2); }
.lm-intl-subtab.active { background: rgba(5,150,105,0.12); border-color: #059669; color: #059669; }
.dark .lm-intl-subtab.active { color: #34d399; border-color: #34d399; background: rgba(52,211,153,0.1); }

/* ── Internacional: fixture de league phase ── */
.lm-intl-fixture { display: flex; flex-direction: column; gap: 12px; max-height: 70vh; overflow-y: auto; padding-bottom: 4px; }
.lm-intl-fix-fecha { background: var(--card-bg, rgba(255,255,255,0.03)); border: 1px solid rgba(0,0,0,0.07); border-radius: 10px; overflow: hidden; }
.dark .lm-intl-fix-fecha { border-color: rgba(255,255,255,0.07); }
.lm-intl-fix-fecha-tit { padding: 6px 12px; font-size: 0.68rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.07em; color: var(--text-muted); background: rgba(0,0,0,0.03); border-bottom: 1px solid rgba(0,0,0,0.06); }
.dark .lm-intl-fix-fecha-tit { background: rgba(255,255,255,0.02); border-bottom-color: rgba(255,255,255,0.06); }
.lm-intl-fix-row { display: grid; grid-template-columns: 1fr 44px 1fr; gap: 6px; align-items: center; padding: 5px 12px; border-bottom: 1px solid rgba(0,0,0,0.04); font-size: 0.78rem; }
.dark .lm-intl-fix-row { border-bottom-color: rgba(255,255,255,0.04); }
.lm-intl-fix-row.mia { background: rgba(5,150,105,0.08); font-weight: 700; }
.lm-intl-fix-row:last-child { border-bottom: none; }
.lm-intl-fix-team { display: flex; align-items: center; gap: 5px; min-width: 0; color: var(--text); overflow: hidden; }
.lm-intl-fix-team span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lm-intl-fix-team.end { justify-content: flex-end; flex-direction: row-reverse; text-align: right; }
.lm-intl-fix-score { font-weight: 800; color: var(--text-bright); text-align: center; font-size: 0.85rem; white-space: nowrap; }

/* ── Grupos CONMEBOL ── */
.lm-grupos-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 12px;
  padding: 12px;
}
.lm-grupo-card {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
}
.lm-grupo-card.mi-grupo {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent) 13%, transparent);
}
.lm-grupo-header {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  padding: 6px 10px;
  background: var(--bg-alt);
  text-transform: uppercase;
  color: var(--text-dim);
}
.lm-grupo-tabla { width: 100%; border-collapse: collapse; font-size: 0.78rem; }
.lm-grupo-tabla th { padding: 4px 6px; color: var(--text-dim); font-weight: 500; text-align: center; }
.lm-grupo-tabla th:nth-child(2) { text-align: left; }
.lm-grupo-tabla td { padding: 5px 6px; text-align: center; border-top: 1px solid var(--border); }
.lm-grupo-tabla td:nth-child(2) { text-align: left; }
.lm-grupo-tabla tr.mio td { background: color-mix(in srgb, var(--accent) 7%, transparent); font-weight: 600; }
.lm-grupo-tabla tr.clasif td { color: var(--text); }
.lm-grupo-tabla tr:not(.clasif) td { color: var(--text-dim); }
.lm-gt-nombre { display: flex; align-items: center; gap: 5px; white-space: nowrap; overflow: hidden; }
.lm-gt-nombre span { overflow: hidden; text-overflow: ellipsis; }
.lm-intl-grupos-wrap { padding: 0; overflow: hidden; }
.lm-intl-header { padding: 12px 16px; font-weight: 700; font-size: 0.95rem; }
.lm-gr-resultados { display: flex; flex-direction: column; gap: 4px; padding: 8px 12px; border-bottom: 1px solid var(--border); }
.lm-gr-res { display: flex; align-items: center; gap: 8px; font-size: 0.82rem; color: var(--text-dim); }
.lm-gr-res.mio { color: var(--text); font-weight: 500; }
.lm-gr-res strong { font-size: 0.95rem; min-width: 32px; text-align: center; }

/* ── Fase F: Negociación de fichajes (modal) ── */
.lm-neg-modal { min-width: 300px; max-width: 440px; }
.lm-neg-modal-head {
  display: flex; align-items: center; gap: 10px;
  padding-bottom: 14px; border-bottom: 1px solid rgba(0,0,0,0.09); margin-bottom: 14px;
}
.dark .lm-neg-modal-head { border-bottom-color: rgba(255,255,255,0.09); }
.lm-neg-modal-info { flex: 1; display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.lm-neg-modal-nombre { font-weight: 800; font-size: 1rem; color: var(--text-bright); }
.lm-neg-modal-club { font-size: 0.78rem; color: var(--text-dim); }
.lm-neg-rat { font-weight: 800; font-size: 1.1rem; color: #059669; flex-shrink: 0; }
.dark .lm-neg-rat { color: #34d399; }
.lm-neg-ronda-label { font-size: 0.72rem; font-weight: 600; letter-spacing: 0.05em; color: var(--text-muted); margin-bottom: 12px; }
.lm-neg-intrans-warn { font-size: 0.78rem; color: #b45309; background: rgba(217,119,6,0.09); border: 1px solid rgba(217,119,6,0.2); border-radius: 8px; padding: 7px 10px; margin-bottom: 12px; }
.dark .lm-neg-intrans-warn { color: #fbbf24; background: rgba(251,191,36,0.08); border-color: rgba(251,191,36,0.2); }
.lm-neg-oferta-row { display: flex; align-items: stretch; gap: 8px; margin-bottom: 18px; }
.lm-neg-oferta-blk { flex: 1; display: flex; flex-direction: column; gap: 4px; padding: 11px 14px; border-radius: 10px; background: var(--bg-surface); border: 1.5px solid rgba(0,0,0,0.08); }
.dark .lm-neg-oferta-blk { background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.09); }
.lm-neg-oferta-tu { border-color: #059669 !important; }
.dark .lm-neg-oferta-tu { border-color: #34d399 !important; }
.lm-neg-oferta-lbl { font-size: 0.65rem; text-transform: uppercase; letter-spacing: 0.07em; color: var(--text-muted); font-weight: 600; }
.lm-neg-oferta-amt { font-size: 1.1rem; font-weight: 800; color: var(--text-bright); }
.lm-neg-sep { color: var(--text-muted); font-size: 1rem; flex-shrink: 0; align-self: center; }
.lm-neg-rechazado-msg { font-size: 0.88rem; color: var(--text-dim); margin-bottom: 18px; line-height: 1.5; }
.lm-neg-acts { display: flex; flex-direction: column; gap: 8px; }
.lm-neg-btn {
  padding: 10px 16px; border-radius: 9px; font-size: 0.84rem;
  cursor: pointer; font-weight: 700; transition: opacity 0.12s, transform 0.1s; border: none;
}
.lm-neg-btn:hover { opacity: 0.88; }
.lm-neg-btn:active { transform: scale(0.98); }
.lm-neg-aceptar { background: #059669; color: #fff; }
.dark .lm-neg-aceptar { background: #10b981; }
.lm-neg-abandon {
  background: transparent; border: 1.5px solid rgba(0,0,0,0.12); color: var(--text-dim);
  font-size: 0.78rem; padding: 8px 14px;
}
.dark .lm-neg-abandon { border-color: rgba(255,255,255,0.14); }
.lm-neg-contra-wrap { display: flex; flex-direction: column; gap: 6px; }
.lm-neg-contra-fmt { font-size: 1rem; font-weight: 800; color: var(--text-bright); padding: 0 2px; }
.lm-neg-contra-row { display: flex; gap: 8px; align-items: center; }
.lm-neg-input {
  flex: 1; min-width: 0; padding: 9px 11px;
  border: 1.5px solid rgba(0,0,0,0.12); border-radius: 9px;
  background: var(--bg-surface); color: var(--text-bright); font-size: 0.84rem;
  font-weight: 600;
}
.dark .lm-neg-input { border-color: rgba(255,255,255,0.14); background: rgba(255,255,255,0.05); }
.lm-neg-input:focus { outline: none; border-color: #059669; }
.lm-neg-contra-btn { background: rgba(0,0,0,0.06); color: var(--text-bright); padding: 9px 16px; border-radius: 9px; border: 1.5px solid rgba(0,0,0,0.12); font-size: 0.84rem; font-weight: 700; cursor: pointer; flex-shrink: 0; }
.dark .lm-neg-contra-btn { background: rgba(255,255,255,0.07); border-color: rgba(255,255,255,0.14); }

/* Botones de acción en la fila de jugador */
.lm-mk-acciones { display: flex; flex-direction: column; gap: 4px; align-items: flex-end; }
.lm-mk-ofertar { padding: 5px 12px; border-radius: 6px; border: 1px solid var(--accent); color: var(--accent); background: transparent; font-size: 0.80rem; cursor: pointer; white-space: nowrap; }
.lm-mk-ofertar-dificil { border-color: #d97706; color: #d97706; }
.lm-mk-ofertar:hover { background: color-mix(in srgb, var(--accent) 10%, transparent); }
.lm-mk-ofertar-activa { background: color-mix(in srgb, var(--accent) 15%, transparent); font-weight: 600; }
.lm-mk-clausula { padding: 4px 10px; border-radius: 6px; border: 1px solid #f90; color: #f90; background: transparent; font-size: 0.75rem; cursor: pointer; white-space: nowrap; }
.lm-mk-clausula:hover { background: color-mix(in srgb, #f90 10%, transparent); }
.lm-mk-novende { font-size: 0.78rem; color: var(--text-dim); white-space: nowrap; }
.lm-mk-cerrado { font-size: 0.78rem; color: var(--text-dim); }

/* ── Copas en background: campeón y bracket ── */
.lm-intl-ajena-campeon { display: flex; align-items: center; gap: 16px; padding: 16px; }
.lm-copa-campeon-titulo { font-size: 0.78rem; color: var(--text-dim); }
.lm-copa-campeon-nombre { font-size: 1.1rem; font-weight: 700; }
.lm-copa-sub { font-size: 0.82rem; color: var(--text-dim); margin-top: 4px; }
.lm-ko-bracket-fondo { padding: 12px; display: flex; flex-direction: column; gap: 16px; }
.lm-ko-ronda-tit { font-size: 0.75rem; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-dim); margin-bottom: 6px; }
.lm-ko-llave { display: flex; align-items: center; gap: 8px; font-size: 0.82rem; padding: 6px 0; border-bottom: 1px solid var(--border); flex-wrap: wrap; }
.lm-ko-score { font-weight: 700; min-width: 80px; text-align: center; }
.lm-ko-ganador { font-size: 0.75rem; color: var(--accent); }
