/* ============================ Ruleta — estilos ============================ */
.rt-topbar { display: flex; align-items: center; gap: var(--sp-3); }
.rt-balance { text-align: right; font-size: var(--fs-xs); color: var(--c-text-muted); line-height: 1.2; }
.rt-balance b { font-family: var(--font-mono); font-size: var(--fs-lg); color: var(--c-gold); }

.rt-layout { display: grid; grid-template-columns: 400px 1fr; gap: var(--sp-6); align-items: start; }
@media (max-width: 980px) { .rt-layout { grid-template-columns: 1fr; } .rt-left, .rt-right { min-width: 0; max-width: 100%; } .rt-board { max-width: 100%; } }

/* ---- Rueda ---- */
.rt-left { display: flex; flex-direction: column; gap: var(--sp-4); align-items: center; }
.rt-wheel-box { position: relative; width: 380px; max-width: 100%; }
#wheel { width: 100%; height: auto; filter: drop-shadow(0 12px 30px rgba(0,0,0,.5)); }
.rt-pointer { position: absolute; top: -4px; left: 50%; transform: translateX(-50%); color: var(--c-gold); font-size: 1.5rem; text-shadow: 0 2px 4px rgba(0,0,0,.6); }

.rt-result { min-height: 64px; display: flex; align-items: center; gap: var(--sp-3); justify-content: center; flex-wrap: wrap; text-align: center; }
.rt-ball-num, .rt-hist { display: inline-flex; align-items: center; justify-content: center; border-radius: 50%; font-weight: 700; font-family: var(--font-mono); }
.rt-ball-num { width: 48px; height: 48px; font-size: 1.4rem; color: #fff; box-shadow: var(--shadow-sm); }
.rt-win { color: var(--c-success); font-weight: 700; }
.rt-lose { color: var(--c-text-muted); }
.rt-red { background: var(--c-red); } .rt-black { background: var(--c-black); } .rt-green { background: var(--c-felt-light); }

.rt-history-wrap { width: 100%; text-align: center; }
.rt-history { display: flex; gap: .3rem; flex-wrap: wrap; justify-content: center; margin-top: .3rem; }
.rt-hist { width: 30px; height: 30px; font-size: .85rem; color: #fff; }

.rt-stats { width: 100%; display: grid; grid-template-columns: repeat(2, 1fr); gap: .5rem; margin-top: var(--sp-2); }
.rt-stats > div { background: var(--glass-bg); backdrop-filter: blur(8px); border: 1px solid var(--glass-border); border-radius: var(--r-sm); padding: .5rem .7rem; box-shadow: var(--glass-hi); }
.rt-stats span { display: block; font-size: var(--fs-xs); color: var(--c-text-muted); }
.rt-stats b { font-family: var(--font-mono); font-size: var(--fs-md); }
.rt-stats b.pos { color: var(--c-success); } .rt-stats b.neg { color: var(--c-danger); }

/* ---- Tablero ---- */
.rt-board {
  position: relative;
  display: grid;
  grid-template-columns: 0.85fr repeat(12, 1fr) 0.85fr;
  grid-template-rows: repeat(3, 54px) 40px 40px;
  gap: 4px;
  background: var(--grad-felt);
  border: 3px solid var(--c-gold-deep);
  border-radius: var(--r-md);
  padding: 8px;
  box-shadow: var(--shadow-md), inset 0 0 60px rgba(0,0,0,.3);
}

/* Puntos de apuesta a combinaciones (split = 2 números, esquina = 4) */
.rt-hot {
  position: absolute; width: 26px; height: 26px; transform: translate(-50%, -50%);
  border: 0; padding: 0; background: transparent; cursor: pointer; z-index: 6; border-radius: 50%;
}
.rt-hot:hover { background: rgba(30,144,255,.45); box-shadow: 0 0 0 2px var(--c-gold); }
.rt-hot .rt-stack { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; }
.rt-cell.rt-hl { box-shadow: inset 0 0 0 3px var(--c-gold); filter: brightness(1.18); z-index: 2; }
.rt-cell {
  position: relative; display: flex; align-items: center; justify-content: center;
  border-radius: 5px; cursor: pointer; user-select: none;
  border: 1px solid rgba(255,255,255,.12);
  font-weight: 700; font-size: .95rem; color: #fff;
  transition: transform .08s, box-shadow .12s, filter .12s;
}
.rt-cell:hover { transform: translateY(-2px); box-shadow: 0 0 0 2px var(--c-gold); z-index: 2; filter: brightness(1.12); }
.rt-num.rt-red { background: var(--c-red); }
.rt-num.rt-black { background: var(--c-black); }
.rt-num.rt-green { background: var(--c-felt-dark); font-size: 1.3rem; }
.rt-zero { writing-mode: vertical-rl; transform: rotate(180deg); }
.rt-zero:hover { transform: rotate(180deg) translateY(2px); }
.rt-side, .rt-out { background: rgba(0,0,0,.28); font-size: .8rem; letter-spacing: .03em; }
.rt-out { text-transform: uppercase; }
.rt-diamond.rt-red::before { content: "◆"; color: #fff; font-size: 1.3rem; }
.rt-diamond.rt-black::before { content: "◆"; color: #fff; font-size: 1.3rem; }
.rt-diamond.rt-red { background: var(--c-red); } .rt-diamond.rt-black { background: var(--c-black); }

.rt-stack { position: absolute; bottom: 2px; right: 2px; }
.rt-betchip {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 22px; height: 22px; padding: 0 4px; border-radius: 50%;
  background: var(--c-gold); color: var(--c-on-gold); font-size: .7rem; font-weight: 800;
  font-family: var(--font-mono); box-shadow: 0 2px 4px rgba(0,0,0,.5); border: 2px solid #fff8;
}
@media (max-width: 560px) {
  .rt-board { grid-template-rows: repeat(3, 42px) 34px 34px; }
  .rt-cell { font-size: .8rem; }
}

/* ---- Controles / fichas ---- */
.rt-controls { margin-top: var(--sp-4); display: flex; flex-direction: column; gap: var(--sp-3); }
.rt-chips { display: flex; gap: var(--sp-3); flex-wrap: wrap; }
.rt-chip {
  --chip: #ccc;
  width: 52px; height: 52px; border-radius: 50%; cursor: pointer;
  background: radial-gradient(circle at 50% 35%, color-mix(in srgb, var(--chip) 80%, #fff), var(--chip));
  border: 3px dashed rgba(255,255,255,.7); color: #fff; font-weight: 800; font-family: var(--font-mono);
  box-shadow: var(--shadow-sm); transition: transform .1s, box-shadow .15s; position: relative;
  text-shadow: 0 1px 2px rgba(0,0,0,.6);
}
.rt-chip:hover { transform: translateY(-3px); }
.rt-chip.sel { box-shadow: 0 0 0 3px var(--c-gold), var(--shadow-md); transform: translateY(-3px); }

.rt-actions { display: flex; align-items: center; gap: var(--sp-3); flex-wrap: wrap; }
.rt-total { font-family: var(--font-mono); color: var(--c-text-soft); margin-right: auto; }
.rt-total b { color: var(--c-gold); }
.rt-note { margin-top: var(--sp-4); font-size: var(--fs-sm); color: var(--c-text-muted); background: var(--glass-bg); backdrop-filter: blur(8px); border: 1px solid var(--glass-border); border-radius: var(--r-md); padding: var(--sp-4); box-shadow: var(--glass-hi); }
