/* dashboard.css — HOME (dashboard) de Meteoro IA.
   Nivel Bloomberg/TradingView/Linear. Un solo acento dominante (cian); verde/rojo
   SOLO semánticos. Espaciado 8px, tipografía Inter + JetBrains Mono, elevación por
   niveles. Diseñado a la DERECHA del sidebar global (.msb pone padding-left:244px
   en >=1024px). Todo el JS va en dashboard.js (CSP estricta, nada inline). */

:root {
  --d-gap: 16px;
  --d-pad: 24px;
  --d-r: 15px;
  --d-r-sm: 11px;
  --d-shadow-1: 0 1px 0 rgba(255, 255, 255, .03) inset, 0 6px 18px rgba(2, 6, 14, .35);
  --d-shadow-2: 0 1px 0 rgba(255, 255, 255, .04) inset, 0 14px 40px rgba(2, 6, 14, .5);
  --d-cyan-soft: rgba(56, 214, 255, .12);
  --d-cyan-line: rgba(56, 214, 255, .32);
  --d-card-2: #0d1626;
  --d-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;
  --d-ink-2: #cfe0f2;
}

/* ── Base de la página ─────────────────────────────────────── */
/* Fondo propio: el dashboard es autónomo (no depende de meteor.css). */
body { background: var(--m-bg); margin: 0; min-height: 100vh; }

.dash {
  font-family: "Inter", system-ui, -apple-system, sans-serif;
  color: var(--m-ink);
  background: var(--m-bg);
  max-width: 1640px;
  margin: 0 auto;
  min-height: 100vh;
  /* arriba 40 · DERECHA 40 · abajo 96 · IZQUIERDA 44: que NADA quede pegado al sidebar */
  padding: 40px 40px 96px 44px;
  -webkit-font-smoothing: antialiased;
}

.dash * { box-sizing: border-box; }

.dash h1, .dash h2, .dash h3 { margin: 0; font-weight: 700; }

/* etiqueta mono-mayúscula (TradingView style) */
.d-label {
  font: 600 11px var(--d-mono);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--m-mut);
}

.pos { color: var(--m-green); }
.neg { color: var(--m-red); }
.acc { color: var(--m-cyan); }

/* ── Elementos SOLO-MÓVIL (ocultos en escritorio por defecto) ── */
.d-mhead, .d-mgreet { display: none; }

/* ── 1) TOPBAR ─────────────────────────────────────────────── */
.d-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--d-gap);
  margin-bottom: 30px;
  flex-wrap: wrap;
}
.d-greet { flex: 1 1 360px; min-width: 0; padding-top: 4px; }
.d-greet h1 {
  font-size: clamp(27px, 3vw, 36px);   /* más grande y prominente, como el diseño */
  line-height: 1.32;                    /* aire para la "¡" y descendentes */
  letter-spacing: -.015em;
  padding-bottom: 4px;
}
.d-greet h1 b { color: var(--m-cyan); font-weight: 800; }   /* el nombre en cian (acento de marca) */
.d-greet p {
  margin: 7px 0 0;
  color: var(--m-mut);
  font-size: 15px;
}
.d-top-r {
  display: flex;
  align-items: center;
  gap: 12px;
  flex: 0 0 auto;
}
.d-search {
  position: relative;
  display: flex;
  align-items: center;
}
.d-search svg { position: absolute; left: 14px; width: 18px; height: 18px; color: var(--m-mut); pointer-events: none; }
.d-search input {
  width: clamp(220px, 28vw, 360px);
  background: var(--d-card-2);
  border: 1px solid var(--m-line);
  border-radius: var(--m-r-pill);
  color: var(--m-ink);
  font: 500 14px "Inter", sans-serif;
  padding: 11px 56px 11px 42px;
  transition: border-color .16s, box-shadow .16s;
}
.d-search input::placeholder { color: var(--m-mut); }
.d-search input:focus {
  outline: none;
  border-color: var(--d-cyan-line);
  box-shadow: 0 0 0 3px var(--d-cyan-soft);
}
.d-search kbd {
  position: absolute; right: 10px;
  font: 600 11px var(--d-mono);
  color: var(--m-mut);
  background: #0a1220;
  border: 1px solid var(--m-line);
  border-radius: 6px;
  padding: 3px 7px;
}
.d-icon-btn {
  position: relative;
  width: 42px; height: 42px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--d-card-2);
  border: 1px solid var(--m-line);
  border-radius: 12px;
  color: var(--d-ink-2);
  cursor: pointer;
  transition: border-color .16s, color .16s;
}
.d-icon-btn:hover { border-color: var(--d-cyan-line); color: var(--m-cyan); }
.d-icon-btn svg { width: 19px; height: 19px; }
.d-badge {
  position: absolute; top: -4px; right: -4px;
  min-width: 17px; height: 17px; padding: 0 4px;
  display: flex; align-items: center; justify-content: center;
  background: var(--m-red); color: #fff;
  font: 700 10px var(--d-mono);
  border-radius: 999px; border: 2px solid var(--m-bg);
}
.d-live-pill {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 9px 15px;
  background: rgba(62, 230, 160, .1);
  border: 1px solid rgba(62, 230, 160, .34);
  border-radius: var(--m-r-pill);
  color: var(--m-green);
  font: 700 13px "Inter", sans-serif;
}
.d-live-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--m-green);
  box-shadow: 0 0 0 0 rgba(62, 230, 160, .6);
  animation: d-pulse 1.8s infinite;
}
.d-live-pill time {
  font: 700 13px var(--d-mono);
  color: #bdf3da;
  letter-spacing: .02em;
}
@keyframes d-pulse {
  0% { box-shadow: 0 0 0 0 rgba(62, 230, 160, .5); }
  70% { box-shadow: 0 0 0 7px rgba(62, 230, 160, 0); }
  100% { box-shadow: 0 0 0 0 rgba(62, 230, 160, 0); }
}

/* ── 2) FRANJA DE 6 KPIs ───────────────────────────────────── */
.d-kpis {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: var(--d-gap);
  margin-bottom: var(--d-gap);
}
.kpi {
  background: linear-gradient(180deg, #121c2e 0%, var(--m-card) 100%);
  border: 1px solid var(--m-line);
  border-radius: var(--d-r);
  padding: 16px 16px 14px;
  box-shadow: var(--d-shadow-1);
  display: flex; flex-direction: column;
  gap: 9px;
  min-height: 124px;
  position: relative;
  transition: border-color .18s, transform .18s;
}
.kpi:hover { border-color: var(--d-cyan-line); transform: translateY(-2px); }
.kpi-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 8px; }
.kpi-val {
  font: 800 27px var(--d-mono);
  letter-spacing: -.01em;
  color: var(--m-ink);
  line-height: 1;
}
.kpi-val.pos { color: var(--m-green); }
.kpi-val.neg { color: var(--m-red); }
.kpi-sub { font: 700 13px var(--d-mono); color: var(--m-mut); margin-top: -3px; }
.kpi-sub.pos { color: var(--m-green); } .kpi-sub.neg { color: var(--m-red); }
.kpi-spark { width: 100%; height: 30px; display: block; margin-top: auto; }
/* anillo de PROB. MODELO */
.kpi-ring { width: 46px; height: 46px; flex: 0 0 auto; }
.kpi-ring text { font: 700 13px var(--d-mono); fill: var(--m-green); }

/* ── 3) FILA HÉROE ─────────────────────────────────────────── */
.d-hero {
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: var(--d-gap);
  min-width: 0;
  /* sin margin-bottom: ahora vive dentro de .d-main, que ya separa con su gap */
}
/* min-width:0 deja que los tracks 1fr encojan por debajo del min-content de sus
   hijos (si no, las 5 métricas o un nombre largo inflan la tarjeta y desbordan). */
.d-hero > * { min-width: 0; }
.card {
  background: var(--m-card);
  border: 1px solid var(--m-line);
  border-radius: var(--d-r);
  box-shadow: var(--d-shadow-1);
}
.card-h {
  display: flex; align-items: center; justify-content: space-between;
  gap: 10px;
  padding: 16px 18px;
  border-bottom: 1px solid var(--m-line);
}
/* Títulos de sección CON COLOR en TODAS las secciones (antes gris pálido): texto en el
   acento cian + su ícono cian, para que cada sección resalte como el Pick del día. */
.card-h .d-label { display: inline-flex; align-items: center; gap: 8px; color: var(--m-cyan); }
.card-h .d-label svg { width: 15px; height: 15px; color: var(--m-cyan); }
/* El Pick del día en VERDE (éxito/máxima convicción), con su estrella verde. */
.pick-card .card-h .d-label,
.pick-card .card-h .d-label svg { color: var(--m-green); }

/* PICK DEL DÍA */
.pick-card { display: flex; flex-direction: column; position: relative; overflow: hidden; }
.pick-card::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(120% 80% at 100% 0%, rgba(56, 214, 255, .08), transparent 60%);
  pointer-events: none;
}
.conf-badge {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 5px 11px;
  background: var(--d-cyan-soft);
  border: 1px solid var(--d-cyan-line);
  border-radius: var(--m-r-pill);
  color: var(--m-cyan);
  font: 700 11.5px var(--d-mono);
  letter-spacing: .04em;
}
.pick-body { padding: 20px 22px 22px; position: relative; }
.pick-teams {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 14px;
  margin-bottom: 18px;
}
.pt-team { display: flex; flex-direction: column; align-items: center; gap: 10px; text-align: center; }
.pt-team .pt-logo, .pt-team .ph {
  width: 58px; height: 58px; object-fit: contain;
  border-radius: 14px; background: #0a1220; padding: 6px;
  border: 1px solid var(--m-line);
}
.pt-team .ph {
  display: flex; align-items: center; justify-content: center;
  font: 800 22px "Inter", sans-serif; color: var(--m-mut);
}
.pt-name { font: 700 15px "Inter", sans-serif; color: var(--m-ink); line-height: 1.2; }
.pt-prob { font: 700 18px var(--d-mono); color: var(--m-cyan); }
.pt-prob span { display: block; font: 600 9.5px var(--d-mono); letter-spacing: .12em; color: var(--m-mut); margin-top: 3px; }
.pt-vs { font: 800 13px var(--d-mono); color: var(--m-mut); letter-spacing: .08em; }
.pick-play {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; flex-wrap: wrap;
  padding: 14px 16px;
  background: var(--d-card-2);
  border: 1px solid var(--m-line);
  border-radius: var(--d-r-sm);
  margin-bottom: 18px;
}
.pick-play .pp-l { font: 700 17px "Inter", sans-serif; color: var(--m-ink); }
.pick-play .pp-l small { display: block; font: 600 10px var(--d-mono); letter-spacing: .12em; color: var(--m-mut); margin-top: 3px; }
.pick-play .pp-edge {
  font: 800 18px var(--d-mono); color: var(--m-green);
  padding: 6px 12px; border-radius: 10px;
  background: rgba(62, 230, 160, .1); border: 1px solid rgba(62, 230, 160, .3);
}
.pick-metrics {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 10px;
}
.pm {
  background: var(--d-card-2);
  border: 1px solid var(--m-line);
  border-radius: var(--d-r-sm);
  padding: 11px 10px;
  text-align: center;
}
.pm .pm-v { font: 800 16px var(--d-mono); color: var(--m-ink); line-height: 1; }
.pm .pm-v.pos { color: var(--m-green); }
.pm .pm-k { display: block; font: 600 9px var(--d-mono); letter-spacing: .1em; color: var(--m-mut); margin-top: 6px; text-transform: uppercase; }

/* MONTE CARLO */
.mc-card { cursor: pointer; transition: border-color .18s, box-shadow .18s; }
.mc-card:hover { border-color: var(--d-cyan-line); box-shadow: var(--d-shadow-2); }
.mc-match { font: 700 12px var(--d-mono); color: var(--m-cyan); white-space: nowrap; overflow: hidden;
  text-overflow: ellipsis; max-width: 55%; }
.mc-cta { padding: 0 20px 16px; font: 700 12px "Inter", sans-serif; color: var(--m-cyan); }
.mc-card:hover .mc-cta { text-decoration: underline; }
.mc-body { padding: 18px 20px 20px; }
.mc-chart { width: 100%; height: 200px; display: block; }
.mc-chart .mc-bar { transition: opacity .15s; }
.mc-line { stroke: var(--m-amber); stroke-width: 1.5; stroke-dasharray: 4 3; opacity: .8; }
.mc-line-label { font: 700 10px var(--d-mono); fill: var(--m-amber); }
.mc-bands {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-top: 16px;
}
.mc-band {
  background: var(--d-card-2);
  border: 1px solid var(--m-line);
  border-radius: var(--d-r-sm);
  padding: 13px 12px;
  text-align: center;
}
.mc-band .mb-k { font: 600 10px var(--d-mono); letter-spacing: .1em; color: var(--m-mut); text-transform: uppercase; }
.mc-band .mb-v { font: 800 22px var(--d-mono); color: var(--m-ink); margin-top: 6px; line-height: 1; }
.mc-band.is-mid { border-color: var(--d-cyan-line); }
.mc-band.is-mid .mb-v { color: var(--m-cyan); }

/* ── 4) RAIL DERECHO + columna principal ───────────────────── */
.d-grid {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: var(--d-gap);
  align-items: start;
}
.d-rail { display: flex; flex-direction: column; gap: var(--d-gap); }
.d-main { display: flex; flex-direction: column; gap: var(--d-gap); min-width: 0; }

/* EN VIVO AHORA */
.live-group + .live-group { margin-top: 4px; }
.live-group-h { font: 700 11px var(--d-mono); letter-spacing: .1em; color: var(--m-cyan); text-transform: uppercase; padding: 4px 0 8px; }
.live-row {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 10px;
  padding: 9px 0;
  border-bottom: 1px solid rgba(32, 48, 75, .5);
}
.live-row:last-child { border-bottom: none; }
.lr-teams { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.lr-team { display: flex; align-items: center; justify-content: space-between; gap: 8px; font: 600 13.5px "Inter", sans-serif; color: var(--d-ink-2); }
.lr-team b { font: 700 14px var(--d-mono); color: var(--m-ink); }
.lr-state {
  font: 700 10.5px var(--d-mono); color: var(--m-green);
  white-space: nowrap;
  display: inline-flex; align-items: center; gap: 5px;
}
.lr-state::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--m-green); animation: d-pulse 1.8s infinite; }

/* RENDIMIENTO 30 DÍAS */
.perf-top { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; margin-bottom: 12px; }
.perf-roi { font: 800 30px var(--d-mono); line-height: 1; }
.perf-spark { width: 100%; height: 56px; display: block; }
.perf-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 9px; margin-top: 14px; }
.perf-stat { background: var(--d-card-2); border: 1px solid var(--m-line); border-radius: var(--d-r-sm); padding: 11px 10px; }
.perf-stat .ps-v { font: 800 15.5px var(--d-mono); color: var(--m-ink); white-space: nowrap; }
.perf-stat .ps-k { font: 600 9.5px var(--d-mono); letter-spacing: .1em; color: var(--m-mut); text-transform: uppercase; margin-top: 4px; }

/* MODELOS EN CONSENSO */
.cons-row { padding: 8px 0; }
.cons-row + .cons-row { border-top: 1px solid rgba(32, 48, 75, .5); }
.cons-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 7px; }
.cons-name { font: 600 13px "Inter", sans-serif; color: var(--d-ink-2); }
.cons-pct { font: 700 13px var(--d-mono); color: var(--m-cyan); }
.cons-pct.muted { color: var(--m-mut); }
.cons-track { height: 6px; border-radius: 999px; background: #0a1220; overflow: hidden; }
.cons-fill { height: 100%; border-radius: 999px; background: linear-gradient(90deg, #2aa9d6, var(--m-cyan)); transition: width .5s ease; }

/* ÚLTIMAS NOTICIAS */
.news-row {
  display: flex; flex-direction: column; gap: 6px;
  padding: 11px 0;
  border-bottom: 1px solid rgba(32, 48, 75, .5);
  text-decoration: none;
}
.news-row:last-child { border-bottom: none; }
.news-meta { display: flex; align-items: center; gap: 8px; }
.news-tag { font: 700 9.5px var(--d-mono); letter-spacing: .08em; text-transform: uppercase; color: var(--m-cyan); background: var(--d-cyan-soft); padding: 2px 7px; border-radius: 6px; }
.news-time { font: 600 11px var(--d-mono); color: var(--m-mut); }
.news-row h4 { margin: 0; font: 600 13.5px "Inter", sans-serif; color: var(--d-ink-2); line-height: 1.35; transition: color .15s; }
.news-row:hover h4 { color: var(--m-ink); }

/* ── 5) CARTELERA DEL DÍA ──────────────────────────────────── */
.board-tabs { display: flex; gap: 8px; overflow-x: auto; padding: 2px 0 2px; scrollbar-width: none; }
.board-tabs::-webkit-scrollbar { display: none; }
.bt {
  flex: 0 0 auto;
  padding: 8px 16px;
  border: 1px solid var(--m-line);
  background: var(--d-card-2);
  border-radius: var(--m-r-pill);
  color: var(--d-ink-2);
  font: 600 13px "Inter", sans-serif;
  cursor: pointer;
  transition: border-color .15s, color .15s;
}
.bt.on { border-color: var(--d-cyan-line); color: var(--m-cyan); background: #0c1a24; }
.board-rail { display: flex; gap: 12px; overflow-x: auto; padding: 16px 18px 18px; scrollbar-width: thin; }
.board-rail::-webkit-scrollbar { height: 7px; }
.board-rail::-webkit-scrollbar-thumb { background: var(--m-line); border-radius: 999px; }
.gcard {
  flex: 0 0 248px;
  background: var(--d-card-2);
  border: 1px solid var(--m-line);
  border-radius: var(--d-r-sm);
  padding: 14px;
  cursor: pointer;
  transition: border-color .16s, transform .16s, box-shadow .16s;
  display: flex; flex-direction: column; gap: 12px;
}
.gcard:hover { border-color: var(--d-cyan-line); transform: translateY(-3px); box-shadow: var(--d-shadow-2); }
.gcard.is-best {
  border-color: rgba(62, 230, 160, .5);
  box-shadow: 0 0 0 1px rgba(62, 230, 160, .25), var(--d-shadow-1);
  background: linear-gradient(180deg, rgba(62, 230, 160, .06), var(--d-card-2));
}
.gc-top { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.gc-sport { font: 700 10px var(--d-mono); letter-spacing: .08em; color: var(--m-mut); text-transform: uppercase; }
.gc-best-tag { font: 700 9.5px var(--d-mono); color: var(--m-green); background: rgba(62, 230, 160, .12); border: 1px solid rgba(62, 230, 160, .3); padding: 3px 7px; border-radius: 6px; letter-spacing: .04em; }
.gc-team { display: flex; align-items: center; gap: 10px; }
.gc-team img, .gc-team .ph { width: 28px; height: 28px; object-fit: contain; border-radius: 8px; background: #0a1220; flex: 0 0 auto; }
.gc-team .ph { display: flex; align-items: center; justify-content: center; font: 800 12px "Inter", sans-serif; color: var(--m-mut); }
.gc-team span { font: 600 13.5px "Inter", sans-serif; color: var(--m-ink); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.gc-foot { display: flex; align-items: center; justify-content: space-between; gap: 8px; padding-top: 10px; border-top: 1px solid var(--m-line); }
.gc-play { font: 600 12px "Inter", sans-serif; color: var(--m-cyan); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.gc-live { font: 700 10.5px var(--d-mono); color: var(--m-green); display: inline-flex; align-items: center; gap: 5px; }
.gc-live::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--m-green); animation: d-pulse 1.8s infinite; }
.gc-time { font: 600 11px var(--d-mono); color: var(--m-mut); }

/* ── 6) APUESTAS CON VALOR ──────────────────────────────────── */
/* Envuelve en varias filas: así NINGÚN nombre queda cortado (antes era scroll y recortaba). */
.val-strip { display: flex; flex-wrap: wrap; gap: 10px; padding: 16px 18px; }
.vchip {
  flex: 0 1 auto; max-width: 100%;
  display: flex; align-items: center; gap: 10px;
  padding: 9px 14px 9px 9px;
  background: var(--d-card-2);
  border: 1px solid var(--m-line);
  border-radius: var(--m-r-pill);
  cursor: pointer;
  transition: border-color .15s, transform .15s;
}
.vchip:hover { border-color: var(--d-cyan-line); transform: translateY(-2px); }
.vchip .vc-pic { width: 30px; height: 30px; border-radius: 50%; object-fit: cover; flex: 0 0 auto; background: #0a1220; border: 1px solid var(--m-line); }
.vchip .vc-pic.ph { display: inline-flex; align-items: center; justify-content: center; font: 700 10px var(--d-mono); color: var(--m-mut); }
.vchip .vc-play { font: 600 13.5px "Inter", sans-serif; color: var(--m-ink); white-space: nowrap; }
.vchip .vc-sport { font: 600 10px var(--d-mono); letter-spacing: .08em; color: var(--m-mut); text-transform: uppercase; }
.vchip .vc-edge { font: 800 14px var(--d-mono); color: var(--m-green); }

/* contenedores futuros (placeholder elegante) */
.d-placeholder {
  display: flex; align-items: center; justify-content: center;
  min-height: 120px; padding: 30px;
  color: var(--m-mut); font: 500 14px "Inter", sans-serif;
  gap: 12px;
}
.d-placeholder .d-shimmer { width: 20px; height: 20px; border-radius: 50%; border: 2px solid var(--m-line); border-top-color: var(--m-cyan); animation: d-spin .8s linear infinite; }
@keyframes d-spin { to { transform: rotate(360deg); } }

/* ── Skeletons (degradación elegante) ──────────────────────── */
.sk { position: relative; overflow: hidden; background: #0e1827; border-radius: 7px; }
.sk::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent, rgba(56, 214, 255, .07), transparent);
  animation: d-sweep 1.3s infinite;
}
@keyframes d-sweep { 100% { transform: translateX(100%); } }
.sk-line { height: 12px; margin: 6px 0; }
.empty-note { color: var(--m-mut); font: 500 13px "Inter", sans-serif; padding: 14px 0; text-align: center; }

/* ── Enlace de cabecera ("Ver centro completo / análisis") ──── */
.card-link {
  margin-left: auto; display: inline-flex; align-items: center; gap: 5px;
  font: 700 11px var(--d-mono); letter-spacing: .04em; text-transform: uppercase;
  color: var(--m-cyan); text-decoration: none; padding: 5px 8px; border-radius: 8px;
  transition: background .15s;
}
.card-link svg { width: 13px; height: 13px; }
.card-link:hover { background: var(--d-cyan-soft); }

/* ── Etiqueta de origen del héroe (WATCH / mejor oportunidad) ── */
.pick-src {
  display: inline-block; font: 700 9.5px var(--d-mono); letter-spacing: .14em;
  color: var(--m-cyan); background: var(--d-cyan-soft);
  border: 1px solid var(--d-cyan-line); border-radius: 6px;
  padding: 3px 8px; margin: 0 0 12px;
}
/* Fecha/hora del partido de la jugada principal (centrada bajo los equipos) */
.pick-when {
  display: flex; align-items: center; justify-content: center; gap: 6px;
  font: 700 11px var(--d-mono); letter-spacing: .06em; color: var(--m-cyan);
  text-transform: capitalize; margin: 2px 0 12px;
}
.pick-when::before {
  content: ""; width: 13px; height: 13px; flex: 0 0 auto; background: currentColor;
  -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='4' width='18' height='18' rx='2'/><path d='M16 2v4M8 2v4M3 10h18'/></svg>") center/contain no-repeat;
  mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='4' width='18' height='18' rx='2'/><path d='M16 2v4M8 2v4M3 10h18'/></svg>") center/contain no-repeat;
}

/* ── Consenso: barra vacía ("—") con borde discreto ────────── */
.cons-fill.is-empty { background: rgba(255, 255, 255, .05); }

/* ── Centro de estadísticas embebido (POWER RANKING top 8) ──── */
.stats-tabs { display: flex; gap: 8px; overflow-x: auto; padding: 12px 18px 4px; scrollbar-width: none; }
.stats-tabs::-webkit-scrollbar { display: none; }
.rank-list { padding: 8px 14px 14px; }
.rank-row {
  display: grid; grid-template-columns: 26px 30px 1fr auto; align-items: center;
  gap: 12px; padding: 9px 8px; border-radius: var(--d-r-sm);
  cursor: pointer; transition: background .15s;
}
.rank-row + .rank-row { border-top: 1px solid rgba(32, 48, 75, .45); }
.rank-row:hover { background: var(--d-card-2); }
.rk-pos { font: 800 14px var(--d-mono); color: var(--m-mut); text-align: center; }
.rk-pos.medal-oro { color: #f2c14e; }
.rk-pos.medal-plata { color: #c8d2de; }
.rk-pos.medal-bronce { color: #cf8b54; }
.rk-logo {
  width: 30px; height: 30px; border-radius: 8px; object-fit: contain;
  background: #0a1220; padding: 3px;
}
span.rk-logo.ph {
  display: inline-flex; align-items: center; justify-content: center;
  font: 800 11px var(--d-mono); color: var(--m-cyan);
  border: 1px solid var(--m-line);
}
.rk-main { min-width: 0; }
.rk-name {
  display: flex; align-items: center; gap: 7px;
  font: 600 14px "Inter", sans-serif; color: var(--m-ink);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-bottom: 6px;
}
.rk-trend { font-size: 11px; line-height: 1; }
.rk-trend.is-up { color: var(--m-green); }
.rk-trend.is-down { color: var(--m-red); }
.rk-trend.is-flat { color: var(--m-mut); }
.rk-bar { height: 5px; border-radius: 999px; background: #0a1220; overflow: hidden; }
.rk-bar span {
  display: block; height: 100%; border-radius: 999px;
  background: linear-gradient(90deg, #2aa9d6, var(--m-cyan));
}
.rk-elo { font: 800 22px var(--d-mono); color: var(--d-ink-2); letter-spacing: -.02em; }

/* ── Analista IA · Resumen ─────────────────────────────────── */
.ai-body { padding: 16px 18px 18px; }
.ai-head { display: flex; align-items: center; gap: 13px; margin-bottom: 14px; }
.ai-avatar {
  width: 56px; height: 56px; border-radius: 14px; object-fit: cover;
  object-position: center;       /* atlas-face.png ya es un retrato cuadrado bien encuadrado */
  border: 1px solid var(--d-cyan-line); background: #0a1220; flex: none;
}
.ai-id { min-width: 0; }
.ai-name { font: 800 16px "Inter", sans-serif; color: var(--m-ink); }
.ai-name span { font-weight: 600; color: var(--m-cyan); font-size: 12px; }
.ai-match { font: 600 12.5px var(--d-mono); color: var(--m-mut); margin-top: 3px; }
.ai-read { font: 500 14px/1.55 "Inter", sans-serif; color: var(--d-ink-2); margin: 0 0 16px; }
.ai-metrics { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 14px; }
.ai-metric { background: var(--d-card-2); border: 1px solid var(--m-line); border-radius: var(--d-r-sm); padding: 11px 13px; }
.aim-k { font: 600 9.5px var(--d-mono); letter-spacing: .12em; text-transform: uppercase; color: var(--m-mut); margin-bottom: 6px; }
.aim-v { font: 800 22px var(--d-mono); color: var(--m-ink); line-height: 1; }
.aim-v small { font-size: 13px; color: var(--m-mut); font-weight: 600; }
.aim-bar { height: 5px; border-radius: 999px; background: #0a1220; overflow: hidden; margin-top: 9px; }
.aim-bar span { display: block; height: 100%; border-radius: 999px; background: linear-gradient(90deg, #2aa9d6, var(--m-cyan)); }
.ai-chips { display: flex; flex-wrap: wrap; gap: 7px; margin-bottom: 16px; }
.ai-chip {
  font: 600 11.5px "Inter", sans-serif; color: var(--d-ink-2);
  background: var(--d-card-2); border: 1px solid var(--m-line);
  border-radius: 999px; padding: 5px 11px;
}
.ai-cta {
  display: inline-flex; align-items: center; gap: 7px;
  font: 700 12.5px "Inter", sans-serif; color: var(--m-cyan); text-decoration: none;
  padding: 9px 15px; border-radius: var(--m-r-pill);
  border: 1px solid var(--d-cyan-line); background: var(--d-cyan-soft);
  transition: background .15s;
}
.ai-cta svg { width: 14px; height: 14px; }
.ai-cta:hover { background: rgba(56, 214, 255, .2); }

/* ── Responsive: tablet ────────────────────────────────────── */
@media (max-width: 1180px) {
  .d-kpis { grid-template-columns: repeat(3, 1fr); }
  .d-hero { grid-template-columns: 1fr; }
  .d-grid { grid-template-columns: 1fr; }
  .d-rail { flex-direction: column; }
}

/* ── Responsive: móvil (app nativa premium · igual al mockup iPhone) ── */
@media (max-width: 720px) {
  /* contenedor a 100% de ancho · NADA desborda por la derecha */
  .dash { padding: 0 14px 92px; max-width: 100%; overflow-x: hidden; }
  body.has-mbn .dash { padding-bottom: calc(var(--m-nav-h) + 24px + env(safe-area-inset-bottom)); }

  /* ── 1) HEADER COMPACTO (hamburguesa · logo · avatar) ── */
  .d-mhead {
    display: flex; align-items: center; gap: 12px;
    position: sticky; top: 0; z-index: 60;
    margin: 0 -14px 12px; padding: 10px 14px calc(10px + env(safe-area-inset-top));
    padding-top: max(10px, env(safe-area-inset-top));
    background: rgba(8, 12, 20, .92);
    -webkit-backdrop-filter: blur(14px); backdrop-filter: blur(14px);
    border-bottom: 1px solid var(--m-line);
  }
  .d-mh-burger {
    flex: 0 0 auto; width: 40px; height: 40px; display: inline-flex; align-items: center; justify-content: center;
    border-radius: 11px; background: var(--d-card-2); border: 1px solid var(--m-line);
    color: var(--d-ink-2); cursor: pointer; -webkit-tap-highlight-color: transparent;
  }
  .d-mh-burger svg { width: 21px; height: 21px; }
  .d-mh-burger:active { opacity: .7; }
  .d-mh-brand { flex: 1 1 auto; min-width: 0; display: flex; align-items: center; gap: 9px; justify-content: center; text-decoration: none; }
  .d-mh-mark { width: 30px; height: 30px; border-radius: 8px; object-fit: cover; flex: 0 0 auto;
    box-shadow: 0 3px 12px rgba(62, 230, 160, .22); }
  .d-mh-wm { display: flex; flex-direction: column; line-height: 1.05; min-width: 0; }
  .d-mh-wm b { font: 800 13px "Inter", system-ui, sans-serif; letter-spacing: .03em; color: var(--m-ink);
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .d-mh-wm i { font: 700 7px "JetBrains Mono", monospace; letter-spacing: .2em; color: var(--m-mut); font-style: normal; margin-top: 2px;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .d-mh-user { flex: 0 0 auto; line-height: 0; }
  .d-mh-av { width: 36px; height: 36px; border-radius: 50%; object-fit: cover; display: block;
    border: 1.5px solid var(--m-cyan); background: #0a1220; }

  /* ── 2) FILA FINA "● EN VIVO   21:08:24" (reusa la pill restilizada) ── */
  .d-top { display: block; margin-bottom: 14px; }
  .d-greet, .d-top-r .d-search, .d-top-r .d-icon-btn { display: none; }   /* fuera saludo grande, buscador y campana */
  .d-top-r { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
  .d-live-pill {
    flex: 1 1 auto; justify-content: space-between; width: 100%;
    padding: 6px 4px; background: transparent; border: none; border-radius: 0;
    font: 800 11px var(--d-mono); letter-spacing: .14em; text-transform: uppercase; color: var(--m-green);
  }
  .d-live-pill time { margin-left: auto; font-size: 13px; letter-spacing: .04em; text-transform: none; }

  /* ── 3) TARJETA DE SALUDO con foto del analista ── */
  .d-mgreet {
    display: flex; align-items: center; gap: 14px;
    background: var(--m-card); border: 1px solid var(--m-line);
    border-radius: 16px; box-shadow: var(--d-shadow-1);
    padding: 16px 18px; margin-bottom: 16px; overflow: hidden;
  }
  .d-mgreet-txt { flex: 1 1 auto; min-width: 0; }
  .d-mgreet-txt h2 { font: 800 21px "Inter", system-ui, sans-serif; line-height: 1.2; color: var(--m-ink); letter-spacing: -.01em; }
  .d-mgreet-txt h2 b { color: var(--m-cyan); font-weight: 800; }
  .d-mgreet-txt p { margin: 6px 0 0; color: var(--m-mut); font: 500 13px "Inter", system-ui, sans-serif; line-height: 1.35; }
  .d-mgreet-photo {
    flex: 0 0 auto; width: 78px; height: 78px; border-radius: 14px;
    object-fit: cover; object-position: center top;
    border: 1px solid var(--d-cyan-line); background: #0a1220;
  }

  /* ── 4) KPIs: 3 por fila × 2 filas, compactos, valor en verde ── */
  .d-kpis { grid-template-columns: repeat(3, 1fr); gap: 8px; margin-bottom: 16px; }
  .kpi { min-height: 0; padding: 11px 10px 10px; gap: 6px; border-radius: 13px; }
  .kpi-top { gap: 4px; }
  .kpi .d-label { font-size: 8.5px; letter-spacing: .08em; line-height: 1.2; }
  .kpi-val { font-size: 18px; }
  .kpi-val:not(.neg) { color: var(--m-green); }   /* valores en verde (dinero/éxito) salvo negativos */
  .kpi-sub { font-size: 10px; margin-top: 0; }
  .kpi-ring { width: 34px; height: 34px; }
  .kpi-ring text { font-size: 11px; }
  .kpi-spark { height: 20px; }

  /* ── 5) PICK DEL DÍA: borde verde, apilado, nada cortado ── */
  .pick-card { border-color: rgba(62, 230, 160, .45);
    box-shadow: 0 0 0 1px rgba(62, 230, 160, .18), var(--d-shadow-1); }
  .pick-body { padding: 16px 14px 18px; }
  .pick-teams { gap: 8px; margin-bottom: 14px; }
  .pt-team .pt-logo, .pt-team .ph { width: 52px; height: 52px; }
  .pt-name { font-size: 13.5px; }
  .pt-prob { font-size: 16px; }
  .pick-play { padding: 12px 13px; margin-bottom: 14px; flex-wrap: wrap; gap: 8px; }
  .pick-play .pp-l { font-size: 15px; min-width: 0; }
  .pick-play .pp-edge { font-size: 14px; flex: 0 0 auto; }
  /* nombres largos no desbordan: ocupan su columna y, si hace falta, parten en 2 líneas */
  .pick-teams { grid-template-columns: 1fr auto 1fr; }
  .pt-team { min-width: 0; }
  .pt-name { font-size: 13px; line-height: 1.15; overflow-wrap: anywhere; }
  /* 5 métricas en una fila SIN cortarse: texto compacto (como el mockup) */
  .pick-metrics { grid-template-columns: repeat(5, 1fr); gap: 5px; }
  .pick-metrics .pm { padding: 8px 3px; min-width: 0; }
  .pick-metrics .pm-v { font-size: 12.5px; }
  .pick-metrics .pm-k { font-size: 6.5px; letter-spacing: .04em; margin-top: 4px; }
  .pm { padding: 9px 4px; }
  .pm .pm-v { font-size: 12.5px; }
  .pm .pm-k { font-size: 7.5px; letter-spacing: .05em; }

  /* ── 6) MONTE CARLO: histograma a todo el ancho, grande ── */
  .mc-body { padding: 14px 14px 16px; }
  .mc-chart { height: 168px; }
  .mc-bands { gap: 8px; }
  .mc-band { padding: 11px 8px; }
  .mc-band .mb-v { font-size: 18px; }

  /* ── 7) CARTELERA DEL DÍA: FILAS apiladas (no scroll horizontal) ── */
  .board-rail { flex-direction: column; gap: 10px; overflow-x: visible; padding: 14px; }
  .gcard {
    flex: 1 1 auto; width: 100%; flex-direction: row; flex-wrap: wrap; align-items: center;
    gap: 8px 10px; padding: 12px 13px;
  }
  .gc-top { order: 0; flex: 1 1 100%; }
  .gc-team { order: 1; flex: 1 1 100%; min-width: 0; }
  .gc-team span { flex: 1 1 auto; min-width: 0; }
  .gc-foot { order: 2; flex: 1 1 100%; }

  /* ── 8) Resto: que todo encaje ── */
  .perf-stats { grid-template-columns: repeat(3, 1fr); }
  .ai-metrics { grid-template-columns: 1fr 1fr; }
  .rank-row { grid-template-columns: 24px 28px 1fr auto; gap: 10px; padding: 11px 6px; }
  .rk-elo { font-size: 19px; }

  /* APUESTAS CON VALOR: chips a ancho completo, el nombre TRUNCA (no desborda) */
  .val-strip { flex-direction: column; padding: 14px; }
  .vchip { flex: 1 1 100%; width: 100%; max-width: 100%; min-width: 0; }
  .vchip .vc-play { flex: 1 1 auto; min-width: 0; overflow: hidden; text-overflow: ellipsis; }
  .vchip .vc-sport { flex: 0 0 auto; }
  .vchip .vc-edge { flex: 0 0 auto; margin-left: auto; }

  /* tap targets >=44px */
  .bt, .vchip, .rank-row, .d-mh-burger, .d-mh-av { min-height: 44px; }
  .d-mh-av { min-height: 0; }   /* el avatar es 36px por diseño */

  /* ── La hamburguesa abre el sidebar (.msb) como panel deslizante ── */
  .d-msb-ov {
    position: fixed; inset: 0; z-index: 198; background: rgba(2, 5, 10, .55);
    opacity: 0; pointer-events: none; transition: opacity .22s ease;
    -webkit-backdrop-filter: blur(2px); backdrop-filter: blur(2px);
  }
  body.msb-open .d-msb-ov { opacity: 1; pointer-events: auto; }
  /* mostramos el sidebar (oculto por defecto en móvil) como drawer izquierdo */
  body.msb-open .msb {
    display: flex !important; flex-direction: column;
    position: fixed; top: 0; left: 0; bottom: 0; width: min(84vw, 300px); z-index: 200;
    padding: max(18px, env(safe-area-inset-top)) 14px calc(16px + env(safe-area-inset-bottom));
    gap: 6px;
    background: linear-gradient(180deg, #0a1220 0%, #070d18 100%);
    border-right: 1px solid var(--m-line);
    box-shadow: 16px 0 46px rgba(0, 0, 0, .5);
    overflow-y: auto;
  }
  /* el sidebar entra desde la izquierda */
  .msb { transform: translateX(-104%); transition: transform .24s ease; }
  body.msb-open .msb { transform: translateX(0); }
  /* estructura interna del sidebar visible en este drawer móvil */
  body.msb-open .msb .msb-brand { display: flex; align-items: center; gap: 11px; padding: 6px 8px 16px;
    text-decoration: none; border-bottom: 1px solid rgba(255, 255, 255, .05); margin-bottom: 10px; }
  body.msb-open .msb .msb-mark { width: 34px; height: 34px; border-radius: 9px; object-fit: cover; flex: 0 0 auto; }
  body.msb-open .msb .msb-wm { display: flex; flex-direction: column; line-height: 1.1; }
  body.msb-open .msb .msb-wm b { font: 800 14.5px "Inter", system-ui, sans-serif; letter-spacing: .04em; color: var(--m-ink); }
  body.msb-open .msb .msb-wm i { font: 700 8px "JetBrains Mono", monospace; letter-spacing: .22em; color: var(--m-mut); font-style: normal; margin-top: 3px; }
  body.msb-open .msb .msb-nav { display: flex; flex-direction: column; gap: 2px; flex: 1; overflow-y: auto; }
  body.msb-open .msb .msb-i {
    display: flex; align-items: center; gap: 12px; padding: 12px 12px; border-radius: 11px;
    text-decoration: none; color: var(--m-mut); position: relative;
    font: 600 14px "Inter", system-ui, sans-serif; white-space: nowrap;
  }
  body.msb-open .msb .msb-ic { display: flex; flex: 0 0 auto; }
  body.msb-open .msb .msb-ic svg { width: 20px; height: 20px; }
  body.msb-open .msb .msb-i.on { color: var(--m-cyan); background: linear-gradient(90deg, rgba(56, 214, 255, .12), rgba(56, 214, 255, .03)); }
  body.msb-open .msb .msb-foot { margin-top: 6px; border-top: 1px solid rgba(255, 255, 255, .05); padding-top: 12px; display: flex; flex-direction: column; gap: 10px; }
  body.msb-open .msb .msb-mode { display: flex; align-items: center; gap: 5px; flex-wrap: wrap; }
  body.msb-open .msb .msb-mode-l { font: 700 8px "JetBrains Mono", monospace; letter-spacing: .18em; color: var(--m-mut); width: 100%; margin-bottom: 2px; }
  body.msb-open .msb .msb-mode-b { flex: 1; min-width: 0; padding: 8px 4px; border-radius: 8px; border: 1px solid var(--m-line);
    background: #0b1322; color: var(--m-mut); font: 600 11px "Inter", system-ui, sans-serif; cursor: pointer; white-space: nowrap; }
  body.msb-open .msb .msb-mode-b.on { border-color: var(--m-green); color: var(--m-green); background: rgba(62, 230, 160, .08); }
  body.msb-open .msb .msb-user { display: flex; align-items: center; gap: 10px; padding: 10px; border-radius: 12px; text-decoration: none;
    background: #0b1322; border: 1px solid var(--m-line); }
  body.msb-open .msb .msb-uav { width: 34px; height: 34px; border-radius: 50%; object-fit: cover; flex: 0 0 auto; border: 1.5px solid var(--m-cyan); }
  body.msb-open .msb .msb-uinfo { display: flex; flex-direction: column; line-height: 1.2; min-width: 0; }
  body.msb-open .msb .msb-uinfo b { font: 700 13px "Inter", system-ui, sans-serif; color: var(--m-ink); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 180px; }
  body.msb-open .msb .msb-uinfo i { font: 700 8.5px "JetBrains Mono", monospace; letter-spacing: .14em; color: var(--m-green); font-style: normal; margin-top: 2px; }
}

/* ── Ficha de enfrentamiento (modal) ───────────────────────────────────────── */
.mm-back {
  position: fixed; inset: 0; z-index: 90;
  background: rgba(5, 9, 17, .72);
  backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
}
.mm-back[hidden] { display: none; }
.mm-card {
  position: relative; width: 100%; max-width: 440px;
  max-height: 88vh; overflow-y: auto;
  background: var(--m-card); border: 1px solid var(--m-line);
  border-radius: 18px; padding: 22px 22px 18px;
  box-shadow: 0 24px 60px rgba(0, 0, 0, .55);
  animation: mm-in .18s ease;
}
@keyframes mm-in { from { opacity: 0; transform: translateY(10px) scale(.98); } to { opacity: 1; transform: none; } }
.mm-x {
  position: absolute; top: 12px; right: 14px;
  background: none; border: 0; color: var(--m-mut);
  font-size: 26px; line-height: 1; cursor: pointer; padding: 2px 6px;
}
.mm-x:hover { color: var(--m-ink); }
.mm-head {
  display: grid; grid-template-columns: 1fr auto 1fr; align-items: center;
  gap: 10px; padding: 4px 0 14px; border-bottom: 1px solid var(--m-line);
}
.mm-side { min-width: 0; text-align: center; }
.mm-side .mm-tn { font: 800 16px "Inter", system-ui, sans-serif; color: var(--m-ink); display: block; overflow-wrap: anywhere; line-height: 1.2; }
.mm-vs { font: 800 12px "JetBrains Mono", monospace; color: var(--m-cyan); letter-spacing: .1em; }
.mm-body { padding: 14px 0 4px; }
.mm-mut { color: var(--m-mut); font: 500 13px "Inter", system-ui, sans-serif; }
.mm-prob { margin-bottom: 12px; }
.mm-prow { display: flex; align-items: center; gap: 8px; font: 700 13px "Inter", system-ui, sans-serif; color: var(--m-ink); margin-bottom: 5px; }
.mm-prow b { color: var(--m-cyan); }
.mm-prow-r { justify-content: flex-end; margin-top: 5px; }
.mm-prow-r b { color: var(--m-green); }
.mm-bar { display: flex; height: 9px; border-radius: 6px; overflow: hidden; background: var(--m-line); }
.mm-ba { background: var(--m-cyan); }
.mm-bd { background: var(--m-mut); opacity: .5; }
.mm-bb { background: var(--m-green); }
.mm-draw { text-align: center; font: 600 11px "JetBrains Mono", monospace; color: var(--m-mut); margin-top: 6px; letter-spacing: .04em; }
.mm-fav { text-align: center; font: 600 12px "Inter", system-ui, sans-serif; color: var(--m-mut); margin: 10px 0; }
.mm-fav b { color: var(--m-ink); }
.mm-stats { display: grid; grid-template-columns: 1fr 1.4fr 1fr; gap: 8px; align-items: start; margin: 4px 0 14px; }
.mm-stat { text-align: center; background: rgba(255,255,255,.02); border: 1px solid var(--m-line); border-radius: 12px; padding: 10px 6px; }
.mm-stat-r { text-align: center; }
.mm-sk { display: block; font: 700 8.5px "JetBrains Mono", monospace; letter-spacing: .12em; color: var(--m-mut); margin-bottom: 5px; }
.mm-stat b { font: 800 19px "Inter", system-ui, sans-serif; color: var(--m-ink); }
.mm-forms { display: flex; flex-direction: column; gap: 6px; }
.mm-frow { display: flex; justify-content: center; gap: 4px; }
.mm-fc { width: 18px; height: 18px; border-radius: 5px; font: 800 10px "JetBrains Mono", monospace; font-style: normal; display: inline-flex; align-items: center; justify-content: center; color: #07101e; }
.mm-fc.g { background: var(--m-green); }
.mm-fc.p { background: var(--m-red); color: #fff; }
.mm-fc.e { background: var(--m-mut); color: #07101e; }
.mm-h2h-t { font: 700 9px "JetBrains Mono", monospace; letter-spacing: .12em; color: var(--m-cyan); margin-bottom: 8px; }
.mm-h2h-row { display: flex; justify-content: space-between; align-items: center; padding: 7px 2px; border-bottom: 1px solid rgba(255,255,255,.04); }
.mm-h2h-d { font: 500 12px "Inter", system-ui, sans-serif; color: var(--m-mut); }
.mm-h2h-s { font: 800 13px "JetBrains Mono", monospace; color: var(--m-ink); }
.mm-foot { padding-top: 14px; margin-top: 6px; border-top: 1px solid var(--m-line); }
.mm-go {
  display: block; text-align: center; text-decoration: none;
  background: linear-gradient(180deg, var(--m-cyan), #21b6e0);
  color: #06101c; font: 800 14px "Inter", system-ui, sans-serif;
  padding: 13px; border-radius: 12px;
}
.mm-go:hover { filter: brightness(1.06); }
body.mm-open { overflow: hidden; }
@media (max-width: 720px) {
  .mm-card { padding: 18px 16px 16px; max-width: 100%; }
  .mm-side .mm-tn { font-size: 14.5px; }
  .mm-stat b { font-size: 17px; }
}

/* Botón "Cambiar" del Monte Carlo (no abre la ficha). */
.mc-change {
  display: inline-flex; align-items: center; gap: 5px;
  background: rgba(56, 214, 255, .1); border: 1px solid var(--m-line);
  color: var(--m-cyan); font: 700 10.5px "Inter", system-ui, sans-serif;
  padding: 5px 10px; border-radius: 999px; cursor: pointer; margin-left: 8px;
}
.mc-change svg { width: 12px; height: 12px; }
.mc-change:hover { background: rgba(56, 214, 255, .18); }
.mc-change[hidden] { display: none; }

/* ── Jugadas de valor: stake + botón registrar ───────────────────────────── */
.vc-stake { font: 800 11px "JetBrains Mono", monospace; color: var(--m-green); white-space: nowrap; }
.vc-reg { background: rgba(56,214,255,.12); border: 1px solid var(--m-cyan); color: var(--m-cyan);
  border-radius: 8px; padding: 5px 10px; font: 800 11px "Inter", system-ui, sans-serif; cursor: pointer; white-space: nowrap; }
.vc-reg:hover { background: rgba(56,214,255,.2); }

/* ── Modal "Registrar mi apuesta" ────────────────────────────────────────── */
#reg-modal .reg-h { font: 800 16px "Inter", system-ui, sans-serif; color: var(--m-ink); padding: 20px 22px 4px; }
#reg-modal .reg-match { font: 700 14px "Inter", system-ui, sans-serif; color: var(--m-cyan); padding: 0 22px; }
#reg-modal .reg-play { font: 600 12.5px "Inter", system-ui, sans-serif; color: var(--m-green); padding: 4px 22px 12px; }
#reg-modal .reg-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; padding: 0 22px; }
#reg-modal label { display: flex; flex-direction: column; gap: 5px; font: 700 10px "JetBrains Mono", monospace; letter-spacing: .08em; color: var(--m-mut); text-transform: uppercase; }
#reg-modal .reg-full { padding: 12px 22px 0; }
#reg-modal input, #reg-modal select { background: var(--m-bg); border: 1px solid var(--m-line); color: var(--m-ink); border-radius: 9px; padding: 10px 12px; font: 600 14px "Inter", system-ui, sans-serif; }
#reg-modal input:focus, #reg-modal select:focus { outline: none; border-color: var(--m-cyan); }
#reg-modal .reg-save { display: block; width: calc(100% - 44px); margin: 16px 22px 6px; background: linear-gradient(180deg, var(--m-cyan), #21b6e0); color: #06101c; border: 0; border-radius: 11px; padding: 12px; font: 800 14px "Inter", system-ui, sans-serif; cursor: pointer; }
#reg-modal .reg-save:hover { filter: brightness(1.06); }
#reg-modal .reg-save:disabled { opacity: .6; }
#reg-modal .reg-msg { text-align: center; font: 600 12px "Inter", system-ui, sans-serif; color: var(--m-mut); padding: 0 22px 18px; min-height: 16px; }

/* Stake "a jugar" + botón registrar en el PICK DEL DÍA (destacado) */
.pp-stake { font: 700 12px "Inter", system-ui, sans-serif; color: var(--m-mut); white-space: nowrap; }
.pp-stake b { color: var(--m-green); font-weight: 800; }
.pick-reg { display: block; width: 100%; margin-top: 12px; background: rgba(56,214,255,.1); border: 1px solid var(--m-cyan); color: var(--m-cyan); border-radius: 11px; padding: 11px; font: 800 13px "Inter", system-ui, sans-serif; cursor: pointer; }
.pick-reg:hover { background: rgba(56,214,255,.2); }

/* ── PICKS DEL DÍA — varias jugadas de valor en grid (no solo el héroe) ── */
.picks-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 12px; }
.pcard { position: relative; background: var(--d-card-2); border: 1px solid var(--m-line);
  border-radius: var(--d-r-sm); padding: 13px 14px 14px; cursor: pointer; transition: border-color .15s, transform .12s; }
.pcard:hover { border-color: var(--d-cyan-line); transform: translateY(-2px); }
.pc-top { display: flex; align-items: center; gap: 9px; margin-bottom: 9px; }
.pc-logo { width: 30px; height: 30px; border-radius: 7px; object-fit: contain; flex: 0 0 auto; background: #0b1322; }
.pc-match { min-width: 0; flex: 1; line-height: 1.2; }
.pc-match b { display: block; font: 700 13px "Inter", system-ui, sans-serif; color: var(--m-ink); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pc-match span { font: 500 11px "Inter", system-ui, sans-serif; color: var(--m-mut); }
.pc-tier { font: 800 8.5px var(--d-mono); letter-spacing: .1em; padding: 3px 6px; border-radius: 6px; flex: 0 0 auto; }
.pc-tier.pick { color: var(--m-green); background: rgba(62,230,160,.12); }
.pc-tier.watch { color: var(--m-cyan); background: var(--d-cyan-soft); }
.pc-when { display: inline-flex; align-items: center; gap: 5px; font: 700 10px var(--d-mono); letter-spacing: .04em; color: var(--m-cyan); background: var(--d-cyan-soft); border-radius: 6px; padding: 3px 8px; margin-bottom: 9px; text-transform: capitalize; }
.pc-when::before { content: ""; width: 11px; height: 11px; flex: 0 0 auto; background: currentColor; -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='4' width='18' height='18' rx='2'/><path d='M16 2v4M8 2v4M3 10h18'/></svg>") center/contain no-repeat; mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='4' width='18' height='18' rx='2'/><path d='M16 2v4M8 2v4M3 10h18'/></svg>") center/contain no-repeat; }
.pc-play { font: 700 15px "Inter", system-ui, sans-serif; color: var(--m-ink); margin-bottom: 11px; }
.pc-play small { font: 600 9px var(--d-mono); letter-spacing: .08em; color: var(--m-mut); margin-left: 4px; }
.pc-foot { display: flex; align-items: center; gap: 7px; flex-wrap: wrap; }
.pc-edge { font: 800 11px var(--d-mono); color: var(--m-green); }
.pc-conf { font: 700 8.5px var(--d-mono); letter-spacing: .08em; color: var(--m-mut); border: 1px solid var(--m-line); border-radius: 5px; padding: 2px 5px; }
.pc-stake { font: 700 11px var(--d-mono); color: var(--d-ink-2); margin-left: auto; }
.pcard .vc-reg { margin-top: 11px; width: 100%; padding: 7px; border-radius: 8px; border: 1px solid var(--m-line);
  background: #0b1322; color: var(--m-cyan); font: 700 11px "Inter", system-ui, sans-serif; cursor: pointer; transition: all .15s; }
.pcard .vc-reg:hover { border-color: var(--d-cyan-line); background: var(--d-cyan-soft); }
