/* ═══════════════════════════════════════════════════════════════
   LA3EEB DAILY — Design System
   Matches La3eeb app (Flutter) design tokens exactly
═══════════════════════════════════════════════════════════════ */

:root {
  /* ── Palette ── */
  --color-bg:           #0D0D0D;
  --color-surface:      #1A1A1A;
  --color-surface-raised: #242424;
  --color-primary:      #0A5C36;
  --color-primary-dim:  rgba(10, 92, 54, 0.15);
  --color-accent:       #F5B800;
  --color-accent-dim:   rgba(245, 184, 0, 0.15);
  --color-error:        #E53935;
  --color-error-dim:    rgba(229, 57, 53, 0.15);
  --color-border:       #2A2A2A;
  --color-text:         #FFFFFF;
  --color-text-secondary: #9E9E9E;

  /* ── Score state colors ── */
  --color-exact:   #43A047;   /* green  — exact score  +3 */
  --color-partial: #F5B800;   /* gold   — right result +1 */
  --color-wrong:   #E53935;   /* red    — wrong        +0 */

  /* ── Typography ── */
  --font:           'Cairo', system-ui, sans-serif;

  /* ── Spacing ── */
  --sp-xs:  4px;
  --sp-sm:  8px;
  --sp-md:  12px;
  --sp-lg:  16px;
  --sp-xl:  24px;

  /* ── Radii (matches La3eeb) ── */
  --r-sm:   6px;
  --r-md:   8px;
  --r-lg:   12px;
  --r-xl:   16px;
  --r-pill: 999px;

  /* ── Shadows ── */
  --shadow-card: 0 2px 12px rgba(0,0,0,0.4);
}

/* ═══════════════════════════════════════════════════════════════
   RESET & BASE
═══════════════════════════════════════════════════════════════ */

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

html {
  font-size: 16px;
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
}

body {
  font-family: var(--font);
  background-color: var(--color-bg);
  color: var(--color-text);
  direction: rtl;
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
  -webkit-font-smoothing: antialiased;
}

button {
  font-family: var(--font);
  cursor: pointer;
  border: none;
  background: none;
  -webkit-tap-highlight-color: transparent;
  user-select: none;
}

/* ═══════════════════════════════════════════════════════════════
   HEADER
═══════════════════════════════════════════════════════════════ */

.app-header {
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
  position: sticky;
  top: 0;
  z-index: 100;
}

.header-inner {
  display: flex;
  align-items: center;
  padding: var(--sp-md) var(--sp-lg);
  max-width: 1280px;
  margin: 0 auto;
  width: 100%;
  gap: var(--sp-sm);
}

/* Logo stays on the right (RTL start), pushes nothing */
.header-inner .brand {
  flex: 1;
}

/* Date centered */
.header-inner .header-date {
  flex: 0 0 auto;
}

/* Hamburger on the far left (RTL end) */
.hamburger-btn {
  flex: 1;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  color: var(--color-text-secondary);
  background: none;
  border: none;
  cursor: pointer;
  padding: 6px;
  border-radius: var(--r-sm);
  transition: color 0.15s, background 0.15s;
}
.hamburger-btn:hover { color: var(--color-text); background: var(--color-surface-raised); }

/* Hide date in header on mobile; show in menu */
@media (max-width: 899px) {
  .header-inner .header-date { display: none; }
}

/* ── Nav Menu (slide-in from left) ── */
.nav-menu {
  position: fixed;
  inset: 0;
  z-index: 400;
  pointer-events: none;
}
.nav-menu.is-open { pointer-events: auto; }

.nav-menu-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  opacity: 0;
  transition: opacity 0.25s ease;
}
.nav-menu.is-open .nav-menu-backdrop { opacity: 1; }

.nav-menu-panel {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  width: 260px;
  background: var(--color-surface);
  border-right: 1px solid var(--color-border);
  display: flex;
  flex-direction: column;
  transform: translateX(-100%);
  transition: transform 0.28s cubic-bezier(0.32, 0.72, 0, 1);
  padding: var(--sp-lg);
  gap: var(--sp-lg);
}
.nav-menu.is-open .nav-menu-panel { transform: translateX(0); }

.nav-menu-top {
  display: flex;
  justify-content: flex-end;
}

.nav-menu-close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  color: var(--color-text-secondary);
  cursor: pointer;
  transition: background 0.15s;
}
.nav-menu-close:hover { background: var(--color-border); color: var(--color-text); }

.nav-menu-date-row {
  font-size: 15px;
  font-weight: 700;
  color: var(--color-text-secondary);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--r-pill);
  padding: 8px 16px;
  text-align: center;
}

.nav-menu-links {
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin-top: var(--sp-sm);
}

.nav-menu-link {
  display: flex;
  align-items: center;
  padding: 11px var(--sp-md);
  border-radius: var(--r-md);
  font-family: var(--font);
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--color-text);
  background: none;
  border: none;
  cursor: pointer;
  text-align: right;
  width: 100%;
  transition: background 0.15s;
}
.nav-menu-link:hover { background: var(--color-surface-raised); }
.nav-menu-link:active { background: var(--color-border); }

/* ── Static page overlay ── */
.page-view-title {
  flex: 1;
  text-align: center;
  font-size: 16px;
  font-weight: 700;
  color: var(--color-text);
  margin: 0;
}

.page-view-body {
  padding: var(--sp-xl) var(--sp-lg);
  max-width: 680px;
  margin: 0 auto;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: var(--sp-lg);
  line-height: 1.9;
  color: var(--color-text-secondary);
  font-size: 0.92rem;
  font-weight: 500;
}

.page-view-body h3 {
  font-size: 1rem;
  font-weight: 800;
  color: var(--color-text);
  margin-top: var(--sp-sm);
}

.page-view-body p { margin: 0; }

.page-view-body a {
  color: var(--color-accent);
  text-decoration: none;
}
.page-view-body a:hover { text-decoration: underline; }

.brand {
  display: flex;
  align-items: center;
  gap: var(--sp-sm);
}

.brand-icon {
  display: flex;
  align-items: center;
}

/* ─── SVG Icon system ───────────────────────────────────────── */

/* Base icon: inherits color from CSS `color`, scaled via width/height */
.icon {
  display: inline-block;
  vertical-align: middle;
  flex-shrink: 0;
  overflow: visible;
}

/* Sizes */
.icon-sm   { width: 16px; height: 16px; }
.icon-md   { width: 20px; height: 20px; }
.icon-lg   { width: 24px; height: 24px; }
.icon-brand { width: 30px; height: 30px; }
.icon-empty { width: 56px; height: 56px; }

/* Color utilities — drives `stroke="currentColor"` / `fill="currentColor"` */
.icon-accent    { color: var(--color-accent); }
.icon-primary   { color: var(--color-primary); }
.icon-secondary { color: var(--color-text-secondary); }
.icon-success   { color: var(--color-exact); }
.icon-error     { color: var(--color-error); }

/* Live pulsing dot — replaces 🔴 emoji */
.live-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-accent);
  margin-inline-end: 4px;
  vertical-align: middle;
  animation: pulse-dot 1.4s ease-in-out infinite;
}

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

/* Streak stat value alignment */
.stat-streak {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
}

.brand-text {
  display: flex;
  align-items: baseline;
  gap: 4px;
}

.brand-name {
  font-size: 22px;
  font-weight: 900;
  color: var(--color-accent);
  line-height: 1;
}

.brand-sub {
  font-size: 13px;
  font-weight: 600;
  color: var(--color-text-secondary);
}

.header-date {
  font-size: 13px;
  font-weight: 600;
  color: var(--color-text-secondary);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--r-pill);
  padding: 4px 12px;
}

/* ═══════════════════════════════════════════════════════════════
   STATS BAR
═══════════════════════════════════════════════════════════════ */

.stats-bar {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
  padding: var(--sp-md) var(--sp-lg);
}

.stat-item {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
}

.stat-value {
  font-size: 20px;
  font-weight: 700;
  color: var(--color-accent);
  line-height: 1;
}

.stat-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--color-text-secondary);
  text-align: center;
}

.stat-separator {
  width: 1px;
  height: 36px;
  background: var(--color-border);
  flex-shrink: 0;
}

/* ═══════════════════════════════════════════════════════════════
   MAIN / LAYOUT
═══════════════════════════════════════════════════════════════ */

#app {
  flex: 1;
  width: 100%;
}

.app-layout {
  max-width: 640px;
  margin: 0 auto;
  width: 100%;
  padding: var(--sp-lg) var(--sp-md);
  padding-bottom: calc(var(--sp-xl) * 2);
}

/* Hidden on mobile, desktop media query below overrides */
.sidebar-col { display: none; }

/* ── Desktop 3-column layout: [empty] [matches] [friends] ────── */
@media (min-width: 900px) {
  .app-layout {
    display: grid;
    grid-template-areas: "empty matches sidebar"; /* visual L→R, ignores RTL */
    grid-template-columns: 300px minmax(0, 640px) 300px;
    gap: var(--sp-xl);
    justify-content: center;
    padding: var(--sp-xl) var(--sp-lg);
    padding-bottom: calc(var(--sp-xl) * 2);
    max-width: none;
    margin: 0;
    align-items: start;
  }

  .app-feed {
    grid-area: matches;
  }

  .sidebar-col {
    grid-area: empty;
    display: flex;
    flex-direction: column;
    gap: var(--sp-md);
    position: sticky;
    top: 76px;
  }

  #friends-section {
    margin-top: 0;
    background:
      repeating-linear-gradient(
        180deg,
        transparent 0px,
        transparent 22px,
        rgba(0, 0, 0, 0.12) 22px,
        rgba(0, 0, 0, 0.12) 44px
      ),
      linear-gradient(170deg, #0f4a2a 0%, #0a3020 55%, #061a0e 100%);
    border-color: rgba(10, 92, 54, 0.45);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5), inset 0 1px 0 rgba(255,255,255,0.05);
  }

  #friends-section .friends-section-title {
    background: none;
    border-bottom-color: transparent;
    font-size: 1.125rem;
  }

  .sidebar-points-box {
    display: flex;
    flex-direction: column;
    gap: var(--sp-sm);
    padding: var(--sp-md) var(--sp-lg);
    background: var(--color-surface);
    border-radius: var(--r-lg);
    border: 1px solid var(--color-border);
  }

  .sidebar-points-title {
    display: flex;
    align-items: center;
    gap: var(--sp-sm);
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: var(--sp-xs);
  }

  .sidebar-points-title .icon {
    color: var(--color-accent);
  }

  .sidebar-points-row {
    display: flex;
    align-items: center;
    gap: var(--sp-sm);
  }

  .sidebar-points-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: var(--r-sm);
    font-size: 0.85rem;
    font-weight: 900;
    flex-shrink: 0;
  }

  .sidebar-points-badge.exact   { background: rgba(67,160,71,0.25);  color: var(--color-exact);   border: 1px solid rgba(67,160,71,0.4); }
  .sidebar-points-badge.partial { background: rgba(245,184,0,0.2);   color: var(--color-accent);  border: 1px solid rgba(245,184,0,0.4); }
  .sidebar-points-badge.wrong   { background: rgba(229,57,53,0.15);  color: var(--color-error);   border: 1px solid rgba(229,57,53,0.35); }

  .sidebar-points-label {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--color-text-secondary);
  }

  .sidebar-howto-box {
    background: var(--color-surface);
    border-radius: var(--r-lg);
    border: 1px solid var(--color-border);
    padding: var(--sp-md) var(--sp-lg);
    display: flex;
    flex-direction: column;
    gap: var(--sp-sm);
  }

  .sidebar-howto-title {
    display: flex;
    align-items: center;
    gap: var(--sp-sm);
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: var(--sp-xs);
  }

  .sidebar-howto-title .icon {
    color: var(--color-accent);
  }

  .sidebar-howto-text {
    font-size: 0.82rem;
    font-weight: 600;
    line-height: 1.75;
    color: var(--color-text-secondary);
  }

  #friends-section .friends-section-title .icon {
    color: var(--color-accent);
    filter: drop-shadow(0 0 6px rgba(245,184,0,0.5));
  }

  #friends-section .friends-room-card {
    border-bottom-color: transparent;
  }

  #friends-section .friends-room-icon,
  #friends-section .friends-room-card .icon {
    color: #fff !important;
  }

  #friends-section .friends-room-name {
    font-weight: 800;
  }

  #friends-section .friends-room-card:hover {
    background: rgba(255, 255, 255, 0.06);
  }

  #friends-section .friends-actions {
    background: none;
  }

  .sidebar-stats-box {
    background: var(--color-surface);
    border-radius: var(--r-lg);
    border: 1px solid var(--color-border);
    padding: var(--sp-md) var(--sp-lg);
    display: flex;
    flex-direction: column;
    gap: var(--sp-md);
  }

  .sidebar-stats-title {
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--color-text);
  }

  .sidebar-stats-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--sp-sm);
  }

  .sidebar-stat-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 3px;
    background: var(--color-bg);
    border-radius: var(--r-md);
    padding: var(--sp-sm) var(--sp-xs);
  }

  .sidebar-stat-val {
    font-size: 1.4rem;
    font-weight: 900;
    color: var(--color-accent);
    line-height: 1;
  }

  .sidebar-stat-lbl {
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--color-text-secondary);
    text-align: center;
  }

  #sidebar-day-chart {
    margin-top: var(--sp-xs);
  }
}

/* ── Decorative pitch SVG — desktop sidebar only ─────────────── */
.friends-pitch-decor {
  display: none;
}

@media (min-width: 900px) {
  .friends-pitch-decor {
    display: block;
    position: absolute;
    inset: 0;
    pointer-events: none;
    overflow: hidden;
    border-radius: var(--r-lg);
  }

  .friends-pitch-decor svg {
    width: 100%;
    height: 100%;
  }

  #friends-section > *:not(.friends-pitch-decor) {
    position: relative;
    z-index: 1;
  }
}

/* ═══════════════════════════════════════════════════════════════
   LOADING STATE
═══════════════════════════════════════════════════════════════ */

.loading-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--sp-lg);
  padding: 60px var(--sp-lg);
  color: var(--color-text-secondary);
  font-size: 15px;
  font-weight: 600;
}

.spinner {
  width: 40px;
  height: 40px;
  border: 3px solid var(--color-border);
  border-top-color: var(--color-accent);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}

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

/* ═══════════════════════════════════════════════════════════════
   EMPTY STATE
═══════════════════════════════════════════════════════════════ */

.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--sp-md);
  padding: 60px var(--sp-lg);
  text-align: center;
}

/* .icon-empty handles size; color set by .icon-secondary */

.empty-state h2 {
  font-size: 20px;
  font-weight: 700;
}

.empty-state p {
  font-size: 14px;
  color: var(--color-text-secondary);
}

/* ═══════════════════════════════════════════════════════════════
   MOCK BANNER
═══════════════════════════════════════════════════════════════ */

.game-description {
  background: rgba(10, 92, 54, 0.15);
  border: 1px solid rgba(10, 92, 54, 0.4);
  border-radius: var(--r-md);
  padding: 8px 14px;
  font-size: 12px;
  font-weight: 600;
  color: #4CAF50;
  text-align: center;
  margin-bottom: var(--sp-md);
}

.mock-banner {
  background: rgba(245, 184, 0, 0.1);
  border: 1px solid rgba(245, 184, 0, 0.3);
  border-radius: var(--r-md);
  padding: 8px 14px;
  font-size: 12px;
  font-weight: 600;
  color: var(--color-accent);
  text-align: center;
  margin-bottom: var(--sp-md);
}

/* ═══════════════════════════════════════════════════════════════
   FIXTURES LIST
═══════════════════════════════════════════════════════════════ */

.fixtures-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-sm);
}

/* ─── League group header ─── */
.date-separator {
  display: flex;
  align-items: center;
  gap: var(--sp-md);
  margin: var(--sp-sm) 0 var(--sp-xs);
}

.date-separator::before,
.date-separator::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--color-border);
}

.date-separator-label {
  font-size: 13px;
  font-weight: 700;
  color: var(--color-text-secondary);
  white-space: nowrap;
  padding: 3px 10px;
  border: 1px solid var(--color-border);
  border-radius: var(--r-pill);
}

.date-separator:first-child {
  margin-top: 0;
}

.league-header {
  display: flex;
  align-items: center;
  gap: var(--sp-sm);
  padding: 0 var(--sp-xs);
  margin-top: calc(-1 * var(--sp-sm));
}

.league-header:first-child { margin-top: 0; }

.league-emoji {
  font-size: 18px;
  line-height: 1;
}

.league-name {
  font-size: 13px;
  font-weight: 700;
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

/* ═══════════════════════════════════════════════════════════════
   MATCH CARD
═══════════════════════════════════════════════════════════════ */

.match-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--r-lg);
  padding: var(--sp-md);
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  overflow: hidden;
}

.match-card:hover {
  border-color: #3a3a3a;
}

/* ─── Card header row ─── */
.card-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--sp-md);
}

.kickoff-time {
  font-size: 12px;
  font-weight: 700;
  color: var(--color-text-secondary);
  font-variant-numeric: tabular-nums;
}

.match-status-badge {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: var(--r-sm);
}

.match-status-badge.status-upcoming {
  background: var(--color-primary-dim);
  color: #4CAF50;
}

.match-status-badge.status-live {
  background: rgba(245, 184, 0, 0.15);
  color: var(--color-accent);
  animation: pulse-live 1.4s ease-in-out infinite;
}

.match-status-badge.status-finished {
  background: var(--color-border);
  color: var(--color-text-secondary);
}

.match-status-badge.status-locked {
  background: var(--color-border);
  color: var(--color-text-secondary);
}

@keyframes pulse-live {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.6; }
}

/* ─── Teams + prediction row ─── */
.card-body {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-sm);
}

.team {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  min-width: 0;
}

.team-home { align-items: flex-end; text-align: end; }
.team-away { align-items: flex-start; text-align: start; }

.team-flag {
  display: inline-block;
  width: 28px;
  height: 21px;
  border-radius: 3px;
  flex-shrink: 0;
  overflow: hidden;
}

.team-name {
  font-size: 14px;
  font-weight: 700;
  color: var(--color-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}

.team-short {
  display: none;
}

/* ─── Prediction steppers ─── */
.prediction-area {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}

.vs-dash {
  font-size: 18px;
  font-weight: 900;
  color: var(--color-text-secondary);
  padding: 0 2px;
}

.stepper {
  display: flex;
  align-items: center;
  gap: 0;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--r-md);
  overflow: hidden;
  transition: border-color 0.2s ease;
}

.stepper:focus-within {
  border-color: var(--color-primary);
}

.step-btn {
  width: 36px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  font-weight: 700;
  color: var(--color-text-secondary);
  transition: background 0.15s ease, color 0.15s ease;
  touch-action: manipulation;
}

.step-btn:active:not(:disabled) {
  background: var(--color-primary-dim);
  color: var(--color-accent);
}

.step-btn:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}

.step-val {
  min-width: 32px;
  text-align: center;
  font-size: 20px;
  font-weight: 900;
  color: var(--color-text);
  font-variant-numeric: tabular-nums;
  user-select: none;
}

/* ─── Locked state ─── */
.match-card.is-locked .stepper {
  opacity: 0.55;
  pointer-events: none;
}

.match-card.is-locked .step-btn {
  cursor: not-allowed;
}

/* ─── Result row (revealed after FT) ─── */
.result-row {
  margin-top: var(--sp-md);
  padding-top: var(--sp-md);
  border-top: 1px solid var(--color-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-sm);
}

.actual-score-label {
  font-size: 11px;
  color: var(--color-text-secondary);
  font-weight: 600;
}

.actual-score {
  font-size: 16px;
  font-weight: 900;
  color: var(--color-text);
  font-variant-numeric: tabular-nums;
}

.points-badge {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  border-radius: var(--r-pill);
  font-size: 13px;
  font-weight: 700;
}

.points-badge.exact {
  background: rgba(67, 160, 71, 0.15);
  border: 1px solid rgba(67, 160, 71, 0.4);
  color: var(--color-exact);
}

.points-badge.partial {
  background: var(--color-accent-dim);
  border: 1px solid rgba(245, 184, 0, 0.4);
  color: var(--color-partial);
}

.points-badge.wrong {
  background: var(--color-error-dim);
  border: 1px solid rgba(229, 57, 53, 0.4);
  color: var(--color-error);
}

.points-badge.pending {
  background: var(--color-border);
  border: 1px solid transparent;
  color: var(--color-text-secondary);
}

/* ─── Live score overlay ─── */
.live-score-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-sm);
  margin-top: var(--sp-sm);
}

.live-score {
  font-size: 13px;
  font-weight: 700;
  color: var(--color-error);
  padding: 2px 8px;
  background: rgba(229, 57, 53, 0.1);
  border-radius: var(--r-pill);
}

/* ═══════════════════════════════════════════════════════════════
   SHARE SECTION
═══════════════════════════════════════════════════════════════ */

.share-section {
  margin-top: var(--sp-xl);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-md);
}

.share-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-sm);
  width: 100%;
  max-width: 400px;
  padding: 14px var(--sp-xl);
  background: #25D366;   /* WhatsApp green */
  color: #fff;
  font-size: 16px;
  font-weight: 700;
  border-radius: var(--r-lg);
  transition: filter 0.15s ease, transform 0.1s ease;
  box-shadow: 0 4px 16px rgba(37, 211, 102, 0.25);
}

.share-btn:active {
  filter: brightness(0.9);
  transform: scale(0.98);
}

.share-icon { font-size: 18px; }

/* ═══════════════════════════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════════════════════════ */

.app-footer {
  text-align: center;
  padding: var(--sp-lg);
  font-size: 11px;
  color: var(--color-text-secondary);
  border-top: 1px solid var(--color-border);
}

/* ═══════════════════════════════════════════════════════════════
   UTILITY
═══════════════════════════════════════════════════════════════ */

.hidden { display: none !important; }

/* ═══════════════════════════════════════════════════════════════
   ANIMATIONS
═══════════════════════════════════════════════════════════════ */

@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

.match-card {
  animation: fadeInUp 0.25s ease both;
}

.match-card:nth-child(1) { animation-delay: 0.00s; }
.match-card:nth-child(2) { animation-delay: 0.04s; }
.match-card:nth-child(3) { animation-delay: 0.08s; }
.match-card:nth-child(4) { animation-delay: 0.12s; }
.match-card:nth-child(5) { animation-delay: 0.16s; }
.match-card:nth-child(6) { animation-delay: 0.20s; }
.match-card:nth-child(7) { animation-delay: 0.24s; }
.match-card:nth-child(8) { animation-delay: 0.28s; }

@keyframes resultReveal {
  from { opacity: 0; transform: scaleY(0.8); transform-origin: top; }
  to   { opacity: 1; transform: scaleY(1); }
}

.result-row {
  animation: resultReveal 0.3s ease both;
}

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE — very wide screens get centered card stack
═══════════════════════════════════════════════════════════════ */

@media (min-width: 641px) {
  .app-header,
  .stats-bar {
    /* already capped via .header-inner, but bar needs its own cap */
  }

  .stats-bar {
    max-width: 100%;
  }

  #app {
    padding: var(--sp-xl) var(--sp-lg);
  }

  .team-name {
    font-size: 15px;
  }

  .step-btn {
    width: 40px;
  }
}

/* ─── Narrow phones: shrink team names ─── */
@media (max-width: 360px) {
  .team-name {
    font-size: 12px;
  }
  .step-btn {
    width: 32px;
    height: 40px;
    font-size: 18px;
  }
  .step-val {
    min-width: 28px;
    font-size: 18px;
  }
}

/* ═══════════════════════════════════════════════════════════════
   SHARE MODAL — bottom sheet
═══════════════════════════════════════════════════════════════ */

.share-modal-body-lock {
  overflow: hidden;
  position: fixed;
  width: 100%;
}

.share-modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.7);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  z-index: 200;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

.share-modal-backdrop--visible {
  opacity: 1;
  pointer-events: auto;
}

.share-modal {
  position: fixed;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%) translateY(100%);
  width: 100%;
  max-width: 480px;
  z-index: 201;
  background: var(--color-surface);
  border-top: 1px solid var(--color-border);
  border-radius: var(--r-xl) var(--r-xl) 0 0;
  padding: 0 var(--sp-lg) calc(var(--sp-xl) + env(safe-area-inset-bottom, 0px));
  max-height: 92dvh;
  overflow-y: auto;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  transition: transform 0.35s cubic-bezier(0.32,0.72,0,1);
}

.share-modal--open {
  transform: translateX(-50%) translateY(0);
}

.share-modal-handle {
  width: 40px;
  height: 4px;
  background: var(--color-border);
  border-radius: var(--r-pill);
  margin: 12px auto var(--sp-md);
}

.share-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--sp-md);
}

.share-modal-title {
  font-size: 18px;
  font-weight: 700;
  color: var(--color-text);
}

.share-modal-close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  color: var(--color-text-secondary);
  transition: background 0.15s ease;
}

.share-modal-close:active {
  background: var(--color-border);
  color: var(--color-text);
}

/* ─── Name input ─── */
.share-name-row {
  display: flex;
  flex-direction: column;
  gap: var(--sp-xs);
  margin-bottom: var(--sp-md);
}

.share-name-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--color-text-secondary);
}

.share-name-optional {
  font-weight: 400;
  opacity: 0.6;
}

.share-name-input {
  font-family: var(--font);
  font-size: 16px;
  font-weight: 700;
  color: var(--color-text);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--r-md);
  padding: 10px 14px;
  direction: rtl;
  outline: none;
  width: 100%;
  transition: border-color 0.2s ease;
}

.share-name-input:focus { border-color: var(--color-primary); }
.share-name-input::placeholder { color: var(--color-text-secondary); font-weight: 400; }

/* ─── Canvas preview ─── */
.share-canvas-wrap {
  width: min(100%, 420px);
  aspect-ratio: 1 / 1;
  flex-shrink: 0;
  align-self: center;
  border-radius: var(--r-lg);
  overflow: hidden;
  border: 1px solid var(--color-border);
  background: #0A3D1F;
}

.share-canvas-wrap canvas {
  width: 100%;
  height: 100%;
  display: block;
}

/* ─── Download button ─── */
.share-download-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-sm);
  width: 100%;
  padding: 13px var(--sp-xl);
  background: var(--color-primary);
  color: var(--color-text);
  font-family: var(--font);
  font-size: 15px;
  font-weight: 700;
  border-radius: var(--r-lg);
  margin-bottom: var(--sp-md);
  transition: filter 0.15s ease, transform 0.1s ease;
}

.share-download-btn:active {
  filter: brightness(0.88);
  transform: scale(0.98);
}

/* ─── Platform grid ─── */
.share-platforms {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-sm);
  margin-bottom: var(--sp-lg);
}

.share-platform-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: var(--sp-sm) var(--sp-xs);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--r-lg);
  transition: border-color 0.15s ease, transform 0.1s ease;
  cursor: pointer;
}

.share-platform-btn:active {
  transform: scale(0.95);
  border-color: #444;
}

.platform-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 46px;
  height: 46px;
  border-radius: 50%;
}

.platform-label {
  font-size: 11px;
  font-weight: 700;
  font-family: var(--font);
  color: var(--color-text-secondary);
}

.platform-whatsapp  { background: rgba(37,211,102,0.15);  color: #25D366; }
.platform-twitter   { background: rgba(255,255,255,0.08); color: var(--color-text); }
.platform-telegram  { background: rgba(36,161,222,0.15);  color: #24A1DE; }
.platform-facebook  { background: rgba(24,119,242,0.15);  color: #1877F2; }
.platform-instagram { background: rgba(225,48,108,0.15);  color: #E1306C; }
.platform-copylink  { background: var(--color-primary-dim); color: var(--color-accent); }

/* ─── Toast ─── */
.share-toast {
  position: fixed;
  bottom: calc(env(safe-area-inset-bottom, 0px) + 20px);
  left: 50%;
  transform: translateX(-50%) translateY(12px);
  background: var(--color-text);
  color: var(--color-bg);
  font-family: var(--font);
  font-size: 13px;
  font-weight: 700;
  padding: 10px 20px;
  border-radius: var(--r-pill);
  white-space: nowrap;
  z-index: 300;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease, transform 0.2s ease;
}

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

/* ═══════════════════════════════════════════════════════════════
   PREDICTION VIEW
═══════════════════════════════════════════════════════════════ */

.predict-view {
  position: fixed;
  inset: 0;
  background: var(--color-bg);
  z-index: 200;
  display: flex;
  flex-direction: column;
  transform: translateY(100%);
  transition: transform 0.28s cubic-bezier(0.4, 0, 0.2, 1);
  overflow-y: auto;
}

.predict-view.is-open {
  transform: translateY(0);
}

.predict-header {
  display: flex;
  align-items: center;
  padding: 14px var(--sp-lg);
  border-bottom: 1px solid var(--color-border);
  position: sticky;
  top: 0;
  background: var(--color-bg);
  z-index: 1;
  gap: var(--sp-sm);
}

.predict-back-btn {
  background: none;
  border: none;
  color: var(--color-text);
  cursor: pointer;
  padding: 8px;
  border-radius: var(--r-sm);
  display: flex;
  align-items: center;
  flex-shrink: 0;
  transition: background 0.15s;
}

.predict-back-btn:hover { background: var(--color-surface); }

.predict-league-label {
  flex: 1;
  text-align: center;
  font-size: 14px;
  font-weight: 700;
  color: var(--color-text-secondary);
}

.predict-header-spacer {
  width: 40px;
  flex-shrink: 0;
}


.predict-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--sp-xl) var(--sp-lg);
  gap: var(--sp-xl);
}

.predict-meta-row {
  display: flex;
  align-items: center;
  gap: var(--sp-sm);
  font-size: 14px;
  color: var(--color-text-secondary);
}

.predict-time-val {
  font-weight: 700;
  font-size: 15px;
  color: var(--color-text);
}

.predict-layout {
  display: flex;
  align-items: center;
  width: 100%;
  gap: var(--sp-md);
}

.predict-team-col {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.predict-flag-lg {
  width: 72px !important;
  height: 54px !important;
  border-radius: 6px;
  display: inline-block !important;
}

.predict-flag-placeholder {
  width: 72px;
  height: 54px;
  border-radius: 6px;
  background: var(--color-surface);
  display: inline-block;
}

.predict-team-name-lg {
  font-size: 14px;
  font-weight: 700;
  text-align: center;
  line-height: 1.3;
  word-break: break-word;
}

.predict-score-area {
  display: flex;
  align-items: center;
  gap: var(--sp-md);
  flex-shrink: 0;
}

.predict-score-col {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}

.predict-score-val {
  font-size: 68px;
  font-weight: 900;
  color: var(--color-accent);
  min-width: 64px;
  text-align: center;
  line-height: 1;
}

.predict-dash-lg {
  font-size: 36px;
  font-weight: 300;
  color: var(--color-text-secondary);
  align-self: center;
  margin-top: 12px; /* align with score numbers */
}

.p-step-btn {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 2px solid var(--color-border);
  background: var(--color-surface);
  color: var(--color-text);
  font-size: 24px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s, border-color 0.15s;
  font-family: inherit;
  flex-shrink: 0;
  line-height: 1;
}

.p-step-btn:hover:not(:disabled) {
  border-color: var(--color-accent);
  background: var(--color-accent-dim);
}

.p-step-btn:active:not(:disabled) {
  transform: scale(0.92);
}

.p-step-btn:disabled {
  opacity: 0.3;
  cursor: default;
}

.predict-result-info {
  background: var(--color-surface);
  border-radius: var(--r-md);
  padding: 12px var(--sp-lg);
  font-size: 14px;
  color: var(--color-text-secondary);
  text-align: center;
  width: 100%;
}

.predict-footer {
  padding: var(--sp-lg);
  display: flex;
  flex-direction: column;
  gap: var(--sp-sm);
  border-top: 1px solid var(--color-border);
}

.predict-confirm-btn {
  width: 100%;
  padding: 16px;
  background: var(--color-primary);
  color: #fff;
  border: none;
  border-radius: var(--r-lg);
  font-size: 17px;
  font-weight: 700;
  font-family: inherit;
  cursor: pointer;
  transition: opacity 0.15s;
}

.predict-confirm-btn:hover:not(:disabled) { opacity: 0.85; }

.predict-confirm-btn:disabled {
  opacity: 0.4;
  cursor: default;
}

.predict-share-btn {
  width: 100%;
  padding: 14px;
  background: transparent;
  border: 2px solid var(--color-border);
  color: var(--color-text);
  border-radius: var(--r-lg);
  font-size: 15px;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-sm);
  transition: border-color 0.15s;
}

.predict-share-btn:hover { border-color: var(--color-accent); }

/* ── Share view content (scrollable body inside predict-view shell) ── */

.share-view-content {
  padding: var(--sp-lg);
  display: flex;
  flex-direction: column;
  gap: var(--sp-lg);
}

/* ══════════════════════════════════════════════
   FRIENDS SECTION (main page)
══════════════════════════════════════════════ */

.friends-section {
  margin-top: var(--sp-lg);
  background: var(--color-surface);
  border-radius: var(--r-lg);
  border: 1px solid var(--color-border);
  overflow: hidden;
  position: relative;
}

.friends-section-title {
  display: flex;
  align-items: center;
  gap: var(--sp-sm);
  padding: var(--sp-md) var(--sp-lg);
  font-weight: 700;
  font-size: 1rem;
  border-bottom: 1px solid var(--color-border);
  color: var(--color-text);
}
.friends-section-title .icon {
  color: var(--color-accent);
}

.friends-section-desc {
  display: none; /* mobile: hidden, shown only in desktop sidebar */
}


@media (min-width: 900px) {
  .friends-section-desc {
    display: block;
    position: relative;
    z-index: 1;
    padding: var(--sp-sm) var(--sp-lg);
    font-size: 0.96rem;
    font-weight: 600;
    line-height: 1.7;
    color: rgba(255, 255, 255, 0.75);
    border-bottom: none;
  }
}

.friends-rooms-list {
  display: flex;
  flex-direction: column;
}

.friends-room-card {
  display: flex;
  align-items: center;
  gap: var(--sp-sm);
  padding: var(--sp-sm) var(--sp-lg);
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--color-border);
  cursor: pointer;
  font-family: 'Cairo', sans-serif;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--color-text);
  width: 100%;
  text-align: right;
  transition: background 0.15s;
}
.friends-room-card:active { background: var(--color-surface-raised); }
.friends-room-icon { color: var(--color-text-secondary); }
.friends-room-name { flex: 1; }

.friends-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-sm);
  padding: var(--sp-md);
}

.friends-create-btn,
.friends-join-btn {
  padding: var(--sp-sm) var(--sp-md);
  border-radius: var(--r-md);
  font-family: 'Cairo', sans-serif;
  font-size: 0.9rem;
  font-weight: 700;
  cursor: pointer;
  border: none;
  transition: opacity 0.15s;
}
.friends-create-btn {
  background: var(--color-primary);
  color: #fff;
}
.friends-join-btn {
  background: var(--color-surface-raised);
  color: var(--color-text);
  border: 1px solid var(--color-border);
}
.friends-create-btn:active,
.friends-join-btn:active { opacity: 0.75; }

/* ══════════════════════════════════════════════
   ROOM VIEW
══════════════════════════════════════════════ */

.room-invite-btn {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--color-text-secondary);
  padding: var(--sp-xs);
  border-radius: var(--r-md);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color 0.15s, background 0.15s;
}
.room-invite-btn:hover { background: var(--color-surface); color: var(--color-text); }

.room-content {
  max-width: 640px;
  width: 100%;
  margin: 0 auto;
  padding: var(--sp-lg) var(--sp-md);
  display: flex;
  flex-direction: column;
  gap: var(--sp-lg);
}

.room-name-heading {
  font-size: 1.2rem;
  font-weight: 800;
  color: var(--color-text);
  margin: 0;
}

.room-loading {
  display: flex;
  justify-content: center;
  padding: var(--sp-xl) 0;
}

.room-section {
  display: flex;
  flex-direction: column;
  gap: var(--sp-sm);
}

.room-section-title {
  display: flex;
  align-items: center;
  gap: var(--sp-xs);
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: var(--sp-xs);
}
.room-section-title .icon {
  color: var(--color-accent);
  flex-shrink: 0;
}

/* Leaderboard */
.leaderboard-row {
  display: flex;
  align-items: center;
  gap: var(--sp-sm);
  padding: var(--sp-sm) var(--sp-md);
  background: var(--color-surface-raised);
  border-radius: var(--r-md);
  border: 1px solid transparent;
}
.leaderboard-row.is-me {
  border-color: var(--color-primary);
}
.leaderboard-rank {
  min-width: 26px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.member-avatar {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 0.9rem;
  color: #fff;
  flex-shrink: 0;
}
.member-avatar.is-me {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}
.leaderboard-name {
  flex: 1;
  font-weight: 600;
  font-size: 0.95rem;
}
.leaderboard-name.is-me {
  font-weight: 800;
  color: var(--color-text);
}
.leaderboard-pts {
  font-weight: 800;
  font-size: 1rem;
  color: var(--color-gold, #F5C518);
}
.leaderboard-pts small {
  font-size: 0.7rem;
  font-weight: 400;
  color: var(--color-text-secondary);
  margin-right: 2px;
}

/* Room fixtures */
.room-fixture-row {
  background: var(--color-surface-raised);
  border-radius: var(--r-md);
  padding: var(--sp-sm) var(--sp-md);
  display: flex;
  flex-direction: column;
  gap: var(--sp-xs);
}
.room-fixture-info {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.room-fixture-teams {
  font-weight: 700;
  font-size: 0.9rem;
}
.room-fixture-time {
  font-size: 0.75rem;
  color: var(--color-text-secondary);
}
.room-fixture-preds {
  display: flex;
  gap: var(--sp-md);
  flex-wrap: wrap;
  padding-top: var(--sp-xs);
  border-top: 1px solid var(--color-border);
}
/* Members predictions strip — sits below a match-card */
.room-members-preds {
  display: flex;
  flex-direction: column;
  gap: 5px;
  padding: var(--sp-sm) var(--sp-md);
  border-top: 1px solid var(--color-border);
  background: rgba(0,0,0,0.12);
}
.fixture-member-cell {
  display: flex;
  align-items: center;
  gap: var(--sp-sm);
}
.member-pred-name {
  flex: 1;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--color-text-secondary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.member-pred-name.is-me {
  color: var(--color-text);
  font-weight: 700;
}
.fixture-pred-val {
  font-size: 0.82rem;
  font-weight: 800;
  color: var(--color-accent);
  min-width: 44px;
  text-align: start;
  flex-shrink: 0;
}
.fixture-pred-val.no-pred {
  color: var(--color-text-secondary);
  font-weight: 400;
}

/* Invite prompt */
.room-invite-prompt {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-md);
  padding: var(--sp-lg);
  background: var(--color-surface-raised);
  border-radius: var(--r-lg);
  border: 1px dashed var(--color-border);
  text-align: center;
}
.room-invite-text {
  color: var(--color-text-secondary);
  font-size: 0.9rem;
  margin: 0;
}
.room-code-display {
  font-size: 2rem;
  font-weight: 900;
  letter-spacing: 0.2em;
  color: var(--color-primary);
}
.copy-link-btn {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--r-md);
  padding: var(--sp-sm) var(--sp-lg);
  font-family: 'Cairo', sans-serif;
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--color-text);
  cursor: pointer;
}

/* ══════════════════════════════════════════════
   MODALS (create/join room)
══════════════════════════════════════════════ */

.modal-sheet {
  position: fixed;
  inset: 0;
  z-index: 300;
  display: flex;
  align-items: flex-end;
  pointer-events: none;
}
.modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
  opacity: 0;
  transition: opacity 0.25s;
}
.modal-sheet-content {
  position: relative;
  background: var(--color-surface);
  width: 100%;
  border-radius: var(--r-xl) var(--r-xl) 0 0;
  padding: var(--sp-xl) var(--sp-lg) calc(var(--sp-xl) + env(safe-area-inset-bottom, 0px));
  transform: translateY(100%);
  transition: transform 0.28s cubic-bezier(0.32, 0.72, 0, 1);
  display: flex;
  flex-direction: column;
  gap: var(--sp-md);
}
.modal-sheet.is-open {
  pointer-events: auto;
}
.modal-sheet.is-open .modal-backdrop {
  opacity: 1;
}
.modal-sheet.is-open .modal-sheet-content {
  transform: translateY(0);
}

.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--sp-sm);
}
.modal-title {
  font-size: 1.1rem;
  font-weight: 800;
}
.modal-close-btn {
  background: var(--color-surface-raised);
  border: none;
  border-radius: 50%;
  width: 32px;
  height: 32px;
  cursor: pointer;
  font-size: 0.85rem;
  color: var(--color-text-secondary);
  display: flex;
  align-items: center;
  justify-content: center;
}

.form-field {
  display: flex;
  flex-direction: column;
  gap: var(--sp-xs);
}
.form-field label {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--color-text-secondary);
}
.form-field input {
  background: var(--color-surface-raised);
  border: 1.5px solid var(--color-border);
  border-radius: var(--r-md);
  padding: var(--sp-sm) var(--sp-md);
  font-family: 'Cairo', sans-serif;
  font-size: 1rem;
  color: var(--color-text);
  direction: rtl;
  width: 100%;
  box-sizing: border-box;
  transition: border-color 0.15s;
}
.form-field input:focus {
  outline: none;
  border-color: var(--color-primary);
}
.form-field input::placeholder {
  color: var(--color-text-secondary);
  opacity: 0.6;
}

/* ══════════════════════════════════════════════
   ROOM — margin fixes
══════════════════════════════════════════════ */

#room-fixtures-list .match-card + .match-card {
  margin-top: 5px;
}

.leaderboard-row + .leaderboard-row {
  margin-top: var(--sp-sm);
}

/* ══════════════════════════════════════════════
   JERSEY BADGE (numbered circle)
══════════════════════════════════════════════ */

.jersey-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  font-weight: 900;
  font-family: var(--font);
  flex-shrink: 0;
  line-height: 1;
}
.jersey-badge.is-me {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

/* ══════════════════════════════════════════════
   RANK BADGE (leaderboard medals)
══════════════════════════════════════════════ */

.rank-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  font-size: 11px;
  font-weight: 900;
  font-family: var(--font);
  flex-shrink: 0;
}
.rank-badge.rank-plain {
  background: var(--color-surface-raised);
  color: var(--color-text-secondary);
}

/* ══════════════════════════════════════════════
   JERSEY PICKER (in modals)
══════════════════════════════════════════════ */

.jersey-picker-label {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--color-text-secondary);
  margin-bottom: var(--sp-xs);
}

.jersey-picker-row {
  display: flex;
  align-items: center;
  gap: var(--sp-md);
}

.jersey-preview-wrap {
  flex-shrink: 0;
  width: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.jersey-controls {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--sp-sm);
}

.jersey-color-swatches {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.jersey-swatch {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  border: 2px solid transparent;
  cursor: pointer;
  transition: transform 0.1s, border-color 0.15s;
  padding: 0;
  flex-shrink: 0;
}
.jersey-swatch:active { transform: scale(0.88); }
.jersey-swatch.selected {
  border-color: #fff;
  box-shadow: 0 0 0 1px rgba(255,255,255,0.4);
}

.jersey-num-row {
  display: flex;
  align-items: center;
  gap: var(--sp-sm);
}

.jersey-num-btn {
  width: 30px;
  height: 30px;
  border-radius: var(--r-sm);
  background: var(--color-surface-raised);
  border: 1px solid var(--color-border);
  color: var(--color-text);
  font-size: 1.1rem;
  font-family: inherit;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s;
  flex-shrink: 0;
}
.jersey-num-btn:active { background: var(--color-border); }

.jersey-num-val {
  font-size: 1.1rem;
  font-weight: 800;
  min-width: 32px;
  text-align: center;
  color: var(--color-text);
}

/* ══════════════════════════════════════════════
   ROOM HEADER — layout
══════════════════════════════════════════════ */

.room-header {
  justify-content: space-between;
}

.room-header-actions {
  display: flex;
  align-items: center;
  gap: 2px;
  flex: 1;
  justify-content: center;
}

.room-action-btn {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--color-text-secondary);
  padding: var(--sp-xs);
  border-radius: var(--r-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color 0.15s, background 0.15s;
}
.room-action-btn:hover { background: var(--color-surface); color: var(--color-text); }
.room-action-btn.danger:hover { color: var(--color-error); }

/* ══════════════════════════════════════════════
   ROOM FIXTURE CARDS — clickable in room view
══════════════════════════════════════════════ */

#room-fixtures-list .match-card {
  cursor: pointer;
  transition: background 0.15s;
}
#room-fixtures-list .match-card:active {
  background: var(--color-surface-raised);
}
