/* ============================================================
   CHS Pollón de Oro — Widget Flotante v1.6.0
   Card: Frosted Glass blanco — header CHS verde
   Fuente: Montserrat
   Mandil: G1=Rojo · G2=Azul · G3=Amarillo
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700;800&display=swap');

/* ── Design Tokens ─────────────────────────────────────────── */
:root {
  /* ── Panel — frosted white ── */
  --pw-card-bg:     rgba(255, 255, 255, 0.92);
  --pw-card-border: rgba(255, 255, 255, 0.75);
  --pw-card-blur:   blur(28px) saturate(170%);

  /* ── Superficies internas ── */
  --pw-surf-1:  rgba(0, 0, 0, 0.03);
  --pw-surf-2:  rgba(0, 0, 0, 0.05);
  --pw-surf-3:  rgba(0, 0, 0, 0.035);
  --pw-divider: rgba(0, 0, 0, 0.08);

  /* ── Texto sobre blanco ── */
  --pw-text:     #172818;
  --pw-text-mid: #4a7452;
  --pw-text-dim: #a0bca4;

  /* ── Verde CHS (sobre blanco) ── */
  --pw-green-700: #14431e;
  --pw-green-600: #1d5e2c;
  --pw-green-500: #277a3a;
  --pw-green-400: #359850;
  --pw-green-300: #48b466;
  --pw-green-line: rgba(39, 122, 58, 0.18);

  /* ── Dorado (sobre blanco) ── */
  --pw-gold:       #9e7810;
  --pw-gold-light: #c29c1e;
  --pw-gold-pale:  #e8c84a;
  --pw-gold-bg:    rgba(158, 120, 16, 0.08);

  /* ── Celdas pendientes ── */
  --pw-pend-bg:     rgba(23, 40, 24, 0.04);
  --pw-pend-border: rgba(23, 40, 24, 0.10);
  --pw-pend-text:   #98b49c;

  /* ── Mandil G1 — Rojo ── */
  --pw-g1-bg:     rgba(229, 57, 53, 0.08);
  --pw-g1-border: rgba(198, 40, 40, 0.45);
  --pw-g1-text:   #b71c1c;
  --pw-g1-solid:  #e53935;
  --pw-g1-glow:   rgba(229, 57, 53, 0.18);

  /* ── Mandil G2 — Azul ── */
  --pw-g2-bg:     rgba(30, 136, 229, 0.08);
  --pw-g2-border: rgba(21, 101, 192, 0.45);
  --pw-g2-text:   #1565c0;
  --pw-g2-solid:  #1e88e5;
  --pw-g2-glow:   rgba(30, 136, 229, 0.18);

  /* ── Mandil G3 — Amarillo ── */
  --pw-g3-bg:     rgba(249, 168, 37, 0.10);
  --pw-g3-border: rgba(230, 81, 0, 0.45);
  --pw-g3-text:   #bf5000;
  --pw-g3-solid:  #f9a825;
  --pw-g3-glow:   rgba(249, 168, 37, 0.18);

  /* ── Layout ── */
  --pw-font:    'Montserrat', system-ui, sans-serif;
  --pw-r-xl:    22px;
  --pw-r-lg:    14px;
  --pw-r-md:    10px;
  --pw-r-sm:    7px;
  --pw-panel-w: 480px;
  --pw-px:      24px;     /* padding horizontal */
  --pw-cols:    5;
  --pw-z:       99999;

  /* ── Motion ── */
  --pw-ease:   cubic-bezier(0.4, 0, 0.2, 1);
  --pw-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
  --pw-fast:   140ms;
  --pw-med:    250ms;
}

/* ── Reset ──────────────────────────────────────────────────── */
#chspw-widget {
  position:    fixed;
  z-index:     var(--pw-z);
  font-family: var(--pw-font);
  font-size:   13px;
  line-height: 1.4;
  box-sizing:  border-box;
  -webkit-font-smoothing:  antialiased;
  -moz-osx-font-smoothing: grayscale;
}
#chspw-widget *, #chspw-widget *::before, #chspw-widget *::after {
  box-sizing: inherit;
}

/* ═══════════════════════════════════════════════════════════
   BOTÓN FLOTANTE (sigue oscuro para contraste en cualquier fondo)
   ═══════════════════════════════════════════════════════════ */
.chspw-toggle-btn {
  display:     flex;
  align-items: center;
  gap:         10px;
  padding:     0 14px 0 16px;
  height:      50px;
  background:  linear-gradient(135deg, #1a4224 0%, #276636 55%, #359850 100%);
  border:      1px solid rgba(255,255,255,.15);
  border-radius:   50px;
  color:           #e8c84a;
  font-family:     var(--pw-font);
  font-size:       12px;
  font-weight:     700;
  letter-spacing:  .1em;
  text-transform:  uppercase;
  cursor:          pointer;
  white-space:     nowrap;
  position:        relative;
  overflow:        hidden;
  box-shadow:
    0 4px 22px rgba(0,0,0,.35),
    0 1px 0 rgba(255,255,255,.12) inset,
    0 -1px 0 rgba(0,0,0,.2) inset;
  transition:
    transform    var(--pw-fast) var(--pw-ease),
    box-shadow   var(--pw-fast) var(--pw-ease),
    opacity      var(--pw-med)  var(--pw-ease),
    filter       var(--pw-fast) var(--pw-ease);
}
.chspw-toggle-btn::before {
  content:    '';
  position:   absolute;
  inset:      0;
  background: linear-gradient(100deg, transparent 20%, rgba(255,255,255,.14) 50%, transparent 80%);
  transform:  translateX(-100%);
  transition: transform .55s ease;
}
.chspw-toggle-btn:hover::before { transform: translateX(100%); }
.chspw-toggle-btn:hover {
  transform:  translateY(-2px);
  filter:     brightness(1.1);
  box-shadow: 0 8px 28px rgba(0,0,0,.4), 0 0 20px rgba(77,179,100,.25);
}
.chspw-toggle-btn:active         { transform: scale(.97); }
.chspw-toggle-btn:focus-visible  { outline: 2px solid #e8c84a; outline-offset: 4px; }

/* Se oculta cuando el panel está abierto */
.chspw-panel.chspw-open ~ .chspw-toggle-btn {
  opacity:        0;
  pointer-events: none;
  transform:      translateY(8px) scale(0.9);
}

.chspw-toggle-icon  { font-size: 20px; line-height: 1; flex-shrink: 0; }
.chspw-toggle-label { flex: 1; }

/* Badge — inline en el flujo flex del botón */
.chspw-badge {
  display:         inline-flex;
  align-items:     center;
  justify-content: center;
  flex-shrink:     0;
  min-width:       22px;
  height:          22px;
  padding:         0 6px;
  background:      linear-gradient(135deg, #b8900e 0%, #e8c84a 60%, #c9a227 100%);
  color:           #1a0e00;
  font-size:       11px;
  font-weight:     900;
  letter-spacing:  -.01em;
  border-radius:   50px;
  border:          2px solid rgba(255,255,255,.25);
  box-shadow:
    0 2px 8px rgba(0,0,0,.4),
    0 1px 0 rgba(255,255,255,.3) inset;
  animation: pw-badge-pop .38s var(--pw-spring) both;
}
@keyframes pw-badge-pop {
  from { transform: scale(0) rotate(-15deg); opacity: 0; }
  to   { transform: scale(1) rotate(0deg);   opacity: 1; }
}
.chspw-badge.chspw-badge-bump {
  animation: pw-badge-bump .35s var(--pw-spring);
}
@keyframes pw-badge-bump {
  0%,100% { transform: scale(1); }
  40%     { transform: scale(1.35); }
}

/* Pulse */
.chspw-toggle-btn.chspw-pulse { animation: pw-pulse 1.8s 3; }
@keyframes pw-pulse {
  0%,100% { box-shadow: 0 4px 22px rgba(0,0,0,.35); }
  50%     { box-shadow: 0 0 0 12px rgba(77,179,100,.12), 0 4px 22px rgba(0,0,0,.35); }
}

/* ═══════════════════════════════════════════════════════════
   PANEL — FROSTED GLASS BLANCO
   ═══════════════════════════════════════════════════════════ */
.chspw-panel {
  position:         absolute;
  width:            var(--pw-panel-w);
  max-width:        calc(100vw - 24px);
  background:       var(--pw-card-bg);
  border:           1px solid var(--pw-card-border);
  border-radius:    var(--pw-r-xl);
  overflow:         hidden;
  backdrop-filter:  var(--pw-card-blur);
  -webkit-backdrop-filter: var(--pw-card-blur);
  box-shadow:
    0 0 0 1px rgba(255,255,255,.5) inset,
    0 24px 64px rgba(0,0,0,.22),
    0 6px 20px rgba(0,0,0,.12),
    0 1px 4px rgba(0,0,0,.08);
  opacity:        0;
  transform:      translateY(14px) scale(.97);
  pointer-events: none;
  visibility:     hidden;
  transition:
    opacity    var(--pw-med) var(--pw-ease),
    transform  var(--pw-med) var(--pw-spring),
    visibility var(--pw-med);
}
.chspw-panel.chspw-open {
  opacity:        1;
  transform:      none;
  pointer-events: auto;
  visibility:     visible;
}

/* Posición */
.chspw-pos-bottom-right .chspw-panel,
.chspw-pos-bottom-left  .chspw-panel { bottom: calc(100% + 14px); }
.chspw-pos-top-right    .chspw-panel,
.chspw-pos-top-left     .chspw-panel { top:    calc(100% + 14px); }
.chspw-pos-bottom-right .chspw-panel,
.chspw-pos-top-right    .chspw-panel { right: 0; }
.chspw-pos-bottom-left  .chspw-panel,
.chspw-pos-top-left     .chspw-panel { left:  0; }

/* ── Header — verde CHS (ancla visual de marca) ─────────── */
.chspw-panel-header {
  display:     flex;
  align-items: center;
  gap:         14px;
  padding:     20px var(--pw-px) 18px;
  background:  linear-gradient(135deg, #152e1c 0%, #1e4828 60%, #276636 100%);
  position:    relative;
}
.chspw-panel-header::after {
  content:  '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height:   2px;
  background: linear-gradient(90deg,
    transparent    0%,
    var(--pw-green-400) 20%,
    var(--pw-gold-pale) 50%,
    var(--pw-green-400) 80%,
    transparent    100%);
  opacity: .7;
}

.chspw-panel-icon {
  width:         40px;
  height:        40px;
  display:       flex;
  align-items:   center;
  justify-content: center;
  background:    rgba(232, 200, 74, 0.15);
  border:        1px solid rgba(232, 200, 74, 0.3);
  border-radius: var(--pw-r-md);
  font-size:     20px;
  flex-shrink:   0;
}
.chspw-panel-title {
  flex:           1;
  font-size:      13.5px;
  font-weight:    800;
  letter-spacing: .12em;
  text-transform: uppercase;
  color:          #e8c84a;
  text-shadow:    0 1px 8px rgba(0,0,0,.3);
}

.chspw-close-btn {
  width:         30px;
  height:        30px;
  display:       flex;
  align-items:   center;
  justify-content: center;
  background:    rgba(255,255,255,.1);
  border:        1px solid rgba(255,255,255,.2);
  border-radius: 50%;
  color:         rgba(255,255,255,.7);
  font-size:     13px;
  cursor:        pointer;
  flex-shrink:   0;
  transition:
    background   var(--pw-fast),
    border-color var(--pw-fast),
    color        var(--pw-fast),
    transform    200ms var(--pw-spring);
}
.chspw-close-btn:hover {
  background:   rgba(229,57,53,.25);
  border-color: rgba(229,57,53,.5);
  color:        #fff;
  transform:    rotate(90deg);
}

/* ── Status bar ──────────────────────────────────────────── */
.chspw-panel-subtitle {
  display:       flex;
  align-items:   center;
  gap:           9px;
  padding:       11px var(--pw-px);
  font-size:     11.5px;
  font-weight:   600;
  letter-spacing:.04em;
  color:         var(--pw-text-mid);
  background:    var(--pw-surf-1);
  border-bottom: 1px solid var(--pw-divider);
  min-height:    40px;
}
.chspw-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background:  var(--pw-pend-border);
  flex-shrink: 0;
}
.chspw-dot.chspw-dot-live {
  background: var(--pw-green-400);
  box-shadow: 0 0 6px var(--pw-green-400);
  animation:  pw-blink 2.2s ease-in-out infinite;
}
.chspw-dot.chspw-dot-error { background: var(--pw-g1-solid); box-shadow: 0 0 6px var(--pw-g1-solid); }
@keyframes pw-blink { 0%,100% { opacity: 1; } 50% { opacity: .2; } }

/* ── Progress bar ────────────────────────────────────────── */
.chspw-progress-bar {
  height:     4px;
  background: rgba(0,0,0,.06);
}
.chspw-progress-fill {
  height:     100%;
  background: linear-gradient(90deg, var(--pw-green-500), var(--pw-green-300) 60%, var(--pw-gold-pale));
  transition: width .8s var(--pw-ease);
}

/* ═══════════════════════════════════════════════════════════
   PODIO — COLAPSIBLE
   ═══════════════════════════════════════════════════════════ */

/* Contenedor details */
.chspw-podium-details {
  border-bottom: 1px solid var(--pw-divider);
}
.chspw-podium-details summary { list-style: none; }
.chspw-podium-details summary::-webkit-details-marker { display: none; }

/* Summary — fila clickeable */
.chspw-podium-summary {
  display:         flex;
  align-items:     center;
  justify-content: space-between;
  padding:         10px var(--pw-px);
  background:      var(--pw-surf-1);
  cursor:          pointer;
  user-select:     none;
  font-size:       9px;
  font-weight:     700;
  letter-spacing:  .16em;
  text-transform:  uppercase;
  color:           var(--pw-text-dim);
  transition:      color var(--pw-fast);
}
.chspw-podium-summary:hover { color: var(--pw-green-400); }

/* Flecha */
.chspw-podium-chevron {
  font-size:  8px;
  display:    inline-block;
  transition: transform 220ms var(--pw-ease);
  opacity:    .6;
}
.chspw-podium-details[open] .chspw-podium-chevron {
  transform: rotate(180deg);
}

/* Contenido interno */
.chspw-podium {
  padding:    22px var(--pw-px) 20px;
  background: var(--pw-surf-1);
}
.chspw-podium-title {
  font-size:      9px;
  font-weight:    700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color:          var(--pw-text-dim);
  text-align:     center;
  margin-bottom:  16px;
}
.chspw-podium-stage {
  display:         flex;
  align-items:     flex-end;
  justify-content: center;
  gap:             12px;
  height:          96px;
  padding:         0 10px;
}
.chspw-podium-empty {
  color:       var(--pw-text-dim);
  font-size:   11px;
  text-align:  center;
  width:       100%;
  padding-top: 28px;
}
.chspw-podium-col {
  display:        flex;
  flex-direction: column;
  align-items:    center;
  gap:            4px;
  flex:           1;
  max-width:      100px;
}
.chspw-podium-wins {
  font-size:   14px;
  font-weight: 800;
  color:       var(--pw-text-mid);
  line-height: 1;
}
.chspw-podium-bar {
  width:         100%;
  border-radius: var(--pw-r-lg) var(--pw-r-lg) 0 0;
  background:    rgba(0,0,0,.08);
  position:      relative;
  overflow:      hidden;
  transition:    height .65s var(--pw-spring);
}
.chspw-podium-bar::after {
  content:    '';
  position:   absolute;
  top: 0; left: 0; right: 0;
  height:     45%;
  background: rgba(255,255,255,.25);
  border-radius: inherit;
}
.chspw-p1 .chspw-podium-bar { height: 58px; }
.chspw-p2 .chspw-podium-bar { height: 42px; }
.chspw-p3 .chspw-podium-bar { height: 28px; }

.chspw-podium-medal {
  font-size:      11px;
  font-weight:    700;
  color:          var(--pw-text-dim);
  letter-spacing: .06em;
}
.chspw-podium-group {
  font-size:      11px;
  font-weight:    800;
  letter-spacing: .04em;
  color:          var(--pw-text-mid);
}

/* Vacío */
.chspw-podium-col.chspw-p-empty { opacity: .25; }

/* Colores G1 */
.chspw-podium-col.chspw-g1 .chspw-podium-wins,
.chspw-podium-col.chspw-g1 .chspw-podium-medal,
.chspw-podium-col.chspw-g1 .chspw-podium-group { color: var(--pw-g1-text); }
.chspw-podium-col.chspw-g1 .chspw-podium-bar   {
  background: linear-gradient(180deg, var(--pw-g1-solid) 0%, rgba(183,28,28,.8) 100%);
  box-shadow: 0 4px 14px var(--pw-g1-glow);
}
/* G2 */
.chspw-podium-col.chspw-g2 .chspw-podium-wins,
.chspw-podium-col.chspw-g2 .chspw-podium-medal,
.chspw-podium-col.chspw-g2 .chspw-podium-group { color: var(--pw-g2-text); }
.chspw-podium-col.chspw-g2 .chspw-podium-bar   {
  background: linear-gradient(180deg, var(--pw-g2-solid) 0%, rgba(21,101,192,.8) 100%);
  box-shadow: 0 4px 14px var(--pw-g2-glow);
}
/* G3 */
.chspw-podium-col.chspw-g3 .chspw-podium-wins,
.chspw-podium-col.chspw-g3 .chspw-podium-medal,
.chspw-podium-col.chspw-g3 .chspw-podium-group { color: var(--pw-g3-text); }
.chspw-podium-col.chspw-g3 .chspw-podium-bar   {
  background: linear-gradient(180deg, var(--pw-g3-solid) 0%, rgba(200,100,0,.8) 100%);
  box-shadow: 0 4px 14px var(--pw-g3-glow);
}

/* ═══════════════════════════════════════════════════════════
   SELECTOR DE JORNADA
   ═══════════════════════════════════════════════════════════ */
.chspw-selector {
  display:       flex;
  align-items:   center;
  gap:           10px;
  padding:       10px var(--pw-px);
  background:    var(--pw-surf-1);
  border-bottom: 1px solid var(--pw-divider);
}

.chspw-sel-btn {
  flex-shrink:     0;
  width:           34px;
  height:          34px;
  display:         flex;
  align-items:     center;
  justify-content: center;
  background:      linear-gradient(135deg, #152e1c 0%, #276636 100%);
  color:           #e8c84a;
  border:          none;
  border-radius:   10px;
  font-size:       22px;
  font-weight:     300;
  line-height:     1;
  cursor:          pointer;
  box-shadow:      0 2px 8px rgba(0,0,0,.18);
  transition:
    filter     var(--pw-fast) var(--pw-ease),
    transform  var(--pw-fast) var(--pw-spring),
    opacity    var(--pw-fast) var(--pw-ease);
}
.chspw-sel-btn:hover:not(:disabled) {
  filter:    brightness(1.18);
  transform: scale(1.08);
}
.chspw-sel-btn:active:not(:disabled) { transform: scale(.93); }
.chspw-sel-btn:disabled {
  opacity: .28;
  cursor:  not-allowed;
  box-shadow: none;
}
.chspw-sel-btn:focus-visible {
  outline:        2px solid #e8c84a;
  outline-offset: 2px;
}

.chspw-sel-center {
  flex:       1;
  text-align: center;
  min-width:  0;
}
.chspw-sel-lbl {
  display:        block;
  font-size:      8px;
  font-weight:    700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color:          var(--pw-text-dim);
  margin-bottom:  1px;
}
.chspw-sel-date {
  display:        block;
  font-size:      15px;
  font-weight:    700;
  color:          var(--pw-text);
  letter-spacing: .02em;
  line-height:    1.25;
}
.chspw-sel-latest {
  display:        inline-block;
  margin-top:     4px;
  padding:        2px 9px;
  font-size:      8px;
  font-weight:    800;
  letter-spacing: .14em;
  text-transform: uppercase;
  background:     linear-gradient(135deg, #152e1c 0%, #276636 100%);
  color:          #e8c84a;
  border-radius:  20px;
}

/* ═══════════════════════════════════════════════════════════
   GRILLA
   ═══════════════════════════════════════════════════════════ */
.chspw-grid {
  display:               grid;
  grid-template-columns: repeat(var(--pw-cols, 5), 1fr);
  gap:                   8px;
  padding:               22px var(--pw-px) 20px;
  background:            transparent;
}

/* ── Celda base ──────────────────────────────────────────── */
.chspw-cell {
  display:         flex;
  flex-direction:  column;
  align-items:     center;
  justify-content: center;
  min-height:      62px;
  padding:         8px 4px 8px;
  gap:             4px;
  border-radius:   var(--pw-r-md);
  border:          1px solid var(--pw-pend-border);
  background:      var(--pw-pend-bg);
  color:           var(--pw-pend-text);
  text-align:      center;
  overflow:        hidden;
  cursor:          default;
  position:        relative;
  transition:
    background   var(--pw-med) var(--pw-ease),
    border-color var(--pw-med) var(--pw-ease),
    box-shadow   var(--pw-med) var(--pw-ease),
    transform    var(--pw-fast) var(--pw-ease);
}

.chspw-cell.chspw-pending .chspw-cell-label {
  font-size:      11px;
  font-weight:    600;
  color:          var(--pw-pend-text);
  letter-spacing: .04em;
}

/* ── Celda jugada ─────────────────────────────────────────── */
.chspw-cell.chspw-played::before {
  content:    '';
  position:   absolute;
  top: 0; left: 0; right: 0;
  height:     3px;
  border-radius: var(--pw-r-md) var(--pw-r-md) 0 0;
}
.chspw-cell:hover {
  cursor:    pointer;
  z-index:   2;
}
.chspw-cell.chspw-pending:hover {
  transform:    translateY(-2px) scale(1.05);
  background:   rgba(23, 40, 24, 0.08);
  border-color: rgba(23, 40, 24, 0.20);
  box-shadow:   0 4px 12px rgba(0, 0, 0, 0.10);
}
.chspw-cell.chspw-played:hover {
  transform:  translateY(-3px) scale(1.07);
  z-index:    2;
  filter:     brightness(1.08);
}

/* G1 — Rojo */
.chspw-cell.chspw-played.chspw-g1 {
  background:   var(--pw-g1-bg);
  border-color: var(--pw-g1-border);
  box-shadow:   0 2px 10px var(--pw-g1-glow);
}
.chspw-cell.chspw-played.chspw-g1::before { background: var(--pw-g1-solid); }
.chspw-cell.chspw-played.chspw-g1 .chspw-cell-label { color: var(--pw-g1-text); }
.chspw-cell.chspw-played.chspw-g1 .chspw-cell-sub   { color: var(--pw-g1-text); }
.chspw-cell.chspw-played.chspw-g1:hover { box-shadow: 0 6px 18px var(--pw-g1-glow); }

/* G2 — Azul */
.chspw-cell.chspw-played.chspw-g2 {
  background:   var(--pw-g2-bg);
  border-color: var(--pw-g2-border);
  box-shadow:   0 2px 10px var(--pw-g2-glow);
}
.chspw-cell.chspw-played.chspw-g2::before { background: var(--pw-g2-solid); }
.chspw-cell.chspw-played.chspw-g2 .chspw-cell-label { color: var(--pw-g2-text); }
.chspw-cell.chspw-played.chspw-g2 .chspw-cell-sub   { color: var(--pw-g2-text); }
.chspw-cell.chspw-played.chspw-g2:hover { box-shadow: 0 6px 18px var(--pw-g2-glow); }

/* G3 — Amarillo */
.chspw-cell.chspw-played.chspw-g3 {
  background:   var(--pw-g3-bg);
  border-color: var(--pw-g3-border);
  box-shadow:   0 2px 10px var(--pw-g3-glow);
}
.chspw-cell.chspw-played.chspw-g3::before { background: var(--pw-g3-solid); }
.chspw-cell.chspw-played.chspw-g3 .chspw-cell-label { color: var(--pw-g3-text); }
.chspw-cell.chspw-played.chspw-g3 .chspw-cell-sub   { color: var(--pw-g3-text); }
.chspw-cell.chspw-played.chspw-g3:hover { box-shadow: 0 6px 18px var(--pw-g3-glow); }

/* GMIX — carrera con grupos mixtos (ej: G2-3) */
.chspw-cell.chspw-played.chspw-gmix {
  background:   linear-gradient(135deg, var(--pw-g2-bg) 0%, var(--pw-g3-bg) 100%);
  border-color: rgba(90, 130, 210, 0.50);
  box-shadow:   0 2px 10px rgba(90, 130, 210, 0.18);
}
.chspw-cell.chspw-played.chspw-gmix::before {
  background: linear-gradient(90deg, var(--pw-g2-solid) 0%, var(--pw-g3-solid) 100%);
}
.chspw-cell.chspw-played.chspw-gmix .chspw-cell-label { color: var(--pw-g2-text); }
.chspw-cell.chspw-played.chspw-gmix .chspw-cell-sub {
  background:              linear-gradient(90deg, var(--pw-g2-text), var(--pw-g3-text));
  -webkit-background-clip: text;
  background-clip:         text;
  -webkit-text-fill-color: transparent;
}
.chspw-cell.chspw-played.chspw-gmix:hover { box-shadow: 0 6px 18px rgba(90, 130, 210, 0.30); }

/* Etapa seleccionada en el selector */
.chspw-cell.chspw-etapa-sel {
  outline:        3px solid var(--pw-gold-pale);
  outline-offset: 3px;
  transform:      scale(1.12) translateY(-2px);
  z-index:        2;
  position:       relative;
  box-shadow:     0 0 0 5px rgba(232,200,74,.18), 0 6px 20px rgba(0,0,0,.28);
}
.chspw-cell.chspw-pending.chspw-etapa-sel {
  outline-color:  rgba(255,255,255,.55);
  box-shadow:     0 0 0 5px rgba(255,255,255,.12), 0 6px 20px rgba(0,0,0,.28);
}

/* Nueva celda */
.chspw-cell.chspw-new { animation: pw-reveal .4s var(--pw-spring) both; }
@keyframes pw-reveal {
  from { opacity: 0; transform: scale(.6); }
  to   { opacity: 1; transform: scale(1); }
}

/* Stagger */
.chspw-panel.chspw-open .chspw-cell { animation: pw-stagger .28s var(--pw-ease) both; }
.chspw-panel.chspw-open .chspw-cell:nth-child(1)  { animation-delay:  20ms; }
.chspw-panel.chspw-open .chspw-cell:nth-child(2)  { animation-delay:  40ms; }
.chspw-panel.chspw-open .chspw-cell:nth-child(3)  { animation-delay:  55ms; }
.chspw-panel.chspw-open .chspw-cell:nth-child(4)  { animation-delay:  70ms; }
.chspw-panel.chspw-open .chspw-cell:nth-child(5)  { animation-delay:  85ms; }
.chspw-panel.chspw-open .chspw-cell:nth-child(6)  { animation-delay: 100ms; }
.chspw-panel.chspw-open .chspw-cell:nth-child(7)  { animation-delay: 115ms; }
.chspw-panel.chspw-open .chspw-cell:nth-child(8)  { animation-delay: 130ms; }
.chspw-panel.chspw-open .chspw-cell:nth-child(9)  { animation-delay: 145ms; }
.chspw-panel.chspw-open .chspw-cell:nth-child(10) { animation-delay: 160ms; }
.chspw-panel.chspw-open .chspw-cell:nth-child(11) { animation-delay: 175ms; }
.chspw-panel.chspw-open .chspw-cell:nth-child(12) { animation-delay: 190ms; }
.chspw-panel.chspw-open .chspw-cell:nth-child(13) { animation-delay: 205ms; }
.chspw-panel.chspw-open .chspw-cell:nth-child(14) { animation-delay: 220ms; }
.chspw-panel.chspw-open .chspw-cell:nth-child(15) { animation-delay: 235ms; }
@keyframes pw-stagger {
  from { opacity: 0; transform: scale(.86) translateY(6px); }
  to   { opacity: 1; transform: none; }
}

/* Tipografía */
.chspw-cell-label {
  font-size:      9px;
  font-weight:    600;
  letter-spacing: .05em;
  line-height:    1.2;
  pointer-events: none;
  opacity:        .65;
}
/* Grupo ganador — texto principal de la celda */
.chspw-cell-sub {
  font-size:      14px;
  font-weight:    800;
  letter-spacing: .04em;
  white-space:    nowrap;
  line-height:    1;
  pointer-events: none;
}

/* Mensaje */
.chspw-grid-message {
  grid-column: 1 / -1;
  padding:     32px var(--pw-px);
  text-align:  center;
  font-size:   12px;
  font-weight: 500;
  color:       var(--pw-text-mid);
  line-height: 1.7;
}
.chspw-grid-message.chspw-no-endpoint { color: var(--pw-gold); }

/* ═══════════════════════════════════════════════════════════
   DIVIDER
   ═══════════════════════════════════════════════════════════ */
.chspw-divider {
  display:         flex;
  align-items:     center;
  justify-content: center;
  padding:         4px 0;
  margin:          0 var(--pw-px);
}
.chspw-divider::before, .chspw-divider::after {
  content:    '';
  flex:       1;
  height:     1px;
}
.chspw-divider::before { background: linear-gradient(90deg, transparent, var(--pw-divider)); }
.chspw-divider::after  { background: linear-gradient(90deg, var(--pw-divider), transparent); }
.chspw-divider-diamond {
  width:        5px;
  height:       5px;
  background:   var(--pw-gold-light);
  border-radius:1px;
  transform:    rotate(45deg);
  flex-shrink:  0;
  margin:       0 8px;
  opacity:      .5;
}

/* ═══════════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════════ */
.chspw-panel-footer {
  display:         flex;
  align-items:     center;
  justify-content: space-between;
  padding:         12px var(--pw-px) 14px;
  border-top:      1px solid var(--pw-divider);
  background:      var(--pw-surf-2);
}
.chspw-refresh-btn {
  display:        flex;
  align-items:    center;
  gap:            6px;
  background:     transparent;
  border:         1px solid var(--pw-green-line);
  color:          var(--pw-green-500);
  font-family:    var(--pw-font);
  font-size:      10.5px;
  font-weight:    700;
  letter-spacing: .07em;
  padding:        6px 16px;
  border-radius:  50px;
  cursor:         pointer;
  transition:
    background   var(--pw-fast),
    border-color var(--pw-fast),
    color        var(--pw-fast);
}
.chspw-refresh-btn:hover {
  background:   rgba(39,122,58,.08);
  border-color: var(--pw-green-400);
  color:        var(--pw-green-600);
}
.chspw-refresh-icon {
  display:    inline-block;
  font-size:  15px;
  transition: transform .5s ease;
}
.chspw-refresh-btn.chspw-loading .chspw-refresh-icon {
  animation: pw-spin .65s linear infinite;
}
@keyframes pw-spin { to { transform: rotate(360deg); } }
.chspw-last-update {
  font-size:      10px;
  color:          var(--pw-text-dim);
  letter-spacing: .04em;
}

/* ═══════════════════════════════════════════════════════════
   LEYENDA
   ═══════════════════════════════════════════════════════════ */
.chspw-legend {
  display:         flex;
  align-items:     center;
  justify-content: center;
  flex-wrap:       wrap;
  gap:             14px;
  padding:         12px var(--pw-px) 14px;
  background:      var(--pw-surf-1);
  border-top:      1px solid var(--pw-divider);
}
.chspw-legend-item {
  display:        flex;
  align-items:    center;
  gap:            6px;
  font-size:      10.5px;
  font-weight:    600;
  color:          var(--pw-text-mid);
  letter-spacing: .05em;
}
.chspw-legend-dot {
  width:         10px;
  height:        10px;
  border-radius: 3px;
  flex-shrink:   0;
}
.chspw-legend-item.chspw-g1 { color: var(--pw-g1-text); }
.chspw-legend-item.chspw-g2 { color: var(--pw-g2-text); }
.chspw-legend-item.chspw-g3 { color: var(--pw-g3-text); }
.chspw-legend-item.chspw-g1 .chspw-legend-dot { background: var(--pw-g1-solid); }
.chspw-legend-item.chspw-g2 .chspw-legend-dot { background: var(--pw-g2-solid); }
.chspw-legend-item.chspw-g3 .chspw-legend-dot { background: var(--pw-g3-solid); }
.chspw-legend-item.chspw-legend-leader { font-weight: 800; }
.chspw-legend-item.chspw-legend-leader .chspw-legend-dot { box-shadow: 0 0 5px currentColor; }

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════ */
@media (max-width: 540px) {
  :root { --pw-panel-w: calc(100vw - 18px); --pw-px: 16px; }

  #chspw-widget {
    left:   9px !important;
    right:  9px !important;
    bottom: 12px !important;
    top:    auto !important;
  }
  .chspw-pos-bottom-right .chspw-panel,
  .chspw-pos-bottom-left  .chspw-panel { right: 0; left: 0; }

  .chspw-toggle-btn   { width: 100%; justify-content: center; }
  .chspw-cell         { min-height: 52px; }
  .chspw-cell-sub     { display: none; }
  .chspw-cell-label   { font-size: 10px; }
  .chspw-podium-stage { height: 78px; }
  .chspw-p1 .chspw-podium-bar { height: 48px; }
  .chspw-p2 .chspw-podium-bar { height: 34px; }
  .chspw-p3 .chspw-podium-bar { height: 22px; }
}

@media (prefers-reduced-motion: reduce) {
  #chspw-widget *, #chspw-widget *::before, #chspw-widget *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}

/* ═══════════════════════════════════════════════════════════
   TOOLTIP CUSTOM
   Appended to <body> — escapa overflow:hidden del panel.
   ═══════════════════════════════════════════════════════════ */
.chspw-tip {
  position:       fixed;
  z-index:        999999;
  pointer-events: none;
  background:     rgba(15, 12, 30, 0.95);
  color:          #f2f2f2;
  border:         1px solid rgba(255,255,255,.12);
  border-radius:  10px;
  padding:        10px 14px;
  max-width:      220px;
  font-family:    'Montserrat', system-ui, sans-serif;
  font-size:      12px;
  line-height:    1.55;
  box-shadow:     0 6px 24px rgba(0,0,0,.55), 0 1px 4px rgba(0,0,0,.3);
  display:        flex;
  flex-direction: column;
  gap:            3px;
  opacity:        0;
  transition:     opacity 120ms ease;
}
.chspw-tip--visible { opacity: 1; }

.chspw-tip-nro {
  font-size:      9px;
  font-weight:    700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color:          rgba(255,255,255,.40);
}
.chspw-tip-grupo {
  font-size:      13px;
  font-weight:    800;
  letter-spacing: .04em;
  color:          #e8e8e8;
}
.chspw-tip-grupo.chspw-g1 { color: #f86060; }
.chspw-tip-grupo.chspw-g2 { color: #5aabff; }
.chspw-tip-grupo.chspw-g3 { color: #ffc840; }
.chspw-tip-grupo.chspw-gmix {
  background:              linear-gradient(90deg, #5aabff 0%, #ffc840 100%);
  -webkit-background-clip: text;
  background-clip:         text;
  -webkit-text-fill-color: transparent;
}
.chspw-tip-horse {
  font-size:      12px;
  font-weight:    700;
  letter-spacing: .01em;
  color:          #fff;
}
.chspw-tip-prize {
  font-size:  10.5px;
  font-weight: 500;
  color:      rgba(255,255,255,.50);
  font-style: italic;
}
