@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;0,9..40,800&family=Instrument+Sans:wght@400;500;600;700&family=Inter:wght@400;500&family=Doto:wght@400;500;600;700;800;900&display=swap');

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box
}

:root {
  --bg: #f5f5f7;
  --surface: #fff;
  --surface-raised: #f9f9fb;
  --text: #111113;
  --text2: #484850;
  --text3: #86868b;
  --accent: #18181b;
  --accent2: #ebebee;
  --green: #00ba7c;
  --red: #f4212e;
  --blue: #1d9bf0;
  --blue-light: rgba(29, 155, 240, .08);
  --border: rgba(0, 0, 0, .08);
  --border-strong: rgba(0, 0, 0, .12);
  --border-light: rgba(0, 0, 0, .04);
  --radius-sm: 10px;
  --radius-md: 14px;
  --radius-lg: 20px;
  --radius: var(--radius-md);
  --radius-full: 9999px;
  --maxw: 600px;
  --font: 'DM Sans', sans-serif;
  --display: 'Doto', sans-serif;
  --stat-color: #6d28d9;
  --purple: #a78bfa;
  --instrument-bg: #f2f2f7;
  --shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);
  --shadow-sm: 0 2px 4px rgba(0, 0, 0, .06);
  --shadow: 0 4px 12px rgba(0, 0, 0, .08);
  --shadow-md: 0 8px 24px rgba(0, 0, 0, .1);
  --shadow-lg: 0 12px 32px rgba(0, 0, 0, .12);
  --section-header-bg: rgba(248, 248, 250, 1);
  --section-header-border: 1px solid var(--border-light);
  --section-list-bg: #fff;
}

html.dark {
  --bg: #000;
  --surface: #000;
  --surface-raised: #0a0a0a;
  --text: #e7e9ea;
  --text2: #b0b3b8;
  --text3: #86868b;
  --accent: #ffffff;
  --accent2: #121214;
  --green: #00ba7c;
  --red: #f4212e;
  --blue: #1d9bf0;
  --blue-light: rgba(29, 155, 240, .12);
  --purple: #a78bfa;
  --border: rgba(255, 255, 255, 0.08);
  --border-strong: rgba(255, 255, 255, 0.12);
  --border-light: rgba(255, 255, 255, 0.04);
  --stat-color: #D8D1F5;
  --instrument-bg: rgba(255, 255, 255, 0.03);
  --shadow-xs: 0 0 0 1px rgba(255, 255, 255, 0.04);
  --shadow-sm: 0 0 0 1px rgba(255, 255, 255, 0.06);
  --shadow: 0 4px 20px rgba(0, 0, 0, 0.4);
  --shadow-md: 0 8px 30px rgba(0, 0, 0, 0.5);
  --shadow-lg: 0 12px 40px rgba(0, 0, 0, 0.6);
  --section-header-bg: rgba(0, 0, 0, 0.85);
  --section-header-border: 1px solid var(--border);
  --section-list-bg: #000;
}

html.dark .header {
  background: rgba(0, 0, 0, .85);
  backdrop-filter: blur(24px) saturate(200%);
  -webkit-backdrop-filter: blur(24px) saturate(200%);
  border-bottom: .5px solid var(--border-light)
}

html.dark #page-game .header,
html.dark #page-profile .header,
html.dark #page-myprofile .header,
html.dark #page-settings .header,
html.dark #page-profile-game .header,
html.dark #page-passview .header,
html.dark #page-pick .header {
  background: var(--section-header-bg);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  border-bottom: 1px solid var(--border)
}

html.dark .bottom-nav {
  background: rgba(0, 0, 0, .85);
  backdrop-filter: blur(24px) saturate(200%);
  -webkit-backdrop-filter: blur(24px) saturate(200%);
  border-top: 1px solid var(--border)
}

html.dark .modal-overlay {
  background: rgba(0, 0, 0, .7)
}

html.dark .modal-overlay.visible .modal {
  background: #000;
  border: 1px solid var(--border-strong);
  box-shadow: 0 20px 50px rgba(0, 0, 0, .8)
}

html.dark .toggle {
  background: #3d3d3d
}

html.dark .toggle.on {
  background: var(--green)
}

html.dark .toggle::after {
  background: #000;
  box-shadow: none
}

html.dark .pred-badge.pre {
  background: rgba(120, 145, 180, .12);
  color: #9bb0ce
}

html.dark .pred-badge.live {
  background: rgba(244, 33, 46, .1);
  color: #f4212e
}

html.dark .pred-badge.sub {
  background: rgba(120, 86, 255, .1);
  color: #a78bfa
}

html.dark .pred-result.hit {
  background: rgba(0, 186, 124, .1);
  color: #00ba7c
}

html.dark .pred-result.miss {
  background: rgba(244, 33, 46, .1);
  color: #f4212e
}

html.dark .pred-result.pending {
  background: #16181c;
  color: var(--text3)
}

html.dark .sub-badge {
  background: rgba(120, 86, 255, .1);
  color: #a78bfa
}

html.dark .league-tag {
  background: #16181c;
  border-color: #2f3336
}

html.dark .btn-primary {
  background: #fff;
  color: #000;
  font-weight: 700;
  border-radius: 16px;
  box-shadow: 0 4px 12px rgba(255, 255, 255, 0.1)
}

html.dark .btn-primary:hover {
  background: #f0f0f0;
  transform: translateY(-1px)
}

html.dark .btn-primary:active {
  background: #e0e0e0;
  transform: scale(0.97)
}

html.dark .btn-outline {
  background: transparent;
  border-color: #536471;
  color: var(--text);
  box-shadow: none
}

html.dark .btn-outline:hover {
  background: rgba(231, 233, 234, .1);
  border-color: #71767b
}

html.dark .btn-green {
  background: var(--green);
  color: #000;
  font-weight: 700;
  border-radius: 16px;
}

html.dark .btn-green:hover {
  filter: brightness(1.1);
}

html.dark .btn-green:active {
  transform: scale(0.97);
}

html.dark .btn-red {
  background: var(--red);
  color: #fff;
  box-shadow: none
}

html.dark .btn-red:hover {
  background: #e0191e;
  color: #fff
}

html.dark .fab {
  background: #e7e9ea;
  color: #0f1419
}

html.dark .fab svg {
  stroke: #0f1419
}

html.dark .follow-btn.not-following {
  background: #e7e9ea;
  color: #0f1419;
  font-weight: 700
}

html.dark .follow-btn.following {
  background: transparent;
  border-color: #536471;
  color: var(--text)
}

html.dark .follow-btn.following:hover {
  border-color: var(--red);
  color: var(--red);
  background: rgba(244, 33, 46, .1)
}

html.dark .sidebar-btn {
  background: #e7e9ea;
  color: #0f1419;
  box-shadow: none;
  font-weight: 700
}

html.dark .sidebar-btn:hover {
  background: #d7dbdc
}

html.dark .icon-btn {
  background: transparent;
  border-color: #2f3336
}

html.dark .icon-btn:hover {
  background: rgba(231, 233, 234, .1);
  border-color: #536471
}

html.dark .icon-btn svg {
  stroke: var(--text2)
}

html.dark .icon-btn.share-btn svg {
  stroke: var(--purple)
}

html.dark .pick-type-btn {
  background: #16181c;
  color: var(--text2);
  border: 1px solid #2f3336
}

html.dark .pick-type-btn.active {
  background: #e7e9ea;
  color: #0f1419;
  border-color: #e7e9ea
}

html.dark .pick-side-btn {
  background: #16181c;
  border-color: #2f3336
}

html.dark .pick-side-btn:hover {
  background: #1e2025;
  border-color: #536471
}

html.dark .pick-side-btn.selected {
  background: #e7e9ea;
  color: #0f1419;
  border-color: #e7e9ea
}

html.dark .compose-tag.active {
  background: #e7e9ea;
  color: #0f1419
}

html.dark .filter-pill.active {
  background: #e7e9ea;
  color: #0f1419;
  border-color: #e7e9ea
}

html.dark .vis-opt.active {
  background: #16181c;
  color: var(--text);
  box-shadow: none;
  border: 1px solid #2f3336
}

html.dark .dial-opt.active {
  background: #e7e9ea;
  color: #0f1419
}

html.dark ::selection {
  background: rgba(29, 155, 240, .3)
}

html.dark .avatar {
  box-shadow: none
}

html.dark .modal-handle {
  background: #3d3d3d
}

html.dark .search-box {
  background: #16181c;
  border-color: #2f3336
}

html.dark .search-box:focus-within {
  border-color: #1d9bf0;
  background: #000;
  box-shadow: 0 0 0 1px #1d9bf0
}

html.dark .compose-input {
  background: #16181c;
  border-color: #2f3336
}

html.dark .compose-input:focus {
  border-color: #1d9bf0;
  background: #000;
  box-shadow: 0 0 0 1px #1d9bf0
}

html.dark .auth-field input {
  background: #16181c;
  border-color: #2f3336
}

html.dark .game-card:hover {
  background: rgba(231, 233, 234, .03)
}

html.dark .pred-card:hover {
  background: rgba(231, 233, 234, .03)
}

html.dark .desktop-sidebar {
  background: #000;
  border-color: #2f3336
}

html.dark .desktop-right {
  background: #000;
  border-color: #2f3336
}

html.dark .tabs {
  border-color: #2f3336
}

html.dark .tab.active {
  border-color: #1d9bf0;
  color: var(--text)
}

html.dark .tab:hover {
  background: rgba(231, 233, 234, .03)
}

html {
  /* overflow-x: clip prevents horizontal scroll bleed without creating a
     scroll container — important so position:sticky descendants pin to the
     viewport. overflow-x: hidden would have broken sticky everywhere. */
  overflow-x: clip;
  height: -webkit-fill-available
}

body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--text);
  font-size: 14px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  min-height: 100vh;
  min-height: -webkit-fill-available;
  overscroll-behavior-y: none;
  letter-spacing: -.012em;
  text-rendering: optimizeLegibility
}

.pm-brand {
  font-family: var(--display) !important;
  font-weight: 900 !important;
  letter-spacing: -0.5px !important;
  text-transform: lowercase !important
}

.pm-accent {
  color: var(--green)
}

html.theme-transition,
html.theme-transition *,
html.theme-transition *::before,
html.theme-transition *::after {
  transition: background-color .4s cubic-bezier(0.4, 0, 0.2, 1), color .4s cubic-bezier(0.4, 0, 0.2, 1), border-color .4s cubic-bezier(0.4, 0, 0.2, 1), box-shadow .4s cubic-bezier(0.4, 0, 0.2, 1) !important
}

/* Auth pending — hide both states, show neutral skeleton */
html.auth-pending .auth-only-show {
  display: none !important
}

html.auth-pending .auth-only-hide {
  display: none !important
}

.auth-skel {
  display: none !important;
  align-items: center
}

html.auth-pending .auth-skel {
  display: flex !important
}

/* Smooth auth resolve */
.auth-only-show,
.auth-only-hide {
  transition: opacity .3s cubic-bezier(0.4, 0, 0.2, 1)
}

.auth-fade-in {
  animation: authReveal .4s cubic-bezier(0.4, 0, 0.2, 1) both
}

@keyframes authReveal {
  from {
    opacity: 0;
    transform: scale(.92)
  }

  to {
    opacity: 1;
    transform: scale(1)
  }
}

::selection {
  background: rgba(74, 108, 247, .16);
  color: var(--text)
}

a {
  color: inherit;
  text-decoration: none
}

button {
  font-family: var(--font);
  cursor: pointer;
  border: none;
  background: none;
  color: inherit;
  font-size: inherit;
  -webkit-tap-highlight-color: transparent;
  transition: transform .2s cubic-bezier(.34, 1.56, .64, 1), opacity .15s ease, background .2s ease, border-color .2s ease;
}

button:active {
  transform: scale(0.96);
}

input,
textarea,
select {
  font-family: var(--font);
  font-size: 16px;
  color: var(--text);
  background: transparent;
  border: none;
  outline: none;
  width: 100%;
  -webkit-appearance: none;
  appearance: none
}

input[type="checkbox"] {
  -webkit-appearance: checkbox;
  appearance: checkbox;
  width: auto;
  margin-left: 4px
}

:focus-visible {
  outline: 2px solid var(--blue);
  outline-offset: 2px
}

input:focus-visible,
textarea:focus-visible,
select:focus-visible {
  outline: none
}

/* Layout */
.app {
  max-width: var(--maxw);
  margin: 0 auto;
  min-height: 100vh;
  background: var(--surface);
  position: relative
}

/* Side borders appear whenever the viewport is wider than the 600px content
   column — i.e. any non-mobile view. On mobile the content is edge-to-edge
   so borders would only sit at the screen edges, invisible. */
@media(min-width:601px) {
  .app {
    border-left: 1px solid var(--border);
    border-right: 1px solid var(--border)
  }
}

.page {
  display: none;
  padding-bottom: calc(80px + env(safe-area-inset-bottom));
  min-height: 100vh;
  min-height: 100dvh
}

.page.active {
  display: block
}

.page.pg-enter {
  animation: pgIn .3s cubic-bezier(0.4, 0, 0.2, 1) both
}

@keyframes pgIn {
  from {
    opacity: 0;
    transform: translateY(6px)
  }

  to {
    opacity: 1;
    transform: translateY(0)
  }
}

/* Entrance animations for content */
.anim-in {
  animation: fadeUp .35s cubic-bezier(0.4, 0, 0.2, 1) both
}

.anim-in-1 {
  animation-delay: .05s
}

.anim-in-2 {
  animation-delay: .1s
}

.anim-in-3 {
  animation-delay: .15s
}

.anim-in-4 {
  animation-delay: .2s
}

.anim-in-5 {
  animation-delay: .25s
}

@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(10px)
  }

  to {
    opacity: 1;
    transform: translateY(0)
  }
}

/* Card entrance stagger */
.card-enter {
  opacity: 0;
  animation: cardIn .3s cubic-bezier(0.4, 0, 0.2, 1) both
}

@keyframes cardIn {
  from {
    opacity: 0;
    transform: translateY(8px)
  }

  to {
    opacity: 1;
    transform: translateY(0)
  }
}

/* Card animations applied via JS staggerCards() only — not on background refreshes */
.search-item {
  animation: cardIn .25s cubic-bezier(0.4, 0, 0.2, 1) both
}

/* Reduce motion for accessibility */
@media(prefers-reduced-motion:reduce) {

  .page.pg-enter,
  .anim-in,
  .card-enter,
  .pred-card,
  .game-card {
    animation: none !important;
    opacity: 1 !important;
    transform: none !important;
    overflow: hidden;
    -webkit-transform: translateZ(0);
    -webkit-mask-image: -webkit-radial-gradient(white, black);
  }
}

/* Unlock Animation */
.pass-just-unlocked {
  animation: passUnlock .8s cubic-bezier(0.16, 1, 0.3, 1) both;
}

@keyframes passUnlock {
  0% {
    opacity: 0;
    transform: translateY(20px) scale(0.96);
    filter: blur(10px);
  }
  30% {
    opacity: 1;
    filter: blur(4px);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
    filter: blur(0);
  }
}

/* Header */
.header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(255, 255, 255, .88);
  backdrop-filter: blur(24px) saturate(200%);
  -webkit-backdrop-filter: blur(24px) saturate(200%);
  padding: 8px 24px 0;
  border-bottom: none;
  transition: padding .3s cubic-bezier(.4, 0, .2, 1);
  overflow: hidden
}

#heroBlock,
#tickerWrap {
  transition: all .3s cubic-bezier(.4, 0, .2, 1);
  transform-origin: top;
  opacity: 1
}

.header-collapsed {
  padding-top: 4px !important
}

.header-collapsed .header-actions-mobile {
  display: flex !important
}

@media(min-width:1080px) {
  .header-collapsed .header-row .logo {
    display: none
  }

  .header-collapsed .header-row {
    margin-bottom: 0
  }

  .header-collapsed .header-row #leagueFilters {
    flex: 1;
    min-width: 0;
    padding: 0;
    margin: 0
  }
}

@media(max-width:1079px) {
  .header-collapsed .header-row {
    margin-bottom: 4px
  }

  .header-collapsed #leagueFilters {
    padding-top: 0;
    padding-bottom: 8px
  }
}

.header-collapsed #heroBlock {
  max-height: 0 !important;
  opacity: 0 !important;
  transform: translateY(-20px) scaleY(0.8);
  pointer-events: none;
  margin-bottom: 0 !important;
  padding: 0 !important
}

.header-collapsed #tickerWrap {
  max-height: 0 !important;
  opacity: 0 !important;
  padding: 0 !important;
  border-bottom: none !important;
  pointer-events: none
}

#page-game>.header,
#page-profile>.header,
#page-myprofile>.header,
#page-settings>.header,
#page-profile-game>.header {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important
}

#page-game>.header .header-row,
#page-profile>.header .header-row,
#page-myprofile>.header .header-row,
#page-settings>.header .header-row,
#page-portal>.header .header-row,
#page-profile-game>.header .header-row {
  margin-bottom: 0
}

/* Custom Pass & Pick View Header Fix */
#passViewHeader,
#pickViewHeader {
  padding-left: 0 !important;
  padding-right: 0 !important;
  padding-bottom: 0 !important;
  border-bottom: 1px solid var(--border) !important;
}
#passViewHeader .header-row,
#pickViewHeader .header-row,
#passViewHeader #passViewCollapsed {
  padding-left: 24px !important;
  padding-right: 24px !important;
}
#passViewHeader #passViewCollapsed {
  padding-bottom: 12px !important;
}

#page-game .tabs,
#page-profile .tabs,
#page-myprofile .tabs,
#page-profile-game .tabs {
  background: var(--section-header-bg)
}

@media(max-width:1079px) {
  #page-home .header {
    display: flex;
    flex-direction: column;
    padding-top: 0
  }

  #page-home .header>#tickerWrap {
    order: -1;
    margin-top: 0
  }

  #page-home .header>.header-row {
    padding-top: 4px
  }
}

.header-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
  position: relative
}

.logo {
  font-family: var(--display);
  font-size: 24px;
  font-weight: 800;
  letter-spacing: -1px;
  line-height: 1;
}

.logo-full {
  display: inline
}

.logo-short {
  display: none
}

.header-actions {
  display: flex;
  gap: 10px;
  align-items: center
}

.icon-btn {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  transition: background .18s cubic-bezier(0.4, 0, 0.2, 1), border-color .18s cubic-bezier(0.4, 0, 0.2, 1), transform .1s cubic-bezier(0.4, 0, 0.2, 1);
  background: var(--surface-raised);
  border: 1px solid var(--border);
  cursor: pointer
}

.icon-btn:hover {
  background: var(--accent2);
  border-color: var(--border-strong)
}

.icon-btn:active {
  transform: scale(.95)
}

.icon-btn svg {
  width: 16px;
  height: 16px;
  stroke: var(--text2);
  fill: none;
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round
}

.icon-btn.share-btn svg {
  stroke: var(--purple)
}

/* Desktop sidebar */
.desktop-sidebar {
  display: none;
  position: fixed;
  top: 0;
  width: 220px;
  height: 100vh;
  padding: 24px 14px;
  flex-direction: column;
  border-right: none;
  background: var(--surface);
  z-index: 300
}

.sidebar-logo {
  font-family: var(--display);
  font-size: 24px;
  font-weight: 600;
  letter-spacing: -.5px;
  padding: 8px 14px 28px
}

.sidebar-logo-full {
  display: inline
}

.sidebar-logo-short {
  display: none
}

.sidebar-nav {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1
}

.sidebar-link {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px 16px;
  border-radius: var(--radius-md);
  font-size: 15px;
  font-weight: 600;
  color: var(--text3);
  cursor: pointer;
  transition: all .2s cubic-bezier(0.4, 0, 0.2, 1);
}

.sidebar-link:hover {
  background: var(--surface-raised);
  color: var(--text);
  transform: translateX(4px);
}

.sidebar-link.active {
  font-weight: 800;
  color: var(--text);
  background: var(--surface-raised);
}

.sidebar-link svg {
  width: 22px;
  height: 22px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
  flex-shrink: 0;
  transition: stroke-width .2s ease;
}

.sidebar-link.active svg {
  stroke-width: 2;
}

.sidebar-link.active svg {
  stroke-width: 1.5
}

.sidebar-btn {
  margin-top: 24px;
  width: 100%;
  padding: 12px;
  border-radius: var(--radius-full);
  background: var(--accent);
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  text-align: center;
  cursor: pointer;
  transition: all .18s cubic-bezier(.4, 0, .2, 1);
  box-shadow: var(--shadow-sm)
}

.sidebar-btn:hover {
  opacity: .88;
  box-shadow: var(--shadow)
}

.sidebar-btn:active {
  transform: scale(.98)
}

.sidebar-user {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: background .15s;
  margin-top: 16px;
  border: 1px solid transparent
}

.sidebar-user:hover {
  background: var(--bg);
  border-color: var(--border)
}

/* Right panel */
.desktop-right {
  display: none;
  position: fixed;
  top: 0;
  width: 280px;
  height: 100vh;
  padding: 84px 20px;
  overflow-y: auto;
  border-left: none;
  background: var(--surface)
}

.right-section {
  margin-bottom: 32px
}

.right-title {
  font-size: 11px;
  font-weight: 700;
  margin-bottom: 16px;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--text3)
}

.right-user {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 10px;
  margin: -1px -10px;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all .15s
}

.right-user:hover {
  background: var(--bg)
}

.right-rank {
  width: 20px;
  font-size: 12px;
  font-weight: 700;
  color: var(--text3);
  text-align: center;
  flex-shrink: 0
}

.right-stats {
  font-size: 11px;
  color: var(--text3)
}

.right-acc {
  font-weight: 700;
  color: var(--text)
}

@media(min-width:1080px) {
  .desktop-sidebar {
    display: flex;
    left: calc(50% - var(--maxw)/2 - 220px)
  }

  .desktop-right {
    display: block;
    left: calc(50% + var(--maxw)/2)
  }

  .bottom-nav {
    display: none !important
  }

  .fab {
    display: none !important
  }

  .app {
    max-width: var(--maxw);
    margin: 0 auto
  }

  .header-row .logo {
    display: none
  }

  .logo-full {
    display: inline
  }

  .logo-short {
    display: none
  }

  .header-actions-mobile {
    display: none !important
  }

  .header-actions-desktop {
    display: flex !important
  }

  #heroBlock {
    padding: 32px 0 24px !important
  }

  .hero-title {
    font-size: 32px !important;
    font-weight: 800 !important;
    letter-spacing: -1.5px !important;
    line-height: 1.05 !important;
    text-transform: uppercase !important;
    background: linear-gradient(to bottom, #fff 0%, #a0a0a0 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    text-shadow: 0 10px 30px rgba(0,0,0,0.3);
  }

  .header {
    padding-top: 16px
  }
}

.hero-title {
  font-size: 26px;
  font-weight: 800;
  letter-spacing: -1px;
  line-height: 1.1;
  text-transform: uppercase;
  color: var(--text);
}

@media(min-width:1080px) {
  #page-home .header {
    display: flex;
    flex-direction: column;
    padding-top: 0
  }

  #page-home .header>#tickerWrap {
    order: -1;
    margin-top: 0
  }

  #page-home .header>.header-row {
    padding-top: 8px
  }
}

/* Medium breakpoint removed — mobile layout now stretches up to 1079px */

/* Avatar */
.avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--accent2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 13px;
  overflow: hidden;
  flex-shrink: 0;
  border: 1px solid var(--border);
  box-shadow: var(--shadow-sm);
  transition: transform .2s ease;
}

.avatar:hover {
  transform: scale(1.05);
}

.avatar.sm {
  width: 30px;
  height: 30px;
  font-size: 12px
}

.avatar.lg {
  width: 68px;
  height: 68px;
  font-size: 26px;
  box-shadow: 0 0 0 2.5px var(--surface), 0 0 0 4px rgba(0, 0, 0, .06), var(--shadow-sm)
}

.avatar.xl {
  width: 84px;
  height: 84px;
  font-size: 32px;
  box-shadow: 0 0 0 3px var(--surface), 0 0 0 4.5px rgba(0, 0, 0, .06), var(--shadow)
}

.avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover
}

/* Tabs */
.tabs {
  display: flex;
  border-bottom: 1px solid var(--border);
  background: var(--surface);
}

.tab {
  flex: 1;
  padding: 16px 0;
  text-align: center;
  font-size: 13px;
  font-weight: 600;
  color: var(--text3);
  position: relative;
  transition: color .2s ease;
  letter-spacing: .01em
}

.tab:hover {
  color: var(--text2)
}

.tab.active {
  color: var(--text);
}

.tab.active::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 40px;
  height: 3px;
  background: var(--accent);
  border-radius: 2px 2px 0 0;
}

/* Bottom Nav */
.bottom-nav {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: rgba(255, 255, 255, .88);
  -webkit-backdrop-filter: blur(24px) saturate(200%);
  backdrop-filter: blur(24px) saturate(200%);
  display: flex;
  justify-content: space-around;
  padding: 12px 0 4px;
  padding-bottom: max(10px, env(safe-area-inset-bottom));
  border-top: 1px solid var(--border-light);
  z-index: 200
}

.nav-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 8px 12px;
  color: var(--text3);
  transition: all .2s ease;
}

.nav-item.active {
  color: var(--text);
}

.nav-item svg {
  width: 24px;
  height: 24px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
  transition: all .2s ease;
}

.nav-item.active svg {
  stroke-width: 2.2;
  transform: translateY(-2px);
}

.nav-item span {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.02em;
}

.nav-item.active span {
  font-weight: 800;
}

/* Cookie consent pill — floats above bottom nav, inline with FAB on mobile */
.cookie-banner {
  position: fixed;
  bottom: calc(80px + max(12px, env(safe-area-inset-bottom)));
  left: 16px;
  z-index: 200;
  padding: 10px 14px;
  background: var(--surface-raised);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  display: none;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  color: var(--text2);
  font-family: var(--font);
  line-height: 1.3;
  box-shadow: 0 4px 20px rgba(0, 0, 0, .25);
  max-width: calc(100vw - 90px)
}

.cookie-banner.visible {
  display: flex
}

.cookie-banner a {
  color: var(--text);
  text-decoration: underline;
  text-underline-offset: 2px
}

.cookie-actions {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-shrink: 0
}

.cookie-btn-accept {
  padding: 5px 12px;
  border-radius: 16px;
  background: var(--accent);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  font-family: var(--font);
  cursor: pointer;
  border: none;
  white-space: nowrap;
  transition: opacity .15s
}

.cookie-btn-accept:hover {
  opacity: .85
}

.cookie-btn-decline {
  padding: 5px 6px;
  font-size: 10px;
  color: var(--text3);
  background: none;
  border: none;
  cursor: pointer;
  font-family: var(--font);
  white-space: nowrap
}

.cookie-btn-decline:hover {
  color: var(--text2)
}

html.dark .cookie-banner {
  background: #16181c;
  border-color: #2f3336;
  box-shadow: 0 4px 20px rgba(0, 0, 0, .5)
}

html.dark .cookie-btn-accept {
  background: #e7e9ea;
  color: #0f1419
}

@media(min-width:1080px) {
  .cookie-banner {
    left: calc(50% - var(--maxw)/2 + 16px);
    bottom: 24px;
    max-width: 320px
  }
}

/* Cards */
/* Gold Option: Market sections & threaded lists */
.market-section {
  border-bottom: 8px solid var(--accent2)
}

.market-section:last-child {
  border-bottom: none
}

.market-header {
  padding: 20px 20px 12px;
  border-bottom: 1px solid var(--border-light);
  display: flex;
  justify-content: space-between;
  align-items: center
}

.market-title {
  font-size: 14px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--text)
}

.market-count {
  font-size: 13px;
  color: var(--text3)
}

.pick-group {
  border-bottom: 1px solid var(--border-light)
}

.pick-group:last-child {
  border-bottom: none
}

.pick-row {
  padding: 16px 20px 16px 36px;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  transition: background .2s
}

.pick-row:hover {
  background: rgba(255, 255, 255, 0.03)
}

.pick-title {
  font-size: 14px;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 8px
}

.pick-title.secondary {
  font-weight: 500;
  opacity: .9
}

.pick-meta {
  font-size: 13px;
  color: var(--text3);
  margin-top: 4px;
  display: flex;
  align-items: center;
  gap: 8px
}

.badge {
  background: var(--accent2);
  border: 1px solid var(--border);
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 600;
  color: var(--text)
}

.badge.green {
  background: rgba(0, 186, 124, .15);
  color: var(--green);
  border-color: transparent
}

.chevron {
  width: 16px;
  height: 16px;
  stroke: var(--text3);
  fill: none;
  stroke-width: 1.5;
  stroke-linecap: round;
  transition: transform .2s
}

.pick-group.expanded .chevron {
  transform: rotate(180deg)
}

.cappers-drawer {
  display: none;
  padding: 0 20px 16px 52px;
  position: relative
}

.pick-group.expanded .cappers-drawer {
  display: block
}

/* The Thread Line */
.cappers-drawer::before {
  content: '';
  position: absolute;
  top: 0;
  bottom: 16px;
  left: 36px;
  width: 2px;
  background: var(--border);
  border-radius: 2px
}

/* Capper Block & Inline Reasoning */
.capper-block {
  padding: 14px 0;
  border-top: 1px solid var(--border-light)
}

.capper-block:first-child,
.capper-block.first {
  border-top: none;
  padding-top: 8px
}

.capper-header {
  display: flex;
  align-items: center;
  gap: 12px
}

.capper-info {
  flex: 1
}

.capper-name {
  font-size: 14px;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 6px
}

.pro-badge {
  font-size: 9px;
  background: rgba(167, 139, 250, .15);
  color: #a78bfa;
  padding: 2px 6px;
  border-radius: 4px;
  text-transform: uppercase;
  letter-spacing: .5px
}

.capper-stats {
  font-size: 12px;
  color: var(--text3);
  margin-top: 2px
}

.btn-subscribe {
  background: var(--text);
  border: none;
  color: var(--bg);
  font-weight: 600;
  font-size: 12px;
  padding: 6px 14px;
  border-radius: var(--radius-full);
  cursor: pointer;
  flex-shrink: 0;
  font-family: var(--font)
}

.btn-follow {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--text);
  font-weight: 600;
  font-size: 12px;
  padding: 6px 14px;
  border-radius: var(--radius-full);
  cursor: pointer;
  flex-shrink: 0;
  font-family: var(--font)
}

.reasoning-text {
  font-size: 13px;
  color: var(--text);
  opacity: .85;
  line-height: 1.5;
  margin-top: 8px;
  margin-left: 44px;
  white-space: pre-wrap
}

/* "See More" alternate lines expander */
.extra-lines-container {
  display: none
}

.extra-lines-container.expanded {
  display: block;
  animation: fadeIn .3s cubic-bezier(0.4, 0, 0.2, 1)
}

.btn-see-more {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  width: 100%;
  padding: 16px;
  font-size: 13px;
  font-weight: 500;
  color: var(--text3);
  background: transparent;
  border: none;
  border-top: 1px solid var(--border-light);
  cursor: pointer;
  transition: color .2s, background .2s;
  font-family: var(--font)
}

.btn-see-more:hover {
  color: var(--text);
  background: rgba(255, 255, 255, 0.02)
}

.btn-see-more svg {
  width: 16px;
  height: 16px;
  stroke: currentColor;
  transition: transform .2s
}

.btn-see-more.expanded svg {
  transform: rotate(180deg)
}

/* ─── Game-page Players tab — flat row chrome (replaces gold .player-card) ─── */
.nx-team-h {
  padding: 16px 20px 8px;
  border-bottom: 1px solid var(--border-light);
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}
.nx-team-title {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--text);
}
.nx-team-count {
  font-size: 12px;
  color: var(--text3);
}
.nx-player-row {
  padding: 14px 20px;
  border-bottom: 1px solid var(--border-light);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  cursor: pointer;
  transition: background .15s
}
.nx-player-row:hover { background: rgba(255, 255, 255, .02) }
.nx-player-row.open { border-bottom: none }
.nx-player-l { flex: 1; min-width: 0 }
.nx-player-headline {
  font-size: 14px;
  font-weight: 600;
  letter-spacing: -.1px;
}
.nx-jersey {
  color: var(--text3);
  font-weight: 500;
  margin-right: 6px;
}
.nx-player-meta {
  font-size: 11px;
  color: var(--text3);
  margin-top: 3px;
}
.nx-player-r {
  flex-shrink: 0;
  text-align: right;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 4px;
}
.nx-player-count {
  font-size: 13px;
  font-weight: 600;
  color: var(--text2);
  line-height: 1;
}
.nx-see-link {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: 12px;
  font-weight: 600;
  color: var(--blue);
  white-space: nowrap;
  cursor: pointer;
}
.nx-see-link svg {
  transition: transform .2s;
}
.nx-player-row.open .nx-see-link svg {
  transform: rotate(180deg);
}
.nx-player-drawer {
  background: rgba(255, 255, 255, .012);
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border-light);
}
/* Stat tabs inside the drawer reuse production .tabs/.tab chrome —
   override only sizing/margin so they fit the drawer width. */
.nx-stat-tabs {
  margin: 0 0 4px 0;
}
.nx-stat-tabs .tab {
  padding: 11px 0;
  font-size: 12px;
}
.nx-stat-tabs .tab.active::after {
  width: 24px;
}
@media (max-width: 380px) {
  .nx-see-link { font-size: 11px }
}

/* ─── Game-page Lines tab — nested expand chrome ─── */
.nx-row {
  padding: 14px 20px;
  display: flex;
  align-items: center;
  gap: 12px;
  cursor: pointer;
  transition: background .15s;
}
.nx-row:hover { background: rgba(255, 255, 255, .02) }
.nx-row.open { border-bottom: 1px solid var(--border-light) }
.nx-row-l { flex: 1; min-width: 0 }
.nx-eyebrow {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--text3);
  margin-bottom: 4px;
}
.nx-headline {
  font-size: 16px;
  font-weight: 700;
  letter-spacing: -.2px;
}
.nx-meta {
  font-size: 11px;
  color: var(--text3);
  margin-top: 3px;
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.nx-row-r {
  flex-shrink: 0;
  text-align: right;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 4px;
}
.nx-pct-row {
  display: inline-flex;
  align-items: baseline;
  gap: 5px;
  line-height: 1;
}
.nx-pct-big {
  font-size: 18px;
  font-weight: 800;
  color: var(--green);
  line-height: 1;
  letter-spacing: -.4px;
}
.nx-pct-label {
  font-size: 12px;
  font-weight: 500;
  color: var(--text3);
  line-height: 1;
  white-space: nowrap;
}
.nx-row.open .nx-see-link svg,
.nx-line-row.open .nx-see-link svg {
  transform: rotate(180deg);
}

/* Tied state — closed market shows two stacked headlines + amber pill */
.nx-tied-stack {
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.nx-tied-line {
  font-size: 14px;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  max-width: 240px;
}
.nx-tied-line .pct {
  font-size: 13px;
  font-weight: 700;
  color: var(--green);
}
.nx-tied-pill {
  font-size: 9px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .4px;
  padding: 2px 6px;
  border-radius: 3px;
  background: rgba(245, 158, 11, .12);
  color: #f59e0b;
}

/* +N locked pill in the closed-market meta */
.nx-locked-pill {
  font-size: 9px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .4px;
  padding: 2px 6px;
  border-radius: 3px;
  background: rgba(167, 139, 250, .12);
  color: var(--purple);
  display: inline-flex;
  align-items: center;
  gap: 3px;
}
.nx-locked-pill svg {
  width: 9px;
  height: 9px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
}

/* Inner line list (level-2 expand) */
.nx-line-list {
  background: rgba(255, 255, 255, .012);
}
.nx-line-row {
  padding: 12px 20px 12px 32px;
  display: flex;
  align-items: center;
  gap: 12px;
  border-bottom: 1px solid var(--border-light);
  cursor: pointer;
  position: relative;
  transition: background .15s;
}
.nx-line-row:hover { background: rgba(255, 255, 255, .02) }
.nx-line-row:last-child { border-bottom: none }
.nx-line-row.consensus::before {
  content: '';
  position: absolute;
  left: 20px;
  top: 12px;
  bottom: 12px;
  width: 2px;
  background: var(--green);
  border-radius: 1px;
}
.nx-line-row.tied-top::before {
  content: '';
  position: absolute;
  left: 20px;
  top: 12px;
  bottom: 12px;
  width: 2px;
  background: #f59e0b;
  border-radius: 1px;
}
.nx-line-row.locked { cursor: default }
.nx-line-row.locked::before {
  content: '';
  position: absolute;
  left: 20px;
  top: 12px;
  bottom: 12px;
  width: 2px;
  background: var(--purple);
  border-radius: 1px;
  opacity: .5;
}
.nx-line-l { flex: 1; min-width: 0 }
.nx-line-pick {
  font-size: 14px;
  font-weight: 600;
  letter-spacing: -.1px;
}
.nx-line-pick.alt {
  color: var(--text2);
  font-weight: 500;
}
.nx-line-pick.locked {
  color: var(--text2);
  display: flex;
  align-items: center;
  gap: 6px;
}
.nx-line-pick.locked svg {
  width: 12px;
  height: 12px;
  stroke: var(--purple);
  fill: none;
  stroke-width: 1.8;
  flex-shrink: 0;
}
.nx-line-meta {
  font-size: 11px;
  color: var(--text3);
  margin-top: 2px;
}
.nx-line-r {
  flex-shrink: 0;
  text-align: right;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 3px;
}
.nx-line-pct {
  font-size: 14px;
  font-weight: 700;
  color: var(--green);
  font-feature-settings: 'tnum' 1;
  line-height: 1;
}
.nx-line-pct.alt {
  color: var(--text2);
  font-weight: 600;
}

/* Tipster drawer (level-3 expand) */
.nx-tipster-list {
  padding: 6px 20px 12px 44px;
  background: rgba(255, 255, 255, .008);
  border-bottom: 1px solid var(--border-light);
}

/* Locked Unlock pill — replaces the See/Hide link on locked rows */
.nx-unlock-btn {
  padding: 5px 10px;
  border-radius: 5px;
  background: rgba(167, 139, 250, .10);
  border: 0.5px solid rgba(167, 139, 250, .32);
  color: var(--purple);
  font-size: 11px;
  font-weight: 700;
  font-family: var(--font);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  text-transform: uppercase;
  letter-spacing: .3px;
  transition: background .15s, border-color .15s;
}
.nx-unlock-btn:hover {
  background: rgba(167, 139, 250, .16);
  border-color: var(--purple);
}

/* Legacy .player-card (unused but kept for safety, in case some other
   code path renders one). The block below was orphaned by an earlier
   refactor — wrapping it back to avoid invalid CSS. */
.player-card {
  margin: 16px 20px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
  -webkit-transform: translateZ(0);
  -webkit-mask-image: -webkit-radial-gradient(white, black);
  position: relative
}

/* Dynamic Header Backgrounds */
.player-header {
  padding: 20px;
  display: flex;
  align-items: center;
  gap: 12px;
  cursor: pointer
}

.player-number {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 800;
  flex-shrink: 0
}

.player-name {
  font-size: 16px;
  font-weight: 700
}

.player-meta {
  font-size: 12px;
  color: var(--text3)
}

/* Clean Underline Tabs */
.player-tabs {
  display: flex;
  border-bottom: 1px solid var(--border);
  overflow-x: auto;
  scrollbar-width: none;
  padding-left: 20px
}

.player-tabs::-webkit-scrollbar {
  display: none
}

.stat-tab {
  padding: 12px 0;
  margin-right: 24px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text3);
  cursor: pointer;
  position: relative;
  white-space: nowrap;
  margin-bottom: -1px;
  display: flex;
  align-items: center;
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  font-family: var(--font)
}

.stat-tab.active {
  color: var(--text);
  border-bottom: 2px solid var(--text)
}

/* Count Pill inside the tab */
.count-pill {
  background: var(--border);
  color: var(--text3);
  padding: 2px 6px;
  border-radius: var(--radius-full);
  font-size: 10px;
  margin-left: 6px
}

.stat-tab.active .count-pill {
  background: var(--accent2);
  color: var(--text)
}

.gold-list .pick-group {
  border-bottom: 1px solid var(--border-light)
}

.gold-list .pick-group:last-child {
  border-bottom: none
}

/* Player Search Bar */
.player-search-container {
  padding: 16px 20px 0
}

.player-search-wrapper {
  position: relative;
  display: flex;
  align-items: center
}

.player-search-icon {
  position: absolute;
  left: 12px;
  width: 16px;
  height: 16px;
  stroke: var(--text3);
  fill: none;
  stroke-width: 1.5;
  pointer-events: none
}

.player-search-input {
  width: 100%;
  background: var(--bg);
  border: 1px solid var(--border);
  color: var(--text);
  padding: 12px 12px 12px 36px;
  border-radius: var(--radius);
  font-family: var(--font);
  font-size: 14px;
  transition: all .2s
}

.player-search-input:focus {
  outline: none;
  border-color: var(--text3);
  background: var(--surface)
}

.player-search-input::placeholder {
  color: var(--text3)
}

.no-results-msg {
  display: none;
  padding: 40px 20px;
  text-align: center;
  color: var(--text3);
  font-size: 14px
}

.game-card {
  padding: 18px 24px;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  transition: background .18s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
  overflow: hidden;
}

.game-card:last-child {
  border-bottom: none
}

.game-card:hover {
  background: var(--surface-raised)
}

.game-card:active {
  background: var(--bg);
  transform: scale(0.995);
}

.allgames-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px
}

@media(min-width:540px) {
  .allgames-grid {
    grid-template-columns: 1fr 1fr
  }
}

.game-row {
  display: flex;
  align-items: center;
  justify-content: space-between
}

.team-info {
  display: flex;
  align-items: center;
  gap: 10px
}

.team-logo {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 700;
  font-family: var(--font);
  color: #fff;
  border: 1px solid rgba(255, 255, 255, .08);
  background: rgba(255, 255, 255, .04);
  flex-shrink: 0;
  box-shadow: 0 1px 4px rgba(0, 0, 0, .15);
  letter-spacing: -.2px
}

.team-name {
  font-weight: 600;
  font-size: 14px
}

.team-record {
  font-size: 12px;
  color: var(--text3);
  margin-left: 6px
}

.game-score {
  font-size: 18px;
  font-weight: 700;
  min-width: 28px;
  text-align: right
}

.game-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 8px
}

.game-status {
  font-size: 12px;
  color: var(--text3);
  font-weight: 500
}

.game-status.live {
  color: var(--red);
  font-weight: 600
}

.league-tag {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--text3);
  background: var(--surface-raised);
  padding: 3px 9px;
  border-radius: 6px;
  border: 1px solid rgba(0, 0, 0, .04)
}

/* League text — colored, no pill */
.league-text {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px
}

.league-text.nba {
  color: #c9631a
}

.league-text.nfl {
  color: #1a7fc9
}

.league-text.mlb {
  color: #b91c1c
}

.league-text.nhl {
  color: #0e7490
}

.league-text.mls {
  color: #16a34a
}

.league-text.epl {
  color: #7c3aed
}

.league-text.la_liga {
  color: #e85d04
}

.league-text.serie_a {
  color: #1d4ed8
}

.league-text.bundesliga {
  color: #dc2626
}

.league-text.ligue_1 {
  color: #0369a1
}

.league-text.champions_league {
  color: #1e40af
}

.league-text.default {
  color: var(--blue)
}

html.dark .league-text.nba {
  color: #f59e0b
}

html.dark .league-text.nfl {
  color: #60a5fa
}

html.dark .league-text.mlb {
  color: #f87171
}

html.dark .league-text.nhl {
  color: #22d3ee
}

html.dark .league-text.mls {
  color: #4ade80
}

html.dark .league-text.epl {
  color: #a78bfa
}

html.dark .league-text.la_liga {
  color: #fb923c
}

html.dark .league-text.serie_a {
  color: #60a5fa
}

html.dark .league-text.bundesliga {
  color: #f87171
}

html.dark .league-text.ligue_1 {
  color: #38bdf8
}

html.dark .league-text.champions_league {
  color: #818cf8
}

html.dark .league-text.default {
  color: #1d9bf0
}

/* New Game Cell */
.gc-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px
}

.gc-time {
  font-size: 11px;
  font-weight: 500;
  color: var(--text3)
}

.gc-time.live {
  color: var(--red);
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 4px
}

.gc-teams {
  display: flex;
  flex-direction: column;
  gap: 8px
}

.gc-team-row {
  display: flex;
  align-items: center;
  gap: 10px
}

.gc-team-name {
  font-size: 14px;
  font-weight: 600;
  flex: 1;
  min-width: 0;
  overflow: hidden;
  -webkit-transform: translateZ(0);
  -webkit-mask-image: -webkit-radial-gradient(white, black);
  text-overflow: ellipsis;
  white-space: nowrap
}

.gc-team-record {
  font-size: 11px;
  color: var(--text3);
  margin-left: 2px;
  font-weight: 400
}

.gc-score {
  font-size: 16px;
  font-weight: 700;
  min-width: 26px;
  text-align: right;
  letter-spacing: -.3px;
  flex-shrink: 0
}

.gc-score.winning {
  color: var(--text)
}

.gc-score.losing {
  color: var(--text3)
}

.gc-pick-count {
  font-size: 13px;
  color: var(--text2);
  font-weight: 500;
  margin-top: 16px;
  letter-spacing: -0.1px;
}

.gc-pick-count b {
  font-weight: 700;
  color: var(--text)
}

.gc-pick-preview {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 10px;
  padding: 10px 12px;
  background: var(--instrument-bg);
  border-radius: 8px
}

.gc-pick-avatar {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--surface-raised);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 9px;
  font-weight: 700;
  flex-shrink: 0;
  border: 1px solid var(--border)
}

.gc-pick-body {
  flex: 1;
  min-width: 0
}

.gc-pick-label {
  font-size: 9px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .3px;
  color: var(--text3);
  line-height: 1;
  margin-bottom: 2px
}

.gc-pick-text {
  font-size: 12px;
  font-weight: 600;
  color: var(--text);
  overflow: hidden;
  -webkit-transform: translateZ(0);
  -webkit-mask-image: -webkit-radial-gradient(white, black);
  text-overflow: ellipsis;
  white-space: nowrap
}

.gc-pick-odds {
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
  flex-shrink: 0;
  letter-spacing: -.2px
}

.gc-bottom {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 14px
}

.gc-pick-type {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 6px;
  background: var(--surface-raised);
  color: var(--text2);
  border: 1px solid rgba(0, 0, 0, .04)
}

.gc-pick-type .dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  flex-shrink: 0
}

.gc-pick-type .dot.pre {
  background: var(--blue)
}

.gc-pick-type .dot.live {
  background: var(--red)
}

.gc-cta {
  font-size: 12px;
  color: var(--green);
  font-weight: 600;
  margin-left: auto;
  flex-shrink: 0
}

.live-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--red);
  display: inline-block;
  animation: livePulse 1.5s cubic-bezier(0.4, 0, 0.2, 1) infinite
}

@keyframes livePulse {

  0%,
  100% {
    opacity: 1
  }

  50% {
    opacity: .35
  }
}

html.dark .gc-pick-type {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, .1)
}

/* Feed Pick Card */
.pred-card {
  padding: 18px 20px;
  border-bottom: 1px solid var(--border);
  transition: background .18s cubic-bezier(0.4, 0, 0.2, 1)
}

.pred-card:last-child {
  border-bottom: none
}

.pred-card:hover {
  background: rgba(0, 0, 0, .01)
}

html.dark .pred-card:hover {
  background: rgba(255, 255, 255, .02)
}

.pred-top {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px
}

.pred-identity {
  display: flex;
  align-items: center;
  gap: 6px;
  flex: 1;
  min-width: 0
}

.pred-user {
  font-weight: 600;
  font-size: 14px;
  cursor: pointer
}

.pred-view-profile {
  font-size: 11px;
  color: var(--blue);
  font-weight: 500;
  cursor: pointer
}

.pred-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 3px;
  flex-shrink: 0
}

.pred-time-text {
  font-size: 11px;
  font-weight: 500;
  color: var(--text3);
  text-transform: uppercase
}

.pred-badge {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .4px;
  padding: 3px 8px;
  border-radius: 5px
}

.pred-badge.pre {
  background: #e4ebf5;
  color: #4b5b7a
}

.pred-badge.live {
  background: #fef2f2;
  color: #b91c1c
}

.pred-badge.sub {
  background: #f5edff;
  color: #6d28d9
}

.pred-game-line {
  display: flex;
  align-items: center;
  gap: 5px;
  margin: 8px 0;
  font-size: 11px;
  color: var(--text3)
}

.pred-game-line .league-text {
  font-size: 10px
}

.pred-game-teams {
  font-weight: 500
}

.pred-pick-box {
  background: var(--surface-raised);
  border: 1px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
  transition: border-color .2s ease;
}

.pred-pick-box:hover {
  border-color: var(--border-strong);
}

.pred-pick-content {
  padding: 12px 14px;
  flex: 1;
  min-width: 0
}

.pred-pick-type {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .3px;
  color: var(--text3);
  margin-bottom: 2px
}

.pred-pick-text {
  font-size: 14px;
  font-weight: 700
}

.pred-pick-reason {
  font-size: 12px;
  color: var(--text2);
  line-height: 1.5;
  margin: 0 14px;
  border-top: 1px solid var(--border-light);
  padding: 0;
}
.pred-pick-reason .reason-toggle {
  display: flex;
  align-items: center;
  gap: 5px;
  width: 100%;
  padding: 8px 0;
  font-size: 12px;
  font-weight: 600;
  color: var(--text3);
  background: none;
  border: none;
  cursor: pointer;
  font-family: var(--font);
}
.pred-pick-reason .reason-toggle:hover { color: var(--text2) }
.pred-pick-reason .reason-toggle svg {
  width: 10px;
  height: 10px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
  flex-shrink: 0;
}
.pred-pick-reason .reason-toggle.open svg { transform: rotate(90deg) }
.pred-pick-reason .reason-body {
  display: none;
  font-size: 12px;
  color: var(--text2);
  line-height: 1.6;
  padding: 0 0 10px 15px;
  white-space: pre-wrap;
  word-break: break-word;
}

.pred-pick-odds {
  font-size: 16px;
  font-weight: 700;
  color: var(--text);
  flex-shrink: 0;
  padding-top: 14px;
  letter-spacing: -.2px
}

/* Locked pick blocker */
.pred-locked {
  border-radius: 8px;
  overflow: hidden;
  -webkit-transform: translateZ(0);
  -webkit-mask-image: -webkit-radial-gradient(white, black);
  border: 1px solid var(--border)
}

.pred-locked-blur {
  padding: 10px 12px;
  filter: blur(8px);
  user-select: none;
  pointer-events: none
}

.pred-locked-blur-type {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .3px;
  color: var(--text3);
  margin-bottom: 2px
}

.pred-locked-blur-text {
  font-size: 14px;
  font-weight: 700;
  color: var(--text)
}

.pred-locked-overlay {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  background: var(--section-header-bg);
  border-top: 1px solid var(--border)
}

html.dark .pred-locked-overlay {
  background: var(--section-header-bg);
  border-top-color: var(--border)
}

.pred-locked-icon {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: rgba(120, 86, 255, .08);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0
}

.pred-locked-icon svg {
  width: 16px;
  height: 16px;
  stroke: #a78bfa;
  fill: none;
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round
}

.pred-locked-info {
  flex: 1;
  min-width: 0
}

.pred-locked-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--text)
}

.pred-locked-sub {
  font-size: 11px;
  color: var(--text3);
  margin-top: 1px
}

.pred-locked-btn {
  flex-shrink: 0;
  padding: 6px 14px;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 700;
  font-family: var(--font);
  cursor: pointer;
  border: none;
  background: var(--accent);
  color: #fff;
  transition: opacity .15s
}

.pred-locked-btn:hover {
  opacity: .85
}

html.dark .pred-locked-btn {
  background: #e7e9ea;
  color: #0f1419
}

.pred-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 8px
}

.pred-view-game {
  font-size: 11px;
  color: var(--blue);
  font-weight: 500;
  cursor: pointer
}

.pred-actions {
  display: flex;
  gap: 16px;
  align-items: center
}

.pred-action {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 13px;
  color: var(--text3);
  transition: color .15s;
  font-weight: 500;
  background: none;
  border: none;
  cursor: pointer;
  font-family: var(--font)
}

.pred-action:hover {
  color: var(--text2)
}

.pred-action svg {
  width: 15px;
  height: 15px
}

.pred-action.liked {
  color: var(--green)
}

.pred-action.disliked {
  color: var(--red)
}

/* Pick Reactions & Comments */
.pick-actions-row {
  display: flex;
  align-items: center;
  gap: 2px;
  margin: 10px 0 0 36px;
  flex-wrap: wrap
}

.pick-react-btn {
  display: flex;
  align-items: center;
  gap: 3px;
  padding: 4px 8px;
  border-radius: 16px;
  font-size: 12px;
  font-weight: 500;
  color: var(--text3);
  background: transparent;
  border: 1px solid transparent;
  cursor: pointer;
  transition: all .18s cubic-bezier(0.4, 0, 0.2, 1);
  -webkit-tap-highlight-color: transparent;
  font-family: var(--font)
}

.pick-react-btn:hover {
  background: var(--accent2);
  border-color: var(--border)
}

.pick-react-btn:active {
  transform: scale(.95)
}

.pick-react-btn.active {
  background: var(--accent2);
  border-color: var(--border-strong);
  color: var(--text);
  font-weight: 600
}

.pick-react-btn.active.react-like {
  color: var(--green);
  background: rgba(5, 150, 105, .08);
  border-color: rgba(5, 150, 105, .2)
}

.pick-react-btn.active.react-dislike {
  color: var(--red);
  background: rgba(224, 49, 49, .08);
  border-color: rgba(224, 49, 49, .2)
}

html.dark .pick-react-btn.active.react-like {
  background: rgba(0, 186, 124, .1);
  border-color: rgba(0, 186, 124, .25)
}

html.dark .pick-react-btn.active.react-dislike {
  background: rgba(244, 33, 46, .1);
  border-color: rgba(244, 33, 46, .25)
}

.pick-react-btn .react-emoji {
  font-size: 14px;
  line-height: 1
}

.pick-react-btn .react-count {
  font-size: 11px;
  font-weight: 600;
  min-width: 8px;
  text-align: center
}

.pick-comment-btn {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 4px 8px;
  border-radius: 16px;
  font-size: 12px;
  font-weight: 500;
  color: var(--text3);
  background: transparent;
  border: 1px solid transparent;
  cursor: pointer;
  transition: all .18s cubic-bezier(0.4, 0, 0.2, 1);
  font-family: var(--font)
}

.pick-comment-btn:hover {
  background: var(--accent2);
  border-color: var(--border)
}

.pick-comment-btn svg {
  width: 14px;
  height: 14px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round
}

.pick-comments {
  margin: 6px 0 0 36px;
  border-top: 1px solid var(--border-light);
  padding-top: 8px
}

.pick-comment {
  display: flex;
  gap: 8px;
  padding: 5px 0
}

.pick-comment-avatar {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--accent2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 9px;
  font-weight: 700;
  flex-shrink: 0;
  cursor: pointer
}

.pick-comment-body {
  flex: 1;
  min-width: 0
}

.pick-comment-header {
  display: flex;
  align-items: baseline;
  gap: 5px;
  margin-bottom: 1px
}

.pick-comment-name {
  font-size: 11px;
  font-weight: 600;
  cursor: pointer
}

.pick-comment-name:hover {
  text-decoration: underline
}

.pick-comment-time {
  font-size: 10px;
  color: var(--text3)
}

.pick-comment-text {
  font-size: 13px;
  line-height: 1.4;
  word-break: break-word
}

.pick-comment-delete {
  font-size: 10px;
  color: var(--text3);
  cursor: pointer;
  background: none;
  border: none;
  font-family: var(--font);
  padding: 0;
  margin-top: 1px
}

.pick-comment-delete:hover {
  color: var(--red)
}

.pick-comment-input-row {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 6px
}

.pick-comment-input {
  flex: 1;
  padding: 7px 12px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 16px;
  font-size: 13px;
  font-family: var(--font);
  transition: border-color .15s;
  color: var(--text)
}

.pick-comment-input:focus {
  border-color: var(--blue);
  box-shadow: 0 0 0 2px var(--blue-light)
}

.pick-comment-input::placeholder {
  color: var(--text3)
}

.pick-comment-send {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  cursor: pointer;
  border: none;
  transition: transform .1s
}

.pick-comment-send:active {
  transform: scale(.9)
}

.pick-comment-send svg {
  width: 12px;
  height: 12px;
  stroke: #fff;
  fill: none;
  stroke-width: 1.5
}

html.dark .pick-comment-send svg {
  stroke: #0f1419
}

@media(max-width:1079px) {
  .pick-comment-send {
    width: 32px;
    height: 32px
  }

  .pick-comment-input {
    font-size: 16px;
    padding: 8px 14px
  }
}

.pred-result {
  display: inline-block;
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .4px;
  padding: 2px 7px;
  border-radius: 5px;
  margin-left: 6px
}

.pred-result.hit {
  background: #ecfdf5;
  color: #16a34a
}

.pred-result.miss {
  background: #fef2f2;
  color: #b91c1c
}

.pred-result.pending {
  background: var(--accent2);
  color: var(--text3)
}

/* Compose */
.compose-area {
  padding: 16px 24px 12px;
  border-bottom: 1px solid var(--border-light)
}

.compose-row {
  display: flex;
  gap: 12px;
  align-items: flex-start
}

.compose-input {
  flex: 1;
  padding: 14px 18px;
  background: var(--surface-raised);
  border: 1px solid var(--border);
  border-radius: 16px;
  font-size: 15px;
  resize: none;
  min-height: 50px;
  max-height: 150px;
  transition: all .2s cubic-bezier(0.4, 0, 0.2, 1);
  cursor: text;
}

.compose-input:focus {
  border-color: var(--green);
  background: var(--surface);
  box-shadow: 0 0 0 1px var(--green);
}

.compose-input::placeholder {
  color: var(--text3);
  font-weight: 500;
}

.compose-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 8px
}

.compose-options {
  display: flex;
  gap: 8px
}

.compose-tag {
  font-size: 12px;
  padding: 4px 10px;
  border-radius: var(--radius-full);
  background: var(--bg);
  color: var(--text2);
  cursor: pointer;
  transition: all .2s
}

.compose-tag:hover {
  background: var(--accent2);
  color: var(--text)
}

.compose-tag.active {
  background: var(--accent);
  color: #fff
}

.btn {
  padding: 10px 20px;
  border-radius: var(--radius-full);
  font-size: 13px;
  font-weight: 600;
  transition: all .18s cubic-bezier(.4, 0, .2, 1);
  letter-spacing: .01em
}

.btn:active {
  transform: scale(.97)
}

.btn-primary {
  background: var(--accent);
  color: #fff;
  box-shadow: var(--shadow-sm)
}

.btn-primary:hover {
  background: #27272b
}

.btn-primary:active {
  background: #1f1f23;
  transform: scale(.97)
}

.btn-outline {
  border: 1.5px solid var(--border-strong);
  color: var(--text2);
  background: var(--surface);
  box-shadow: var(--shadow-xs)
}

.btn-outline:hover {
  border-color: var(--text3);
  background: var(--surface-raised)
}

.btn-sm {
  padding: 6px 16px;
  font-size: 12px
}

.btn-green {
  background: var(--green);
  color: #fff;
  box-shadow: var(--shadow-sm)
}

.btn-green:hover {
  opacity: .9
}

.btn-red {
  background: var(--red);
  color: #fff;
  box-shadow: var(--shadow-sm)
}

.btn-red:hover {
  opacity: .9
}

/* Filters */
.filter-row {
  display: flex;
  gap: 8px;
  padding: 10px 0 12px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch
}

.filter-row::-webkit-scrollbar {
  display: none
}

.filter-pill {
  padding: 6px 12px;
  border-radius: var(--radius-full);
  font-size: 12px;
  font-weight: 500;
  white-space: nowrap;
  background: transparent;
  color: var(--text3);
  transition: all .18s cubic-bezier(0.4, 0, 0.2, 1);
  flex-shrink: 0;
  border: 1px solid var(--border)
}

.filter-pill:hover {
  color: var(--text2);
  border-color: var(--border-strong)
}

.filter-pill.active {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent)
}

/* Profile */
.profile-header {
  padding: 28px 24px;
  text-align: center
}

.profile-name {
  font-family: var(--display);
  font-size: 22px;
  font-weight: 600;
  margin-top: 12px;
  letter-spacing: -.4px
}

.profile-handle {
  color: var(--text3);
  font-size: 13px;
  margin-top: 2px;
  font-weight: 500
}

.profile-bio {
  font-size: 14px;
  color: var(--text2);
  margin-top: 10px;
  max-width: 300px;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.5
}

.profile-stats {
  display: flex;
  justify-content: center;
  gap: 32px;
  margin-top: 16px
}

.stat {
  text-align: center
}

.stat-num {
  font-size: 20px;
  font-weight: 700;
  letter-spacing: -.5px
}

.stat-label {
  font-size: 10px;
  color: var(--text3);
  text-transform: uppercase;
  letter-spacing: .5px;
  font-weight: 500;
  margin-top: 1px
}

.profile-actions {
  display: flex;
  gap: 8px;
  justify-content: center;
  margin-top: 16px
}

.follow-btn {
  padding: 8px 20px;
  border-radius: var(--radius-full);
  font-size: 13px;
  font-weight: 600;
  transition: all .18s cubic-bezier(.4, 0, .2, 1)
}

.follow-btn:active {
  transform: scale(.97)
}

.follow-btn.not-following {
  background: var(--accent);
  color: #fff;
  font-weight: 700;
  border: 1.5px solid var(--accent)
}

.follow-btn.following {
  background: var(--surface);
  color: var(--text2);
  border: 1.5px solid var(--border-strong)
}

.follow-btn.following:hover {
  border-color: var(--red);
  color: var(--red)
}

.follow-btn.not-following {
  background: var(--accent);
  color: #fff;
  box-shadow: var(--shadow-sm)
}

/* Search */
.search-container {
  padding: 12px 24px
}

.search-box {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 16px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  transition: all .15s
}

.search-box:focus-within {
  border-color: var(--blue);
  background: var(--surface);
  box-shadow: 0 0 0 3px var(--blue-light)
}

.search-box svg {
  width: 18px;
  height: 18px;
  stroke: var(--text3);
  fill: none;
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
  flex-shrink: 0
}

.search-box input {
  font-size: 14px
}

.search-box input::placeholder {
  color: var(--text3)
}

.search-dropdown {
  background: var(--surface);
  border-radius: 0 0 var(--radius) var(--radius);
  overflow: hidden;
  -webkit-transform: translateZ(0);
  -webkit-mask-image: -webkit-radial-gradient(white, black);
  display: none;
  box-shadow: var(--shadow)
}

.search-dropdown.visible {
  display: block
}

.search-item {
  padding: 14px 24px;
  display: flex;
  align-items: center;
  gap: 12px;
  cursor: pointer;
  transition: background .18s cubic-bezier(0.4, 0, 0.2, 1)
}

.search-item:hover {
  background: var(--bg)
}

.search-item-type {
  font-size: 11px;
  color: var(--text3);
  text-transform: uppercase;
  letter-spacing: .5px
}

/* Game Page */
.game-header-section {
  padding: 24px
}

.game-teams {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 24px;
  margin-bottom: 16px
}

.game-team {
  text-align: center;
  min-width: 80px
}

.game-team .team-logo {
  width: 44px;
  height: 44px;
  margin: 0 auto 8px;
  font-size: 14px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, .2)
}

.game-team .team-name {
  font-size: 14px;
  font-weight: 700
}

.game-vs {
  font-size: 12px;
  color: var(--text3);
  font-weight: 600
}

.game-score-big {
  font-size: 34px;
  font-weight: 800;
  letter-spacing: -.8px
}

.game-status-bar {
  text-align: center;
  margin-bottom: 20px
}

/* Graph placeholder */

/* ── New Game View Market Cards ── */
.gv-market { margin: 12px 16px; border-radius: var(--radius-md); border: 1px solid rgba(255,255,255,.12); overflow: hidden }
.gv-market-header { padding: 12px 14px; background: var(--instrument-bg); display: flex; align-items: center; justify-content: space-between }
.gv-market-type { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .3px }
.gv-market-count { font-size: 10px; color: var(--text3) }
.gv-market-picks { max-height: 0; overflow: hidden; transition: max-height .3s ease }
.gv-market-toggle { display: flex; align-items: center; justify-content: center; padding: 8px; font-size: 11px; font-weight: 600; color: var(--text3); cursor: pointer; gap: 4px; border-top: .5px solid var(--border-light); background: none; border-left: none; border-right: none; border-bottom: none; width: 100%; font-family: var(--font); transition: color .15s }
.gv-market-toggle:hover { color: var(--text2) }
.gv-market-toggle svg { transition: transform .2s }
.gv-market-toggle.open svg { transform: rotate(180deg) }
.gv-pro-banner { padding: 10px 14px; border-top: 1px solid var(--border-light); display: flex; align-items: center; justify-content: space-between; cursor: pointer; transition: background .12s; background: rgba(0,186,124,.02) }
.gv-pro-banner:hover { background: rgba(0,186,124,.05) }
.gv-pro-av { width: 28px; height: 28px; border-radius: var(--radius-full); background: rgba(0,186,124,.1); display: flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 700; color: var(--green); flex-shrink: 0; overflow: hidden }
.gv-unlock-btn { font-size: 11px; font-weight: 700; padding: 6px 14px; border-radius: var(--radius-sm); background: var(--green); color: #000; border: none; cursor: pointer; font-family: var(--font); white-space: nowrap; flex-shrink: 0 }
.gv-pick { display: flex; flex-direction: column; gap: 6px; padding: 12px 14px; border-top: .5px solid var(--border-light); cursor: pointer; transition: background .12s }
.gv-pick:hover { background: rgba(255,255,255,.02) }
.gv-pick-row { display: flex; align-items: center; gap: 10px; width: 100% }
.gv-pick-av { width: 28px; height: 28px; border-radius: var(--radius-full); background: rgba(255,255,255,.06); display: flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 700; flex-shrink: 0; overflow: hidden }
.gv-pick-info { flex: 1; min-width: 0 }
.gv-pick-name { font-size: 12px; font-weight: 600; display: flex; align-items: center; gap: 4px; flex-wrap: wrap }
.gv-pick-detail { font-size: 13px; color: var(--text2); margin-top: 2px; overflow: hidden; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; white-space: normal; line-height: 1.5; padding-left: 38px; }
.gv-pick-detail.expanded { display: block; -webkit-line-clamp: unset; }
.gv-pick-odds { font-size: 13px; font-weight: 700; flex-shrink: 0 }
.gv-acc-pill { font-size: 9px; font-weight: 700; color: var(--green); padding: 2px 6px; border-radius: var(--radius-full); background: rgba(0,186,124,.1); border: 1px solid rgba(0,186,124,.15) }
.gv-tip-buy { font-size: 11px; font-weight: 700; padding: 5px 12px; border-radius: var(--radius-sm); background: var(--text); color: var(--bg); border: none; cursor: pointer; font-family: var(--font); flex-shrink: 0 }
.gv-prop-tab { padding: 8px 12px; font-size: 11px; font-weight: 600; font-family: var(--font); color: var(--text3); background: none; border: none; border-bottom: 2px solid transparent; cursor: pointer; white-space: nowrap; transition: all .15s }
.gv-prop-tab.active { color: var(--text); border-bottom-color: var(--green) }
.gv-prop-tab:hover { color: var(--text2) }
.gv-prop-tab.empty { opacity: .4 }

/* Game unlock modal */
.gv-modal-overlay { position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0,0,0,.7); z-index: 200; display: flex; align-items: flex-end; justify-content: center; opacity: 0; transition: opacity .2s ease; pointer-events: none }
.gv-modal-overlay.open { opacity: 1; pointer-events: auto }
.gv-modal-sheet { width: 100%; max-width: 500px; background: #111; border-radius: 20px 20px 0 0; transform: translateY(100%); transition: transform .3s cubic-bezier(.32,.72,0,1) }
.gv-modal-overlay.open .gv-modal-sheet { transform: translateY(0) }
.gv-modal-pick { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border-radius: var(--radius-sm); border: 1px solid var(--border-light); margin-bottom: 6px; cursor: pointer; transition: all .15s }
.gv-modal-pick.selected { border-color: var(--green); background: rgba(0,186,124,.04) }
.gv-modal-check { width: 20px; height: 20px; border-radius: 6px; border: 2px solid var(--border); display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: all .15s }
.gv-modal-pick.selected .gv-modal-check { border-color: var(--green); background: var(--green) }
.gv-modal-check svg { width: 12px; height: 12px; stroke: #000; fill: none; stroke-width: 3; opacity: 0; transition: opacity .15s }
.gv-modal-pick.selected .gv-modal-check svg { opacity: 1 }
.gv-modal-buy:disabled { opacity: .4; cursor: default }

/* All games grid */
.allgames-grid { display: grid; grid-template-columns: 1fr; gap: 8px }
@media(min-width:540px) { .allgames-grid { grid-template-columns: 1fr 1fr } }
.gv-prop-content { }

.game-graph {
  margin: 0 24px 20px;
  height: 160px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  position: relative;
  overflow: hidden
}

.game-graph canvas {
  width: 100%;
  height: 100%
}

/* Prediction Stats */
.pred-stats {
  padding: 14px 24px;
  display: flex;
  gap: 8px
}

.pred-stat-box {
  flex: 1;
  background: var(--surface-raised);
  border-radius: var(--radius-md);
  padding: 12px;
  text-align: center
}

.pred-stat-box .label {
  font-size: 10px;
  color: var(--text3);
  text-transform: uppercase;
  letter-spacing: .5px;
  font-weight: 500
}

.pred-stat-box .value {
  font-size: 18px;
  font-weight: 700;
  margin-top: 2px;
  letter-spacing: -.3px
}

/* Market lines (sportsbook odds grid) */
.market-lines-grid {
  padding: 0 24px 16px
}

.market-lines-grid .market-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px
}

.market-header-title {
  font-size: 13px;
  font-weight: 700
}

.market-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 8px
}

.market-cell {
  background: var(--surface-raised);
  border-radius: var(--radius-md);
  padding: 12px;
  text-align: center
}

.market-cell .market-label {
  font-size: 10px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--text3);
  margin-bottom: 3px
}

.market-cell .market-value {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: -.2px
}

.market-cell .market-sub {
  font-size: 11px;
  color: var(--text3);
  margin-top: 3px
}

.market-vs {
  display: flex;
  justify-content: space-between;
  font-size: 12px;
  color: var(--text3);
  padding: 0 4px;
  margin-top: 2px
}

.market-expand {
  font-size: 12px;
  color: var(--text3);
  font-weight: 500;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 4px;
  transition: color .2s
}

.market-expand:hover {
  color: var(--text)
}

.market-expand svg {
  width: 14px;
  height: 14px;
  transition: transform .2s
}

.market-expand.open svg {
  transform: rotate(180deg)
}

.books-table {
  margin-top: 12px;
  width: 100%;
  font-size: 13px;
  display: none
}

.books-table.visible {
  display: table
}

.books-table th {
  text-align: left;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--text3);
  padding: 8px 10px
}

.books-table td {
  padding: 8px 10px;
  border-top: 1px solid var(--border-light)
}

.books-table .book-name {
  font-weight: 600;
  color: var(--text2)
}

.community-vs-market {
  display: flex;
  gap: 10px;
  margin-top: 14px
}

.cvm-box {
  flex: 1;
  background: var(--surface-raised);
  border-radius: var(--radius-md);
  padding: 12px;
  text-align: center
}

.cvm-box .cvm-label {
  font-size: 10px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--text3);
  margin-bottom: 2px
}

.cvm-box .cvm-value {
  font-size: 14px;
  font-weight: 700
}

/* Settings */
.settings-section {
  padding: 24px
}

.settings-group {
  margin-bottom: 28px
}

.settings-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .6px;
  color: var(--text3);
  margin-bottom: 12px
}

.settings-field {
  padding: 14px 0;
  border-bottom: 1px solid var(--border-light);
  display: flex;
  align-items: center;
  justify-content: space-between
}

.settings-field-label {
  font-size: 14px;
  font-weight: 500
}

.settings-field input[type="text"],
.settings-field input[type="number"] {
  text-align: right;
  max-width: 160px;
  font-size: 14px;
  padding: 6px 10px;
  border-radius: 8px;
  background: var(--bg);
  border: 1px solid var(--border);
  transition: border-color .18s cubic-bezier(0.4, 0, 0.2, 1), box-shadow .18s cubic-bezier(0.4, 0, 0.2, 1)
}

.settings-field input[type="text"]:focus,
.settings-field input[type="number"]:focus {
  border-color: var(--text3);
  box-shadow: 0 0 0 3px rgba(0, 0, 0, .03)
}

.settings-field textarea {
  width: 100%;
  margin-top: 8px;
  padding: 12px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  resize: none;
  min-height: 60px;
  transition: border-color .18s
}

.settings-field textarea:focus {
  border-color: var(--text3)
}

.toggle {
  width: 46px;
  height: 26px;
  border-radius: var(--radius-full);
  background: var(--accent2);
  position: relative;
  cursor: pointer;
  transition: background .25s cubic-bezier(.4, 0, .2, 1)
}

.toggle.on {
  background: var(--green)
}

.toggle::after {
  content: '';
  position: absolute;
  top: 2px;
  left: 2px;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: #fff;
  transition: transform .25s cubic-bezier(.4, 0, .2, 1);
  box-shadow: 0 1px 4px rgba(0, 0, 0, .15)
}

.toggle.on::after {
  transform: translateX(20px)
}

/* ── Settings Tabs ── */
.s-nav {
  display: flex;
  padding: 0 20px;
  gap: 0;
  border-bottom: 1px solid var(--border);
  overflow-x: auto;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  background: var(--surface)
}
.s-nav::-webkit-scrollbar { display: none }
.s-nav-item {
  padding: 12px 16px;
  font-size: 12px;
  font-weight: 600;
  color: var(--text3);
  cursor: pointer;
  white-space: nowrap;
  border: none;
  border-bottom: 2px solid transparent;
  transition: color .15s, border-color .15s;
  background: none;
  font-family: var(--font)
}
.s-nav-item:hover { color: var(--text2) }
.s-nav-item.active { color: var(--text); border-bottom-color: var(--green) }

.s-panel { display: none }
.s-panel.active { display: block; animation: sPanelIn .2s ease }
@keyframes sPanelIn { from { opacity: 0; transform: translateY(6px) } to { opacity: 1; transform: translateY(0) } }

.s-section-title {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .6px;
  color: var(--text3);
  padding: 20px 0 10px
}
.s-card {
  background: var(--surface-raised);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  overflow: hidden;
  margin-bottom: 12px
}
.s-row {
  padding: 14px 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border-bottom: 1px solid var(--border)
}
.s-row:last-child { border-bottom: none }
.s-row.clickable { cursor: pointer; transition: background .12s }
.s-row.clickable:hover { background: var(--accent2) }
.s-row-left { display: flex; align-items: center; gap: 12px; flex: 1; min-width: 0 }
.s-row-icon {
  width: 36px; height: 36px;
  border-radius: var(--radius-sm);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0
}
.s-row-text { flex: 1; min-width: 0 }
.s-row-title { font-size: 14px; font-weight: 600 }
.s-row-sub { font-size: 12px; color: var(--text3); margin-top: 1px }
.s-row-value { font-size: 13px; color: var(--text3); flex-shrink: 0 }
.s-row-chevron { width: 16px; height: 16px; stroke: var(--text3); fill: none; stroke-width: 1.5; flex-shrink: 0 }

.s-input-group { padding: 14px 16px; border-bottom: 1px solid var(--border) }
.s-input-group:last-child { border-bottom: none }
.s-input-label { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: .3px; color: var(--text3); margin-bottom: 6px }
.s-input {
  width: 100%; padding: 10px 12px;
  background: var(--bg); border: 1px solid var(--border); border-radius: 8px;
  color: var(--text); font-size: 14px; font-family: var(--font); outline: none;
  transition: border-color .15s
}
.s-input:focus { border-color: var(--text3) }
.s-input::placeholder { color: var(--text3) }
.s-social-row { display: flex; align-items: center; gap: 10px }
.s-social-icon { width: 16px; height: 16px; flex-shrink: 0 }

.s-pro-banner {
  background: linear-gradient(135deg, rgba(109,40,217,.12), rgba(167,139,250,.05));
  border: 1px solid rgba(167,139,250,.18);
  border-radius: var(--radius-md);
  padding: 16px; display: flex; align-items: center; gap: 14px;
  cursor: pointer; transition: border-color .18s; margin-bottom: 12px
}
.s-pro-banner:hover { border-color: rgba(167,139,250,.4) }

.s-danger-btn {
  background: none; border: none; font-family: var(--font);
  font-size: 14px; font-weight: 500; cursor: pointer;
  padding: 14px 16px; width: 100%; text-align: left;
  border-bottom: 1px solid var(--border); transition: background .12s
}
.s-danger-btn:last-child { border-bottom: none }
.s-danger-btn:hover { background: var(--accent2) }
.s-danger-btn.red { color: var(--red) }
.s-danger-btn.blue { color: var(--blue) }

/* Modal */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, .45);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  z-index: 500;
  display: none;
  -webkit-overflow-scrolling: touch;
  overflow-y: auto
}

.modal-overlay.visible {
  display: flex;
  align-items: flex-end;
  justify-content: center
}

.modal {
  background: var(--surface);
  width: 100%;
  max-width: var(--maxw);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: 24px;
  padding-bottom: max(24px, env(safe-area-inset-bottom));
  border-radius: 20px 20px 0 0;
  animation: slideUp .32s cubic-bezier(.22, 1, .36, 1);
  max-height: 100vh;
  max-height: 100dvh
}

@media(min-width:640px) {
  .modal-overlay.visible {
    align-items: flex-start;
    padding: 40px 20px;
    overflow-y: auto
  }

  .modal {
    border-radius: 20px;
    max-height: none;
    margin: auto;
    box-shadow: 0 12px 40px rgba(0, 0, 0, .15), 0 4px 12px rgba(0, 0, 0, .06)
  }
}

@media(max-width:639px) {
  .modal-overlay {
    background: var(--surface);
    backdrop-filter: none;
    -webkit-backdrop-filter: none
  }

  .modal {
    min-height: 100vh;
    min-height: 100dvh;
    max-height: none;
    border-radius: 0;
    padding-top: 0;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch
  }

  .modal-handle {
    display: none
  }

  .modal h3 {
    position: sticky;
    top: 0;
    background: var(--surface);
    padding: 16px 0 12px;
    margin: 0 0 12px;
    border-bottom: 1px solid var(--border-light);
    z-index: 10
  }

  .modal-mobile-close {
    display: block
  }
}

.modal-mobile-close {
  display: none;
  position: sticky;
  top: 0;
  background: var(--surface);
  padding: max(12px, env(safe-area-inset-top)) 0 0;
  z-index: 11
}

#whopEmbed iframe {
  width: 100% !important;
  min-height: 580px !important
}

.modal-mobile-close button {
  font-size: 14px;
  font-weight: 500;
  color: var(--blue);
  padding: 4px 0
}

@media(max-width:639px) {
  .modal-close-x {
    top: max(16px, env(safe-area-inset-top)) !important
  }
}

@keyframes slideUp {
  from {
    transform: translateY(100%);
    opacity: .8
  }

  to {
    transform: translateY(0);
    opacity: 1
  }
}

@keyframes slideDown {
  from {
    transform: translateY(0);
    opacity: 1
  }

  to {
    transform: translateY(100%);
    opacity: .8
  }
}

@keyframes fadeOut {
  from {
    opacity: 1
  }

  to {
    opacity: 0
  }
}

.modal-overlay.closing {
  animation: fadeOut .25s cubic-bezier(0.4, 0, 0.2, 1) forwards;
  pointer-events: none
}

.modal-overlay.closing .modal {
  animation: slideDown .25s cubic-bezier(.4, 0, .2, 1) forwards
}

.modal-handle {
  width: 40px;
  height: 4px;
  background: rgba(0, 0, 0, .12);
  border-radius: 3px;
  margin: 0 auto 20px
}

.modal h3 {
  font-family: var(--font);
  font-size: 16px;
  font-weight: 700;
  margin-bottom: 20px;
  letter-spacing: -.2px
}

/* Prediction Form */
.pred-form-group {
  margin-bottom: 16px
}

.pred-form-group label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--text3);
  display: block;
  margin-bottom: 7px
}

.pred-form-group select,
.pred-form-group input[type="text"],
.pred-form-group input[type="number"] {
  width: 100%;
  padding: 10px 14px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  font-size: 14px;
  transition: all .15s
}

.pred-form-group select:focus,
.pred-form-group input[type="text"]:focus,
.pred-form-group input[type="number"]:focus {
  border-color: var(--blue);
  background: var(--surface);
  box-shadow: 0 0 0 3px var(--blue-light)
}

.pred-form-group textarea {
  width: 100%;
  padding: 10px 14px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  font-size: 14px;
  resize: none;
  min-height: 60px;
  transition: all .15s
}

.pred-form-group textarea:focus {
  border-color: var(--blue);
  background: var(--surface);
  box-shadow: 0 0 0 3px var(--blue-light)
}

/* Pick type row */
.pick-type-row {
  display: flex;
  gap: 5px;
  flex-wrap: wrap
}

.pick-type-btn {
  padding: 8px 14px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 600;
  background: var(--bg);
  color: var(--text2);
  transition: all .18s cubic-bezier(.4, 0, .2, 1);
  border: 1px solid transparent
}

.pick-type-btn:hover {
  border-color: var(--border)
}

.pick-type-btn.active {
  background: var(--accent);
  color: #fff;
  box-shadow: 0 1px 3px rgba(0, 0, 0, .1)
}

/* Pick side buttons */
.pred-pick-section {
  margin-bottom: 16px
}

.pred-pick-section label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--text3);
  display: block;
  margin-bottom: 7px
}

.pred-pick-section select {
  width: 100%;
  padding: 11px 14px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  font-size: 14px;
  transition: border-color .2s
}

.pred-pick-section select:focus {
  border-color: var(--text3)
}

.pick-side-row {
  display: flex;
  gap: 8px
}

.pick-side-btn {
  flex: 1;
  padding: 14px 12px;
  border-radius: var(--radius-md);
  background: var(--bg);
  text-align: center;
  transition: all .18s cubic-bezier(.4, 0, .2, 1);
  border: 1.5px solid var(--border)
}

.pick-side-btn:hover {
  border-color: var(--border-strong);
  background: var(--surface-raised)
}

.pick-side-btn.selected {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
  box-shadow: var(--shadow-sm)
}

.pick-side-team {
  font-size: 14px;
  font-weight: 600;
  display: block
}

/* Line adjuster */
.pick-line-input {
  display: flex;
  align-items: center;
  gap: 0;
  border-radius: var(--radius-md);
  overflow: hidden;
  -webkit-transform: translateZ(0);
  -webkit-mask-image: -webkit-radial-gradient(white, black);
  background: var(--bg);
  border: 1px solid var(--border)
}

.line-adj {
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: 500;
  color: var(--text3);
  transition: all .15s;
  background: transparent;
  flex-shrink: 0
}

.line-adj:hover {
  background: var(--accent2);
  color: var(--text)
}

.line-adj:active {
  background: var(--border)
}

.line-value {
  text-align: center;
  font-size: 16px;
  font-weight: 700;
  padding: 10px 0;
  flex: 1;
  background: transparent;
  letter-spacing: -.2px
}

/* Player input */
.pick-player-input {
  width: 100%;
  padding: 11px 14px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  font-size: 14px;
  transition: border-color .2s cubic-bezier(0.4, 0, 0.2, 1), box-shadow .2s cubic-bezier(0.4, 0, 0.2, 1)
}

.pick-player-input:focus {
  border-color: var(--blue);
  box-shadow: 0 0 0 3px var(--blue-light)
}

/* Visibility picker */
.vis-picker {
  display: flex;
  gap: 4px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 3px
}

.vis-opt {
  flex: 1;
  padding: 8px 8px;
  border-radius: 7px;
  font-size: 12px;
  font-weight: 600;
  text-align: center;
  color: var(--text2);
  transition: all .2s cubic-bezier(.4, 0, .2, 1);
  position: relative
}

.vis-opt.active {
  background: var(--surface);
  color: var(--text);
  box-shadow: 0 1px 4px rgba(0, 0, 0, .08), 0 0 1px rgba(0, 0, 0, .05)
}

.vis-opt.vis-subs:not(.active) {
  color: var(--text3)
}

.vis-opt.vis-subs.disabled {
  opacity: .5;
  cursor: default
}

.vis-lock-icon {
  font-size: 10px;
  margin-left: 2px
}

/* Toast */
.toast {
  position: fixed;
  bottom: calc(100px + env(safe-area-inset-bottom));
  left: 50%;
  transform: translateX(-50%) translateY(8px);
  background: var(--text);
  color: var(--surface);
  padding: 10px 20px;
  border-radius: var(--radius-md);
  font-size: 13px;
  font-weight: 600;
  font-family: var(--font);
  z-index: 99999;
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s cubic-bezier(0.4, 0, 0.2, 1), transform .25s cubic-bezier(0.4, 0, 0.2, 1);
  max-width: 340px;
  text-align: center;
  line-height: 1.4
}

.toast.visible {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0)
}

.toast a {
  color: var(--green);
  text-decoration: underline;
  font-weight: 600
}

.player-autocomplete {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: var(--surface);
  border: 1px solid var(--border);
  border-top: 0;
  border-radius: 0 0 12px 12px;
  box-shadow: var(--shadow-md);
  z-index: 10;
  max-height: 220px;
  overflow-y: auto;
  display: none
}

.player-autocomplete.visible {
  display: block
}

.player-ac-item {
  padding: 12px 16px;
  font-size: 14px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 10px;
  transition: background .15s
}

.player-ac-item:hover {
  background: var(--bg)
}

.player-ac-team {
  font-size: 11px;
  color: var(--text3);
  font-weight: 700
}

/* Accuracy bar */
.accuracy-bar {
  height: 4px;
  background: var(--accent2);
  border-radius: 3px;
  overflow: hidden;
  -webkit-transform: translateZ(0);
  -webkit-mask-image: -webkit-radial-gradient(white, black);
  margin-top: 8px
}

.accuracy-fill {
  height: 100%;
  background: var(--green);
  border-radius: 3px;
  transition: width .5s cubic-bezier(0.4, 0, 0.2, 1)
}

/* Back button */
.back-btn {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 14px;
  font-weight: 500;
  color: var(--text2);
  padding: 8px 0
}

.back-btn svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round
}

/* Subscription badge */
.sub-badge {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: 9px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .6px;
  color: #6d28d9;
  background: #f0e6ff;
  padding: 3px 7px;
  border-radius: 6px;
  vertical-align: middle;
  line-height: 1
}

/* Profile action buttons — responsive placement */
.profile-actions-inline {
  display: flex;
  gap: 5px;
  flex-shrink: 0
}

.profile-actions-inline .btn {
  border-radius: 8px
}

.profile-actions-below {
  display: none;
  gap: 6px;
  margin-top: 8px
}

.profile-actions-below .btn {
  border-radius: 8px
}

@media(max-width:480px) {
  .profile-actions-inline {
    display: none !important
  }

  .profile-actions-below {
    display: flex !important
  }
}

/* Fade in */
.fade-in {
  animation: fadeIn .35s cubic-bezier(.4, 0, .2, 1)
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(8px)
  }

  to {
    opacity: 1;
    transform: translateY(0)
  }
}

@keyframes tickerScroll {
  0% {
    transform: translateX(0)
  }

  100% {
    transform: translateX(-50%)
  }
}

@keyframes livePulse {

  0%,
  100% {
    opacity: 1
  }

  50% {
    opacity: .3
  }
}

/* Scrollbar */
::-webkit-scrollbar {
  width: 0;
  height: 0
}

.hide-scrollbar::-webkit-scrollbar {
  display: none
}

.hide-scrollbar {
  -ms-overflow-style: none;
  scrollbar-width: none
}

/* Sleek Inputs */
.sleek-input {
  width: 100%;
  padding: 14px 18px;
  background: #0a0a0a;
  border: 1.5px solid rgba(255, 255, 255, 0.08);
  border-radius: 12px;
  color: var(--text);
  font-size: 14px;
  font-family: var(--font);
  line-height: 1.6;
  outline: none;
  transition: all 0.2s ease;
  box-sizing: border-box;
}

.sleek-input:focus {
  background: #000;
  border-color: var(--purple);
  box-shadow: inset 0 0 0 1px var(--purple), 0 0 15px rgba(167, 139, 250, 0.12);
}

.sleek-input::placeholder {
  color: var(--text3);
  opacity: 0.5;
}

.sleek-input-container {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 2px 18px;
  background: #0a0a0a;
  border: 1.5px solid rgba(255, 255, 255, 0.08);
  border-radius: 12px;
  transition: all 0.2s ease;
}

.sleek-input-container:focus-within {
  background: #000;
  border-color: var(--purple);
  box-shadow: inset 0 0 0 1px var(--purple), 0 0 15px rgba(167, 139, 250, 0.12);
}

.sleek-input-container input {
  flex: 1;
  padding: 14px 0;
  background: none;
  border: none;
  color: var(--text);
  font-size: 14px;
  font-family: var(--font);
  outline: none;
}

/* Auth fields (in modal) */
.auth-field {
  margin-bottom: 16px
}

.auth-field input {
  width: 100%;
  padding: 14px 18px;
  background: var(--surface-raised);
  border: 1px solid var(--border);
  border-radius: 16px;
  font-size: 15px;
  transition: all .2s ease;
}

.auth-field input:focus {
  border-color: var(--green);
  background: var(--surface);
  box-shadow: 0 0 0 1px var(--green);
}

.auth-field input::placeholder {
  color: var(--text3)
}

.auth-switch {
  margin-top: 16px;
  font-size: 13px;
  color: var(--text3);
  text-align: center
}

.auth-switch a {
  color: var(--text);
  font-weight: 600;
  cursor: pointer
}

/* Auth loading overlay */
.auth-loading {
  position: absolute;
  inset: 0;
  background: var(--surface);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  z-index: 10;
  border-radius: var(--radius);
  animation: fadeIn .2s cubic-bezier(0.4, 0, 0.2, 1)
}

.auth-loading .auth-spinner {
  width: 40px;
  height: 40px;
  position: relative
}

.auth-loading .auth-spinner::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 3px solid var(--border);
  border-top-color: var(--green);
  animation: authSpin .8s cubic-bezier(.4, .15, .6, .85) infinite
}

.auth-loading .auth-spinner::after {
  content: '';
  position: absolute;
  inset: 6px;
  border-radius: 50%;
  border: 2px solid transparent;
  border-bottom-color: var(--accent);
  animation: authSpin 1.2s cubic-bezier(.4, .15, .6, .85) infinite reverse
}

.auth-loading .auth-loading-text {
  font-size: 14px;
  font-weight: 600;
  margin-top: 16px;
  color: var(--text);
  animation: authTextPulse 2s ease-in-out infinite
}

.auth-loading .auth-loading-sub {
  font-size: 12px;
  color: var(--text3);
  margin-top: 4px
}

@keyframes authSpin {
  to {
    transform: rotate(360deg)
  }
}

@keyframes authTextPulse {

  0%,
  100% {
    opacity: 1
  }

  50% {
    opacity: .5
  }
}

.auth-loading .auth-steps {
  margin-top: 20px;
  width: 100%;
  max-width: 240px
}

.auth-loading .auth-step {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 0;
  font-size: 12px;
  color: var(--text3);
  transition: all .3s cubic-bezier(0.4, 0, 0.2, 1)
}

.auth-loading .auth-step.active {
  color: var(--text);
  font-weight: 500
}

.auth-loading .auth-step.done {
  color: var(--green)
}

.auth-loading .auth-step-dot {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: 2px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 10px;
  transition: all .3s cubic-bezier(0.4, 0, 0.2, 1)
}

.auth-loading .auth-step.active .auth-step-dot {
  border-color: var(--green);
  box-shadow: 0 0 0 3px rgba(22, 163, 74, .15);
  animation: authDotPulse 1.5s ease-in-out infinite
}

.auth-loading .auth-step.done .auth-step-dot {
  border-color: var(--green);
  background: var(--green);
  color: #fff
}

@keyframes authDotPulse {

  0%,
  100% {
    box-shadow: 0 0 0 3px rgba(22, 163, 74, .15)
  }

  50% {
    box-shadow: 0 0 0 6px rgba(22, 163, 74, .08)
  }
}

html.dark .auth-loading .auth-step.done .auth-step-dot {
  color: #000
}

/* Checkout / payment loading — reusable component */
.tm-loader {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 48px 20px;
  text-align: center
}

.tm-loader-ring {
  width: 48px;
  height: 48px;
  position: relative;
  margin-bottom: 18px
}

.tm-loader-ring::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 3px solid var(--border);
  border-top-color: var(--green);
  animation: authSpin .8s cubic-bezier(.4, .15, .6, .85) infinite
}

.tm-loader-ring::after {
  content: '';
  position: absolute;
  inset: 7px;
  border-radius: 50%;
  border: 2px solid transparent;
  border-bottom-color: var(--accent);
  animation: authSpin 1.2s cubic-bezier(.4, .15, .6, .85) infinite reverse
}

.tm-loader-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
  animation: authTextPulse 2s ease-in-out infinite
}

/* Feed skeleton loading */
.skel {
  animation: skelPulse 1.5s ease-in-out infinite
}

.tab-fade {
  transition: opacity .15s cubic-bezier(0.4, 0, 0.2, 1), transform .15s cubic-bezier(0.4, 0, 0.2, 1)
}

.tab-fade.fading {
  opacity: 0;
  transform: translateY(4px)
}

@keyframes skelPulse {

  0%,
  100% {
    opacity: .35
  }

  50% {
    opacity: .15
  }
}

.skel-card {
  padding: 16px 20px;
  border-bottom: 1px solid var(--border-light)
}

.skel-row {
  display: flex;
  align-items: center;
  gap: 12px
}

.skel-av {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--accent2);
  flex-shrink: 0
}

.skel-line {
  height: 10px;
  border-radius: 5px;
  background: var(--accent2)
}

.skel-line.w60 {
  width: 60%
}

.skel-line.w40 {
  width: 40%
}

.skel-line.w80 {
  width: 80%
}

.skel-line.w30 {
  width: 30%
}

.skel-body {
  margin-top: 10px;
  display: flex;
  flex-direction: column;
  gap: 8px
}

.tm-loader-sub {
  font-size: 13px;
  color: var(--text3);
  margin-top: 5px;
  line-height: 1.5
}

.tm-loader-steps {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: 20px;
  width: 100%;
  max-width: 220px
}

.tm-loader-step {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12px;
  color: var(--text3);
  transition: all .3s
}

.tm-loader-step.active {
  color: var(--text);
  font-weight: 500
}

.tm-loader-step.done {
  color: var(--green)
}

.tm-loader-step-dot {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 2px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 9px;
  transition: all .3s
}

.tm-loader-step.active .tm-loader-step-dot {
  border-color: var(--green);
  animation: authDotPulse 1.5s ease-in-out infinite
}

.tm-loader-step.done .tm-loader-step-dot {
  border-color: var(--green);
  background: var(--green);
  color: #fff
}

html.dark .tm-loader-step.done .tm-loader-step-dot {
  color: #000
}

@keyframes tmPopIn {
  0% {
    transform: scale(0);
    opacity: 0
  }

  60% {
    transform: scale(1.15)
  }

  100% {
    transform: scale(1);
    opacity: 1
  }
}

/* Quick predict floating btn */
.fab {
  position: fixed;
  bottom: calc(80px + max(12px, env(safe-area-inset-bottom)));
  right: max(16px, calc(50% - var(--maxw)/2 + 16px));
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: var(--accent);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 20px rgba(0, 0, 0, .25);
  z-index: 150;
  transition: transform .2s cubic-bezier(.4, 0, .2, 1), box-shadow .2s cubic-bezier(0.4, 0, 0.2, 1);
  -webkit-tap-highlight-color: transparent
}

.fab:hover {
  transform: scale(1.08);
  box-shadow: 0 6px 24px rgba(0, 0, 0, .3)
}

.fab svg {
  width: 22px;
  height: 22px;
  stroke: #fff;
  fill: none;
  stroke-width: 1.5
}

/* Utility */
.mt-8 {
  margin-top: 8px
}

.mt-12 {
  margin-top: 12px
}

.mt-16 {
  margin-top: 16px
}

.px-20 {
  padding-left: 20px;
  padding-right: 20px
}

.text-center {
  text-align: center
}

.text-sm {
  font-size: 13px
}

.text-xs {
  font-size: 12px
}

.text-muted {
  color: var(--text3)
}

.fw-600 {
  font-weight: 600
}

.flex {
  display: flex
}

.items-center {
  align-items: center
}

.gap-8 {
  gap: 8px
}

.gap-6 {
  gap: 6px
}

.justify-between {
  justify-content: space-between
}

.cursor-pointer {
  cursor: pointer
}

/* Capper About Tab */
.cl-section-title {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--text3);
  margin-bottom: 12px
}

.cl-pick {
  padding: 12px;
  background: var(--accent2);
  border-radius: var(--radius-md);
  margin-bottom: 8px
}

.cl-pick-type {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .3px;
  color: var(--text3);
  margin-bottom: 2px
}

.cl-pick-text {
  font-size: 14px;
  font-weight: 700
}

.cl-pick-meta {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 4px;
  font-size: 11px;
  color: var(--text3);
  flex-wrap: wrap
}

.cl-pick-result {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .3px;
  padding: 2px 6px;
  border-radius: 4px
}

.cl-pick-result.hit {
  background: rgba(22, 163, 74, .1);
  color: var(--green)
}

.cl-pick-result.miss {
  background: rgba(224, 49, 49, .1);
  color: var(--red)
}

.cl-pick-result.pending {
  background: var(--accent2);
  color: var(--text3)
}

html.dark .cl-pick-result.hit {
  background: rgba(0, 186, 124, .1);
  color: #00ba7c
}

html.dark .cl-pick-result.miss {
  background: rgba(244, 33, 46, .1);
  color: #f4212e
}

.loading-screen {
  position: fixed;
  inset: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #000;
  z-index: 99999;
  transition: opacity .5s cubic-bezier(0.4, 0, 0.2, 1), visibility .5s
}

.loading-screen.hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none
}

.loader-logo-container {
  --size: clamp(120px, 14vw, 160px);
  position: relative;
  width: var(--size);
  height: var(--size);
  display: flex;
  justify-content: center;
  align-items: center
}

.progress-ring {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  transform: rotate(-90deg)
}

.progress-ring .bg-ring {
  fill: none;
  stroke: rgba(255, 255, 255, .05);
  stroke-width: 1
}

.progress-ring .progress-circle {
  fill: none;
  stroke: rgba(255, 255, 255, .20);
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-dasharray: 24 252.46;
  stroke-dashoffset: 0;
  animation: orbit 2s linear infinite
}

@keyframes orbit {
  0% {
    stroke-dashoffset: 0
  }

  100% {
    stroke-dashoffset: -276.46
  }
}

.loading-logo-text {
  font-family: 'Doto', sans-serif;
  font-weight: 700;
  font-size: clamp(30px, 3.8vw, 42px);
  line-height: 1;
  letter-spacing: .06em;
  color: rgba(255, 255, 255, .85);
  z-index: 1;
  position: relative;
  margin-top: 1px;
  animation: breathe 4s ease-in-out infinite
}

@keyframes breathe {

  0%,
  100% {
    opacity: .80
  }

  50% {
    opacity: 1
  }
}

/* ── Page Loader Overlay ── */
.page-loader {
  position: fixed;
  inset: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  background: var(--surface);
  z-index: 200;
  transition: opacity .45s cubic-bezier(0.4, 0, 0.2, 1), visibility .45s cubic-bezier(0.4, 0, 0.2, 1)
}

.page-loader.hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none
}

.page-loader .loader-logo-container {
  --size: clamp(80px, 10vw, 110px)
}

.page-loader .progress-ring .bg-ring {
  stroke: var(--border);
  stroke-width: 1.5
}

.page-loader .progress-ring .progress-circle {
  stroke: var(--green);
  stroke-width: 1.5
}

.page-loader .loading-logo-text {
  color: var(--text);
  font-size: clamp(20px, 2.8vw, 28px)
}

/* Fullscreen variant — covers entire viewport above everything */
.page-loader--fullscreen {
  z-index: 99998
}

/* Section variant — constrained to .app column (between vertical lines on desktop) */
.page-loader--section {
  max-width: var(--maxw);
  margin: 0 auto
}

@media(min-width:1080px) {
  .page-loader--section {
    left: calc(50% - var(--maxw)/2);
    right: calc(50% - var(--maxw)/2)
  }
}

/* =========================================
   Utility Classes (Typography & Components)
   ========================================= */
.text-xs {
  font-size: 11px;
}

.text-sm {
  font-size: 13px;
}

.text-base {
  font-size: 14px;
}

.text-lg {
  font-size: 18px;
}

.text-xl {
  font-size: 22px;
}

.font-medium {
  font-weight: 500;
}

.font-semibold {
  font-weight: 600;
}

.font-bold {
  font-weight: 700;
}

.text-muted {
  color: var(--text3);
}

.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  overflow: hidden;
  -webkit-transform: translateZ(0);
  -webkit-mask-image: -webkit-radial-gradient(white, black);
}

.card-hover:hover {
  background: rgba(231, 233, 234, .03);
}

.badge {
  padding: 4px 8px;
  border-radius: var(--radius-sm);
  font-size: 11px;
  font-weight: 600;
}

.avatar-circle {
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  -webkit-transform: translateZ(0);
  -webkit-mask-image: -webkit-radial-gradient(white, black);
}


/* =========================================
   Tactile Micro-Interactions
   ========================================= */
button:active,
.card:active,
.pick-type-btn:active,
.filter-pill:active,
.avatar:active {
  transform: scale(0.96) !important;
}

/* Game and feed cards stay flat on press — they're list rows, not
   tap-targets that need physical feedback. The scale animation
   reads as a glitch on long, thin rows. We block ALL interactive
   states (active, focus, hover-on-touch) and any descendant that
   could otherwise inherit a parent rule. */
.pred-card:active,
.pred-card *:active,
.pred-card:focus,
.pred-card:focus-within,
.game-card:active,
.game-card *:active,
.game-card:focus,
.game-card:focus-within {
  transform: none !important;
  -webkit-transform: translateZ(0) !important;
  scale: none !important;
}

/* Reusable Skeleton Shimmer Effect */
@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

@keyframes shimmer {
  0% {
    background-position: -1000px 0;
  }

  100% {
    background-position: 1000px 0;
  }
}

.skeleton {
  background: linear-gradient(90deg, var(--surface-raised) 25%, var(--border) 50%, var(--surface-raised) 75%);
  background-size: 1000px 100%;
  animation: shimmer 2s infinite linear;
  border-radius: var(--radius-sm);
}

/* Feedback banner — shown occasionally at the very top, above all sidebars */
:root {
  --feedback-banner-h: 36px;
}

.feedback-banner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 8px 14px;
  background-color: var(--surface);
  background-image: linear-gradient(rgba(74, 108, 247, 0.10), rgba(74, 108, 247, 0.10));
  border-bottom: 1px solid rgba(74, 108, 247, 0.22);
  font-size: 13px;
  line-height: 1.3;
  color: var(--text);
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: var(--feedback-banner-h);
  z-index: 400;
}

/* When banner is shown, push sidebars + main app down so nothing overlaps */
body.has-feedback-banner .desktop-sidebar,
body.has-feedback-banner .desktop-right {
  top: var(--feedback-banner-h);
  height: calc(100vh - var(--feedback-banner-h));
}

body.has-feedback-banner .app {
  padding-top: var(--feedback-banner-h);
}

/* Sticky page headers must stick below the banner, not under it */
body.has-feedback-banner .header {
  top: var(--feedback-banner-h);
}

.feedback-banner-text {
  color: var(--text2);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.feedback-banner-cta {
  background: none;
  border: none;
  color: var(--blue);
  font-weight: 700;
  font-size: 13px;
  font-family: var(--font);
  cursor: pointer;
  padding: 2px 4px;
  flex-shrink: 0;
}

.feedback-banner-cta:hover {
  text-decoration: underline;
}

.feedback-banner-close {
  background: none;
  border: none;
  color: var(--text3);
  cursor: pointer;
  padding: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-sm);
  flex-shrink: 0;
}

.feedback-banner-close:hover {
  color: var(--text);
  background: rgba(255, 255, 255, 0.04);
}

@media (max-width: 480px) {
  :root {
    --feedback-banner-h: 34px;
  }

  .feedback-banner {
    padding: 7px 10px;
    font-size: 12px;
    gap: 8px;
  }

  .feedback-banner-cta {
    font-size: 12px;
  }
}

/* ═══ Modal & Popover Animations ═══ */
@keyframes modalOverlayIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

@keyframes modalOverlayOut {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
  }
}

@keyframes modalContentIn {
  from {
    opacity: 0;
    transform: scale(.92) translateY(12px);
  }

  to {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}

@keyframes modalContentOut {
  from {
    opacity: 1;
    transform: scale(1) translateY(0);
  }

  to {
    opacity: 0;
    transform: scale(.95) translateY(8px);
  }
}

@keyframes sheetSlideIn {
  from {
    transform: translateY(100%);
  }

  to {
    transform: translateY(0);
  }
}

@keyframes sheetSlideOut {
  from {
    transform: translateY(0);
  }

  to {
    transform: translateY(100%);
  }
}

@keyframes toastIn {
  from {
    opacity: 0;
    transform: translateY(-12px) scale(.95);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes toastOut {
  from {
    opacity: 1;
    transform: translateY(0) scale(1);
  }

  to {
    opacity: 0;
    transform: translateY(-8px) scale(.97);
  }
}
/* Payout Module - Premium Fintech Edition */
/* Payout Module - Ultra-Compact Edition */
.payout-card {
  position: relative;
  padding: 8px 16px;
  background: linear-gradient(145deg, #0f110e, #050505);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
  overflow: hidden;
  margin-top: 4px;
}

.payout-card-info {
  flex: 1;
  position: relative;
  z-index: 2;
}

.payout-card-title {
  font-size: 13px;
  font-weight: 800;
  color: var(--text);
  margin-bottom: 2px;
  letter-spacing: -0.2px;
}

.payout-card-desc {
  font-size: 11px;
  color: var(--text3);
  line-height: 1.4;
  opacity: 0.8;
}

.payout-icon-bg {
  position: absolute;
  right: -5px;
  bottom: -5px;
  width: 60px;
  height: 60px;
  color: #00ba7c;
  opacity: 0.02;
  transform: rotate(-10deg);
  pointer-events: none;
}

@media (max-width: 580px) {
  .payout-card {
    flex-direction: column;
    align-items: flex-start;
    gap: 24px;
    padding: 24px;
  }
  .payout-card .premium-action-button {
    width: 100%;
    padding: 16px;
  }
}

/* Premium Action Buttons */
.premium-action-button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  background: linear-gradient(135deg, #00ba7c, #00a66e);
  color: #fff;
  border: none;
  border-radius: 12px;
  font-family: var(--font);
  font-weight: 700;
  cursor: pointer;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 4px 14px rgba(0, 186, 124, 0.25);
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

.premium-action-button:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(0, 186, 124, 0.35);
  filter: brightness(1.05);
}

.premium-action-button:active {
  transform: translateY(0);
  box-shadow: 0 2px 10px rgba(0, 186, 124, 0.2);
  filter: brightness(0.95);
}

.premium-action-button svg {
  stroke: #fff;
  transition: transform 0.2s ease;
}

.premium-action-button:hover svg {
  transform: translateY(2px);
}

/* ── Pick Cell Redesign — Game Row with Team Colors ── */
.pick-game-row { display: flex; align-items: center; justify-content: space-between; margin: 0 0 8px }
.pick-game-left { display: flex; align-items: center; gap: 5px }
.pick-game-left .team-logo { flex-shrink: 0 }
.pick-matchup-vs { font-size: 11px; font-weight: 500; color: var(--text3); padding: 0 1px }
.pick-team-name { font-size: 14px; font-weight: 700; color: var(--text) }
.pick-game-time { font-size: 11px; color: var(--text3); font-weight: 500; flex-shrink: 0 }

/* Pick Box — context + headline redesign */
.pick-context { font-size: 10px; font-weight: 600; color: var(--text3); text-transform: uppercase; letter-spacing: .3px; margin-bottom: 4px; display: flex; align-items: center; gap: 6px }
.pick-context-dot { width: 3px; height: 3px; border-radius: 50%; background: var(--text3) }
.pick-headline { display: flex; align-items: baseline; justify-content: space-between; gap: 10px }
.pick-headline-text { font-size: 15px; font-weight: 700; letter-spacing: -.1px; line-height: 1.3 }
.pick-headline-odds { font-size: 15px; font-weight: 700; color: var(--text); flex-shrink: 0; letter-spacing: -.2px }

/* League pill in top-right */
.pick-league { font-size: 9px; font-weight: 800; letter-spacing: .4px; text-transform: uppercase; padding: 2px 6px; border-radius: 4px; flex-shrink: 0 }
.pick-league.nba { color: #f59e0b; background: rgba(245, 158, 11, .08) }
.pick-league.nfl { color: #60a5fa; background: rgba(96, 165, 250, .08) }
.pick-league.mlb { color: #f87171; background: rgba(248, 113, 113, .08) }
.pick-league.nhl { color: #22d3ee; background: rgba(34, 211, 238, .08) }
.pick-league.mls { color: #4ade80; background: rgba(74, 222, 128, .08) }
.pick-league.epl { color: #a78bfa; background: rgba(167, 139, 250, .08) }
.pick-league.la_liga { color: #fb923c; background: rgba(251, 146, 60, .08) }
.pick-league.serie_a { color: #60a5fa; background: rgba(96, 165, 250, .08) }
.pick-league.bundesliga { color: #f87171; background: rgba(248, 113, 113, .08) }
.pick-league.ligue_1 { color: #38bdf8; background: rgba(56, 189, 248, .08) }
.pick-league.champions_league { color: #818cf8; background: rgba(129, 140, 248, .08) }
.pick-league.default { color: #1d9bf0; background: rgba(29, 155, 240, .08) }

/* ── Tipsters Section (game page) ── */
.ts-section { padding: 8px 16px 12px }
.ts-avatars { display: flex; flex-shrink: 0 }
.ts-avatar { width: 26px; height: 26px; border-radius: 50%; background: rgba(167,139,250,.12); border: 2px solid var(--surface-raised); display: flex; align-items: center; justify-content: center; font-size: 9px; font-weight: 700; color: var(--purple); overflow: hidden }
.ts-avatar + .ts-avatar { margin-left: -8px }
.ts-avatar.more { font-size: 8px; background: rgba(167,139,250,.08) }
.ts-header { display: flex; align-items: center; gap: 10px; padding: 12px 14px; cursor: pointer; border-radius: var(--radius-md); border: 1px solid rgba(167,139,250,.15); background: linear-gradient(135deg, rgba(167,139,250,.06) 0%, rgba(167,139,250,.02) 50%, transparent 100%); transition: border-color .15s }
.ts-header:hover { border-color: rgba(167,139,250,.25) }
.ts-header-text { flex: 1; min-width: 0 }
.ts-header-title { font-size: 13px; font-weight: 700; line-height: 1.3 }
.ts-header-sub { font-size: 11px; color: var(--text3); margin-top: 1px }
.ts-chevron { width: 14px; height: 14px; stroke: var(--text3); fill: none; stroke-width: 1.5; flex-shrink: 0; transition: transform .25s cubic-bezier(.32,.72,0,1) }
.ts-section.open .ts-chevron { transform: rotate(180deg) }
.ts-section.open .ts-header { border-radius: var(--radius-md) var(--radius-md) 0 0; border-bottom-color: transparent; background: var(--surface-raised); border-color: rgba(167,139,250,.15) }
.ts-list { border: 1px solid rgba(167,139,250,.15); border-top: none; border-radius: 0 0 var(--radius-md) var(--radius-md); overflow: hidden; max-height: 0; opacity: 0; transition: max-height .35s cubic-bezier(.32,.72,0,1), opacity .2s ease; background: var(--surface-raised) }
.ts-row { display: flex; align-items: center; gap: 10px; padding: 10px 14px; cursor: pointer; border-top: .5px solid rgba(167,139,250,.08); transition: background .12s }
.ts-row:hover { background: rgba(167,139,250,.04) }
.ts-row-avatar { width: 32px; height: 32px; border-radius: 50%; background: rgba(167,139,250,.1); border: 1px solid rgba(167,139,250,.08); display: flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 700; color: var(--purple); flex-shrink: 0; overflow: hidden }
.ts-row-info { flex: 1; min-width: 0 }
.ts-row-name { font-size: 13px; font-weight: 600; display: flex; align-items: center; gap: 5px }
.ts-row-meta { font-size: 10px; color: var(--text3); margin-top: 2px }
.ts-row-stats { text-align: right; flex-shrink: 0; margin-right: 2px }
.ts-row-acc { font-size: 15px; font-weight: 800; color: var(--purple); letter-spacing: -.3px }
.ts-row-acc-label { font-size: 8px; color: var(--text3); text-transform: uppercase; letter-spacing: .3px; margin-top: 1px }
.ts-row-action { flex-shrink: 0 }
.ts-unlock-btn { padding: 6px 12px; border-radius: 8px; font-size: 11px; font-weight: 700; font-family: var(--font); cursor: pointer; border: none; transition: all .15s }
.ts-unlock-btn.buy { background: var(--text); color: #000 }
.ts-unlock-btn.buy:hover { opacity: .85 }
.ts-unlock-btn.owned { background: rgba(167,139,250,.08); color: var(--purple); border: 1px solid rgba(167,139,250,.15); cursor: default }

/* ── Locked Cell v4.2 — descriptive headline, purple unlock button ── */
.locked-box { border-radius: 12px; overflow: hidden; border: 1px solid rgba(167,139,250,.15); background: var(--surface-raised) }
.locked-inner { display: flex; align-items: center; gap: 12px; padding: 12px }
.locked-icon { width: 40px; height: 40px; border-radius: 10px; flex-shrink: 0; background: rgba(167,139,250,.08); display: flex; align-items: center; justify-content: center }
.locked-icon svg { width: 18px; height: 18px; stroke: var(--purple); fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round }
.locked-info { flex: 1; min-width: 0 }
.locked-type { font-size: 14px; font-weight: 700; letter-spacing: -.1px; color: var(--text) }
.locked-detail { font-size: 11px; color: var(--text3); margin-top: 1px }
.locked-btn { display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 8px 0; border-radius: 10px; flex-shrink: 0; font-family: var(--font); cursor: pointer; border: none; background: var(--purple); color: #000; min-width: 80px; box-shadow: 0 4px 12px rgba(167,139,250,.2); transition: transform .1s, opacity .15s, box-shadow .2s }
.locked-btn:hover { opacity: .95; transform: translateY(-1px); box-shadow: 0 6px 16px rgba(167,139,250,.3) }
.locked-btn:active { transform: translateY(0); scale: 0.96 }
.locked-btn-label { font-size: 9px; font-weight: 800; text-transform: uppercase; letter-spacing: .4px; opacity: .7; line-height: 1; margin-bottom: 2px }
.locked-btn-price { font-size: 14px; font-weight: 800; line-height: 1 }
.locked-also-in { padding: 8px 12px; font-size: 11px; color: var(--text3); border-top: 1px solid var(--border-light); background: rgba(167,139,250,0.03) }
.locked-also-in a { color: var(--purple); font-weight: 600; cursor: pointer; text-decoration: none }
.locked-also-in a:hover { text-decoration: underline }

/* ── Locked Pick View ── */
.pv-locked-card { border-radius: var(--radius-md); overflow: hidden; border: 1px solid rgba(167,139,250,.15); background: var(--surface-raised) }
.pv-locked-top { padding: 24px 20px; text-align: center }
.pv-locked-icon { width: 52px; height: 52px; border-radius: 14px; background: rgba(167,139,250,.08); display: flex; align-items: center; justify-content: center; margin: 0 auto 16px }
.pv-locked-icon svg { width: 24px; height: 24px; stroke: var(--purple); fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round }
.pv-locked-title { font-size: 18px; font-weight: 800; letter-spacing: -.2px; margin-bottom: 4px }
.pv-locked-sub { font-size: 13px; color: var(--text3); line-height: 1.5 }
.pv-unlock-btn { width: 100%; padding: 14px; border-radius: var(--radius-md); font-size: 15px; font-weight: 800; font-family: var(--font); cursor: pointer; border: none; background: var(--purple); color: #000; display: flex; align-items: center; justify-content: center; gap: 8px; box-shadow: 0 4px 16px rgba(167,139,250,.25); transition: transform .1s, opacity .15s, box-shadow .2s }
.pv-unlock-btn:hover { opacity: .95; transform: translateY(-1px); box-shadow: 0 6px 20px rgba(167,139,250,.35) }
.pv-unlock-btn:active { transform: translateY(0); scale: 0.98 }
.pv-unlock-btn svg { width: 18px; height: 18px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round }
.pv-or-sub { text-align: center; margin-top: 8px; font-size: 11px; color: var(--text3) }
.pv-or-sub a { color: var(--purple); font-weight: 600; cursor: pointer; text-decoration: none; background: none; border: none; font-family: var(--font); font-size: 11px }
.pv-or-sub a:hover { text-decoration: underline }
.pv-also-in { padding: 10px 20px; font-size: 11px; color: var(--text3); border-top: 1px solid var(--border-light); background: rgba(167,139,250,.03) }
.pv-also-in a { color: var(--purple); font-weight: 600; cursor: pointer; text-decoration: none }
.pv-also-in a:hover { text-decoration: underline }

/* ── Passview sticky buy footer ── */
.pv-sticky-footer { position: sticky; bottom: 0; z-index: 10; padding: 12px 20px 80px; background: linear-gradient(transparent, var(--surface) 30%) }
@media (min-width: 1080px) { .pv-sticky-footer { padding-bottom: 20px } }
.pv-buy-btn { width: 100%; padding: 14px; border-radius: var(--radius-md); font-size: 15px; font-weight: 800; font-family: var(--font); cursor: pointer; border: none; background: var(--purple); color: #000; display: flex; align-items: center; justify-content: center; gap: 8px; box-shadow: 0 4px 16px rgba(167,139,250,.25); transition: transform .1s, opacity .15s, box-shadow .2s }
.pv-buy-btn:hover { opacity: .95; transform: translateY(-1px); box-shadow: 0 6px 20px rgba(167,139,250,.35) }
.pv-buy-btn:active { transform: translateY(0); scale: 0.98 }
.pv-buy-btn svg { width: 18px; height: 18px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round }

/* Cookie banner raised when sticky buy footer is present */
body.has-sticky-buy .cookie-banner { bottom: calc(160px + max(12px, env(safe-area-inset-bottom))) }

/* Hide FAB on pick/passview pages */
.fab.fab-hidden { display: none !important }

/* ── Game strip inside pick box ── */
.locked-game { display: flex; align-items: center; justify-content: space-between; padding: 8px 12px; border-bottom: 1px solid var(--border-light) }
.locked-game-left { display: flex; align-items: center; gap: 5px }
.locked-game-team { font-size: 12px; font-weight: 600; color: var(--text2) }
.locked-game-vs { font-size: 9px; color: var(--text3); padding: 0 1px }
.locked-game-time { font-size: 10px; color: var(--text3); font-weight: 500 }

/* Sales page — isolated, centered layout */
#page-share { overflow-y: auto; -webkit-overflow-scrolling: touch }
#page-share .sp-sticky-cta { position: sticky; bottom: 0; z-index: 50; padding: 12px 20px 20px; background: linear-gradient(transparent, var(--surface) 30%) }
body.share-active .app { margin-left: 0 !important; max-width: var(--maxw) !important; margin: 0 auto !important }
body.share-active .desktop-sidebar { display: none !important }
body.share-active .bottom-nav { display: none !important }
body.share-active .fab { display: none !important }
body.share-active #desktopRight { display: none !important }

/* ── New game tab consensus design ── */
.gv2-market { padding: 16px; border-top: 1px solid rgba(255,255,255,.08) }
.gv2-label { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; color: var(--text3); margin-bottom: 8px }
.gv2-consensus { font-size: 18px; font-weight: 800; letter-spacing: -.3px; margin-bottom: 2px }
.gv2-meta { font-size: 11px; color: var(--text3); margin-bottom: 8px }
.gv2-meta .pct { color: var(--green); font-weight: 800 }
.gv2-bar { height: 3px; border-radius: 2px; display: flex; overflow: hidden; background: rgba(255,255,255,.04); margin-bottom: 12px }
.gv2-bar-fill { border-radius: 2px }
.gv2-expand { display: flex; align-items: center; justify-content: center; gap: 6px; width: 100%; padding: 10px 0; font-size: 12px; font-weight: 600; color: var(--text3); background: none; border: none; cursor: pointer; font-family: var(--font); transition: color .12s }
.gv2-expand:hover { color: var(--text2) }
.gv2-expand svg { width: 10px; height: 10px; stroke: currentColor; fill: none; stroke-width: 2 }
.gv2-panel { background: rgba(255,255,255,.03); border-radius: 8px; padding: 6px 14px; margin-top: 6px }

/* Pick rows — consistent sizing */
.gv2-row { display: flex; align-items: center; gap: 8px; padding: 8px 0; cursor: pointer; transition: background .12s }
.gv2-row:hover { background: rgba(255,255,255,.02) }
.gv2-row + .gv2-row { border-top: .5px solid rgba(255,255,255,.04) }
.gv2-row-av { width: 22px; height: 22px; border-radius: 50%; background: var(--accent2); display: flex; align-items: center; justify-content: center; font-size: 8px; font-weight: 700; flex-shrink: 0; overflow: hidden }
.gv2-row-name { font-size: 12px; font-weight: 600; color: var(--text2); display: flex; align-items: center; gap: 4px }
.gv2-row-pick { font-size: 12px; font-weight: 700; margin-top: 1px; display: flex; align-items: center; justify-content: space-between }
.gv2-row-odds { font-size: 11px; color: var(--text3); font-weight: 600; flex-shrink: 0 }

/* Locked pick rows */
.gv2-locked { display: flex; align-items: center; gap: 8px; padding: 8px 0 }
.gv2-locked + .gv2-row, .gv2-row + .gv2-locked { border-top: .5px solid rgba(255,255,255,.04) }
.gv2-locked-av { width: 22px; height: 22px; border-radius: 50%; background: rgba(167,139,250,.08); display: flex; align-items: center; justify-content: center; flex-shrink: 0 }
.gv2-locked-av svg { width: 10px; height: 10px; stroke: var(--purple); fill: none; stroke-width: 1.8 }
.gv2-locked-info { flex: 1; min-width: 0 }
.gv2-locked-name { font-size: 12px; font-weight: 600; color: var(--text2) }
.gv2-locked-sub { font-size: 10px; color: var(--text3); margin-top: 1px }
.gv2-locked-price { font-size: 11px; font-weight: 700; color: var(--purple); cursor: pointer; flex-shrink: 0 }

/* Analysis toggle */
.gv2-analysis-row { text-align: right; padding: 0 0 4px 30px }
.gv2-analysis-btn { font-size: 11px; color: var(--text3); cursor: pointer; display: inline-flex; align-items: center; gap: 3px; background: none; border: none; font-family: var(--font) }
.gv2-analysis-btn:hover { color: var(--text2) }
.gv2-analysis-btn svg { width: 8px; height: 8px; stroke: currentColor; fill: none; stroke-width: 2 }
.gv2-analysis-text { display: none; margin-top: 6px; font-size: 12px; color: var(--text2); line-height: 1.6; padding: 8px 10px; border-left: 2px solid rgba(167,139,250,.2); background: rgba(255,255,255,.02); border-radius: 0 6px 6px 0; text-align: left }

/* Player rows */
.gv2-player { display: flex; align-items: center; gap: 10px; padding: 12px 16px; cursor: pointer; transition: background .12s; border-top: 1px solid rgba(255,255,255,.08) }
.gv2-player:hover { background: rgba(255,255,255,.02) }
.gv2-player-av { width: 28px; height: 28px; border-radius: 50%; background: rgba(255,255,255,.05); display: flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 700; flex-shrink: 0; color: var(--text2) }
.gv2-player-name { font-size: 14px; font-weight: 700 }
.gv2-player-meta { font-size: 10px; color: var(--text3); margin-top: 1px }
.gv2-player-chev { width: 10px; height: 10px; stroke: var(--text3); fill: none; stroke-width: 2; flex-shrink: 0; transition: transform .2s }
.gv2-player-body { background: rgba(255,255,255,.02); border-bottom: .5px solid rgba(255,255,255,.06); padding: 0 16px }

/* Player stat market — compact version */
.gv2-stat { padding: 12px 0; border-top: .5px solid rgba(255,255,255,.06) }
.gv2-stat-header { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 6px }
.gv2-stat-left .gv2-label { margin-bottom: 2px }
.gv2-stat-pick { font-size: 15px; font-weight: 800; letter-spacing: -.2px }
.gv2-stat-right { font-size: 11px; color: var(--text3) }

/* Team group header */
.gv2-team-hdr { display: flex; align-items: center; gap: 8px; padding: 14px 16px 6px }
.gv2-team-name { font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; color: var(--text2) }
