
    /* =============================================
       CSS VARIABLES — DARK & LIGHT THEMES
    ============================================= */
    :root {
      --transition-theme: background 0.5s ease, color 0.5s ease, border-color 0.5s ease;
    }

    [data-theme="dark"] {
      --bg-base:        #080910;
      --bg-surface:     #0f1018;
      --bg-card:        #13141f;
      --bg-card-hover:  #181929;
      --bg-nav:         rgba(8,9,16,0.75);
      --border:         rgba(255,255,255,0.07);
      --border-hover:   rgba(255,255,255,0.15);
      --text-primary:   #f0f2ff;
      --text-secondary: #8b8fa8;
      --text-muted:     #4a4d65;
      --accent:         #2ECC71;
      --accent-glow:    rgba(46,204,113,0.25);
      --accent-subtle:  rgba(46,204,113,0.08);
      --accent-2:       #1abc9c;
      --danger:         #e74c3c;
      --badge-bg:       rgba(46,204,113,0.12);
      --hero-gradient:  radial-gradient(ellipse 80% 50% at 50% -20%, rgba(46,204,113,0.15) 0%, transparent 60%);
      --card-shadow:    0 4px 24px rgba(0,0,0,0.4);
      --noise-opacity:  0.025;
      --grid-color:     rgba(255,255,255,0.025);
    }

    [data-theme="light"] {
      --bg-base:        #f4f6f2;
      --bg-surface:     #eef0ec;
      --bg-card:        #ffffff;
      --bg-card-hover:  #f9faf8;
      --bg-nav:         rgba(244,246,242,0.85);
      --border:         rgba(0,0,0,0.08);
      --border-hover:   rgba(0,0,0,0.18);
      --text-primary:   #111318;
      --text-secondary: #545a6e;
      --text-muted:     #a0a8b8;
      --accent:         #1a9e52;
      --accent-glow:    rgba(26,158,82,0.2);
      --accent-subtle:  rgba(26,158,82,0.07);
      --accent-2:       #16876f;
      --danger:         #c0392b;
      --badge-bg:       rgba(26,158,82,0.1);
      --hero-gradient:  radial-gradient(ellipse 80% 50% at 50% -20%, rgba(26,158,82,0.1) 0%, transparent 60%);
      --card-shadow:    0 4px 24px rgba(0,0,0,0.08);
      --noise-opacity:  0.015;
      --grid-color:     rgba(0,0,0,0.04);
    }

    /* =============================================
       RESET & BASE
    ============================================= */
    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

    html {
      scroll-behavior: smooth;
      font-size: 16px;
    }

    body {
      font-family: 'DM Sans', sans-serif;
      background: var(--bg-base);
      color: var(--text-primary);
      line-height: 1.6;
      overflow-x: hidden;
      transition: var(--transition-theme);
    }

    /* =============================================
       NOISE TEXTURE OVERLAY
    ============================================= */
    body::before {
      content: '';
      position: fixed;
      inset: 0;
      background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
      opacity: var(--noise-opacity);
      pointer-events: none;
      z-index: 1000;
    }

    /* =============================================
       GRID BACKGROUND
    ============================================= */
    .grid-bg {
      position: fixed;
      inset: 0;
      z-index: 0;
      background-image:
        linear-gradient(var(--grid-color) 1px, transparent 1px),
        linear-gradient(90deg, var(--grid-color) 1px, transparent 1px);
      background-size: 64px 64px;
      pointer-events: none;
      transition: var(--transition-theme);
    }

    /* =============================================
       HERO VIDEO BACKGROUND
    ============================================= */
    .hero-video-wrap {
      position: absolute;
      inset: 0;
      z-index: 0;
      overflow: hidden;
    }

    .hero-video-wrap video {
      width: 100%;
      height: 100%;
      object-fit: cover;
      opacity: 0.18;
      transform: scale(1.05);
      transition: transform 0.1s linear;
      will-change: transform;
    }

    [data-theme="light"] .hero-video-wrap video {
      opacity: 0.08;
    }

    .hero-video-wrap::after {
      content: '';
      position: absolute;
      inset: 0;
      background: linear-gradient(to bottom,
        transparent 50%,
        var(--bg-base) 100%);
    }

    /* =============================================
       HERO GLOW
    ============================================= */
    .hero-glow {
      position: absolute;
      inset: 0;
      background: var(--hero-gradient);
      pointer-events: none;
      z-index: 1;
      transition: var(--transition-theme);
    }

    /* =============================================
       NAVIGATION
    ============================================= */
    .nav {
      position: sticky;
      top: 0;
      z-index: 100;
      background: var(--bg-nav);
      backdrop-filter: blur(20px) saturate(180%);
      -webkit-backdrop-filter: blur(20px) saturate(180%);
      border-bottom: 1px solid var(--border);
      transition: var(--transition-theme);
    }

    .nav-inner {
      max-width: 1280px;
      margin: 0 auto;
      padding: 0 24px;
      height: 72px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 24px;
    }

    .nav-logo {
      display: flex;
      align-items: center;
      gap: 12px;
      text-decoration: none;
    }

    .nav-logo-badge {
      width: 38px;
      height: 38px;
      background: var(--accent);
      border-radius: 10px;
      display: flex;
      align-items: center;
      justify-content: center;
      font-family: 'Bebas Neue', sans-serif;
      font-size: 18px;
      color: #fff;
      letter-spacing: 1px;
      box-shadow: 0 0 20px var(--accent-glow);
      transition: box-shadow 0.3s ease;
    }

    .nav-logo:hover .nav-logo-badge {
      box-shadow: 0 0 32px var(--accent-glow);
    }

    .nav-logo-text {
      font-family: 'Bebas Neue', sans-serif;
      font-size: 22px;
      letter-spacing: 2px;
      color: var(--text-primary);
      transition: var(--transition-theme);
    }

    .nav-links {
      display: flex;
      gap: 32px;
      list-style: none;
    }

    .nav-links a {
      font-size: 12px;
      font-weight: 500;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--text-secondary);
      text-decoration: none;
      transition: color 0.2s ease;
      position: relative;
    }

    .nav-links a::after {
      content: '';
      position: absolute;
      bottom: -4px;
      left: 0;
      width: 0;
      height: 1px;
      background: var(--accent);
      transition: width 0.3s ease;
    }

    .nav-links a:hover { color: var(--text-primary); }
    .nav-links a:hover::after { width: 100%; }
    .nav-links a.active { color: var(--accent); }
    .nav-links a.active::after { width: 100%; }

    .nav-right {
      display: flex;
      align-items: center;
      gap: 16px;
    }

    /* THEME TOGGLE */
    .theme-toggle {
      width: 48px;
      height: 26px;
      background: var(--border);
      border-radius: 13px;
      border: 1px solid var(--border);
      cursor: pointer;
      position: relative;
      transition: background 0.3s ease, border-color 0.3s ease;
      flex-shrink: 0;
    }

    .theme-toggle:hover { border-color: var(--accent); }

    .theme-toggle-knob {
      position: absolute;
      top: 3px;
      left: 3px;
      width: 18px;
      height: 18px;
      background: var(--text-primary);
      border-radius: 50%;
      transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1), background 0.3s;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 10px;
    }

    [data-theme="light"] .theme-toggle-knob {
      transform: translateX(22px);
      background: var(--accent);
    }

    .btn-login {
      padding: 9px 22px;
      background: var(--accent);
      color: #fff;
      border: none;
      border-radius: 8px;
      font-size: 12px;
      font-weight: 600;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      text-decoration: none;
      cursor: pointer;
      transition: all 0.2s ease;
      box-shadow: 0 0 0 var(--accent-glow);
    }

    .btn-login:hover {
      transform: translateY(-1px);
      box-shadow: 0 8px 24px var(--accent-glow);
    }

    /* =============================================
       HERO SECTION
    ============================================= */
    .hero {
      position: relative;
      padding: 120px 24px 80px;
      overflow: hidden;
      min-height: 500px;
      display: flex;
      align-items: center;
    }

    .hero-content {
      position: relative;
      z-index: 2;
      max-width: 1280px;
      margin: 0 auto;
      width: 100%;
    }

    .hero-eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 6px 14px;
      background: var(--accent-subtle);
      border: 1px solid rgba(46,204,113,0.2);
      border-radius: 99px;
      font-size: 11px;
      font-weight: 600;
      letter-spacing: 0.15em;
      text-transform: uppercase;
      color: var(--accent);
      margin-bottom: 24px;
      transition: var(--transition-theme);
    }

    .hero-eyebrow-dot {
      width: 6px;
      height: 6px;
      border-radius: 50%;
      background: var(--accent);
      animation: pulse-dot 2s ease-in-out infinite;
    }

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

    .hero-title {
      font-family: 'Bebas Neue', sans-serif;
      font-size: clamp(72px, 12vw, 140px);
      line-height: 0.9;
      letter-spacing: -0.01em;
      color: var(--text-primary);
      margin-bottom: 24px;
      transition: var(--transition-theme);
    }

    .hero-title .accent-word {
      color: var(--accent);
      position: relative;
      display: inline-block;
    }

    .hero-sub {
      font-size: 16px;
      color: var(--text-secondary);
      max-width: 480px;
      line-height: 1.7;
      margin-bottom: 48px;
      transition: var(--transition-theme);
    }

    .hero-stats {
      display: flex;
      gap: 40px;
      flex-wrap: wrap;
    }

    .hero-stat {
      display: flex;
      flex-direction: column;
      gap: 4px;
    }

    .hero-stat-number {
      font-family: 'Bebas Neue', sans-serif;
      font-size: 38px;
      letter-spacing: 0.02em;
      color: var(--text-primary);
      transition: var(--transition-theme);
    }

    .hero-stat-label {
      font-size: 11px;
      font-weight: 500;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--text-muted);
      transition: var(--transition-theme);
    }

    .hero-divider {
      width: 1px;
      height: 48px;
      background: var(--border);
      align-self: center;
      transition: var(--transition-theme);
    }

    /* Parallax tennis ball */
    .hero-ball {
      position: absolute;
      right: -60px;
      top: 50%;
      transform: translateY(-50%);
      width: 520px;
      height: 520px;
      border-radius: 50%;
      background: radial-gradient(circle at 35% 35%,
        rgba(46,204,113,0.3) 0%,
        rgba(26,158,82,0.1) 40%,
        transparent 70%);
      border: 1px solid rgba(46,204,113,0.15);
      z-index: 1;
      will-change: transform;
      transition: var(--transition-theme);
    }

    .hero-ball::before {
      content: '';
      position: absolute;
      inset: 40px;
      border-radius: 50%;
      border: 1px solid rgba(46,204,113,0.1);
    }

    .hero-ball::after {
      content: '';
      position: absolute;
      inset: 80px;
      border-radius: 50%;
      border: 1px solid rgba(46,204,113,0.07);
    }

    /* =============================================
       BREADCRUMB BAR
    ============================================= */
    .breadcrumb-bar {
      background: var(--bg-surface);
      border-bottom: 1px solid var(--border);
      transition: var(--transition-theme);
    }

    .breadcrumb-inner {
      max-width: 1280px;
      margin: 0 auto;
      padding: 12px 24px;
      display: flex;
      align-items: center;
      gap: 8px;
      font-size: 12px;
      color: var(--text-muted);
    }

    .breadcrumb-inner span { color: var(--accent); font-weight: 500; }

    /* =============================================
       FILTERS SECTION
    ============================================= */
    .filters-section {
      padding: 32px 24px;
      max-width: 1280px;
      margin: 0 auto;
      position: relative;
      z-index: 2;
    }

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

    .filter-label {
      font-size: 11px;
      font-weight: 600;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--text-muted);
      margin-right: 4px;
      transition: var(--transition-theme);
    }

    .filter-select {
      appearance: none;
      background: var(--bg-card);
      border: 1px solid var(--border);
      color: var(--text-primary);
      padding: 10px 36px 10px 14px;
      border-radius: 8px;
      font-size: 13px;
      font-family: 'DM Sans', sans-serif;
      cursor: pointer;
      transition: border-color 0.2s ease, background 0.2s ease;
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7' viewBox='0 0 12 7'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238b8fa8' fill='none' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
      background-repeat: no-repeat;
      background-position: right 12px center;
      min-width: 180px;
    }

    .filter-select:hover, .filter-select:focus {
      border-color: var(--accent);
      outline: none;
    }

    .btn-clear {
      padding: 10px 18px;
      background: transparent;
      border: 1px solid var(--border);
      color: var(--text-secondary);
      border-radius: 8px;
      font-size: 12px;
      font-weight: 500;
      font-family: 'DM Sans', sans-serif;
      cursor: pointer;
      transition: all 0.2s ease;
    }

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

    .filter-count {
      margin-left: auto;
      font-size: 12px;
      color: var(--text-muted);
      font-family: 'DM Mono', monospace;
      transition: var(--transition-theme);
    }

    .filter-count strong {
      color: var(--accent);
    }

    /* =============================================
       TOURNAMENTS GRID
    ============================================= */
    .tournaments-section {
      padding: 0 0px 80px;
      max-width: 1280px;
      margin: 0 auto;
      position: relative;
      z-index: 2;
    }

    .tournaments-grid {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
      gap: 20px;
    }

    /* =============================================
       TOURNAMENT CARD
    ============================================= */
    .card {
      background: var(--bg-card);
      border: 1px solid var(--border);
      border-radius: 16px;
      overflow: hidden;
      cursor: pointer;
      transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1),
                  box-shadow 0.3s ease,
                  border-color 0.3s ease,
                  background 0.5s ease;
      box-shadow: var(--card-shadow);
      position: relative;
    }

    .card::before {
      content: '';
      position: absolute;
      inset: 0;
      border-radius: 16px;
      background: linear-gradient(135deg, var(--accent-subtle) 0%, transparent 60%);
      opacity: 0;
      transition: opacity 0.3s ease;
      pointer-events: none;
      z-index: 0;
    }

    .card:hover {
      transform: translateY(-4px);
      box-shadow: 0 20px 60px rgba(0,0,0,0.3), 0 0 0 1px var(--accent);
      border-color: var(--accent);
    }

    [data-theme="light"] .card:hover {
      box-shadow: 0 12px 40px rgba(26,158,82,0.15), 0 0 0 1px var(--accent);
    }

    .card:hover::before { opacity: 1; }

    .card-image {
      width: 100%;
      height: 200px;
      background: linear-gradient(135deg, var(--accent-subtle) 0%, var(--bg-surface) 100%);
      display: flex;
      align-items: center;
      justify-content: center;
      position: relative;
      overflow: hidden;
      transition: var(--transition-theme);
    }

    .card-image-logo {
      width: 120px;
      height: 80px;
      object-fit: contain;
      opacity: 0.7;
      filter: drop-shadow(0 4px 12px var(--accent-glow));
      transition: opacity 0.3s ease, transform 0.3s ease;
      z-index: 1;
    }

    .card:hover .card-image-logo {
      opacity: 1;
      transform: scale(1.05);
    }

    .card-image-overlay {
      position: absolute;
      inset: 0;
      background: radial-gradient(circle at 50% 120%,
        var(--accent-subtle) 0%,
        transparent 70%);
      transition: var(--transition-theme);
    }

    .card-image-lines {
      position: absolute;
      inset: 0;
      background-image:
        linear-gradient(var(--grid-color) 1px, transparent 1px),
        linear-gradient(90deg, var(--grid-color) 1px, transparent 1px);
      background-size: 32px 32px;
    }

    /* Status badge on image */
    .card-status-badge {
      position: absolute;
      top: 14px;
      right: 14px;
      z-index: 2;
      padding: 5px 12px;
      border-radius: 99px;
      font-size: 10px;
      font-weight: 700;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      display: flex;
      align-items: center;
      gap: 6px;
    }

    .card-status-badge.em-andamento {
      background: rgba(46,204,113,0.15);
      border: 1px solid rgba(46,204,113,0.3);
      color: #2ECC71;
    }

    .card-status-badge.inscricoes {
      background: rgba(52,152,219,0.15);
      border: 1px solid rgba(52,152,219,0.3);
      color: #3498db;
    }

    .card-status-badge.planejamento {
      background: rgba(255,255,255,0.06);
      border: 1px solid rgba(255,255,255,0.12);
      color: var(--text-muted);
    }

    .card-status-badge.finalizado {
      background: rgba(231,76,60,0.1);
      border: 1px solid rgba(231,76,60,0.2);
      color: #e74c3c;
    }

    .status-dot {
      width: 5px;
      height: 5px;
      border-radius: 50%;
      background: currentColor;
    }

    .status-dot.pulse {
      animation: pulse-ring 1.5s ease-in-out infinite;
    }

    @keyframes pulse-ring {
      0%, 100% { opacity: 1; box-shadow: 0 0 0 0 currentColor; }
      50% { opacity: 0.7; box-shadow: 0 0 0 4px transparent; }
    }

    .card-body {
      padding: 20px 24px 24px;
      position: relative;
      z-index: 1;
    }

    .card-genre {
      display: flex;
      align-items: center;
      gap: 6px;
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--accent);
      margin-bottom: 8px;
      transition: var(--transition-theme);
    }

    .card-title {
      font-family: 'DM Sans', sans-serif;
      font-size: 18px;
      font-weight: 600;
      letter-spacing: -0.01em;
      line-height: 1.3;
      color: var(--text-primary);
      margin-bottom: 16px;
      transition: color 0.3s ease, var(--transition-theme);
    }

    .card:hover .card-title { color: var(--accent); }

    .card-meta {
      display: flex;
      align-items: center;
      gap: 20px;
      margin-bottom: 20px;
      flex-wrap: wrap;
    }

    .card-meta-item {
      display: flex;
      align-items: center;
      gap: 6px;
      font-size: 12px;
      color: var(--text-secondary);
      transition: var(--transition-theme);
    }

    .card-meta-item svg {
      color: var(--text-muted);
      flex-shrink: 0;
    }

    .card-footer {
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding-top: 16px;
      border-top: 1px solid var(--border);
      transition: var(--transition-theme);
    }

    .vagas-bar-wrap {
      flex: 1;
      margin-right: 16px;
    }

    .vagas-bar-label {
      display: flex;
      justify-content: space-between;
      font-size: 11px;
      color: var(--text-muted);
      margin-bottom: 6px;
      font-family: 'DM Mono', monospace;
      transition: var(--transition-theme);
    }

    .vagas-bar-label strong {
      color: var(--text-secondary);
    }

    .vagas-bar {
      height: 3px;
      background: var(--border);
      border-radius: 99px;
      overflow: hidden;
      transition: var(--transition-theme);
    }

    .vagas-bar-fill {
      height: 100%;
      background: var(--accent);
      border-radius: 99px;
      transition: width 0.6s cubic-bezier(0.34, 1.56, 0.64, 1);
    }

    .vagas-bar-fill.full {
      background: linear-gradient(90deg, var(--accent), var(--danger));
    }

    .btn-details {
      padding: 9px 18px;
      background: var(--accent-subtle);
      border: 1px solid rgba(46,204,113,0.2);
      color: var(--accent);
      border-radius: 8px;
      font-size: 12px;
      font-weight: 600;
      font-family: 'DM Sans', sans-serif;
      text-decoration: none;
      cursor: pointer;
      white-space: nowrap;
      transition: all 0.2s ease;
      display: inline-flex;
      align-items: center;
      gap: 6px;
    }

    .btn-details:hover {
      background: var(--accent);
      color: #fff;
      border-color: var(--accent);
      transform: translateX(2px);
    }

    .btn-details svg {
      transition: transform 0.2s ease;
    }

    .btn-details:hover svg {
      transform: translateX(3px);
    }

    /* =============================================
       SECTION DIVIDER
    ============================================= */
    .section-divider {
      border: none;
      height: 1px;
      background: var(--border);
      margin: 0 24px;
      max-width: calc(1280px - 48px);
      margin-left: auto;
      margin-right: auto;
      transition: var(--transition-theme);
    }

    /* =============================================
       EMPTY STATE
    ============================================= */
    .empty-state {
      text-align: center;
      padding: 80px 24px;
      display: none;
    }

    .empty-state.visible { display: block; }

    .empty-icon {
      font-size: 48px;
      margin-bottom: 16px;
      opacity: 0.4;
    }

    .empty-title {
      font-family: 'Bebas Neue', sans-serif;
      font-size: 32px;
      color: var(--text-muted);
      margin-bottom: 8px;
    }

    .empty-sub {
      font-size: 14px;
      color: var(--text-muted);
    }

    /* =============================================
       PARALLAX SCROLL SECTIONS
    ============================================= */
    .parallax-section {
      position: relative;
      padding: 100px 24px;
      overflow: hidden;
      border-top: 1px solid var(--border);
      transition: var(--transition-theme);
    }

    .parallax-bg {
      position: absolute;
      inset: -100px;
      z-index: 0;
      will-change: transform;
    }

    .parallax-content {
      position: relative;
      z-index: 1;
      max-width: 1280px;
      margin: 0 auto;
    }

    .section-label {
      font-size: 11px;
      font-weight: 600;
      letter-spacing: 0.2em;
      text-transform: uppercase;
      color: var(--accent);
      margin-bottom: 12px;
      display: flex;
      align-items: center;
      gap: 10px;
    }

    .section-label::before {
      content: '';
      width: 24px;
      height: 1px;
      background: var(--accent);
    }

    .section-title {
      font-family: 'Bebas Neue', sans-serif;
      font-size: clamp(40px, 6vw, 72px);
      line-height: 0.95;
      color: var(--text-primary);
      margin-bottom: 20px;
      transition: var(--transition-theme);
    }

    /* =============================================
       RANKING TABLE (Parallax Section)
    ============================================= */
    .ranking-table-wrap {
      margin-top: 48px;
      background: var(--bg-card);
      border: 1px solid var(--border);
      border-radius: 16px;
      overflow: hidden;
      transition: var(--transition-theme);
    }

    .ranking-table {
      width: 100%;
      border-collapse: collapse;
    }

    .ranking-table th {
      padding: 14px 20px;
      text-align: left;
      font-size: 10px;
      font-weight: 700;
      letter-spacing: 0.15em;
      text-transform: uppercase;
      color: var(--text-muted);
      border-bottom: 1px solid var(--border);
      background: var(--bg-surface);
      transition: var(--transition-theme);
    }

    .ranking-table td {
      padding: 14px 20px;
      font-size: 14px;
      color: var(--text-secondary);
      border-bottom: 1px solid var(--border);
      transition: var(--transition-theme);
    }

    .ranking-table tr:last-child td { border-bottom: none; }

    .ranking-table tr:hover td {
      background: var(--accent-subtle);
      color: var(--text-primary);
    }

    .rank-num {
      font-family: 'DM Mono', monospace;
      font-size: 12px;
      color: var(--text-muted);
      width: 40px;
    }

    .rank-1 .rank-num { color: #f0c040; }
    .rank-2 .rank-num { color: #b0b8c8; }
    .rank-3 .rank-num { color: #cd7f32; }

    .rank-avatar {
      width: 32px;
      height: 32px;
      border-radius: 50%;
      background: var(--accent);
      display: inline-flex;
      align-items: center;
      justify-content: center;
      font-size: 12px;
      font-weight: 700;
      color: #fff;
      margin-right: 10px;
      vertical-align: middle;
      flex-shrink: 0;
    }

    .rank-name-cell {
      display: flex;
      align-items: center;
    }

    .rank-stat {
      font-family: 'DM Mono', monospace;
      font-size: 13px;
      color: var(--text-primary);
      font-weight: 500;
    }

    /* =============================================
       SCROLL PROGRESS
    ============================================= */
    .scroll-progress {
      position: fixed;
      top: 0;
      left: 0;
      height: 2px;
      background: var(--accent);
      z-index: 200;
      transition: width 0.1s linear;
      box-shadow: 0 0 8px var(--accent-glow);
    }

    /* =============================================
       FOOTER
    ============================================= */
    footer {
      border-top: 1px solid var(--border);
      padding: 40px 24px;
      transition: var(--transition-theme);
    }

    .footer-inner {
      max-width: 1280px;
      margin: 0 auto;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 24px;
      flex-wrap: wrap;
    }

    .footer-copy {
      font-size: 12px;
      color: var(--text-muted);
      transition: var(--transition-theme);
    }

    .footer-links {
      display: flex;
      gap: 20px;
    }

    .footer-links a {
      font-size: 12px;
      color: var(--text-muted);
      text-decoration: none;
      transition: color 0.2s ease;
    }

    .footer-links a:hover { color: var(--accent); }

    /* =============================================
       CARD ENTER ANIMATIONS
    ============================================= */
    .card {
      opacity: 0;
      transform: translateY(30px);
      transition: opacity 0.5s ease, transform 0.5s ease,
                  box-shadow 0.3s ease, border-color 0.3s ease,
                  background 0.5s ease;
    }

    .card.visible {
      opacity: 1;
      transform: translateY(0);
    }

    /* =============================================
       MOBILE
    ============================================= */
    @media (max-width: 768px) {
      .nav-links { display: none; }
      .hero { padding: 80px 20px 60px; }
      .hero-ball { display: none; }
      .hero-title { font-size: clamp(56px, 15vw, 90px); }
      .hero-stats { gap: 24px; }
      .hero-divider { display: none; }
      .tournaments-grid { grid-template-columns: 1fr; }
      .filters-row { gap: 8px; }
      .filter-select { min-width: 140px; }
      .filter-count { width: 100%; margin-left: 0; }
    }

    @media (max-width: 480px) {
      .nav-inner { padding: 0 16px; }
      .nav-logo-text { display: none; }
    }
  
    /* =============================================
       HAMBURGER + MOBILE MENU
    ============================================= */
    .hamburger {
      display:none; flex-direction:column; justify-content:center; gap:5px;
      width:40px; height:40px; cursor:pointer; border:none;
      background:transparent; padding:6px; border-radius:8px;
      transition:background 0.2s;
    }
    .hamburger:hover { background:var(--accent-subtle); }
    .hamburger span {
      display:block; height:2px; background:var(--text-primary);
      border-radius:2px; transition:all 0.35s cubic-bezier(0.34,1.56,0.64,1);
      transform-origin:center;
    }
    .hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
    .hamburger.open span:nth-child(2) { opacity:0; transform:scaleX(0); }
    .hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

    .mobile-menu {
      position:fixed; inset:0; z-index:99;
      background:var(--bg-base); display:flex; flex-direction:column;
      padding:0; pointer-events:none;
      transform:translateX(100%);
      transition:transform 0.4s cubic-bezier(0.77,0,0.175,1);
    }
    .mobile-menu.open { transform:translateX(0); pointer-events:auto; }

    .mobile-menu-header {
      display:flex; align-items:center; justify-content:space-between;
      padding:16px 24px; border-bottom:1px solid var(--border);
      background:var(--bg-surface); min-height:72px;
    }
    .mobile-menu-logo { display:flex; align-items:center; gap:12px; text-decoration:none; }
    .mobile-menu-logo-badge {
      width:36px; height:36px; background:var(--accent); border-radius:9px;
      display:flex; align-items:center; justify-content:center;
      font-family:'Bebas Neue',sans-serif; font-size:16px; color:#fff;
    }
    .mobile-menu-logo-text { font-family:'Bebas Neue',sans-serif; font-size:20px; letter-spacing:2px; color:var(--text-primary); }

    .mobile-menu-body { flex:1; overflow-y:auto; padding:24px; display:flex; flex-direction:column; gap:8px; }
    .mobile-menu-item {
      display:flex; align-items:center; gap:14px;
      padding:14px 16px; border-radius:12px;
      font-size:16px; font-weight:500; color:var(--text-primary);
      text-decoration:none; border:1px solid transparent;
      transition:all 0.2s; cursor:pointer;
    }
    .mobile-menu-item:hover, .mobile-menu-item.active {
      background:var(--accent-subtle); border-color:rgba(46,204,113,0.2); color:var(--accent);
    }
    .mobile-menu-item svg { color:var(--accent); flex-shrink:0; }

    .mobile-menu-divider { height:1px; background:var(--border); margin:8px 0; }

    .mobile-menu-footer {
      padding:20px 24px; border-top:1px solid var(--border);
      display:flex; align-items:center; justify-content:space-between; gap:16px;
    }
    .mobile-theme-row { display:flex; align-items:center; gap:10px; font-size:13px; color:var(--text-secondary); }
    .mobile-assoc-btn {
      padding:11px 22px; background:var(--accent); color:#fff; border:none;
      border-radius:10px; font-size:13px; font-weight:700; font-family:'DM Sans',sans-serif;
      text-decoration:none; cursor:pointer; transition:all 0.2s; white-space:nowrap;
    }
    .mobile-assoc-btn:hover { box-shadow:0 6px 20px var(--accent-glow); }

    @media (max-width:860px) {
      .hamburger { display:flex; }
      .nav-links { display:none !important; }
      .nav-right .btn-login, .nav-right .btn-assoc { display:none; }
      .theme-toggle {  }
    }

    /* FOOTER MOBILE */
    @media (max-width:768px) {
      .footer-top { grid-template-columns:1fr !important; gap:28px !important; padding:36px 20px 24px !important; }
      .footer-bottom { padding:16px 20px !important; }
      .footer-brand { text-align:center; }
      .footer-socials { justify-content:center; }
    }
    @media (max-width:480px) {
      .footer-top { padding:28px 16px 20px !important; }
    }

  