    /* Component-specific styles only - theme in css/theme.css */
    :root {
      --surface-raised: var(--card, oklch(1 0 0));
      --border-strong: var(--border, oklch(0.85 0.03 265));
    }
    html {
      scroll-behavior: smooth;
      overscroll-behavior: contain;
    }
    /* Smooth theme transitions on all theme-aware elements */
    body, .card, .btn, .btn-secondary, .search-wrap input, .custom-select-trigger,
    .leaderboard-row, .site-header, .filters, .activity-toast, .toast, .lb-expand-btn,
    .card-img-wrap, .card-body, .badge, .lb-search-wrap input {
      transition: background-color 0.25s ease, color 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
    }
    /* Loading skeleton for cards */
    .skeleton {
      background: linear-gradient(90deg, var(--bg-soft) 25%, color-mix(in oklch, var(--bg-soft) 70%, var(--card)) 50%, var(--bg-soft) 75%);
      background-size: 200% 100%;
      animation: skeleton-shimmer 1.4s ease-in-out infinite;
      border-radius: var(--radius-sm);
    }
    @keyframes skeleton-shimmer {
      0% { background-position: 200% 0; }
      100% { background-position: -200% 0; }
    }
    * { 
      margin: 0; 
      padding: 0; 
      box-sizing: border-box;
    }
    /* CSS-only card entrance animation - smoother than GSAP on large lists */
    @keyframes cardEnter {
      from { opacity: 0; transform: translateY(12px) scale(0.98); }
      to { opacity: 1; transform: translateY(0) scale(1); }
    }
    .card-enter {
      animation: cardEnter 0.3s ease-out forwards;
    }
    
    /* Custom cursor and ripple effects disabled - see theme.css */
    body {
      font-family: var(--font-sans);
      min-height: 100vh;
      line-height: 1.6;
      letter-spacing: 0.02em;
      font-size: 0.9375rem;
      -webkit-font-smoothing: antialiased;
      -moz-osx-font-smoothing: grayscale;
      text-wrap: pretty;
    }
    /* Cursor style */
    h1#main-title .typed-cursor {
      display: inline !important;
      opacity: 1;
      color: var(--accent);
      font-weight: 300;
      animation: typedjsBlink 0.7s infinite;
      vertical-align: baseline;
    }
    h1#main-title span {
      display: inline;
    }
    @keyframes typedjsBlink {
      50% { opacity: 0; }
    }
    /* Enhanced title with typing effect - inline-block keeps cursor inline with text */
    h1#main-title {
      min-height: 1.5em;
      display: inline-block;
    }
    h1#main-title.typing-complete {
      animation: titleGlow 2s ease-in-out infinite;
    }
    @keyframes titleGlow {
      0%, 100% { text-shadow: 0 1px 4px color-mix(in oklch, var(--foreground) 45%, transparent), 0 0 0 transparent; }
      50% { text-shadow: 0 1px 4px color-mix(in oklch, var(--foreground) 45%, transparent), 0 0 20px color-mix(in oklch, var(--accent) 30%, transparent); }
    }
    .container { 
      position: relative; 
      z-index: 1; 
      max-width: 1600px; 
      margin: 0 auto; 
      padding: 1.5rem 2rem; 
      width: 100%;
      /* Removed will-change: scroll-position - causes lag in Chrome */
    }
    /* Header styling moved to theme.css */
    .site-logo img,
    .site-logo svg {
      position: relative;
      z-index: 2;
      filter: drop-shadow(0 0 8px color-mix(in oklch, var(--accent) 60%, transparent));
      transition: filter 0.4s ease;
    }
    .site-logo:hover img,
    .site-logo:hover svg {
      filter: drop-shadow(0 0 16px color-mix(in oklch, var(--accent) 90%, transparent));
    }
    h1 { 
      font-size: 1.35rem; 
      font-weight: 500; 
      letter-spacing: -0.015em; /* Looser tracking for premium feel */
      color: var(--text);
      line-height: 1.55; /* Better line-height for readability */
      text-shadow: 0 1px 4px color-mix(in oklch, var(--foreground) 45%, transparent);
    }
    .card-title {
      font-weight: 700;
      font-size: 0.95rem;
      letter-spacing: -0.01em;
      line-height: 1.35;
      color: var(--text);
      display: -webkit-box;
      -webkit-line-clamp: 2;
      -webkit-box-orient: vertical;
      overflow: hidden;
    }
    .tagline { color: var(--text-secondary); font-size: 0.8125rem; margin-top: 0.25rem; }
    .header-actions { display: flex; gap: 0.75rem; flex-wrap: wrap; align-items: center; }
    .btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 0.5rem;
      background: var(--primary);
      color: var(--primary-foreground);
      font-weight: 600;
      padding: 0.65rem 1.6rem;
      border: 2px solid var(--primary);
      border-radius: var(--radius-lg);
      cursor: pointer;
      font-size: 0.875rem;
      font-family: inherit;
      box-shadow: var(--shadow-sm);
      transition: all 0.3s ease;
      line-height: 1.4;
    }
    .btn:hover {
      background: var(--accent);
      border-color: var(--accent);
      color: var(--primary-foreground);
      transform: translateY(-2px);
      box-shadow: var(--shadow);
    }
    .btn:active {
      transform: scale(0.96);
    }
    .btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
    .btn:disabled { opacity: 0.5; cursor: not-allowed; transform: none; }
    .btn-secondary {
      background: transparent;
      color: var(--accent);
      border: 2px solid var(--accent);
      padding: 0.65rem 1.6rem;
      border-radius: var(--radius-lg);
      font-family: inherit;
      font-weight: 600;
      font-size: 0.875rem;
      transition: all 0.3s ease;
      line-height: 1.4;
    }
    .btn-secondary:hover { background: var(--accent); border-color: var(--accent); color: var(--primary-foreground); transform: translateY(-2px); box-shadow: var(--shadow); }
    .btn-secondary:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
    .theme-toggle {
      width: 40px;
      height: 40px;
      border-radius: var(--radius-lg);
      border: 1px solid var(--border-strong);
      background: var(--surface-raised);
      color: var(--text-secondary);
      cursor: pointer;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.1rem;
      transition: color 0.2s ease, border-color 0.2s ease, background 0.2s ease;
      position: relative;
    }
    .theme-toggle .sun-icon, .theme-toggle .moon-icon, .theme-toggle .warm-icon {
      position: absolute;
      transition: opacity 0.2s ease, transform 0.3s ease;
    }
    /* Light mode: sun visible, others hidden */
    body:not(.dark):not(.theme-warm):not(.theme-neo) .theme-toggle .sun-icon { opacity: 1; transform: scale(1); }
    body:not(.dark):not(.theme-warm):not(.theme-neo) .theme-toggle .moon-icon { opacity: 0; transform: scale(0.5); }
    body:not(.dark):not(.theme-warm):not(.theme-neo) .theme-toggle .warm-icon { opacity: 0; transform: scale(0.5); }
    body:not(.dark):not(.theme-warm):not(.theme-neo) .theme-toggle .neo-icon { opacity: 0; transform: scale(0.5); }
    /* Dark mode: moon visible, others hidden */
    body.dark .theme-toggle .sun-icon { opacity: 0; transform: scale(0.5); }
    body.dark .theme-toggle .moon-icon { opacity: 1; transform: scale(1); }
    body.dark .theme-toggle .warm-icon { opacity: 0; transform: scale(0.5); }
    body.dark .theme-toggle .neo-icon { opacity: 0; transform: scale(0.5); }
    /* Warm mode: warm icon visible, others hidden */
    body.theme-warm .theme-toggle .sun-icon { opacity: 0; transform: scale(0.5); }
    body.theme-warm .theme-toggle .moon-icon { opacity: 0; transform: scale(0.5); }
    body.theme-warm .theme-toggle .warm-icon { opacity: 1; transform: scale(1); }
    body.theme-warm .theme-toggle .neo-icon { opacity: 0; transform: scale(0.5); }
    /* Neo mode: neo icon visible, others hidden */
    body.theme-neo .theme-toggle .sun-icon { opacity: 0; transform: scale(0.5); }
    body.theme-neo .theme-toggle .moon-icon { opacity: 0; transform: scale(0.5); }
    body.theme-neo .theme-toggle .warm-icon { opacity: 0; transform: scale(0.5); }
    body.theme-neo .theme-toggle .neo-icon { opacity: 1; transform: scale(1); }
    .theme-toggle:hover { color: var(--accent); border-color: var(--accent); background: var(--accent-dim); box-shadow: var(--shadow); transform: translateY(-1px); }
    .theme-toggle:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
    /* Universal hover highlight for all clickable elements */
    .lb-copy, .copy-btn, .lb-expand-btn, .view-btn, .search-clear { transition: box-shadow 0.2s ease; }
    .lb-copy:hover, .copy-btn:hover, .lb-expand-btn:hover, .view-btn:hover, .search-clear:hover {
      box-shadow: 0 0 12px color-mix(in oklch, var(--accent) 40%, transparent);
    }
    .custom-select-trigger:hover { box-shadow: 0 0 12px color-mix(in oklch, var(--accent) 35%, transparent), 0 0 16px color-mix(in oklch, var(--accent) 20%, transparent); }
    a[href] { transition: color 0.2s ease, text-shadow 0.2s ease; }
    .creator-name:hover, .leaderboard-creator-block a:hover, .leaderboard-community-block a:hover, .lb-twitter-line a:hover {
      text-shadow: 0 0 12px color-mix(in oklch, var(--accent) 50%, transparent);
    }
    .card-links a, .req-badges a, .raffle-details-wrap a, .discord-id-pill a { transition: box-shadow 0.2s ease; }
    .card-links a:hover, .req-badges a:hover, .raffle-details-wrap a:hover, .discord-id-pill a:hover {
      box-shadow: 0 0 10px color-mix(in oklch, var(--accent) 30%, transparent);
    }
    /* Light mode handled by theme.css (:root / .dark) */
    .filters {
      position: relative;
      z-index: 100;
      display: flex;
      flex-wrap: wrap;
      align-items: center;
      gap: 1rem;
      margin-bottom: 1.75rem;
      padding: 1rem 1.25rem;
      background: var(--surface-raised);
      border: 2px solid var(--border);
      border-radius: var(--radius-lg);
      transition: box-shadow 0.3s cubic-bezier(0.65, 0.05, 0.36, 1), 
                  transform 0.3s cubic-bezier(0.65, 0.05, 0.36, 1);
      transform: translate3d(0,0,0);
      box-shadow: 0 4px 20px color-mix(in oklch, var(--foreground) 25%, transparent), inset 0 1px 0 color-mix(in oklch, var(--background) 8%, transparent);
    }
    .filters:focus-within {
      box-shadow: 0 8px 32px color-mix(in oklch, var(--foreground) 35%, transparent),
                  0 0 0 1px color-mix(in oklch, var(--accent) 25%, transparent),
                  0 0 24px color-mix(in oklch, var(--accent) 20%, transparent);
      transform: translate3d(0, -1px, 0);
    }
    .filters label { font-size: 0.8125rem; color: var(--text-secondary); font-weight: 500; }
    .filters select, .filters input {
      background: var(--surface-raised);
      border: 1px solid var(--border);
      color: var(--text);
      padding: 0.5rem 0.75rem;
      border-radius: 10px;
      font-size: 0.875rem;
      font-family: inherit;
      transition: border-color 0.2s ease, box-shadow 0.2s ease;
    }
    /* Remove spinner arrows from number input */
    .filters input[type="number"] {
      -moz-appearance: textfield;
      appearance: textfield;
    }
    .filters input[type="number"]::-webkit-outer-spin-button,
    .filters input[type="number"]::-webkit-inner-spin-button {
      -webkit-appearance: none;
      appearance: none;
      margin: 0;
    }
    .filters select option {
      background: var(--bg-soft);
      color: var(--text);
    }
    .filters select:focus, .filters input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-dim); }
    /* Search stats panel - shows when searching for specific project */
    .search-stats-panel {
      display: flex;
      flex-wrap: wrap;
      gap: 1rem;
      margin: 0.75rem 0 1.25rem 0;
      padding: 0.875rem 1.25rem;
      background: var(--surface-overlay);
      border: 1px solid var(--border);
      border-radius: 12px;
      font-size: 0.8125rem;
      color: var(--text-secondary);
      transform: translateZ(0);
    }
    .search-stats-panel .search-stat {
      display: flex;
      align-items: center;
      gap: 0.4rem;
      padding: 0.25rem 0.6rem;
      background: var(--surface-raised);
      border: 1px solid var(--border);
      border-radius: 8px;
      white-space: nowrap;
    }
    .search-stats-panel .stat-value {
      color: var(--accent);
      font-weight: 600;
      font-size: 0.875rem;
      font-variant-numeric: tabular-nums;
    }
    .custom-select-wrap { position: relative; display: inline-block; }
    .custom-select-wrap select { position: absolute; left: 0; top: 0; width: 100%; height: 100%; opacity: 0; cursor: pointer; z-index: 1; pointer-events: none; }
    .custom-select-trigger {
      position: relative; z-index: 2;
      display: flex; align-items: center; justify-content: space-between; gap: 0.5rem;
      padding: 0.5rem 0.75rem; border-radius: 12px; font-size: 0.875rem;
      background: var(--surface-raised); border: 1px solid var(--border); color: var(--text);
      min-width: 140px; cursor: pointer;
      transition: box-shadow 0.25s cubic-bezier(0.65, 0.05, 0.36, 1), 
                  border-color 0.25s cubic-bezier(0.65, 0.05, 0.36, 1),
                  transform 0.25s cubic-bezier(0.65, 0.05, 0.36, 1);
      transform: translate3d(0,0,0);
    }
    .custom-select-trigger:hover {
      border-color: color-mix(in oklch, var(--accent) 35%, transparent);
      box-shadow: 0 0 12px color-mix(in oklch, var(--accent) 25%, transparent);
      transform: translate3d(0, -1px, 0);
    }
    .custom-select-trigger:focus {
      border-color: var(--accent);
      box-shadow: 0 0 0 3px var(--accent-dim), 0 0 16px color-mix(in oklch, var(--accent) 30%, transparent);
    }
    .custom-select-trigger::after { content: ''; border: 5px solid transparent; border-top-color: var(--muted-foreground); margin-top: 4px; }
    .custom-select-dropdown {
      position: absolute; top: 100%; left: 0; right: 0; margin-top: 2px;
      background: var(--card); border: 2px solid var(--border); border-radius: 10px;
      box-shadow: var(--shadow-lg);
      z-index: 9999; max-height: 220px; overflow-y: auto;
      list-style: none; padding: 0.35rem; margin: 0; display: none;
      opacity: 1; transform: translateZ(0); isolation: isolate;
    }
    .dark .custom-select-dropdown {
      background: var(--card); border: 2px solid var(--border);
      box-shadow: var(--shadow-lg);
    }
    .custom-select-dropdown.open { display: block; }
    .custom-select-dropdown li { padding: 0.4rem 0.6rem; border-radius: 8px; cursor: pointer; font-size: 0.875rem; color: var(--foreground); font-weight: 500; }
    .custom-select-dropdown li:hover { background: var(--secondary); color: var(--accent); }
    .custom-select-dropdown li.selected { background: color-mix(in oklch, var(--accent) 15%, transparent); color: var(--accent); }
    .dark .custom-select-dropdown li { color: var(--foreground); }
    .dark .custom-select-dropdown li:hover { background: var(--secondary); color: var(--accent); }
    .dark .custom-select-dropdown li.selected { background: color-mix(in oklch, var(--accent) 18%, transparent); color: var(--accent); }
    .custom-select-dropdown::-webkit-scrollbar { width: 6px; }
    .custom-select-dropdown::-webkit-scrollbar-track { background: var(--bg-soft); border-radius: 3px; }
    .custom-select-dropdown::-webkit-scrollbar-thumb { background: var(--surface-hover); border-radius: 3px; }
    /* Side-by-side: half creators, half communities — bigger volume, minimalistic ranks */
    .leaderboard-section {
      display: flex;
      flex-direction: row;
      flex-wrap: wrap;
      gap: 1.5rem;
      margin-bottom: 2rem;
      background: var(--surface-raised);
      border: 1px solid var(--border);
      border-radius: var(--radius-lg);
      padding: 1.25rem 1.5rem;
      overflow: hidden;
    }
    .leaderboard-section .leaderboard-col { flex: 1 1 0; min-width: 0; }
    .leaderboard-col {
      background: var(--surface-overlay);
      border: 2px solid var(--border);
      border-radius: var(--radius);
      padding: 0;
      max-height: 500px; /* Increased height for better visibility */
      min-height: 200px; /* Ensure minimum height */
      height: auto; /* Allow content to determine height up to max */
      overflow: hidden; /* Container doesn't scroll, inner content does */
      box-shadow: var(--shadow);
      transition: box-shadow 0.2s ease;
      display: flex;
      flex-direction: column;
      position: relative;
    }
    /* Inner scrollable content area */
    .leaderboard-col-content {
      overflow-y: auto;
      overflow-x: hidden;
      flex: 1;
      padding: 1.25rem 1.5rem;
      /* Optimized scrolling - performance improvements */
      -webkit-overflow-scrolling: touch;
      scroll-behavior: auto; /* Changed from smooth to auto for better performance */
      overscroll-behavior: contain;
      /* Custom scrollbar */
      scrollbar-width: thin;
      scrollbar-color: var(--surface-hover) var(--bg-soft);
    }
    /* Sticky grid header row (Rank | Name | Raffles | Button) */
    .leaderboard-col-header {
      position: static !important;
      background: var(--surface-overlay);
      display: grid;
      grid-template-columns: 48px 1fr 90px auto;
      gap: 0.6rem;
      align-items: center;
      padding: 6px 16px;
      margin: 0;
      border-bottom: 1px solid var(--border);
      font-size: 0.75rem;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 0.06em;
      color: var(--muted-foreground);
    }
    .leaderboard-col-header span { font-weight: 400; opacity: 0.7; }
    .leaderboard-col-header-spacer {
      min-width: 5.75rem;
      height: 0.5rem;
      pointer-events: none;
    }
    .leaderboard-col:hover { box-shadow: var(--shadow-lg), 0 0 0 1px var(--accent-dim); }
    .leaderboard-col-content::-webkit-scrollbar { 
      width: 8px; /* Wider scrollbar for better visibility */
    }
    .leaderboard-col-content::-webkit-scrollbar-track {
      background: var(--border);
      border-radius: 4px;
      margin: 4px 0;
    }
    .leaderboard-col-content::-webkit-scrollbar-thumb {
      background: var(--muted-foreground);
      border-radius: 4px;
      border: 1px solid var(--border);
      opacity: 0.5;
    }
    .leaderboard-col-content::-webkit-scrollbar-thumb:hover {
      background: var(--foreground);
    }
    .lb-header-wrap {
      display: flex;
      flex-direction: column;
      gap: 0.5rem;
      padding: 1rem 1.25rem 0.75rem 1.25rem;
      background: var(--surface-overlay);
      border-bottom: 1px solid var(--border);
    }
    .lb-search-wrap {
      display: flex;
      align-items: center;
      gap: 0.4rem;
      background: var(--bg);
      border: 1px solid var(--border);
      border-radius: 8px;
      padding: 0.35rem 0.5rem;
      transition: border-color 0.2s ease, box-shadow 0.2s ease;
    }
    .lb-search-wrap:focus-within {
      border-color: var(--accent);
      box-shadow: 0 0 0 3px var(--accent-dim);
    }
    .lb-search-icon {
      width: 16px;
      height: 16px;
      color: var(--muted-foreground);
      flex-shrink: 0;
      opacity: 0.7;
    }
    .lb-search-wrap input {
      flex: 1;
      min-width: 0;
      border: none;
      outline: none;
      background: transparent;
      font-size: 0.75rem;
      color: var(--text);
      padding: 0.1rem 0;
    }
    .lb-search-wrap input::placeholder {
      color: var(--muted-foreground);
      opacity: 0.6;
    }
    #leaderboard-section .leaderboard-col:last-of-type h3 { font-size: 0.65rem; }
    .leaderboard-row {
      display: flex;
      flex-wrap: nowrap;
      align-items: center;
      gap: 0.5rem;
      padding: 0.5rem 0;
      font-size: 0.875rem;
      border-radius: 8px;
      transition: background 0.2s ease; /* Simplified transition - removed transform/box-shadow for better scroll performance */
      position: relative;
      cursor: pointer;
      /* Performance: prevent repaints during scroll */
      contain: layout style;
    }
    .leaderboard-row:hover {
      background: var(--surface-hover);
    }
    .leaderboard-row .rank { color: var(--muted-foreground); min-width: 1.5rem; font-weight: 400; font-size: 0.6rem; opacity: 0.6; }
    .leaderboard-row .name { flex: 1; min-width: 0; }
    .leaderboard-row a {
      color: var(--text);
      text-decoration: none;
      display: flex;
      align-items: center;
      gap: 0.2rem;
      flex: 1;
      min-width: 0;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
      transition: color 0.15s ease;
    }
    .leaderboard-row a:hover { color: var(--accent); }
    .leaderboard-row .count { color: var(--accent); font-weight: 600; min-width: 1.5rem; text-align: right; font-size: 0.875rem; }
    .leaderboard-row-wrap { margin-bottom: 0.35rem; }
    .leaderboard-row-wrap .leaderboard-row { padding-right: 0.8rem; }
    .leaderboard-row {
      display: grid;
      grid-template-columns: 48px 1fr 90px auto;
      gap: 0.6rem;
      align-items: center;
      padding: 8px 16px;
      font-size: 0.9rem;
      min-height: 48px;
    }
    .leaderboard-row .rank { font-size: 0.85rem; font-weight: 700; color: var(--text); }
    .leaderboard-row .count { font-weight: 700; color: var(--accent); text-align: right; font-size: 0.9rem; }
    .leaderboard-creator-block a { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 100%; font-size: 0.9rem; }
    .lb-discord-id { font-size: 0.8rem; }
    .lb-twitter-line { font-size: 0.8rem; }
    .lb-row-hidden { display: none !important; }
    .lb-expand-btn {
      margin-left: auto;
      padding: 4px 10px;
      font-size: 0.8rem;
      font-weight: 600;
      border: 1px solid var(--border);
      background: var(--surface-overlay);
      color: var(--text-secondary);
      border-radius: var(--radius-full);
      cursor: pointer;
      font-family: inherit;
      flex-shrink: 0;
      white-space: nowrap;
      transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
      line-height: 1.3;
    }
    .lb-expand-btn:hover { background: var(--surface-hover); color: var(--accent); border-color: var(--accent); }
    .lb-expand-btn[aria-expanded="true"] { color: var(--accent); border-color: var(--accent); }
    .lb-expand-btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
    /* Leaderboard loading overlay */
    .lb-loading-overlay { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; background: rgba(var(--bg-rgb, 10,10,10), 0.6); z-index: 20; opacity: 0; pointer-events: none; transition: opacity 0.2s ease; }
    .lb-loading-overlay.visible { opacity: 1; pointer-events: auto; }
    .lb-spinner {
      position: relative;
      width: 28px;
      height: 28px;
      display: inline-block;
    }
    .lb-spinner::before,
    .lb-spinner::after {
      content: '';
      position: absolute;
      border-radius: 50%;
      border-style: solid;
      border-color: transparent;
    }
    .lb-spinner::before {
      inset: 0;
      border-width: 3px;
      border-top-color: var(--accent);
      border-right-color: color-mix(in oklch, var(--accent) 40%, transparent);
      animation: spin-ccw 0.9s linear infinite;
    }
    .lb-spinner::after {
      inset: 6px;
      border-width: 3px;
      border-bottom-color: var(--accent);
      border-left-color: color-mix(in oklch, var(--accent) 40%, transparent);
      animation: spin-cw 0.7s linear infinite;
    }
    @keyframes spin-cw { to { transform: rotate(360deg); } }
    @keyframes spin-ccw { to { transform: rotate(-360deg); } }
    @keyframes lb-spin { to { transform: rotate(360deg); } }
    /* Award-winning independent scroll for raffles list - separate from page scroll */
    .lb-raffles-list {
      list-style: none;
      padding: 0.4rem 0.75rem;
      margin: 0.25rem 0 0 0;
      font-size: 0.75rem;
      max-height: 200px;
      overflow-y: auto;
      overflow-x: hidden;
      background: var(--bg);
      border: 1px solid var(--border);
      border-radius: var(--radius-md);
      scrollbar-width: thin;
      scrollbar-color: var(--surface-hover) var(--bg-soft);
      overscroll-behavior: contain;
      -webkit-overflow-scrolling: touch;
    }
    /* Custom scrollbar styling - more visible */
    .lb-raffles-list::-webkit-scrollbar { 
      width: 8px; /* Slightly wider for better visibility */
    }
    .lb-raffles-list::-webkit-scrollbar-track { 
      background: var(--bg-soft); 
      border-radius: 4px;
      margin: 0.25rem 0;
    }
    .lb-raffles-list::-webkit-scrollbar-thumb { 
      background: var(--accent-dim); 
      border-radius: 4px;
      border: 1px solid var(--border);
    }
    .lb-raffles-list::-webkit-scrollbar-thumb:hover { 
      background: var(--accent); 
    }
    .lb-raffles-list.collapsed { display: none; }
    .lb-raffles-list[hidden] { display: none; }
    /* Loading spinner inside raffle list */
    .lb-raffles-list .lb-loading {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 0.5rem;
      padding: 1rem 0;
      color: var(--muted-foreground);
      font-size: 0.8rem;
    }
    .lb-raffles-list .lb-loading .lb-spinner {
      width: 16px;
      height: 16px;
    }
    .lb-raffles-list .lb-loading .lb-spinner::before {
      inset: 0;
      border-width: 2px;
    }
    .lb-raffles-list .lb-loading .lb-spinner::after {
      inset: 4px;
      border-width: 2px;
    }
    @keyframes lb-spin {
      to { transform: rotate(360deg); }
    }
    /* Main raffles list loading spinner */
    #raffles-list.loading {
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      gap: 0.75rem;
      min-height: 300px;
      color: var(--muted-foreground);
      font-size: 0.9375rem;
    }
    /* Multi-layer loading spinner */
    .raffles-spinner {
      position: relative;
      width: 44px;
      height: 44px;
      margin-bottom: 0.75rem;
    }
    .raffles-spinner::before,
    .raffles-spinner::after {
      content: '';
      position: absolute;
      border-radius: 50%;
      border-style: solid;
      border-color: transparent;
    }
    .raffles-spinner::before {
      inset: 0;
      border-width: 3px;
      border-top-color: var(--accent);
      border-right-color: color-mix(in oklch, var(--accent) 40%, transparent);
      animation: spin-ccw 1s linear infinite;
    }
    .raffles-spinner::after {
      inset: 8px;
      border-width: 3px;
      border-bottom-color: var(--accent);
      border-left-color: color-mix(in oklch, var(--accent) 40%, transparent);
      animation: spin-cw 0.7s linear infinite;
    }
    #raffles-list.loading {
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      gap: 0.75rem;
      min-height: 300px;
      color: var(--muted-foreground);
      font-size: 0.9375rem;
    }
    /* Pulsing dots after loading text */
    #raffles-list.loading::after {
      content: '';
      animation: loadingDots 1.5s steps(4, end) infinite;
    }
    @keyframes loadingDots {
      0%  { content: ''; }
      25% { content: '.'; }
      50% { content: '..'; }
      75% { content: '...'; }
    }
    .lb-raffles-list li { padding: 0.35rem 0; border-bottom: 1px solid var(--border); }
    .lb-raffles-list li:last-child { border-bottom: none; }
    .lb-raffles-list a { color: var(--text); text-decoration: none; font-weight: 500; }
    .lb-raffles-list a:hover { color: var(--accent); }
    .leaderboard-creator-block { flex: 1; min-width: 0; display: flex; flex-direction: column; align-items: flex-start; gap: 0.15rem; }
    .leaderboard-creator-block a { font-size: 0.85rem; font-weight: 600; }
    .lb-creator-avatar { width: 24px; height: 24px; border-radius: 50%; object-fit: cover; flex-shrink: 0; border: 1px solid var(--border); background: var(--surface-hover); }
    .lb-creator-name-row { display: flex; align-items: center; gap: 0.35rem; flex-wrap: nowrap; overflow: hidden; }
    .lb-discord-id { font-size: 0.72rem; color: var(--muted-foreground); display: inline-flex; align-items: center; gap: 0.25rem; flex-wrap: nowrap; white-space: nowrap; }
    .lb-discord-id .lb-copy { padding: 1px 4px; font-size: 0.65rem; background: var(--surface-overlay); border: 1px solid var(--border); color: var(--text-secondary); border-radius: 3px; cursor: pointer; font-family: inherit; transition: background 0.15s ease, color 0.15s ease; flex-shrink: 0; }
    .lb-discord-id .lb-copy:hover { background: var(--accent); color: var(--bg); border-color: var(--accent); }
    .lb-discord-profile-btn { display: inline-flex; align-items: center; justify-content: center; width: 26px; height: 26px; padding: 0; background: var(--surface-overlay); border: 1px solid var(--border); border-radius: 6px; cursor: pointer; transition: background 0.15s ease, border-color 0.15s ease, box-shadow 0.2s ease; flex-shrink: 0; }
    .lb-discord-profile-btn img { width: 14px; height: 14px; display: block; pointer-events: none; }
    .lb-discord-profile-btn:hover { background: var(--discord-brand, #5865F2); border-color: var(--discord-brand, #5865F2); box-shadow: 0 0 10px color-mix(in oklch, var(--discord-brand, #5865F2) 40%, transparent); }
    .lb-discord-profile-btn:hover img { filter: brightness(0) invert(1); }
    .lb-x-profile-btn { display: inline-flex; align-items: center; justify-content: center; width: 26px; height: 26px; padding: 0; background: var(--surface-overlay); border: 1px solid var(--border); border-radius: 6px; cursor: pointer; transition: background 0.15s ease, border-color 0.15s ease, box-shadow 0.2s ease; flex-shrink: 0; }
    .lb-x-profile-btn svg { width: 14px; height: 14px; display: block; pointer-events: none; fill: currentColor; color: var(--text); }
    .lb-x-profile-btn:hover { background: var(--text); border-color: var(--text); box-shadow: 0 0 10px hsl(0 0% 100% / 0.15); }
    .lb-x-profile-btn:hover svg { color: var(--bg); }
    .lb-alpha-btn { display: inline-flex; align-items: center; justify-content: center; width: 26px; height: 26px; padding: 0; background: var(--surface-overlay); border: 1px solid var(--border); border-radius: 6px; cursor: pointer; transition: background 0.15s ease, border-color 0.15s ease, box-shadow 0.2s ease; flex-shrink: 0; }
    .lb-alpha-btn img { width: 14px; height: 14px; display: block; pointer-events: none; border-radius: 2px; }
    .lb-alpha-btn:hover { background: var(--alphabot-brand, #6366f1); border-color: var(--alphabot-brand, #6366f1); box-shadow: 0 0 10px color-mix(in oklch, var(--alphabot-brand, #6366f1) 40%, transparent); }
    .lb-alpha-btn:hover img { filter: brightness(0) invert(1); }
    .lb-row-actions { display: flex; align-items: center; gap: 0.4rem; margin-left: auto; }
    .leaderboard-community-block { flex: 1; min-width: 0; display: flex; flex-direction: column; align-items: flex-start; gap: 0.15rem; }
    .leaderboard-community-block .lb-community-name-row { display: flex; align-items: center; gap: 0.35rem; flex-wrap: wrap; }
    .leaderboard-community-block .lb-community-name { font-size: 0.85rem; font-weight: 600; color: var(--text); }
    .leaderboard-community-block .lb-community-handle { font-size: 0.72rem; color: var(--muted-foreground); font-weight: 500; }
    .leaderboard-community-block .lb-community-meta { font-size: 0.72rem; color: var(--muted-foreground); }
    .lb-twitter-line { font-size: 0.7rem; color: var(--muted-foreground); }
    .lb-twitter-line a { color: var(--accent); text-decoration: none; }
    .lb-twitter-line a:hover { text-decoration: underline; }
    #raffles-list {
      position: relative;
      z-index: 1;
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
      gap: 1.25rem;
      margin-top: 0.5rem;
      transition: grid-template-columns 0.4s cubic-bezier(0.65, 0.05, 0.36, 1), 
                  gap 0.4s cubic-bezier(0.65, 0.05, 0.36, 1);
      transform: translate3d(0,0,0);
    }
    #raffles-list.view-list,
    #raffles-list.view-compact {
      transition: grid-template-columns 0.4s cubic-bezier(0.65, 0.05, 0.36, 1);
    }
    #raffles-list.view-list { grid-template-columns: 1fr; }
    #raffles-list.view-list .card { display: flex; flex-direction: row; }
    #raffles-list.view-list .card-img-wrap { width: 140px; min-width: 140px; height: 100px; }
    #raffles-list.view-compact .card-img-wrap { height: 80px; }
    /* Award-winning glassmorphic cards - borrowed from maximkich.com & unitedofweb.com patterns */
    .card {
      background: var(--card);
      border: 2px solid var(--border);
      border-radius: var(--radius-lg);
      overflow: hidden;
      box-shadow: var(--shadow);
      transform-origin: center center;
      position: relative;
      transition: transform 200ms ease-out, box-shadow 200ms ease-out;
      cursor: pointer;
    }
    .card.visible {
      opacity: 1;
      transform: translate3d(0, 0, 0) scale(1);
    }
    .card:hover {
      transform: translateY(-4px);
      box-shadow: var(--shadow-lg);
      border-color: var(--ring);
    }
    .card-body { background: linear-gradient(180deg, transparent 0%, color-mix(in oklch, var(--foreground) 6%, transparent) 100%); padding: 1.25rem; position: relative; z-index: 2; }
    .card-img-wrap {
      height: 150px;
      background: var(--bg-soft);
      overflow: hidden;
      position: relative;
    }
    .card-img-wrap::after {
      content: '';
      position: absolute;
      inset: 0;
      background: linear-gradient(180deg, transparent 60%, color-mix(in oklch, var(--card) 40%, transparent) 100%);
      pointer-events: none;
    }
    .card-img-wrap img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      transition: transform 0.4s cubic-bezier(0.65, 0.05, 0.36, 1), opacity 0.3s ease;
      transform: translate3d(0,0,0) scale(1);
      transform-origin: center center;
    }
    .card-img-wrap img[loading="lazy"] { opacity: 0; }
    .card-img-wrap img.loaded { opacity: 1; }
    .card-img-wrap.img-error { background: color-mix(in oklch, var(--foreground) 15%, transparent); }
    .card:hover .card-img-wrap img {
      transform: scale(1.08) translate3d(0,0,0);
    }
    .card-header { display: flex; justify-content: space-between; align-items: flex-start; gap: 0.5rem; margin-bottom: 0.6rem; }
    .badge { font-size: 0.65rem; padding: 0.25rem 0.55rem; border-radius: var(--radius-md); text-transform: uppercase; font-weight: 700; letter-spacing: 0.04em; border: 1px solid var(--border); }
    .badge-active { background: var(--accent); color: var(--accent-foreground); border-color: var(--border); }
    .badge-finalised { background: var(--secondary); color: var(--muted-foreground); border-color: var(--border); }
    .card-meta { display: flex; flex-wrap: wrap; gap: 0.5rem; font-size: 0.8125rem; color: var(--text-secondary); margin-bottom: 0.75rem; }
    .card-meta span { display: inline-flex; align-items: center; gap: 0.3rem; }
    .req-badges { display: flex; flex-wrap: wrap; gap: 0.4rem; margin-bottom: 0.6rem; }
    .req-badges a.req-action-btn {
      cursor: pointer;
      position: relative;
    }
    .req-badges a {
      display: inline-flex;
      align-items: center;
      gap: 0.25rem;
      padding: 0.3rem 0.6rem;
      background: var(--secondary);
      border: 1px solid var(--border);
      border-radius: var(--radius-md);
      font-size: 0.75rem;
      font-weight: 500;
      color: var(--accent);
      text-decoration: none;
      transition: transform 150ms ease-out, background 150ms ease-out;
    }
    .req-badges a:hover {
      background: var(--accent);
      color: var(--accent-foreground);
      border-color: var(--border);
      transform: translateY(-1px);
    }
    .card-links { display: flex; flex-wrap: wrap; gap: 0.45rem; }
    .card-links-label { font-size: 0.7rem; text-transform: uppercase; color: var(--muted-foreground); margin-bottom: 0.35rem; letter-spacing: 0.05em; font-weight: 600; }
    .card-links a {
      padding: 0.4rem 0.75rem;
      background: var(--secondary);
      border: 1px solid var(--border);
      border-radius: var(--radius-md);
      font-size: 0.78rem;
      font-weight: 600;
      color: var(--accent);
      text-decoration: none;
      transition: transform 150ms ease-out, background 150ms ease-out;
    }
    .card-links a:hover {
      background: var(--accent);
      color: var(--accent-foreground);
      border-color: var(--border);
      transform: translateY(-1px);
    }
    .raffle-details-wrap { margin-top: 1rem; padding-top: 1rem; border-top: 1px solid var(--border); font-size: 0.8125rem; }
    .raffle-details-section { margin-bottom: 0.6rem; }
    .raffle-details-section strong { display: block; font-size: 0.7rem; text-transform: uppercase; color: var(--muted-foreground); margin-bottom: 0.35rem; letter-spacing: 0.04em; font-weight: 700; }
    .discord-role-pills { display: flex; flex-wrap: wrap; gap: 0.35rem; margin-top: 0.3rem; }
    .discord-role-pill { display: inline-flex; align-items: center; gap: 0.2rem; font-size: 0.75rem; padding: 0.25rem 0.55rem; background: var(--secondary); border: 1px solid var(--border); border-radius: var(--radius-md); color: var(--text-secondary); transition: background 150ms ease-out; }
    .discord-role-pill:hover { background: var(--muted); border-color: var(--border); }
    .discord-join-wrap { margin-top: 0.35rem; font-size: 0.75rem; }
    .discord-join-wrap .discord-join-link { color: var(--accent); text-decoration: none; }
    .discord-join-wrap .discord-join-link:hover { text-decoration: underline; }
    .raffle-details-group { margin-bottom: 0.75rem; }
    .raffle-details-group-title { font-size: 0.7rem; text-transform: uppercase; color: var(--text-secondary); margin-bottom: 0.4rem; letter-spacing: 0.05em; font-weight: 600; }
    .raffle-details-wrap a, .req-badges a, .discord-id-pill a { color: var(--accent); text-decoration: underline; text-underline-offset: 2px; }
    .raffle-details-wrap a:hover, .discord-id-pill a:hover { color: var(--accent-foreground); }
    /* req-badges and card-links hover handled above */
    .created-by { display: inline-flex; align-items: center; gap: 0.5rem; }
    .created-by-avatar { width: 24px; height: 24px; border-radius: 50%; object-fit: cover; }
    .discord-id-pill { display: inline-flex; align-items: center; gap: 0.35rem; background: var(--surface-overlay); padding: 0.25rem 0.5rem; border-radius: 8px; font-family: 'JetBrains Mono', monospace; font-size: 0.8rem; margin-top: 0.35rem; color: var(--text); border: 1px solid var(--border); }
    .discord-id-pill .copy-btn { background: var(--surface-hover); border: 1px solid var(--border); color: var(--text); padding: 0.2rem 0.4rem; border-radius: 6px; cursor: pointer; font-size: 0.75rem; transition: background 0.15s ease, color 0.15s ease; }
    .discord-id-pill .copy-btn:hover { background: var(--accent); color: var(--bg); border-color: var(--accent); }
    .empty, .loading { text-align: center; padding: 3rem; color: var(--text-secondary); font-size: 0.9375rem; line-height: 1.6; }
    .toast {
      position: fixed;
      bottom: 1.5rem;
      right: 1.5rem;
      z-index: 10000;
      max-width: 400px;
      padding: 0.85rem 1.35rem;
      background: var(--surface-raised);
      border: 1px solid var(--border-strong);
      border-radius: var(--radius-lg);
      color: var(--text);
      font-size: 0.875rem;
      box-shadow: var(--shadow-lg);
      transition: transform 0.2s ease, opacity 0.2s ease;
      pointer-events: auto;
    }
    .toast.ok { border-color: var(--accent); color: var(--text); }
    .toast.err { border-color: var(--destructive); color: var(--destructive-foreground); }
    /* Activity toast overlay - fixed bottom-center viewport */
    .activity-toast-overlay {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      z-index: 10000;
      display: flex;
      align-items: flex-end;
      justify-content: center;
      padding: 0 1rem 1.25rem;
      background: transparent;
      opacity: 0;
      pointer-events: none;
      transition: opacity 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    }
    .activity-toast-overlay.visible {
      opacity: 1;
      pointer-events: none; /* Allow clicks through overlay - don't block page */
    }
    .activity-toast-overlay.visible .activity-toast {
      pointer-events: auto; /* Only toast itself is clickable */
    }
    /* Ensure overlay doesn't block page content */
    .activity-toast-overlay {
      pointer-events: none !important;
    }
    .activity-toast-overlay .activity-toast {
      pointer-events: auto;
    }
    .activity-toast {
      position: fixed;
      bottom: calc(20px + env(safe-area-inset-bottom, 0px));
      left: 50%;
      top: auto;
      right: auto;
      transform: translateX(-50%) scale(0.95);
      z-index: 10001;
      background: var(--card);
      border: 2px solid var(--accent);
      border-radius: 50px;
      padding: 10px 20px;
      display: flex;
      flex-direction: row;
      align-items: center;
      gap: 0.5rem;
      text-align: center;
      color: var(--primary-foreground);
      font-size: 14px;
      box-shadow: 0 8px 24px color-mix(in oklch, var(--foreground) 60%, transparent), 0 0 12px color-mix(in oklch, var(--accent) 30%, transparent);
      max-width: 320px;
      min-width: 180px;
      opacity: 0;
      pointer-events: auto;
      transition: opacity 0.25s ease, transform 0.25s cubic-bezier(0.4, 0, 0.2, 1);
      backface-visibility: hidden;
      -webkit-backface-visibility: hidden;
    }
    @media (max-width: 480px) {
      .activity-toast {
        bottom: calc(12px + env(safe-area-inset-bottom, 0px));
        padding: 8px 14px;
        font-size: 13px;
      }
    }
    .activity-toast-overlay.visible .activity-toast {
      opacity: 1;
      transform: translateX(-50%) scale(1);
    }
    .activity-toast .spinner {
      position: relative;
      width: 20px;
      height: 20px;
      flex-shrink: 0;
      display: inline-block;
    }
    .activity-toast .spinner::before,
    .activity-toast .spinner::after {
      content: '';
      position: absolute;
      border-radius: 50%;
      border-style: solid;
      border-color: transparent;
    }
    .activity-toast .spinner::before {
      inset: 0;
      border-width: 2px;
      border-top-color: var(--accent);
      border-right-color: color-mix(in oklch, var(--accent) 40%, transparent);
      animation: spin-ccw 0.9s linear infinite;
    }
    .activity-toast .spinner::after {
      inset: 5px;
      border-width: 2px;
      border-bottom-color: var(--accent);
      border-left-color: color-mix(in oklch, var(--accent) 40%, transparent);
      animation: spin-cw 0.7s linear infinite;
    }
    .activity-toast.done .spinner { display: none; }
    .activity-toast .text { 
      font-weight: 500;
      color: var(--primary-foreground);
      line-height: 1.4;
      font-size: 14px;
    }
    .activity-toast .progress-wrap { 
      position: absolute; 
      bottom: 0; 
      left: 0; 
      right: 0; 
      height: 4px; 
      background: color-mix(in oklch, var(--foreground) 30%, transparent); 
      border-radius: 0 0 48px 48px; 
      overflow: hidden; 
    }
    .activity-toast .progress-bar { 
      height: 100%; 
      background: linear-gradient(90deg, var(--accent), var(--accent-strong)); 
      border-radius: 0 2px 2px 0; 
      width: 0%; 
      transition: width 0.2s ease-out;
    }
    .activity-toast .progress-bar.countdown { transition: width 0.1s linear; }
    .discord-id-pill .copy-btn.copied { background: var(--accent); color: var(--bg); border-color: var(--accent); }
    .search-wrap { flex: 1; min-width: 180px; max-width: 280px; position: relative; }
    .search-wrap input { width: 100%; padding-right: 2rem; }
    .search-clear {
      position: absolute;
      right: 0.5rem;
      top: 50%;
      transform: translateY(-50%);
      background: none;
      border: none;
      color: var(--muted-foreground);
      cursor: pointer;
      font-size: 1rem;
      padding: 0.25rem;
      line-height: 1;
      opacity: 0;
      pointer-events: none;
      transition: opacity 0.15s ease, color 0.15s ease;
    }
    .search-wrap:has(input:not(:placeholder-shown)) .search-clear,
    .search-wrap input:not(:placeholder-shown) + .search-clear { opacity: 1; pointer-events: auto; }
    .search-clear:hover { color: var(--accent); }
    .search-clear:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; border-radius: 4px; }
    .load-more-wrap { text-align: center; padding: 1.5rem; }
    .load-more-wrap .btn { 
      min-height: 44px; 
      min-width: 44px;
      animation: pulseGlow 2s ease-in-out infinite;
    }
    @keyframes pulseGlow {
      0%, 100% { box-shadow: 0 2px 16px var(--accent-glow); }
      50% { box-shadow: 0 4px 24px color-mix(in oklch, var(--accent) 50%, transparent); }
    }
    .refresh-lb { min-height: 44px; padding: 0.5rem 0.75rem; }

    /* ============================================
       RESPONSIVE — Mobile & Tablet
       ============================================ */
    /* Tablet (641px - 1024px) */
    @media (max-width: 1024px) {
      .container { padding: 1rem 1.25rem; }
      .leaderboard-section { flex-direction: column; gap: 1rem; }
      .leaderboard-section .leaderboard-col { min-width: 100%; max-height: 480px; }
      .leaderboard-col { max-height: 420px; }
      #raffles-list { grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 1rem; }
    }

    /* Mobile (< 640px) */
    @media (max-width: 640px) {
      html { font-size: 15px; }
      .container { padding: 0.75rem 1rem; padding-bottom: calc(0.75rem + env(safe-area-inset-bottom, 0px)); }

      /* Header */
      .header-inner { flex-wrap: wrap; gap: 8px; padding: 8px 12px; }
      .site-header .logo-section { min-width: auto; gap: 8px; }
      .site-header .main-title h1 { font-size: 1rem; }
      .site-header .main-title p { font-size: 0.65rem; }
      .header-promo { min-width: auto; padding: 4px 10px; gap: 6px; flex: 1 1 100%; order: 3; }
      .promo-title { font-size: 0.75rem; }
      .promo-desc { display: none; }
      .promo-btn { font-size: 0.7rem; padding: 3px 10px; }
      .site-header .actions-section { min-width: auto; }
      .site-header .creator-section { min-width: auto; }

      /* Filters */
      .filters { flex-direction: column; align-items: stretch; gap: 0.6rem; padding: 0.75rem 1rem; border-radius: 14px; }
      .filters > * { width: 100%; }
      .search-wrap { max-width: 100%; min-width: auto; }
      .custom-select-trigger { min-width: auto; width: 100%; }

      /* Cards */
      #raffles-list { grid-template-columns: 1fr; gap: 0.875rem; }
      #raffles-list.view-list .card { flex-direction: column; }
      #raffles-list.view-list .card-img-wrap { width: 100%; height: 140px; }
      .card { border-radius: 16px; }

      /* Leaderboards */
      .leaderboard-section { flex-direction: column; padding: 1rem; gap: 1rem; }
      .leaderboard-section .leaderboard-col { min-width: 100%; max-height: 480px; border-radius: var(--radius-lg); }
      .lb-header-wrap { padding: 1rem 1.25rem 0.75rem; gap: 0.6rem; }
      .lb-section-heading { font-size: 0.85rem; font-weight: 600; color: var(--text); margin: 0; display: flex; align-items: center; gap: 0.35rem; }
    .lb-muted { font-size: 0.78rem; color: var(--muted-foreground); font-weight: 400; }
      .leaderboard-col-content { padding: 0.75rem 1rem; }
      .leaderboard-row-wrap { margin-bottom: 0.5rem; }
      .leaderboard-row {
        grid-template-columns: 44px 1fr 80px auto;
        padding: 10px 16px;
        font-size: 0.88rem;
        gap: 0.6rem;
        min-height: 52px;
      }
      .leaderboard-row .rank { font-size: 0.8rem; }
      .leaderboard-row .count { font-size: 0.9rem; }
      .leaderboard-creator-block a { font-size: 0.9rem; }
      .lb-discord-id { font-size: 0.75rem; gap: 0.3rem; }
      .lb-expand-btn { padding: 4px 10px; font-size: 0.72rem; }
      .lb-raffles-list { max-height: 200px; padding: 0.6rem 1rem; font-size: 0.82rem; }
      .leaderboard-col-header {
        grid-template-columns: 44px 1fr 80px auto;
      }
      /* Touch targets */
      .btn, .btn-secondary, .view-btn, .lb-expand-btn, .lb-copy {
        min-height: 36px;
        min-width: 36px;
      }

      /* Toast */
      .toast { padding: 10px 16px; font-size: 0.8125rem; }
      .activity-toast { left: 12px; right: 12px; max-width: none; bottom: calc(12px + env(safe-area-inset-bottom, 0px)); }

      /* Stats bar */
      h1#main-title { font-size: 1.1rem; }
      .tagline { font-size: 0.8125rem; }
    }

    /* Small phones (< 380px) */
    @media (max-width: 380px) {
      .site-header .creator-section span { display: none; }
      .leaderboard-row {
        grid-template-columns: 40px 1fr 70px auto;
        padding: 8px 12px;
        font-size: 0.82rem;
        gap: 0.5rem;
        min-height: 46px;
      }
      .leaderboard-row .rank { font-size: 0.75rem; }
      .leaderboard-creator-block a { font-size: 0.82rem; }
      .lb-discord-id { font-size: 0.7rem; }
      .lb-expand-btn { padding: 3px 8px; font-size: 0.68rem; }
      .leaderboard-col-header {
        grid-template-columns: 40px 1fr 70px auto;
      }
    }

    @media (min-width: 768px) { .view-btn { min-height: 44px; } }
    @keyframes spin { to { transform: rotate(360deg); } }
    .view-switcher { display: flex; align-items: center; gap: 0.4rem; }
    .view-btn {
      padding: 0.4rem 0.75rem;
      background: var(--surface-overlay);
      border: 1px solid var(--border);
      border-radius: 10px;
      color: var(--text-secondary);
      font-size: 0.8125rem;
      font-weight: 500;
      cursor: pointer;
      font-family: inherit;
      transition: border-color 0.25s cubic-bezier(0.65, 0.05, 0.36, 1), 
                  color 0.25s cubic-bezier(0.65, 0.05, 0.36, 1), 
                  background 0.25s cubic-bezier(0.65, 0.05, 0.36, 1), 
                  transform 0.25s cubic-bezier(0.65, 0.05, 0.36, 1);
      transform: translate3d(0,0,0);
      position: relative;
    }
    .view-btn::before {
      content: '';
      position: absolute;
      inset: 0;
      border-radius: 10px;
      background: radial-gradient(circle at center, color-mix(in oklch, var(--accent) 12%, transparent) 0%, transparent 70%);
      opacity: 0;
      transition: opacity 0.3s cubic-bezier(0.65, 0.05, 0.36, 1);
      pointer-events: none;
    }
    .view-btn:hover { 
      border-color: var(--border-strong); 
      color: var(--text); 
      background: var(--surface-hover); 
      transform: translate3d(0, -2px, 0) scale(1.02);
    }
    .view-btn:hover::before { opacity: 1; }
    .view-btn.active { border-color: var(--accent); color: var(--accent); background: var(--accent-dim); }
    .view-btn:active { transform: translate3d(0, 0, 0) scale(0.97); }
    .view-btn:hover {
      /* No will-change needed */
    }
    .view-btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
    .skip-link {
      position: absolute;
      top: -3rem;
      left: 1rem;
      padding: 0.5rem 1rem;
      background: var(--accent);
      color: var(--bg);
      font-weight: 600;
      border-radius: var(--radius-lg);
      z-index: 200;
      transition: top 0.2s ease;
    }
    .skip-link:focus { top: 1rem; outline: 2px solid var(--text); outline-offset: 2px; }
    .visually-hidden { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
    @media (prefers-reduced-motion: reduce) {
      .card:hover, .btn:hover, .btn-secondary:hover { transform: none; }
      .card-img-wrap img { transition: none; }
      .card { animation: none; }
      html { scroll-behavior: auto; }
    }
    /* Chrome-specific performance optimizations */
    @supports (-webkit-appearance: none) {
      /* Disable backdrop-filter in Chrome - causes severe lag */
      .card {
        backdrop-filter: none;
        -webkit-backdrop-filter: none;
        background: var(--surface);
      }
      .leaderboard-col-header,
      .leaderboard-col {
        backdrop-filter: none;
        -webkit-backdrop-filter: none;
      }
      /* Reduce complex transforms in Chrome */
      .card:hover {
        transform: translate3d(0, -2px, 0);
      }
    }
    /* Neo Brutalism overrides — sharp corners on pills when in neo mode */
    body.theme-neo .badge,
    body.theme-neo .req-badges a,
    body.theme-neo .card-links a,
    body.theme-neo .discord-role-pill {
      border-radius: 0;
    }
    /* Tabular numbers for counters */
    .count, .lb-discord-id, .leaderboard-row .count {
      font-variant-numeric: tabular-nums;
    }
