/* ===============================================================
   Bad Bets — Live Scoreboard Ticker
   Sticky horizontal strip showing live/final/upcoming games with
   our pick overlay. Inject below the site header on key pages.
   =============================================================== */

.bb-ticker {
  position: sticky;
  top: 60px;          /* below site header */
  z-index: 50;
  background: rgba(11, 14, 20, 0.92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
  margin: 0 -20px 16px;   /* extend full width inside main */
  font-family: var(--font-display);
}

.bb-ticker-inner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 10px;
  padding: 8px 14px;
}

/* ----- LEFT controls (sport + date) ----- */
.bb-ticker-controls {
  display: flex; gap: 4px; align-items: center;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border);
  border-radius: 8px; padding: 3px;
}
.bb-ticker-controls button {
  background: transparent; border: 0; color: var(--text-2);
  font-family: var(--font-display); font-weight: 800;
  font-size: 11px; letter-spacing: 0.8px;
  padding: 4px 8px; border-radius: 5px; cursor: pointer;
  transition: all .12s;
}
.bb-ticker-controls button:hover { color: var(--text); background: rgba(255,255,255,0.04); }
.bb-ticker-controls button.active {
  background: var(--amber); color: #0e1419;
}
.bb-ticker-date {
  font-size: 11px; letter-spacing: 0.5px;
  color: var(--text); font-weight: 700;
  min-width: 56px; text-align: center;
  padding: 0 4px;
}

/* ----- RAIL (scrolling game tiles) ----- */
.bb-ticker-rail-wrap {
  overflow: hidden;
  position: relative;
  mask-image: linear-gradient(to right,
              transparent 0, black 20px, black calc(100% - 40px), transparent 100%);
}
.bb-ticker-rail {
  display: flex; gap: 0;
  overflow-x: auto;
  scroll-behavior: smooth;
  scrollbar-width: none;        /* Firefox */
}
.bb-ticker-rail::-webkit-scrollbar { display: none; }
.bb-ticker-rail.paused { animation-play-state: paused; }

/* Individual game tile */
.bb-ticker-tile {
  flex: 0 0 auto;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 10px;
  padding: 6px 16px;
  border-right: 1px solid var(--border);
  text-decoration: none; color: var(--text);
  font-family: var(--font-display);
  position: relative;
  transition: background .15s;
  min-width: 200px;
}
.bb-ticker-tile:hover {
  background: rgba(255,255,255,0.04);
}
.bb-ticker-tile.our-pick::before {
  content: ""; position: absolute; left: 0; top: 6px; bottom: 6px;
  width: 3px; background: var(--amber); border-radius: 0 2px 2px 0;
}
.bb-ticker-tile.our-pick.cashed::before { background: var(--green); }
.bb-ticker-tile.our-pick.missed::before { background: var(--red); }

/* Tile status (top): inning + outs, or final, or start time */
.bb-ticker-status {
  grid-column: 1 / -1;
  font-size: 10px; letter-spacing: 0.8px;
  font-weight: 800;
  display: flex; align-items: center; gap: 6px;
  margin-bottom: 2px;
}
.bb-ticker-status.live  { color: var(--red); }
.bb-ticker-status.final { color: var(--muted); }
.bb-ticker-status.pre   { color: var(--text-2); }
.bb-ticker-status .live-dot {
  width: 7px; height: 7px; border-radius: 50%; background: var(--red);
  animation: bb-ticker-pulse 1.2s ease-in-out infinite;
}
@keyframes bb-ticker-pulse {
  0%, 100% { opacity: 1; }
  50%      { opacity: 0.4; }
}

/* Tile teams (logo + abbr + score) */
.bb-ticker-team {
  display: grid;
  grid-template-columns: 16px 30px auto;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  white-space: nowrap;
}
.bb-ticker-team.our-side {
  font-weight: 900;
}
.bb-ticker-team.our-side .bb-ticker-abbr {
  color: var(--amber);
}
.bb-ticker-team.lead .bb-ticker-score { color: var(--text); font-weight: 900; }
.bb-ticker-team:not(.lead) .bb-ticker-score { color: var(--text-2); }
.bb-ticker-logo {
  width: 16px; height: 16px; object-fit: contain;
}
.bb-ticker-abbr {
  font-family: var(--font-display); font-weight: 700;
  font-size: 11px; letter-spacing: 0.5px;
  color: var(--text-2);
}
.bb-ticker-score {
  font-family: var(--font-display); font-weight: 800;
  font-size: 13px;
  font-variant-numeric: tabular-nums;
  text-align: right;
  min-width: 16px;
}

/* Bad Bets overlay (right side of tile): our pick + live edge */
.bb-ticker-edge {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 10px; letter-spacing: 0.5px; font-weight: 800;
  padding: 2px 6px; border-radius: 4px;
  margin-left: auto;
}
.bb-ticker-edge.win   { background: rgba(40,214,112,0.15); color: var(--green); }
.bb-ticker-edge.loss  { background: rgba(255,71,87,0.15);  color: var(--red); }
.bb-ticker-edge.flat  { background: rgba(255,170,0,0.10);  color: var(--amber); }
.bb-ticker-edge.cashed{ background: rgba(40,214,112,0.20); color: var(--green); }
.bb-ticker-edge.missed{ background: rgba(255,71,87,0.18);  color: var(--red); }

/* Props watch (small green check next to scores if props cashed) */
.bb-ticker-props {
  display: inline-flex; align-items: center; gap: 3px;
  font-size: 10px; color: var(--green); font-weight: 800;
  margin-left: 4px;
}

/* ----- RIGHT link ----- */
.bb-ticker-link {
  font-size: 11px; font-weight: 800; letter-spacing: 0.5px;
  color: var(--amber); text-decoration: none;
  padding: 4px 10px; border-radius: 6px;
  border: 1px solid rgba(255,170,0,0.3);
  white-space: nowrap;
  transition: all .15s;
}
.bb-ticker-link:hover {
  background: rgba(255,170,0,0.12);
}

/* Empty state */
.bb-ticker-empty {
  color: var(--muted); font-size: 12px;
  padding: 10px 14px;
  font-style: italic;
}

/* Skeleton — shown for first ~200ms while data loads */
.bb-ticker-skeleton-bar {
  display: inline-block;
  height: 10px;
  background: linear-gradient(90deg,
    rgba(255,255,255,0.04) 0%,
    rgba(255,255,255,0.10) 50%,
    rgba(255,255,255,0.04) 100%);
  background-size: 200% 100%;
  border-radius: 3px;
  animation: bb-ticker-shimmer 1.2s ease-in-out infinite;
}
@keyframes bb-ticker-shimmer {
  0%   { background-position:  100% 0; }
  100% { background-position: -100% 0; }
}

/* ===== Mobile (≤700px) — compact 2-row layout ===== */
@media (max-width: 700px) {
  .bb-ticker {
    top: 0;                        /* mobile header may be hidden via hamburger */
    margin: 0 -16px 12px;
    border-bottom: 1px solid var(--border);
  }
  .bb-ticker-inner {
    grid-template-columns: 1fr auto;   /* 2-col: controls left, link right */
    grid-template-rows: auto auto;      /* 2 rows: top controls, bottom rail */
    grid-template-areas:
      "controls link"
      "rail     rail";
    gap: 4px 8px;
    padding: 6px 10px;
  }
  .bb-ticker-controls { grid-area: controls; }
  .bb-ticker-link     { grid-area: link; font-size: 10px; padding: 3px 8px; }
  .bb-ticker-rail-wrap { grid-area: rail; }

  /* Smaller controls */
  .bb-ticker-controls button { padding: 3px 6px; font-size: 10px; }
  .bb-ticker-date            { font-size: 10px; min-width: 44px; }

  /* Smaller tiles so 2-3 fit on a phone width */
  .bb-ticker-tile {
    padding: 5px 12px;
    min-width: 160px;
  }
  .bb-ticker-status { font-size: 9px; gap: 4px; }
  .bb-ticker-team   { grid-template-columns: 14px 26px auto; gap: 5px; }
  .bb-ticker-logo   { width: 14px; height: 14px; }
  .bb-ticker-abbr   { font-size: 10px; }
  .bb-ticker-score  { font-size: 12px; }
  .bb-ticker-edge   { font-size: 9px; padding: 1px 5px; }
  .bb-ticker-props  { font-size: 9px; }
}

/* ===== Extra narrow (≤380px) — even tighter ===== */
@media (max-width: 380px) {
  .bb-ticker-tile { min-width: 140px; padding: 5px 10px; }
  .bb-ticker-controls button { font-size: 9px; padding: 2px 5px; }
  .bb-ticker-link            { font-size: 9px; padding: 2px 6px; }
}

/* Touch-friendly: bigger tap targets even on small screens */
@media (hover: none) {
  .bb-ticker-controls button,
  .bb-ticker-link {
    min-height: 32px;
    display: inline-flex;
    align-items: center;
  }
}
