:root{
  --nx-primary: #071A2B;   /* Navy (trust) */
  --nx-primary-2: #0B2A44; /* slightly lighter navy */
  --nx-accent: #16B6D8;    /* sea blue accent */
  --nx-text: #EAF2FF;
  --nx-muted: rgba(234,242,255,.72);
  --nx-card: rgba(255,255,255,.06);
  --nx-border: rgba(255,255,255,.10);
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  font-family: system-ui, -apple-system, "Segoe UI", Arial, sans-serif;
  background: var(--bg);
  padding-bottom: 120px; /* space for bottom nav + betslip */
}

/* =========================
   LEAGUE SLIDER
========================= */
.sports-slider {
  display: flex;
  gap: 10px;
  padding: 12px;
  overflow-x: auto;
  background: #fff;
}
.league-card {
  min-width: 120px;
  background: #fff;
  border-radius: 10px;
  padding: 10px 8px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 700;
  box-shadow: 0 2px 6px rgba(0,0,0,0.06);
}
.league-card img {
  width: 36px;
  height: 36px;
}

/* =========================
   QUICK ACTIONS
========================= */
.quick-actions {
  display: flex;
  justify-content: space-around;
  padding: 12px 0;
  background: #fff;
}
.quick-actions a {
  text-decoration: none;
  color: #111;
}
.action {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  font-size: 12px;
  font-weight: 700;
}
.icon {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--green-light);
  color: var(--green-dark);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
}

/* =========================
   FILTERS
========================= */
.sporty-filters {
  display: flex;
  gap: 6px;
  padding: 10px;
}
.filter {
  flex: 1;
  background: #fff;
  padding: 10px 6px;
  text-align: center;
  font-size: 13px;
  font-weight: 700;
  border-radius: 6px;
  border: 1px solid #e5e7eb;
}
.filter.active {
  border-top: 3px solid var(--green-dark);
  color: var(--green-dark);
}

/* =========================
   LIVE & UPCOMING
========================= */
.live-section {
  background: var(--dark-bg);
  padding: 10px;
}
.live-title {
  color: #fff;
  font-weight: 800;
  margin: 6px 4px 10px;
}
.live-card {
  background: var(--dark-card);
  border-radius: 10px;
  padding: 12px;
  margin-bottom: 10px;
  color: #fff;
}
.live-top {
  font-size: 13px;
  color: var(--muted);
  display: flex;
  gap: 8px;
}
.live-time {
  color: var(--live-green);
  font-weight: 700;
}
.live-body {
  display: flex;
  justify-content: space-between;
  margin-top: 8px;
}
.teams {
  flex: 1;
}
.team {
  margin: 4px 0;
}
.odds {
  display: flex;
  gap: 6px;
}
.odd-box {
  background: #2a2f36;
  padding: 10px 12px;
  border-radius: 6px;
  min-width: 64px;
  text-align: center;
  text-decoration: none;
}
.odd-box span {
  color: var(--live-green);
  font-weight: 700;
}
.odd-box.selected {
  background: var(--green-dark);
  color: #fff;
}

/* UPCOMING */
.live-section.upcoming {
  background: var(--green-dark);
}
.live-section.upcoming .live-card {
  background: #fff;
  color: #000;
}
.live-section.upcoming .odd-box {
  background: var(--green-main);
}
.live-section.upcoming .odd-box span {
  color: #fff;
}

/* =========================
   WINNERS
========================= */
.winners-section {
  background: #fff;
  padding: 16px 14px;
  margin-top: 10px;
}
.winners-title {
  font-size: 20px;
  font-weight: 800;
  color: var(--green-dark);
  margin-bottom: 14px;
}
.winners-scroll {
  display: flex;
  gap: 12px;
  overflow-x: auto;
}
.winner-card {
  min-width: 240px;
  background: linear-gradient(135deg, #2d3e47, #1a252d);
  color: #fff;
  border-radius: 12px;
  padding: 16px;
}

/* ===============================
   BETBUZZY FOOTER – FIXED & MATCHED
================================ */

.site-footer {
  width: 100%;
  background: #0B3D2E;
  color: #cfd3da;
  margin-top: 20px;
}

/* ===== 18+ BAR ===== */
.footer-age {
  background: #eef0f2;
  color: #555;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  font-size: 13px;
}

.age-icon {
  background: #999;
  color: #fff;
  width: 22px;
  height: 22px;
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
}

.age-text {
  font-weight: 700;
  font-size: 14px;
}

.footer-copy {
  margin-left: auto;
  font-size: 12px;
  color: #666;
}

/* ===== FOOTER BODY ===== */
.footer-body {
  background: linear-gradient(180deg, #0f3d2e, #071f17);
  padding: 36px 16px 140px; /* space for bottom nav */
  text-align: center;
}

/* ===== PARTNERS ===== */
.footer-partners {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 18px;
}

.partner-text {
  font-weight: 700;
  color: #17c964;
}

.divider {
  color: #4ade80;
}

.league-logo {
  height: 36px;
}

/* ===== TAGLINE ===== */
.footer-tagline {
  font-size: 18px;
  font-weight: 600;
  margin: 18px 0 22px;
  color: #ffffff;
}

/* ===== PAYMENT METHODS ===== */
.footer-subtitle {
  font-size: 14px;
  color: #aab2bd;
  margin-bottom: 10px;
}

.footer-payments {
  display: flex;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 22px;
}

.footer-payments img {
  height: 28px;
  background: #ffffff;
  padding: 4px 8px;
  border-radius: 6px;
}

/* ===== LINKS ===== */
.footer-links {
  margin-bottom: 18px;
}

.footer-links a {
  color: #17c964;
  margin: 0 8px;
  font-size: 14px;
  text-decoration: underline;
}

/* ===== LEGAL TEXT ===== */
.footer-legal {
  font-size: 13px;
  color: #aab2bd;
  line-height: 1.5;
  margin: 0;
}
/* ===============================
   BOTTOM NAV – FIXED & CLEAN
================================ */

.bottom-nav {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  height: 64px;
  background: linear-gradient(180deg, #0b3d2e, #071f17);
  display: flex;
  justify-content: space-around;
  align-items: center;
  border-top: 1px solid rgba(255,255,255,0.08);
  z-index: 1000;
}

/* NAV LINKS */
.bottom-nav a {
  flex: 1;
  text-decoration: none;
  color: #9aa0a6;
  font-size: 11px;
  font-weight: 600;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  transition: all 0.2s ease;
}

/* ICON */
.bottom-nav a i,
.bottom-nav a img {
  font-size: 20px;
  height: 20px;
  color: #9aa0a6;
  transition: all 0.2s ease;
}

/* ACTIVE */
.bottom-nav a.active {
  color: #17c964;
}

.bottom-nav a.active i,
.bottom-nav a.active img {
  color: #17c964;
  transform: translateY(-2px);
}

/* HOVER (DESKTOP SAFE) */
.bottom-nav a:hover {
  color: #ffffff;
}

/* ===============================
   PAGE OFFSET (IMPORTANT)
================================ */

#page-content {
  padding-bottom: 150px; /* footer + nav + betslip */
}
/* =========================
   FORCE SELECTED ODD (SPORTYBET)
========================= */

/* LIVE + UPCOMING + GENERAL */
.live-section .odd-box.selected,
.live-section.upcoming .odd-box.selected,
.odd-box.selected {
  background-color: #0B3D2E !important; /* deep green */
  color: #ffffff !important;
}

/* Odds number */
.live-section .odd-box.selected span,
.live-section.upcoming .odd-box.selected span,
.odd-box.selected span {
  color: #ffffff !important;
  font-weight: 800;
}

/* Pressed / locked feel */
.odd-box {
  transition: background-color 0.15s ease,
              transform 0.1s ease;
}

.odd-box.selected {
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.25);
}

.odd-box:active {
  transform: scale(0.97);
}
/* =========================
   LIVE / UPCOMING TABS
========================= */
.sporty-tabs {
  display: flex;
  gap: 10px;
  padding: 10px;
  background: #fff;
}

.sporty-tab {
  flex: 1;
  padding: 12px 0;
  font-size: 14px;
  font-weight: 700;
  border-radius: 6px;
  border: 1px solid #e5e7eb;
  background: #f9fafb;
  color: #111;
  cursor: pointer;
  transition: all .15s ease;
}

/* ACTIVE TAB */
.sporty-tab.active {
  background: var(--green-dark);
  color: #fff;
  border-color: var(--green-dark);
}

/* PRESS EFFECT */
.sporty-tab:active {
  transform: scale(0.97);
}
/* =========================
   LIVE / UPCOMING TABS
========================= */
.bets-tabs {
  display: flex;
  gap: 8px;
  padding: 10px;
  background: #ffffff;
}

.bets-tab {
  flex: 1;
  padding: 12px 0;
  font-size: 14px;
  font-weight: 800;
  border-radius: 6px;
  border: 1px solid #e5e7eb;
  background: #f3f4f6;
  color: #111;
  cursor: pointer;
  transition: all 0.15s ease;
}

.bets-tab.active {
  background: #0B3D2E;
  color: #ffffff;
  border-color: #0B3D2E;
}

.bets-tab:active {
  transform: scale(0.97);
}
.league-name{
  font-size:12px;
  font-weight:700;
  color:#4ade80;
  margin-bottom:4px;
}

.live-score{
  margin-left:auto;
  font-weight:800;
  color:#28d760;
}
.more-markets-row{
  text-align:center;
  margin:8px 0;
}

.more-markets-btn{
  background:#fff;
  border:1.5px solid #0B3D2E;
  color:#0B3D2E;
  font-weight:700;
  padding:6px 14px;
  border-radius:6px;
  cursor:pointer;
}
.more-toggle{
  display:flex;
  justify-content:space-between;
  padding:10px;
  font-weight:700;
  cursor:pointer;
  background:#f3f4f6;
  border-top:1px solid #eee;
}

.more-markets{
  display:none;
  padding:10px;
  background:#fafafa;
}

.more-markets.open{
  display:block;
}
.more-market-btn{
  display:inline-block;
  margin-top:6px;
  padding:6px 10px;
  background:#1e88e5;
  color:#fff;
  border-radius:4px;
  font-size:13px;
  text-decoration:none;
}

.market-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:10px;
  margin-top:15px;
}
.back-btn{
  display:inline-block;
  margin-bottom:10px;
  color:#1e88e5;
  font-weight:500;
  text-decoration:none;
}
/* =========================
   MATCH PAGE
========================= */
.match-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px;
  background: #0b3d2e;
  color: #fff;
  font-weight: 600;
}

.match-header a {
  color: #fff;
  text-decoration: none;
  font-size: 18px;
}

.match-container {
  padding: 12px;
}

.match-card {
  background: #fff;
  border-radius: 8px;
  margin-bottom: 14px;
  box-shadow: 0 2px 6px rgba(0,0,0,.08);
  overflow: hidden;
}

.match-teams {
  padding: 12px;
  font-weight: 700;
  display: flex;
  justify-content: space-between;
  border-bottom: 1px solid #eee;
}

.market-title {
  padding: 10px 12px;
  font-size: 14px;
  font-weight: 600;
  background: #f4f6f8;
  border-top: 1px solid #eee;
}

.market-odds {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  padding: 12px;
}

.market-odds.two {
  grid-template-columns: repeat(2, 1fr);
}

.market-odds .odd-box {
  padding: 10px;
  text-align: center;
  border-radius: 6px;
  background: #f9f9f9;
  border: 1px solid #ddd;
}

/* Correct score text visibility */
.market-grid .odd-box small {
  color: #fff;
  font-weight: 600;
}

/* Make background darker so white pops */
.market-grid .odd-box {
  background: #1e1e1e;
  border: 1px solid #333;
}


.market-odds .odd-box span {
  font-weight: 700;
  font-size: 15px;
  color: #111;
}

.market-odds .odd-box.selected {
  background: #0b3d2e;
  color: #fff;
}

.market-odds .odd-box.selected span,
.market-odds .odd-box.selected small {
  color: #fff;
}
/* =========================
   MATCH PAGE HEADER (PRO)
========================= */
.market-header.premium {
  background: linear-gradient(135deg, #0b3d2e, #145a44);
  color: #fff;
  padding: 14px 16px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  gap: 12px;
  box-shadow: 0 4px 10px rgba(0,0,0,0.15);
}

.market-header.premium .back-icon {
  font-size: 20px;
  font-weight: bold;
  color: #fff;
  text-decoration: none;
}

.market-header.premium .market-title {
  font-size: 15px;
  font-weight: 600;
}

.market-header.premium .vs {
  margin: 0 6px;
  opacity: 0.8;
}
/* =========================
   MATCH PAGE TOP BAR
========================= */
.match-topbar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  background: linear-gradient(135deg, #0b3d2e, #0f5132);
  border-radius: 10px;
  margin-bottom: 12px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.2);
}

.back-btn-pro {
  width: 34px;
  height: 34px;
  background: rgba(255,255,255,0.15);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}

.back-btn-pro:hover {
  background: rgba(255,255,255,0.25);
}

.back-icon {
  color: #fff;
  font-size: 22px;
  font-weight: bold;
  line-height: 1;
}

.match-title-pro {
  color: #fff;
  font-size: 15px;
  font-weight: 600;
}

.vs-pro {
  margin: 0 6px;
  opacity: 0.8;
}
/* =========================
   MARKET TEXT VISIBILITY
========================= */

/* Make ALL market labels white */
.market-card .odd-box small,
.market-grid .odd-box small {
  color: #fff !important;
  font-weight: 600;
}

/* Make odds pop */
.market-card .odd-box span,
.market-grid .odd-box span {
  color: #fff !important;
  font-weight: 700;
}

/* Dark professional background for market boxes */
.market-card .odd-box,
.market-grid .odd-box {
  background: #1f2933;
  border: 1px solid #2f3b47;
}

/* Hover effect */
.market-card .odd-box:hover,
.market-grid .odd-box:hover {
  background: #263445;
}

/* Selected state */
.market-card .odd-box.selected,
.market-grid .odd-box.selected {
  background: #0b3d2e;
  border-color: #0b3d2e;
}
/* =========================
   UPCOMING MATCH – CLEAN UI
========================= */
.live-section.upcoming .live-card{
  background: linear-gradient(180deg,#1b222a,#141a20);
  border-radius: 12px;
  margin: 10px;
  padding: 12px;
  color: #fff;
}

.live-section.upcoming .live-top{
  font-size: 12px;
  color: #9ca3af;
  display: flex;
  justify-content: space-between;
  margin-bottom: 8px;
}

.live-section.upcoming .teams{
  font-size: 15px;
  font-weight: 800;
  line-height: 1.4;
  margin-bottom: 10px;
}

.live-section.upcoming .odds{
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 8px;
}

.live-section.upcoming .odd-box{
  background: #202833;
  color: #22c55e;
  border-radius: 8px;
  padding: 12px 0;
  text-align: center;
  font-weight: 900;
}

/* MORE MARKETS BUTTON */
.more-toggle{
  margin-top: 10px;
  display: flex;
  justify-content: center;
}

.more-toggle span{
  background: #2563eb;
  color: #fff;
  padding: 8px 14px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 800;
}
/* =========================
   FIX ODDS NOT CLICKABLE
========================= */
.live-card,
.live-section,
.teams,
.live-top {
  position: relative;
  z-index: 1;
}

.odds {
  position: relative;
  z-index: 5;
}

.odd-box {
  position: relative;
  z-index: 10;
  cursor: pointer;
  pointer-events: auto;
}
/* =========================
   UPCOMING MATCH UI (PRO)
========================= */
.live-section.upcoming .live-card {
  background: linear-gradient(180deg, #1c2229, #14191f);
  border-radius: 10px;
  margin: 10px;
  padding: 12px;
  color: #fff;
}

.live-section.upcoming .live-top {
  font-size: 12px;
  color: #9ca3af;
  display: flex;
  justify-content: space-between;
  margin-bottom: 8px;
}

.live-section.upcoming .teams {
  font-size: 15px;
  font-weight: 700;
  line-height: 1.4;
  margin-bottom: 10px;
}

.live-section.upcoming .odds {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
}

.live-section.upcoming .odd-box {
  background: #2a3139;
  color: #22c55e;
  padding: 12px 0;
  text-align: center;
  border-radius: 6px;
  font-weight: 900;
}

.live-section.upcoming .odd-box:hover {
  background: #0b3d2e;
  color: #fff;
}
/* =========================
   LIVE MATCH UI (PRO)
========================= */
.live-section:not(.upcoming) .live-card {
  background: linear-gradient(180deg, #1b2026, #12161b);
  border-radius: 10px;
  margin: 10px;
  padding: 12px;
  color: #fff;
}

.live-section:not(.upcoming) .live-top {
  display: flex;
  justify-content: space-between;
  font-size: 12px;
  color: #22c55e;
  margin-bottom: 8px;
}

.live-section:not(.upcoming) .teams {
  font-size: 15px;
  font-weight: 700;
  margin-bottom: 10px;
}

.live-section:not(.upcoming) .teams strong {
  color: #22c55e;
  margin-left: 6px;
}

.live-section:not(.upcoming) .odds {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
}

.live-section:not(.upcoming) .odd-box {
  background: #2d333a;
  color: #22c55e;
  padding: 12px 0;
  text-align: center;
  border-radius: 6px;
  font-weight: 900;
}
.match-section {
  background: #0b3d2e;
  padding: 10px;
}

.section-title {
  color: #fff;
  font-weight: 800;
  padding: 8px;
}

.match-row {
  background: #1a1f24;
  border-radius: 10px;
  padding: 12px;
  margin-bottom: 10px;
  display: flex;
  flex-direction: column;
}

.match-left {
  color: #fff;
}

.match-meta {
  font-size: 12px;
  opacity: .8;
  margin-bottom: 6px;
}

.match-teams div {
  font-weight: 700;
  margin-bottom: 4px;
}

.match-odds {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin-top: 10px;
}

.odd-box {
  background: #e6f4ea;
  color: #064c2b;
  text-align: center;
  padding: 12px 0;
  border-radius: 8px;
  font-weight: 900;
}

.more-market-btn {
  margin-top: 10px;
  text-align: center;
  background: #0b6e3f;
  color: #fff;
  padding: 8px;
  border-radius: 8px;
  font-weight: 700;
  text-decoration: none;
}
/* =========================
   DIFFERENTIATE UPCOMING MATCHES
   (LIGHT THEME)
========================= */

/* UPCOMING section background */
#upcoming.match-section {
  background: #f5f7f6; /* light neutral */
}

/* Upcoming match cards */
#upcoming .match-row {
  background: #ffffff;
  color: #111;
  border-radius: 10px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}

/* Meta text (time / league) */
#upcoming .match-meta {
  color: #6b7280;
}

/* Team names */
#upcoming .match-teams div {
  color: #111;
  font-weight: 700;
}

/* Odds boxes */
#upcoming .odd-box {
  background: #eef6f1;
  color: #0b6e3f;
  border: 1px solid #d1e7dd;
}

/* Selected odd (keep brand green) */
#upcoming .odd-box.selected {
  background: #0b6e3f !important;
  color: #ffffff !important;
}

/* More markets button */
#upcoming .more-market-btn {
  background: #0b6e3f;
  color: #ffffff;
}
/* UPCOMING MATCHES TITLE */
#upcoming .section-title {
  color: #000000;
  font-weight: 900;
}
.team-row{
  display:flex;
  align-items:center;
  gap:8px;
  font-weight:700;
}

.team-logo{
  width:20px;
  height:20px;
  object-fit:contain;
  opacity:.9;
}
.match-odds,
.match-odds .odd-box {
  pointer-events: auto;
  cursor: pointer;
  position: relative;
  z-index: 5;
}
.footer-legal-links {
  margin: 14px 0;
  text-align: center;
  font-size: 14px;
}

.footer-legal-links a {
  color: #0b6e3f; /* DARK GREEN */
  text-decoration: none;
  font-weight: 600;
  margin: 0 6px;
}

.footer-legal-links a:hover {
  color: #22c55e; /* lighter green hover */
  text-decoration: underline;
}

.footer-legal-links span {
  color: #6b7280;
}
/* LIVE ACTION WRAPPER */
.live-action{
  text-decoration:none;
  color:#000; /* BLACK TEXT */
}

/* LIVE ICON */
.live-icon{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:16px;
  font-weight:700;
  color:#000; /* BLACK */
}

/* LIVE TEXT */
.live-text{
  font-size:14px;
  font-weight:800;
  color:#000; /* BLACK */
}

/* BLINKING DOT */
.live-dot{
  width:22px;
  height:22px;
  border-radius:50%;
  background:#e11d48;
  box-shadow:0 0 6px rgba(225,29,72,0.9);
  animation: liveBlink 1.2s infinite ease-in-out;
}

/* BLINK ANIMATION */
@keyframes liveBlink{
  0%{
    opacity:1;
    box-shadow:0 0 4px rgba(225,29,72,0.6);
  }
  50%{
    opacity:0.4;
    box-shadow:0 0 12px rgba(225,29,72,1);
  }
  100%{
    opacity:1;
    box-shadow:0 0 4px rgba(225,29,72,0.6);
  }
}
/* ALL QUICK ACTION TEXT */
.quick-actions .action{
  font-weight:800;       /* BOLD LIKE LIVE */
  color:#000;            /* BLACK TEXT */
}

/* ICON TEXT ALIGNMENT */
.quick-actions .action div,
.quick-actions .action span{
  font-weight:800;
  color:#000;
}

/* REMOVE UNDERLINES COMPLETELY */
.quick-actions a{
  text-decoration:none;
  color:#000;
}
/* =========================
   SPORTY SCROLLING WINNERS
========================= */

.sporty-winners-wrapper{
  overflow:hidden;
  margin:14px 0;
  background:#ffffff;
}

.sporty-winners-track{
  display:flex;
  gap:14px;
  width:max-content;
  animation:sportyScroll 60s linear infinite;
}

.sporty-winner-card{
  min-width:260px;
  background:#2f343d;
  color:#ffffff;
  border-radius:14px;
  padding:14px 16px;
  position:relative;
  overflow:hidden;
}

.winner-text{
  position:relative;
  z-index:2;
}

.winner-phone{
  font-weight:700;
  font-size:14px;
  opacity:.95;
}

.winner-amount{
  margin:6px 0;
  font-size:20px;
  font-weight:900;
  color:#2ee56b;
}

.winner-label{
  font-size:13px;
  opacity:.9;
}

.winner-bg-icon{
  position:absolute;
  right:-10px;
  bottom:-12px;
  font-size:64px;
  opacity:.08;
}

/* =========================
   INDEX UPCOMING LEAGUE TABS
========================= */
.index-league-tabs{
  display:flex;
  gap:10px;
  padding:10px 12px;
  overflow-x:auto;
  background:#ffffff;
}

.index-league-tabs::-webkit-scrollbar{
  display:none;
}

.index-league-tabs .league-tab{
  padding:8px 14px;
  border-radius:20px;
  background:#eef6f1;
  color:#0b6e3f;
  font-weight:800;
  font-size:13px;
  white-space:nowrap;
  cursor:pointer;
}

.index-league-tabs .league-tab.active{
  background:#0b6e3f;
  color:#ffffff;
}
/* ===== CASINO QUICK ACTION ===== */
.casino-action{
  background:linear-gradient(135deg,#7c3aed,#ca8a04);
  color:#fff;
  font-weight:800;
  position:relative;
  overflow:hidden;
}

.casino-action::after{
  content:'';
  position:absolute;
  top:0;
  left:-100%;
  width:100%;
  height:100%;
  background:rgba(255,255,255,0.15);
  transform:skewX(-20deg);
  animation:casinoShine 3s infinite;
}

@keyframes casinoShine{
  0%{left:-100%}
  50%{left:120%}
  100%{left:120%}
}

.casino-icon{
  font-size:22px;
}
to {
  transform: translateX(-50%);
}
/* ===== NAVOXWIN / BETBUZZY SLIDER ===== */
.nx-slider{
  position:relative;
  width:100%;
  max-width:1200px;
  margin:12px auto;
  border-radius:16px;
  overflow:hidden;
  background:#061a2b;
}

.nx-track{
  display:flex;
  width:100%;
  transform:translateX(0);
  transition:transform .45s ease;
  touch-action:pan-y;
}

.nx-slide{
  min-width:100%;
  user-select:none;
}

.nx-slide img{
  width:100%;
  display:block;
  height:auto;
}

/* nav arrows */
.nx-nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  border:0;
  width:44px;
  height:44px;
  border-radius:999px;
  cursor:pointer;
  font-size:26px;
  font-weight:900;
  color:#fff;
  background:rgba(0,0,0,.35);
  backdrop-filter: blur(6px);
}

.nx-prev{ left:10px; }
.nx-next{ right:10px; }

.nx-nav:hover{ background:rgba(0,0,0,.55); }

/* dots */
.nx-dots{
  position:absolute;
  left:50%;
  bottom:10px;
  transform:translateX(-50%);
  display:flex;
  gap:8px;
  padding:6px 10px;
  border-radius:999px;
  background:rgba(0,0,0,.25);
  backdrop-filter: blur(6px);
}

.nx-dot{
  width:10px;
  height:10px;
  border-radius:999px;
  background:rgba(255,255,255,.35);
  cursor:pointer;
}

.nx-dot.active{
  background:rgba(255,255,255,.95);
}
/* =========================
   NAVOXWIN PREMIUM BOTTOM NAV
========================= */

.nx-bottom-nav{
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 9999;

  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;

  padding: 10px 10px calc(10px + env(safe-area-inset-bottom));
  background: rgba(7, 26, 43, .92);          /* Navy */
  border-top: 1px solid rgba(255,255,255,.10);
  backdrop-filter: blur(10px);

  /* Premium shadow */
  box-shadow: 0 -16px 40px rgba(0,0,0,.35);
}

.nx-tab{
  text-decoration: none;
  color: rgba(255,255,255,.75);

  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;

  padding: 10px 8px;
  border-radius: 16px;
  font-weight: 900;
  letter-spacing: .2px;

  transition: transform .15s ease, background .15s ease, color .15s ease;
}

.nx-ico{
  width: 24px;
  height: 24px;
  display: grid;
  place-items: center;
  margin-bottom: 4px;
}

.nx-ico svg{
  width: 24px;
  height: 24px;
  color: currentColor;
}

.nx-label{
  font-size: 11.5px;
  line-height: 1;
  opacity: .95;
}

/* PREMIUM ACTIVE TAB */
.nx-tab.active{
  color: #E8FBFF;
  background: linear-gradient(180deg, rgba(22,182,216,.22), rgba(255,255,255,.06));
  border: 1px solid rgba(22,182,216,.35);

  /* premium lift */
  transform: translateY(-2px);

  /* glow */
  box-shadow:
    0 10px 26px rgba(0,0,0,.35),
    0 0 0 1px rgba(22,182,216,.18) inset,
    0 0 24px rgba(22,182,216,.22);
}

.nx-tab.active .nx-ico svg{
  filter: drop-shadow(0 8px 16px rgba(22,182,216,.20));
}

/* HOVER (desktop) */
@media (hover:hover){
  .nx-tab:hover{
    color:#fff;
    background: rgba(255,255,255,.06);
    transform: translateY(-1px);
  }
}

/* Add spacing so content doesn't hide behind bottom nav */
body{
  padding-bottom: 92px;
}
/* =========================
   NAVOXWIN • WINNERS TICKER
   Targets your current markup:
   .sporty-winners-wrapper, .sporty-winners-track,
   .sporty-winner-card, .winner-text, .winner-phone,
   .winner-amount, .winner-label, .winner-bg-icon
========================= */

.sporty-winners-wrapper{
  margin-top:14px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:16px;
  overflow:hidden;
  background:
    radial-gradient(900px 240px at 18% 0%, rgba(34,197,94,.10), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.03));
  box-shadow: 0 18px 50px rgba(0,0,0,.40);
}

/* scrolling lane */
.sporty-winners-track{
  display:flex;
  align-items:stretch;
  gap:12px;
  padding:14px;
  will-change: transform;
}

/* each card */
.sporty-winner-card{
  min-width: 260px;
  max-width: 320px;
  flex: 0 0 auto;

  position:relative;
  overflow:hidden;

  border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background:
    linear-gradient(135deg, rgba(255,255,255,.07), rgba(255,255,255,.04));
  box-shadow: 0 14px 34px rgba(0,0,0,.30);

  padding:12px 14px;
  transform: translateZ(0);
  transition: transform .12s ease, border-color .18s ease, background .18s ease;
}

.sporty-winner-card:hover{
  transform: translateY(-1px);
  border-color: rgba(34,197,94,.26);
}

/* subtle premium glow */
.sporty-winner-card::before{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius:16px;
  background: linear-gradient(135deg, rgba(34,197,94,.22), rgba(255,255,255,.06), rgba(255,255,255,0));
  opacity:.22;
  pointer-events:none;
}

/* text block */
.winner-text{
  position:relative;
  z-index:2;
  display:flex;
  flex-direction:column;
  gap:6px;
}

.winner-phone{
  font-weight:950;
  letter-spacing:.2px;
  color: rgba(234,240,255,.92);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.winner-amount{
  font-weight:950;
  letter-spacing:.2px;
  color: rgba(234,240,255,.98);
  display:flex;
  align-items:center;
  gap:8px;
}

/* green chip feeling */
.winner-amount::after{
  content:"WIN";
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:5px 8px;
  border-radius:999px;
  font-size:11px;
  font-weight:950;
  letter-spacing:.25px;
  color: rgba(234,240,255,.95);
  background: rgba(34,197,94,.14);
  border:1px solid rgba(34,197,94,.22);
  box-shadow: 0 10px 22px rgba(0,0,0,.20);
}

.winner-label{
  font-size:12px;
  font-weight:850;
  color: rgba(234,240,255,.62);
  letter-spacing:.2px;
}

/* trophy icon background */
.winner-bg-icon{
  position:absolute;
  right:10px;
  bottom:8px;
  font-size:36px;
  opacity:.18;
  z-index:1;
  filter: drop-shadow(0 12px 26px rgba(0,0,0,.35));
  transform: rotate(-8deg);
}

/* make it tighter on small screens */
@media (max-width: 520px){
  .sporty-winners-track{ padding:12px; gap:10px; }
  .sporty-winner-card{ min-width: 230px; padding:11px 12px; border-radius:14px; }
  .winner-bg-icon{ font-size:34px; }
}
/* =========================================
   NAVOXWIN — DASHBOARD STYLES (main.css)
   Matches the "new navy premium UI"
   Scope: .dashboard-page
========================================= */

.dashboard-page{
  background:
    radial-gradient(1200px 800px at 15% 0%, rgba(91,140,255,.14), transparent 55%),
    radial-gradient(900px 600px at 85% 10%, rgba(34,197,94,.08), transparent 50%),
    #061423;
  color: rgba(234,242,255,.95);
  padding-bottom: 110px; /* space for fixed bottom-nav */
}

/* Support both wrappers safely */
.dashboard-page .dash-wrap,
.dashboard-page .container{
  max-width: 980px;
  margin: 0 auto;
  padding: 14px 14px 0;
}

/* ===== Section title (matches first UI) ===== */
.dashboard-page .dash-section-title{
  margin: 14px 2px 10px;
  font-weight: 950;
  font-size: 13px;
  letter-spacing: .45px;
  color: rgba(234,242,255,.70);
  text-transform: uppercase;
}

/* ===== HERO / BALANCE CARD ===== */
.dashboard-page .balance-header{
  background: linear-gradient(180deg, rgba(7,26,43,.98), rgba(7,26,43,.78));
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 18px;
  padding: 16px 14px 14px;
  box-shadow: 0 18px 50px rgba(0,0,0,.28);
  height: auto;
  min-height: unset;
}

/* ===== Identity row (new UI) ===== */
.dashboard-page .dash-idrow{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.dashboard-page .dash-avatar{
  width: 44px;
  height: 44px;
  border-radius: 16px;
  display:flex;
  align-items:center;
  justify-content:center;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  flex: 0 0 auto;
}

.dashboard-page .dash-avatar svg{
  width: 22px;
  height: 22px;
  stroke: rgba(234,242,255,.95);
}

.dashboard-page .dash-idtext{
  flex: 1 1 auto;
  min-width: 0;
}

.dashboard-page .dash-label{
  font-size: 12px;
  font-weight: 900;
  color: rgba(234,242,255,.70);
  letter-spacing: .3px;
  text-transform: uppercase;
}

.dashboard-page .dash-phone{
  font-size: 15px;
  font-weight: 950;
  color: rgba(234,242,255,.98);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.dashboard-page .dash-meta{
  margin-top: 2px;
  font-size: 12px;
  color: rgba(234,242,255,.65);
}

/* Verification pill */
.dashboard-page .dash-verify{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 999px;
  font-weight: 950;
  font-size: 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color: rgba(234,242,255,.92);
  white-space: nowrap;
}

.dashboard-page .dash-verify svg{
  width: 18px;
  height: 18px;
  stroke: rgba(234,242,255,.92);
}

.dashboard-page .dash-verify--yes{
  border-color: rgba(34,197,94,.35);
  background: rgba(34,197,94,.12);
}

.dashboard-page .dash-verify--no{
  border-color: rgba(239,68,68,.35);
  background: rgba(239,68,68,.10);
}

/* ===== Balance row ===== */
.dashboard-page .balance-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  margin: 14px 0 12px;
}

.dashboard-page .balance-row span{
  font-size: 13px;
  color: rgba(234,242,255,.75);
  font-weight: 800;
}

.dashboard-page .balance-row strong{
  font-size: 18px;
  font-weight: 950;
  color: rgba(234,242,255,.98);
}

/* ===== Deposit / Withdraw buttons (fix giant panels) ===== */
.dashboard-page .balance-actions{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  align-items: start;
  align-content: start;
}

.dashboard-page .balance-actions a{
  text-decoration:none;
  border-radius: 14px;
  padding: 12px 12px;
  font-weight: 950;
  font-size: 14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 8px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(91,140,255,.18);
  color: rgba(234,242,255,.96);
  transition: transform .08s ease, background .15s ease, border-color .15s ease;
  height: 52px;        /* ✅ forces button height */
  min-height: 52px;    /* ✅ prevents stretching */
}

.dashboard-page .balance-actions a svg{
  width: 18px;
  height: 18px;
  stroke: rgba(234,242,255,.95);
  display:block;
}

.dashboard-page .balance-actions a:hover{
  background: rgba(91,140,255,.22);
  border-color: rgba(91,140,255,.42);
}

.dashboard-page .balance-actions a:active{
  transform: scale(.98);
}

/* ===== Quick Actions cards (new UI grid) ===== */
.dashboard-page .dash-actions{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

@media (min-width: 900px){
  .dashboard-page .dash-actions{
    grid-template-columns: repeat(4, 1fr);
  }
}

.dashboard-page .dash-action{
  text-decoration:none;
  border-radius: 16px;
  padding: 14px 12px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(7,26,43,.86);
  box-shadow: 0 14px 40px rgba(0,0,0,.20);
  color: rgba(234,242,255,.95);
  display:flex;
  gap: 10px;
  align-items:center;
  transition: transform .08s ease, background .15s ease, border-color .15s ease;
  min-height: 62px;
}

.dashboard-page .dash-action:hover{
  background: rgba(7,26,43,.92);
  border-color: rgba(91,140,255,.30);
}

.dashboard-page .dash-action:active{
  transform: scale(.99);
}

.dashboard-page .dash-ico{
  width: 40px;
  height: 40px;
  border-radius: 14px;
  display:flex;
  align-items:center;
  justify-content:center;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.06);
  flex: 0 0 auto;
}

.dashboard-page .dash-ico svg{
  width: 20px;
  height: 20px;
  stroke: rgba(234,242,255,.92);
}

.dashboard-page .dash-action .txt{
  display:flex;
  flex-direction:column;
  gap: 2px;
  min-width: 0;
}

.dashboard-page .dash-action .t{
  font-weight: 950;
  font-size: 14px;
  line-height: 1.15;
  white-space: nowrap;
  overflow:hidden;
  text-overflow: ellipsis;
}

.dashboard-page .dash-action .s{
  font-size: 12px;
  color: rgba(234,242,255,.70);
  white-space: nowrap;
  overflow:hidden;
  text-overflow: ellipsis;
}

/* Bottom nav compatibility */
.dashboard-page .bottom-nav a,
.dashboard-page .bottom-nav span{
  font-size: 12px;
  line-height: 1.2;
}
/* =========================================
   NAVOXWIN — DASHBOARD MOBILE FIX (FORCE)
   Scope: .dashboard-page only
   Paste at BOTTOM of main.css
========================================= */

.dashboard-page{
  padding-bottom: 110px;
}

/* keep dashboard centered */
.dashboard-page .dash-wrap{
  max-width: 980px;
  margin: 0 auto;
  padding: 14px 14px 0;
}

/* ---------- Identity row ---------- */
.dashboard-page .dash-idrow{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  margin-bottom: 12px;
  min-width: 0;
}

.dashboard-page .dash-avatar{
  width: 44px;
  height: 44px;
  border-radius: 16px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex: 0 0 auto;
}

.dashboard-page .dash-avatar svg{
  width: 22px;
  height: 22px;
  display:block;
}

/* allow text area to shrink instead of overflowing */
.dashboard-page .dash-idtext{
  flex: 1 1 auto;
  min-width: 0;
}

.dashboard-page .dash-label{
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .3px;
  text-transform: uppercase;
  opacity: .75;
}

.dashboard-page .dash-phone{
  font-size: 15px;
  font-weight: 950;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.dashboard-page .dash-meta{
  margin-top: 2px;
  font-size: 12px;
  opacity: .70;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* verified pill must not force overflow */
.dashboard-page .dash-verify{
  flex: 0 0 auto;
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 999px;
  font-weight: 950;
  font-size: 12px;
  white-space: nowrap;
}

.dashboard-page .dash-verify svg{
  width: 18px;
  height: 18px;
  display:block;
}

/* ---------- Balance row ---------- */
.dashboard-page .balance-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  margin: 14px 0 12px;
}

.dashboard-page .balance-row span{
  font-size: 13px;
  font-weight: 800;
  opacity: .80;
}

.dashboard-page .balance-row strong{
  font-size: 18px;
  font-weight: 950;
  white-space: nowrap;
}

/* ---------- Deposit/Withdraw buttons ---------- */
.dashboard-page .balance-actions{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.dashboard-page .balance-actions a{
  display:flex;
  align-items:center;
  justify-content:center;
  gap: 8px;
  padding: 12px 12px;
  border-radius: 14px;
  font-weight: 950;
  font-size: 14px;
  text-decoration: none;
  min-height: 46px;
  white-space: nowrap;
}

.dashboard-page .balance-actions a svg{
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
  display:block;
}

/* ---------- Section title ---------- */
.dashboard-page .dash-section-title{
  margin: 14px 2px 10px;
  font-weight: 950;
  font-size: 13px;
  letter-spacing: .4px;
  text-transform: uppercase;
  opacity: .78;
}

/* ---------- Quick actions grid (mobile best) ---------- */
.dashboard-page .dash-actions{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

/* action card */
.dashboard-page .dash-action{
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 14px 12px;
  border-radius: 16px;
  text-decoration: none;
  min-height: 64px;
  min-width: 0; /* allow ellipsis */
}

.dashboard-page .dash-ico{
  width: 40px;
  height: 40px;
  border-radius: 14px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex: 0 0 auto;
}

.dashboard-page .dash-ico svg{
  width: 20px;
  height: 20px;
  display:block;
}

/* text truncation */
.dashboard-page .dash-action .txt{
  display:flex;
  flex-direction:column;
  gap: 2px;
  min-width: 0;
}

.dashboard-page .dash-action .t{
  font-weight: 950;
  font-size: 14px;
  line-height: 1.15;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.dashboard-page .dash-action .s{
  font-size: 12px;
  opacity: .70;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ---------- Responsive upgrades ---------- */
@media (min-width: 900px){
  .dashboard-page .dash-actions{
    grid-template-columns: repeat(4, 1fr);
  }
}

/* super small phones */
@media (max-width: 380px){
  .dashboard-page .dash-idrow{
    flex-wrap: wrap;
    row-gap: 10px;
  }

  .dashboard-page .dash-verify{
    width: 100%;
    justify-content:center;
  }

  .dashboard-page .balance-actions{
    grid-template-columns: 1fr;
  }
}


