/* ==========================================================================
   Live Odds — premium sportsbook-style in-play odds panel.
   Tokens from theme.css only; no external dependencies.
   ========================================================================== */

/* ── Tab dot pulse ────────────────────────────────────────────────── */
.lo-tab-btn { position: relative; }

.lo-tab-dot {
  display: inline-block;
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--tertiary);
  margin-right: 5px;
  vertical-align: middle;
  position: relative; top: -1px;
  animation: lo-pulse 1.6s ease-in-out infinite;
}

@keyframes lo-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: 0.5; transform: scale(0.8); }
}

/* ── Section shell ────────────────────────────────────────────────── */
.live-odds-section {
  padding: 0;
  font-family: var(--te-font);
}

/* ── Top bar ──────────────────────────────────────────────────────── */
.live-odds-top {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem 1rem;
  margin-bottom: 1.5rem;
}

.live-odds-top__left {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  min-width: 0;
}

/* LIVE pill — pulsing dot inside */
.live-odds-live-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.25rem 0.65rem;
  border-radius: 999px;
  font-size: 0.6875rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: color-mix(in srgb, var(--tertiary) 18%, transparent);
  color: var(--tertiary);
  border: 1px solid color-mix(in srgb, var(--tertiary) 30%, transparent);
  line-height: 1;
}

.lo-live-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--tertiary);
  flex-shrink: 0;
  animation: lo-pulse 1.4s ease-in-out infinite;
}

.live-odds-heading {
  margin: 0;
  font-size: 1.1rem;
  font-weight: 800;
  letter-spacing: -0.025em;
  color: var(--on-surface);
}

.live-odds-updated {
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--on-surface-variant);
  white-space: nowrap;
  opacity: 0.8;
}

/* ── Loading ──────────────────────────────────────────────────────── */
.live-odds-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 3rem 1rem;
}

.live-odds-loading__inner {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  color: var(--on-surface-variant);
  font-size: 0.875rem;
}

.live-odds-spinner {
  display: inline-block;
  width: 20px; height: 20px;
  border-radius: 50%;
  border: 2.5px solid color-mix(in srgb, var(--outline) 30%, transparent);
  border-top-color: var(--primary-container);
  animation: lo-spin 0.75s linear infinite;
  flex-shrink: 0;
}

@keyframes lo-spin { to { transform: rotate(360deg); } }

/* ── Alerts ───────────────────────────────────────────────────────── */
.lo-alert {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  border-radius: var(--te-radius-md);
  padding: 1rem 1.25rem;
  font-size: 0.875rem;
}

.lo-alert--info {
  background: color-mix(in srgb, var(--primary-container) 8%, transparent);
  border: 1px solid color-mix(in srgb, var(--primary-container) 20%, transparent);
}

.lo-alert--warn {
  background: color-mix(in srgb, var(--tertiary) 8%, transparent);
  border: 1px solid color-mix(in srgb, var(--tertiary) 20%, transparent);
}

.lo-alert__icon {
  color: var(--on-surface-variant);
  flex-shrink: 0;
  margin-top: 1px;
}

.lo-alert__title {
  display: block;
  font-weight: 800;
  font-size: 0.875rem;
  color: var(--on-surface);
  margin-bottom: 0.25rem;
}

.lo-alert__body {
  font-size: 0.8125rem;
  color: var(--on-surface-variant);
  line-height: 1.5;
}

/* ── Main wrap ────────────────────────────────────────────────────── */
.live-odds-main {
  animation: lo-fade-in 0.3s ease-out;
}

@keyframes lo-fade-in {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Grids ────────────────────────────────────────────────────────── */
.lo-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  align-items: start;
}

.lo-grid > * { min-width: 0; }

/* Primary 3-col on wide; secondary 2-col */
@media (min-width: 768px) {
  .lo-grid--primary  { grid-template-columns: repeat(2, 1fr); }
  .lo-grid--secondary { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 1024px) {
  .lo-grid--primary  { grid-template-columns: repeat(3, 1fr); }
  .lo-grid--secondary { grid-template-columns: repeat(2, 1fr); }
}

.lo-grid--enter {
  opacity: 0;
  animation: lo-grid-enter 0.4s ease forwards;
}

@keyframes lo-grid-enter { to { opacity: 1; } }

/* ── Show more button ─────────────────────────────────────────────── */
.live-odds-more {
  margin: 1.25rem 0 0.25rem;
  display: flex;
  justify-content: center;
}

.lo-more-btn {
  appearance: none;
  font-family: inherit;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  padding: 0.6rem 1.25rem;
  min-height: 40px;
  border-radius: 999px;
  background: transparent;
  color: var(--on-surface-variant);
  border: 1px solid var(--te-border);
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
}

.lo-more-btn:hover {
  background: var(--surface-container);
  color: var(--on-surface);
  border-color: color-mix(in srgb, var(--outline) 60%, transparent);
}

.lo-more-btn:focus-visible {
  outline: 2px solid var(--primary-container);
  outline-offset: 3px;
}

.lo-more-btn__chevron {
  transition: transform 0.2s ease;
}

.lo-more-btn[aria-expanded="true"] .lo-more-btn__chevron {
  transform: rotate(180deg);
}

/* ── Cards ────────────────────────────────────────────────────────── */
.lo-card {
  border-radius: var(--te-radius-lg);
  background: var(--surface-container);
  border: 1px solid color-mix(in srgb, var(--outline) 15%, transparent);
  box-shadow: 0 1px 3px color-mix(in srgb, var(--shadow) 6%, transparent),
              0 4px 12px color-mix(in srgb, var(--shadow) 4%, transparent);
  overflow: hidden;
  transition: box-shadow 0.2s ease, transform 0.2s ease, border-color 0.2s ease;
}

@media (hover: hover) and (pointer: fine) {
  .lo-card:hover {
    box-shadow: 0 2px 8px color-mix(in srgb, var(--shadow) 10%, transparent),
                0 8px 24px color-mix(in srgb, var(--shadow) 8%, transparent);
    transform: translateY(-2px);
    border-color: color-mix(in srgb, var(--outline) 30%, transparent);
  }
}

/* Primary market cards slightly elevated */
.lo-grid--primary .lo-card {
  background: linear-gradient(160deg,
    var(--surface-container-high) 0%,
    var(--surface-container) 100%);
}

.lo-card__head {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.8rem 1rem 0.7rem;
  background: var(--surface-container-high);
  border-bottom: 1px solid color-mix(in srgb, var(--outline) 10%, transparent);
}

.lo-card__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 30px; height: 30px;
  border-radius: var(--te-radius-sm);
  background: color-mix(in srgb, var(--primary-container) 14%, transparent);
  color: var(--primary-container);
}

.lo-card__icon svg {
  width: 16px; height: 16px;
  display: block;
}

.lo-card__title {
  margin: 0;
  font-size: 0.6875rem;
  font-weight: 800;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--on-surface-variant);
  line-height: 1.3;
  flex: 1;
  min-width: 0;
}

/* "Popular" badge on 1X2 card */
.lo-card__badge {
  display: none;
  font-size: 0.6rem;
  font-weight: 800;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  padding: 0.15rem 0.45rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--tertiary) 18%, transparent);
  color: var(--tertiary);
  white-space: nowrap;
}

.lo-card[data-bet-id="59"] .lo-card__badge {
  display: inline-flex;
}

.lo-card__body {
  padding: 0.75rem 0.85rem 0.9rem;
}

/* ── Bookmaker blocks ─────────────────────────────────────────────── */
.lo-bk + .lo-bk { margin-top: 1rem; }

.lo-bk__label {
  font-size: 0.625rem;
  font-weight: 800;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--on-surface-variant);
  margin-bottom: 0.5rem;
  opacity: 0.7;
  padding: 0 0.1rem;
}

.lo-bk__content {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

/* ── Standard outcome rows ────────────────────────────────────────── */
.lo-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.4rem 0.5rem 0.4rem 0.6rem;
  border-radius: var(--te-radius-sm);
  background: var(--surface-container-low);
  transition: background 0.12s;
}

.lo-row:nth-child(even) {
  background: color-mix(in srgb, var(--surface-container) 70%, transparent);
}

.lo-row__label {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--on-surface);
  flex: 1;
  min-width: 0;
}

/* ── Odds buttons ─────────────────────────────────────────────────── */
.lo-odd-btn {
  appearance: none;
  font-family: inherit;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.3rem;
  padding: 0.3rem 0.65rem;
  min-width: 52px;
  min-height: 32px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--primary-container) 30%, transparent);
  background: color-mix(in srgb, var(--primary-container) 10%, transparent);
  color: var(--primary-container);
  cursor: pointer;
  transition: background 0.14s, border-color 0.14s, transform 0.12s, box-shadow 0.14s;
  white-space: nowrap;
}

.lo-odd-btn:hover {
  background: color-mix(in srgb, var(--primary-container) 20%, transparent);
  border-color: color-mix(in srgb, var(--primary-container) 50%, transparent);
  transform: scale(1.05);
  box-shadow: 0 2px 8px color-mix(in srgb, var(--primary-container) 20%, transparent);
}

.lo-odd-btn:active {
  transform: scale(0.97);
  background: color-mix(in srgb, var(--primary-container) 28%, transparent);
}

.lo-odd-btn:focus-visible {
  outline: 2px solid var(--primary-container);
  outline-offset: 2px;
}

.lo-odd-btn__val {
  font-size: 0.9375rem;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  line-height: 1;
}

/* Suspended state */
.lo-row--suspended .lo-odd-btn,
.lo-ou--suspended .lo-odd-btn {
  color: var(--on-surface-variant);
  background: color-mix(in srgb, var(--outline) 10%, transparent);
  border-color: color-mix(in srgb, var(--outline) 20%, transparent);
  text-decoration: line-through;
  pointer-events: none;
  opacity: 0.55;
}

/* ── Over/Under grouped lines ─────────────────────────────────────── */
.lo-ou {
  padding: 0.55rem 0.5rem 0.6rem;
  border-radius: var(--te-radius-sm);
  background: var(--surface-container-low);
}

.lo-ou + .lo-ou { margin-top: 0.45rem; }

.lo-ou__header {
  margin-bottom: 0.5rem;
}

.lo-ou__line-label {
  font-size: 0.6875rem;
  font-weight: 800;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--on-surface-variant);
  opacity: 0.85;
}

.lo-ou__pair {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.45rem;
}

/* O/U buttons are a bit taller for tap targets */
.lo-odd-btn--ou {
  flex-direction: column;
  gap: 0.15rem;
  padding: 0.45rem 0.5rem;
  min-height: 52px;
  border-radius: var(--te-radius-md);
  width: 100%;
}

.lo-odd-btn--over {
  background: color-mix(in srgb, var(--primary-container) 10%, transparent);
  border-color: color-mix(in srgb, var(--primary-container) 25%, transparent);
  color: var(--primary-container);
}

.lo-odd-btn--under {
  background: color-mix(in srgb, var(--secondary) 10%, transparent);
  border-color: color-mix(in srgb, var(--secondary) 25%, transparent);
  color: var(--secondary-container, var(--secondary));
}

html.theme-dark .lo-odd-btn--under {
  color: var(--secondary);
}

.lo-odd-btn--over:hover {
  background: color-mix(in srgb, var(--primary-container) 22%, transparent);
  border-color: color-mix(in srgb, var(--primary-container) 45%, transparent);
}

.lo-odd-btn--under:hover {
  background: color-mix(in srgb, var(--secondary) 22%, transparent);
  border-color: color-mix(in srgb, var(--secondary) 45%, transparent);
}

.lo-odd-btn__side {
  font-size: 0.6rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0.75;
  line-height: 1;
}

/* ── Odds movement flash ──────────────────────────────────────────── */

/* Green: odds drifted up (better for punter) */
@keyframes lo-flash-up {
  0%   { background-color: color-mix(in srgb, var(--success) 35%, transparent);
         box-shadow: 0 0 0 2px color-mix(in srgb, var(--success) 45%, transparent); }
  80%  { background-color: color-mix(in srgb, var(--success) 12%, transparent); }
  100% { background-color: color-mix(in srgb, var(--primary-container) 10%, transparent);
         box-shadow: none; }
}

/* Red: odds shortened */
@keyframes lo-flash-down {
  0%   { background-color: color-mix(in srgb, var(--danger) 35%, transparent);
         box-shadow: 0 0 0 2px color-mix(in srgb, var(--danger) 45%, transparent); }
  80%  { background-color: color-mix(in srgb, var(--danger) 12%, transparent); }
  100% { background-color: color-mix(in srgb, var(--primary-container) 10%, transparent);
         box-shadow: none; }
}

.lo-odd-btn.lo-odd--flash-up {
  animation: lo-flash-up 1s ease-out forwards;
}

.lo-odd-btn.lo-odd--flash-down {
  animation: lo-flash-down 1s ease-out forwards;
}

/* Movement arrow badge */
.lo-odd-btn__move {
  font-size: 0.6rem;
  font-weight: 900;
  line-height: 1;
  position: absolute;
  top: 3px;
  right: 5px;
}

/* ── Disclaimer ───────────────────────────────────────────────────── */
.live-odds-disclaimer {
  font-size: 0.6875rem;
  line-height: 1.5;
  color: var(--on-surface-variant);
  opacity: 0.7;
  margin-top: 1.75rem;
  margin-bottom: 0;
  text-align: center;
}

/* ── Dark mode adjustments ────────────────────────────────────────── */
html.theme-dark .lo-card {
  box-shadow: 0 1px 3px rgba(0,0,0,0.25), 0 4px 12px rgba(0,0,0,0.2);
}

html.theme-dark .lo-odd-btn {
  color: var(--primary-fixed, var(--primary-container));
  background: color-mix(in srgb, var(--primary-container) 14%, transparent);
  border-color: color-mix(in srgb, var(--primary-container) 28%, transparent);
}

html.theme-dark .lo-odd-btn:hover {
  background: color-mix(in srgb, var(--primary-container) 26%, transparent);
}

html.theme-dark .live-odds-spinner {
  border-color: color-mix(in srgb, var(--outline) 35%, transparent);
  border-top-color: var(--primary-fixed, var(--primary-container));
}

/* ── Reduced motion ───────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .lo-grid--enter,
  .live-odds-main,
  .lo-card,
  .lo-odd-btn,
  .lo-live-dot,
  .lo-tab-dot {
    animation: none !important;
    opacity: 1 !important;
    transition: none !important;
  }
}

/* ── Mobile ───────────────────────────────────────────────────────── */
@media (max-width: 480px) {
  .live-odds-heading { font-size: 1rem; }

  .lo-card__body { padding: 0.65rem 0.75rem 0.8rem; }

  /* Bigger tap targets on phone */
  .lo-odd-btn {
    min-height: 36px;
    min-width: 58px;
    font-size: 1rem;
  }

  .lo-odd-btn--ou {
    min-height: 58px;
  }

  .lo-row__label { font-size: 0.8rem; }

  .live-odds-disclaimer { font-size: 0.625rem; }
}
