@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&family=Space+Mono:wght@400;700&display=swap";:root{--bg-primary: #fafaf8;--bg-secondary: #f0efeb;--bg-card: #ffffff;--bg-hover: #f5f4f0;--text-primary: #1a1a1a;--text-secondary: #6b6b6b;--text-tertiary: #9e9e9e;--accent: #ff4d00;--accent-soft: rgba(255, 77, 0, .08);--accent-hover: #e64500;--border: #e5e4e0;--border-light: #eeede9;--win: #2db84b;--loss: #e53935;--draw: #9e9e9e;--rock: #78909c;--paper: #f9a825;--scissors: #ef5350;--lizard: #66bb6a;--spock: #42a5f5;--blade: #ab47bc;--dog: #8d6e63;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-pill: 100px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 2px 8px rgba(0, 0, 0, .06);--shadow-lg: 0 4px 24px rgba(0, 0, 0, .08);--transition: .2s cubic-bezier(.25, .46, .45, .94);--font-sans: "Space Grotesk", system-ui, -apple-system, sans-serif;--font-mono: "Space Mono", "SF Mono", "Fira Code", monospace}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}.app{display:flex;flex-direction:column;min-height:100vh}.app-content{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:32px 24px 64px}.header{position:sticky;top:0;z-index:100;background:#fafaf8d9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border-light)}.header-inner{max-width:1200px;margin:0 auto;padding:16px 24px;display:flex;align-items:center;justify-content:space-between}.header-left{display:flex;align-items:center;gap:12px}.header-logo-link,.header-title-link{text-decoration:none;color:inherit}.header-logo{width:32px;height:32px;background:var(--text-primary);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--bg-primary);font-family:var(--font-mono);font-size:14px;font-weight:700;letter-spacing:-.5px}.header-title{font-size:15px;font-weight:600;letter-spacing:-.3px;color:var(--text-primary)}.header-subtitle{font-size:12px;font-family:var(--font-mono);color:var(--text-tertiary);letter-spacing:.5px;text-transform:uppercase}.header-nav{display:flex;align-items:center;gap:4px}.nav-link{padding:6px 14px;font-family:var(--font-mono);font-size:12px;font-weight:500;letter-spacing:.5px;text-transform:uppercase;text-decoration:none;color:var(--text-tertiary);border-radius:var(--radius-pill);transition:all var(--transition)}.nav-link:hover{color:var(--text-primary);background:var(--bg-hover)}.nav-link--active{color:var(--text-primary);background:var(--bg-secondary)}.search-filters{padding:24px 0 0}.search-filters-row{display:flex;align-items:flex-end;gap:12px;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:4px;flex:1;min-width:140px}.filter-group--small{flex:.5;min-width:100px}.filter-group:first-child{flex:2;min-width:200px}.filter-label{font-size:10px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:1.5px;color:var(--text-tertiary);font-weight:500}.filter-input{height:40px;padding:0 14px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-card);color:var(--text-primary);font-family:var(--font-sans);font-size:14px;transition:all var(--transition);outline:none;width:100%}.filter-input::placeholder{color:var(--text-tertiary)}.filter-input:focus{border-color:var(--text-primary);box-shadow:0 0 0 1px var(--text-primary)}.filter-input--date{font-family:var(--font-mono);font-size:13px;cursor:pointer}.filter-input--date::-webkit-calendar-picker-indicator{opacity:.5;cursor:pointer}.filter-clear{height:40px;padding:0 20px;border:1px solid var(--border);border-radius:var(--radius-pill);background:transparent;color:var(--text-secondary);font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.5px;text-transform:uppercase;cursor:pointer;transition:all var(--transition);white-space:nowrap;flex-shrink:0}.filter-clear:hover{background:var(--text-primary);color:var(--bg-primary);border-color:var(--text-primary)}.filter-clear--hidden{visibility:hidden;pointer-events:none}.game-list-header{display:flex;align-items:center;justify-content:space-between;padding:20px 0 16px;border-bottom:1px solid var(--border);flex-wrap:wrap;gap:8px}.game-list-header-left{display:flex;align-items:center;gap:16px}.game-list-title{font-size:13px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:1.5px;color:var(--text-tertiary)}.game-list-count{font-size:12px;font-family:var(--font-mono);color:var(--text-tertiary)}.game-table{width:100%;border-collapse:collapse}.game-table th{padding:12px 16px;text-align:left;font-size:10px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:1.5px;color:var(--text-tertiary);font-weight:500;border-bottom:1px solid var(--border);white-space:nowrap}.game-table td{padding:14px 16px;font-size:14px;border-bottom:1px solid var(--border-light);transition:background var(--transition)}.game-table tr:hover td{background:var(--bg-hover)}.game-table .col-time{font-family:var(--font-mono);font-size:12px;color:var(--text-secondary);white-space:nowrap}.game-table .col-player{font-weight:500}.game-table .col-played{font-family:var(--font-mono);font-size:13px}.game-table .col-result{text-align:center}.player-winner{color:var(--text-primary);font-weight:600}.player-loser{color:var(--text-tertiary)}.player-draw{color:var(--text-secondary)}.hand-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--radius-pill);font-size:12px;font-family:var(--font-mono);font-weight:500;letter-spacing:.3px}.hand-badge--ROCK{background:#78909c1a;color:var(--rock)}.hand-badge--PAPER{background:#f9a8251a;color:var(--paper)}.hand-badge--SCISSORS{background:#ef53501a;color:var(--scissors)}.hand-badge--LIZARD{background:#66bb6a1a;color:var(--lizard)}.hand-badge--SPOCK{background:#42a5f51a;color:var(--spock)}.hand-badge--BLADE{background:#ab47bc1a;color:var(--blade)}.hand-badge--DOG{background:#8d6e631a;color:var(--dog)}.hand-emoji{font-size:14px}.result-badge{display:inline-flex;align-items:center;justify-content:center;padding:2px 10px;border-radius:var(--radius-pill);font-size:10px;font-family:var(--font-mono);font-weight:700;letter-spacing:1px;text-transform:uppercase}.result-badge--win-a,.result-badge--win-b{background:#2db84b1a;color:var(--win)}.result-badge--draw{background:#9e9e9e1a;color:var(--draw)}.live-feed{margin-bottom:32px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm)}.live-feed-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.live-feed-title-wrap{display:flex;align-items:center;gap:8px}.live-feed-title{font-family:var(--font-mono);font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-primary)}.live-dot{width:8px;height:8px;border-radius:50%;background:var(--text-tertiary);transition:background var(--transition)}.live-dot--active{background:var(--accent);box-shadow:0 0 #ff4d0066;animation:pulse-live 2s infinite}@keyframes pulse-live{0%{transform:scale(.95);box-shadow:0 0 #ff4d0066}70%{transform:scale(1);box-shadow:0 0 0 6px #ff4d0000}to{transform:scale(.95);box-shadow:0 0 #ff4d0000}}.live-feed-status{font-family:var(--font-mono);font-size:11px;color:var(--text-tertiary)}.live-feed-list{display:flex;flex-direction:column;gap:8px}.game-row-detailed{display:flex;align-items:center;gap:16px;padding:12px 20px;background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-md);transition:all var(--transition);animation:slide-down-fade .5s cubic-bezier(.16,1,.3,1) forwards;opacity:0;transform:translateY(-10px)}.game-row-detailed:hover{border-color:var(--border);box-shadow:var(--shadow-sm);background:var(--bg-hover)}@keyframes slide-down-fade{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}.game-row-time{font-family:var(--font-mono);font-size:11px;color:var(--text-tertiary);min-width:100px;flex-shrink:0}.game-row-matchup{display:flex;flex:1;align-items:center;justify-content:space-between}.game-row-player{display:flex;align-items:center;gap:12px;flex:1;font-size:14px;font-weight:500}.game-row-player--right{justify-content:flex-end}.game-row-vs-badge{padding:0 16px;flex-shrink:0}.live-feed-empty{padding:24px;text-align:center;font-family:var(--font-mono);font-size:12px;color:var(--text-tertiary);background:var(--bg-hover);border-radius:var(--radius-md)}.game-cards{display:none;flex-direction:column;gap:8px;padding-top:12px}.game-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:16px;transition:all var(--transition)}.game-card:hover{border-color:var(--border);box-shadow:var(--shadow-sm)}.game-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.game-card-time{font-family:var(--font-mono);font-size:11px;color:var(--text-tertiary);letter-spacing:.3px}.game-card-matchup{display:flex;align-items:center;gap:12px}.game-card-player{flex:1;text-align:center}.game-card-player-name{font-size:14px;font-weight:500;margin-bottom:4px}.game-card-vs{font-family:var(--font-mono);font-size:10px;font-weight:700;color:var(--text-tertiary);letter-spacing:2px;flex-shrink:0}.pagination{display:flex;align-items:center;justify-content:center;gap:8px;padding:32px 0}.pagination-btn{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 12px;border:1px solid var(--border);border-radius:var(--radius-pill);background:var(--bg-card);color:var(--text-primary);font-family:var(--font-mono);font-size:13px;font-weight:500;cursor:pointer;transition:all var(--transition);-webkit-user-select:none;user-select:none}.pagination-btn:hover:not(:disabled){background:var(--text-primary);color:var(--bg-primary);border-color:var(--text-primary)}.pagination-btn:disabled{opacity:.3;cursor:not-allowed}.pagination-btn--active{background:var(--text-primary);color:var(--bg-primary);border-color:var(--text-primary)}.pagination-info{font-family:var(--font-mono);font-size:12px;color:var(--text-tertiary);padding:0 8px}.pagination-ellipsis{font-family:var(--font-mono);font-size:13px;color:var(--text-tertiary);padding:0 4px}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;gap:16px}.loading-spinner{width:24px;height:24px;border:2px solid var(--border);border-top-color:var(--text-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-family:var(--font-mono);font-size:12px;color:var(--text-tertiary);letter-spacing:.5px;text-transform:uppercase}.error-container{display:flex;flex-direction:column;align-items:center;padding:80px 20px;gap:12px}.error-icon{font-size:32px}.error-text{font-size:14px;color:var(--text-secondary)}.error-retry{margin-top:8px;padding:8px 20px;border:1px solid var(--text-primary);border-radius:var(--radius-pill);background:transparent;color:var(--text-primary);font-family:var(--font-mono);font-size:12px;font-weight:500;letter-spacing:.5px;text-transform:uppercase;cursor:pointer;transition:all var(--transition)}.error-retry:hover{background:var(--text-primary);color:var(--bg-primary)}.game-mode-filter{display:flex;gap:4px;flex-wrap:wrap}.mode-btn{padding:4px 12px;border:1px solid var(--border);border-radius:var(--radius-pill);background:transparent;color:var(--text-tertiary);font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.3px;cursor:pointer;transition:all var(--transition)}.mode-btn:hover{color:var(--text-primary);border-color:var(--text-secondary)}.mode-btn--active{background:var(--text-primary);color:var(--bg-primary);border-color:var(--text-primary)}.mode-btn--active:hover{color:var(--bg-primary);background:var(--text-secondary);border-color:var(--text-secondary)}.player-link{color:inherit;text-decoration:none;transition:color var(--transition);cursor:pointer}.player-link:hover{color:var(--accent)}.back-link{display:inline-flex;align-items:center;gap:4px;font-family:var(--font-mono);font-size:12px;color:var(--text-tertiary);text-decoration:none;letter-spacing:.3px;margin-bottom:24px;transition:color var(--transition);background:none;border:none;padding:0;cursor:pointer}.back-link:hover{color:var(--text-primary)}.player-profile{padding-top:8px}.profile-header{margin-bottom:32px}.profile-name{font-size:32px;font-weight:700;letter-spacing:-.5px;margin-bottom:4px}.profile-meta{font-family:var(--font-mono);font-size:13px;color:var(--text-tertiary);letter-spacing:.3px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:40px}.stat-card{padding:20px;border-radius:var(--radius-md);border:1px solid var(--border-light);text-align:center}.stat-card-value{font-size:28px;font-weight:700;font-family:var(--font-mono);letter-spacing:-1px;margin-bottom:4px}.stat-card-label{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-tertiary)}.stat-card--wins .stat-card-value{color:var(--win)}.stat-card--losses .stat-card-value{color:var(--loss)}.stat-card--draws .stat-card-value{color:var(--draw)}.stat-card--rate .stat-card-value{color:var(--accent)}.profile-section{margin-bottom:40px}.section-title{font-size:13px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:1.5px;color:var(--text-tertiary);margin-bottom:16px;padding-bottom:8px;border-bottom:1px solid var(--border)}.hand-dist{display:flex;flex-direction:column;gap:8px}.hand-dist-row{display:flex;align-items:center;gap:12px}.hand-dist-row .hand-badge{min-width:80px;text-align:center}.hand-dist-bar-wrap{flex:1;height:8px;background:var(--bg-secondary);border-radius:4px;overflow:hidden}.hand-dist-bar{height:100%;background:var(--text-primary);border-radius:4px;min-width:2px;transition:width .5s ease}.hand-dist-count{font-family:var(--font-mono);font-size:12px;color:var(--text-secondary);min-width:100px;text-align:right}.recent-games{display:flex;flex-direction:column;gap:6px}.recent-game{display:flex;align-items:center;gap:12px;padding:10px 14px;border:1px solid var(--border-light);border-radius:var(--radius-md);transition:all var(--transition)}.recent-game:hover{border-color:var(--border)}.recent-game-time{font-family:var(--font-mono);font-size:11px;color:var(--text-tertiary);white-space:nowrap;min-width:100px}.recent-game-detail{font-size:13px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.result-badge--win{background:#2db84b1a;color:var(--win)}.result-badge--loss{background:#e539351a;color:var(--loss)}.rankings-page{padding-top:8px}.rankings-header{display:flex;align-items:baseline;gap:16px;margin-bottom:24px}.rankings-title{font-size:28px;font-weight:700;letter-spacing:-.5px}.rankings-count{font-family:var(--font-mono);font-size:13px;color:var(--text-tertiary)}.rankings-table-wrap{overflow-x:auto}.rankings-table{width:100%;border-collapse:collapse}.rankings-table th{padding:12px 16px;text-align:left;font-size:10px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:1.5px;color:var(--text-tertiary);font-weight:500;border-bottom:1px solid var(--border);white-space:nowrap}.sortable-th{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color var(--transition)}.sortable-th:hover{color:var(--text-primary)}.sortable-th--active{color:var(--text-primary);font-weight:600}.rankings-table td{padding:12px 16px;font-size:14px;border-bottom:1px solid var(--border-light);transition:background var(--transition)}.rankings-table tr:hover td{background:var(--bg-hover)}.col-rank{font-family:var(--font-mono);font-weight:600;color:var(--text-tertiary);width:50px}.col-num{font-family:var(--font-mono);font-size:13px;text-align:right}.col-wins{color:var(--win)}.col-losses{color:var(--loss)}.col-draws{color:var(--draw)}.col-rate{font-weight:600;color:var(--text-primary)}.rankings-cards{display:none;flex-direction:column;gap:8px}.ranking-card{padding:14px 16px;border:1px solid var(--border-light);border-radius:var(--radius-md);transition:all var(--transition)}.ranking-card:hover{border-color:var(--border)}.ranking-card-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.ranking-card-rank{font-family:var(--font-mono);font-size:13px;font-weight:700;color:var(--text-tertiary)}.ranking-card-name{font-weight:600;font-size:15px}.ranking-card-stats{display:flex;gap:16px}.ranking-card-stat{display:flex;align-items:baseline;gap:4px}.ranking-card-stat-value{font-family:var(--font-mono);font-size:14px;font-weight:600}.ranking-card-stat-label{font-family:var(--font-mono);font-size:10px;color:var(--text-tertiary);text-transform:uppercase}.ranking-card-rate{color:var(--accent)}@media(max-width:768px){.header-inner{padding:12px 16px}.app-content{padding:0 16px 48px}.search-filters-row{flex-direction:column;gap:10px}.filter-group{min-width:100%}.filter-clear{width:100%}.game-list-header{flex-direction:column;align-items:flex-start}.stats-grid{grid-template-columns:repeat(2,1fr)}.profile-name{font-size:24px}.stat-card-value{font-size:22px}.game-table-wrap,.rankings-table-wrap{display:none}.game-cards,.rankings-cards{display:flex}.recent-game{flex-wrap:wrap;gap:8px}.recent-game-time{min-width:auto}.game-row-detailed{flex-wrap:wrap;padding:10px 14px;gap:8px}.game-row-time{width:100%;margin-bottom:2px}.game-row-matchup{flex-direction:column;gap:8px}.game-row-player{width:100%;justify-content:space-between}.game-row-player--right{flex-direction:row-reverse}.game-row-vs-badge{padding:2px 0}.mode-btn{flex:1;text-align:center}}@media(min-width:769px){.game-table-wrap,.rankings-table-wrap{display:block}.game-cards,.rankings-cards{display:none}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.leaderboard{margin-top:32px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden}.leaderboard-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-light);gap:16px}.leaderboard-title{font-family:Space Grotesk,sans-serif;font-size:1rem;font-weight:600;color:var(--text-primary);display:block}.leaderboard-subtitle{font-size:.8rem;color:var(--text-tertiary);font-weight:400;display:block;margin-top:2px}.leaderboard-list{padding:8px 0}.leaderboard-row{display:flex;align-items:center;gap:16px;padding:12px 24px;transition:transform .4s ease,background-color .6s ease}.leaderboard-row:hover{background:var(--bg-hover)}.leaderboard-row--up{animation:slideUp .8s ease}.leaderboard-row--down{animation:slideDown .8s ease}@keyframes slideUp{0%{transform:translateY(12px);background-color:#2db84b1a}70%{background-color:#2db84b0f}to{transform:translateY(0);background-color:transparent}}@keyframes slideDown{0%{transform:translateY(-12px);background-color:#e5393514}70%{background-color:#e539350a}to{transform:translateY(0);background-color:transparent}}.leaderboard-rank{width:28px;text-align:center;font-family:Space Mono,monospace;font-size:.85rem;font-weight:600;color:var(--text-secondary);flex-shrink:0}.leaderboard-name{flex:1;font-family:Space Grotesk,sans-serif;font-size:.9rem;font-weight:500;color:var(--text-primary);text-decoration:none;transition:color .15s}.leaderboard-name:hover{color:var(--accent)}.leaderboard-stats{display:flex;gap:16px;font-family:Space Mono,monospace;font-size:.8rem}.leaderboard-wins{color:var(--win);font-weight:700;min-width:36px;text-align:right}.leaderboard-losses{color:var(--loss);font-weight:500;min-width:36px;text-align:right}.leaderboard-draws{color:var(--draw);font-weight:500;min-width:36px;text-align:right}.leaderboard-games{color:var(--text-secondary);min-width:36px;text-align:right}.leaderboard-rate{color:var(--text-tertiary);min-width:36px;text-align:right}.leaderboard-empty{padding:40px 24px;text-align:center;color:var(--text-tertiary);font-size:.9rem}@media(max-width:600px){.leaderboard-header{padding:16px;flex-direction:column;align-items:flex-start;gap:4px}.leaderboard-row{padding:10px 16px;gap:12px}.leaderboard-stats{gap:10px;font-size:.75rem}.leaderboard-wins,.leaderboard-losses,.leaderboard-draws,.leaderboard-games,.leaderboard-rate{min-width:28px}}.not-found{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;text-align:center;gap:12px}.not-found-code{font-family:Space Mono,monospace;font-size:5rem;font-weight:700;color:var(--text-primary);line-height:1;letter-spacing:-2px}.not-found-message{font-family:Space Grotesk,sans-serif;font-size:1.25rem;color:var(--text-secondary);font-weight:500}.not-found-redirect{font-size:.9rem;color:var(--text-tertiary);margin-top:16px}.not-found-redirect strong{color:var(--accent);font-weight:700}.autocomplete-wrapper{position:relative}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;z-index:100;margin-top:4px;padding:4px 0;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 24px #00000014;list-style:none;max-height:280px;overflow-y:auto}.autocomplete-item{padding:10px 16px;font-family:Space Grotesk,sans-serif;font-size:.9rem;color:var(--text-primary);cursor:pointer;transition:background-color .1s}.autocomplete-item:hover,.autocomplete-item--active{background:var(--bg-hover)}.autocomplete-item--active{color:var(--accent)}
