.genre-search-selector{width:100%;max-width:500px;margin:0 auto}.genre-search-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.genre-search-header h3{margin:0;color:var(--text);font-size:1.1rem}.current-genre{font-size:.9rem;color:var(--muted)}.genre-badge{background:var(--btn-primary);color:#fff;padding:2px 8px;border-radius:12px;font-weight:600;font-size:.8rem}.genre-search-input-container{position:relative;margin-bottom:16px}.search-input-wrapper{position:relative;display:flex;align-items:center}.genre-search-input{width:100%;padding:12px 16px 12px 40px;border:2px solid var(--card-border);border-radius:12px;background:var(--card-bg);color:var(--text);font-size:.95rem;transition:all .3s ease;outline:none}.genre-search-input:focus{border-color:var(--btn-primary);box-shadow:0 0 0 3px #3b82f61a}.search-icon{position:absolute;left:12px;color:var(--muted);font-size:1.1rem;pointer-events:none}.search-suggestions{position:absolute;top:100%;left:0;right:0;background:var(--card-bg);border:2px solid var(--card-border);border-radius:12px;box-shadow:0 8px 25px #00000026;max-height:300px;overflow-y:auto;z-index:1000;margin-top:4px}.suggestion-item{width:100%;padding:12px 16px;border:none;background:transparent;color:var(--text);text-align:left;cursor:pointer;transition:all .2s ease;border-bottom:1px solid var(--card-border);display:flex;flex-direction:column;gap:4px}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover,.suggestion-item.selected{background:var(--btn-primary);color:#fff}.suggestion-name{font-weight:600;font-size:.95rem}.suggestion-keywords{font-size:.8rem;opacity:.7}.no-suggestions{padding:16px;text-align:center;color:var(--muted)}.no-suggestions small{display:block;margin-top:4px;font-size:.8rem}.genre-quick-actions{margin-bottom:16px}.quick-genre-btn{width:100%;margin-bottom:12px;padding:12px 16px;font-size:.95rem}.popular-genres{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.popular-label{font-size:.85rem;color:var(--muted);font-weight:600;margin-right:4px}.popular-genre-btn{padding:6px 12px;font-size:.8rem;border-radius:16px;flex-shrink:0}.search-help{margin-top:16px}.help-details{background:var(--card-bg);border:1px solid var(--card-border);border-radius:8px;padding:12px}.help-details summary{cursor:pointer;font-weight:600;color:var(--text);font-size:.9rem;outline:none;list-style:none;display:flex;align-items:center;gap:8px}.help-details summary::-webkit-details-marker{display:none}.help-details[open] summary{margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--card-border)}.help-content{color:var(--muted);font-size:.85rem;line-height:1.4}.help-content p{margin:0 0 8px}.help-categories{display:flex;flex-wrap:wrap;gap:6px;margin:8px 0}.help-category{background:rgba(var(--btn-primary-rgb),.1);color:var(--btn-primary);padding:2px 8px;border-radius:12px;font-size:.75rem;font-weight:500}@media (max-width: 768px){.genre-search-selector{max-width:100%}.genre-search-header{flex-direction:column;align-items:flex-start;gap:8px}.popular-genres{justify-content:flex-start}.popular-genre-btn{font-size:.75rem;padding:4px 8px}}[data-theme=dark] .search-suggestions{border-color:var(--card-border);box-shadow:0 8px 25px #0006}[data-theme=dark] .suggestion-item:hover,[data-theme=dark] .suggestion-item.selected{background:var(--btn-primary)}.search-suggestions{animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.suggestion-item{animation:fadeIn .1s ease-out}.leaderboard-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.leaderboard-modal{background:var(--card-bg);border-radius:20px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:1200px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:modalSlideIn .3s ease-out}.leaderboard-header{display:flex;justify-content:space-between;align-items:center;padding:24px 32px 20px;border-bottom:2px solid var(--card-border);background:var(--gradient-primary);color:#fff}.header-title h2{margin:0;font-size:1.75rem;font-weight:700}.header-title p{margin:4px 0 0;opacity:.9;font-size:.95rem}.close-btn{padding:8px 16px;font-size:1.2rem;border:2px solid rgba(255,255,255,.3);background:#ffffff1a;color:#fff}.close-btn:hover{background:#fff3;border-color:#ffffff80}.period-tabs{display:flex;background:var(--card-bg);border-bottom:2px solid var(--card-border);overflow-x:auto}.period-tab{flex:1;min-width:120px;padding:16px 20px;border:none;background:transparent;color:var(--muted);cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;gap:4px;font-weight:600;border-bottom:3px solid transparent}.period-tab.active{color:var(--btn-primary);background:rgba(var(--btn-primary-rgb),.1);border-bottom-color:var(--btn-primary)}.period-tab:hover:not(.active){background:rgba(var(--btn-primary-rgb),.05);color:var(--text)}.tab-icon{font-size:1.4rem}.tab-label{font-size:.85rem}.leaderboard-filters{display:flex;gap:20px;padding:20px 32px;background:var(--card-bg);border-bottom:1px solid var(--card-border);flex-wrap:wrap;align-items:center}.filter-group{display:flex;align-items:center;gap:8px;min-width:0;flex:1}.filter-group label{font-weight:600;color:var(--text);font-size:.9rem;white-space:nowrap}.filter-select{padding:8px 12px;border:2px solid var(--card-border);border-radius:8px;background:var(--card-bg);color:var(--text);font-size:.9rem;min-width:120px;cursor:pointer;transition:all .3s ease}.filter-select:focus{outline:none;border-color:var(--btn-primary);box-shadow:0 0 0 3px rgba(var(--btn-primary-rgb),.1)}.leaderboard-content{flex:1;overflow-y:auto;padding:24px 32px;background:var(--app-bg)}.leaderboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--muted)}.leaderboard-loading .spinner{width:40px;height:40px;border:4px solid var(--card-border);border-top:4px solid var(--btn-primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.leaderboard-error{text-align:center;padding:60px 20px;color:var(--muted)}.leaderboard-error h3{color:var(--text);margin-bottom:12px}.leaderboard-stats{display:flex;gap:24px;margin-bottom:24px;justify-content:center;flex-wrap:wrap}.stat-item{text-align:center;padding:16px 20px;background:var(--card-bg);border-radius:12px;border:2px solid var(--card-border);min-width:120px;transition:all .3s ease}.stat-item:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(var(--btn-primary-rgb),.15)}.stat-value{display:block;font-size:1.8rem;font-weight:700;color:var(--btn-primary);margin-bottom:4px}.stat-label{font-size:.85rem;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.025em}.leaderboard-table-container{background:var(--card-bg);border-radius:12px;overflow:hidden;border:2px solid var(--card-border)}.leaderboard-table{width:100%;border-collapse:collapse;font-size:.9rem}.leaderboard-table th{background:var(--gradient-primary);color:#fff;padding:16px 12px;text-align:left;font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.025em;border-bottom:2px solid var(--card-border)}.sortable-col{cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .2s ease;position:relative}.sortable-col:hover{background:#ffffff1a}.sortable-col.active{background:#ffffff26}.leaderboard-table td{padding:16px 12px;border-bottom:1px solid var(--card-border);vertical-align:middle}.leaderboard-row:hover{background:rgba(var(--btn-primary-rgb),.05)}.leaderboard-row.perfect-round{background:rgba(var(--success-rgb),.05);border-left:4px solid var(--success)}.rank-cell{text-align:center;width:80px;font-weight:700;font-size:1.1rem}.rank-display{display:inline-block;padding:4px 8px;border-radius:8px;background:rgba(var(--btn-primary-rgb),.1);color:var(--btn-primary)}.player-cell{width:200px}.player-info{display:flex;align-items:center;gap:12px}.player-avatar{width:40px;height:40px;border-radius:50%;overflow:hidden;flex-shrink:0}.player-avatar img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.1rem}.player-details{display:flex;flex-direction:column;min-width:0}.player-name{font-weight:600;color:var(--text);font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-level{font-size:.8rem;color:var(--muted);font-weight:600}.score-cell{text-align:right;width:120px}.score-value{font-weight:700;color:var(--text);font-size:1rem}.perfect-badge{margin-left:8px;font-size:.9rem}.mode-cell,.difficulty-cell{width:100px}.mode-badge,.difficulty-badge{display:inline-block;padding:4px 8px;border-radius:12px;font-size:.75rem;font-weight:600;text-align:center;white-space:nowrap}.mode-badge{background:rgba(var(--accent-rgb),.15);color:var(--accent)}.difficulty-badge{background:rgba(var(--btn-primary-rgb),.15);color:var(--btn-primary)}.difficulty-badge.difficulty-1{background:#22c55e26;color:#22c55e}.difficulty-badge.difficulty-2{background:#3b82f626;color:#3b82f6}.difficulty-badge.difficulty-3{background:#f59e0b26;color:#f59e0b}.difficulty-badge.difficulty-4{background:#ef444426;color:#ef4444}.difficulty-badge.difficulty-5{background:#8b451326;color:#8b4513}.time-cell,.moves-cell{text-align:center;width:80px;font-weight:600;color:var(--muted)}.date-cell{width:100px;font-size:.85rem;color:var(--muted)}.no-data{text-align:center;padding:60px 20px;color:var(--muted)}.no-data h3{color:var(--text);margin-bottom:12px}.no-data small{display:block;margin-top:8px;font-size:.8rem}@media (max-width: 1024px){.leaderboard-modal{max-width:95vw;margin:10px}.leaderboard-content{padding:16px 20px}.leaderboard-header{padding:20px 24px 16px}.leaderboard-filters{padding:16px 20px;gap:16px}}@media (max-width: 768px){.leaderboard-overlay{padding:10px}.leaderboard-modal{max-height:95vh}.header-title h2{font-size:1.4rem}.header-title p{font-size:.85rem}.period-tabs{flex-wrap:wrap}.period-tab{min-width:100px;padding:12px 16px}.leaderboard-filters{flex-direction:column;align-items:stretch}.filter-group{flex-direction:column;align-items:stretch;gap:6px}.filter-select{width:100%}.leaderboard-stats{gap:16px}.stat-item{min-width:100px;padding:12px 16px}.stat-value{font-size:1.5rem}.leaderboard-table{font-size:.8rem}.leaderboard-table th,.leaderboard-table td{padding:8px 6px}.player-info{gap:8px}.player-avatar{width:32px;height:32px}.rank-cell,.time-cell,.moves-cell,.date-cell{width:auto}.player-cell{width:auto;min-width:120px}.score-cell{width:auto}}@media (max-width: 480px){.leaderboard-table-container{overflow-x:auto}.leaderboard-table{min-width:600px}}[data-theme=dark] .leaderboard-modal{box-shadow:0 20px 60px #0009}[data-theme=dark] .period-tab.active{background:rgba(var(--btn-primary-rgb),.2)}[data-theme=dark] .leaderboard-row.perfect-round{background:rgba(var(--success-rgb),.1)}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.leaderboard-row{transition:all .2s ease}.stat-item,.period-tab{transition:all .3s cubic-bezier(.4,0,.2,1)}.game-mode-instructions{width:100%;margin-bottom:20px}.setup-prompt{background:var(--gradient-primary);color:#fff;border-radius:16px;padding:24px;text-align:center;animation:setupPulse 3s ease-in-out infinite}.setup-prompt-content h3{margin:0 0 12px;font-size:1.4rem;font-weight:700}.setup-prompt-content p{margin:0 0 20px;opacity:.9;font-size:1rem}.setup-actions{margin:20px 0}.setup-actions .btn{padding:16px 32px;font-size:1.1rem;font-weight:700;background:#fff3;border:2px solid rgba(255,255,255,.3);color:#fff;transition:all .3s ease}.setup-actions .btn:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-2px);box-shadow:0 8px 25px #0003}.setup-hint{margin-top:16px;opacity:.8}.setup-hint small{font-size:.9rem}@keyframes setupPulse{0%,to{transform:scale(1);box-shadow:0 4px 20px rgba(var(--btn-primary-rgb),.3)}50%{transform:scale(1.02);box-shadow:0 8px 30px rgba(var(--btn-primary-rgb),.4)}}.game-mode-instructions:not(.setup-prompt){background:var(--card-bg);border:2px solid var(--card-border);border-radius:16px;overflow:hidden;transition:all .3s ease}.game-mode-instructions:not(.setup-prompt):hover{box-shadow:0 4px 20px rgba(var(--btn-primary-rgb),.1);border-color:rgba(var(--btn-primary-rgb),.3)}.mode-header{padding:20px;background:var(--gradient-primary);color:#fff}.mode-title-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.mode-title{display:flex;align-items:center;gap:12px}.mode-icon{font-size:1.5rem}.mode-title h3{margin:0;font-size:1.2rem;font-weight:700}.details-toggle{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;border-radius:8px;padding:8px 12px;font-size:.9rem;cursor:pointer;transition:all .2s ease;min-width:60px}.details-toggle:hover{background:#ffffff4d;transform:translateY(-1px)}.mode-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;text-align:center;margin-top:4px}.mode-stats-grid.with-multiplier{grid-template-columns:repeat(5,1fr)}.stat-item{display:flex;flex-direction:column;gap:6px;min-width:0}.mode-header .stat-label{font-size:.8rem;font-weight:600;color:#fff;opacity:.9;text-transform:uppercase;letter-spacing:.025em}.mode-details .stat-label{font-size:.8rem;font-weight:600;color:var(--text);opacity:.8;text-transform:uppercase;letter-spacing:.025em}.mode-header .stat-value{font-size:14px;font-weight:700;background:#ffffff26;color:#fff!important;padding:4px 8px;border-radius:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;text-align:center;display:block;margin-bottom:0}.mode-details .stat-value{font-size:12px;font-weight:700;background:rgba(var(--btn-primary-rgb),.1);color:var(--text)!important;padding:6px 8px;border-radius:6px;text-align:center;display:block;margin-bottom:0;border:1px solid rgba(var(--btn-primary-rgb),.2);line-height:1.2;min-height:28px;display:flex;align-items:center;justify-content:center}.stat-value .mobile-text{display:none}.stat-value .desktop-text{display:inline}.mode-details{padding:20px;background:var(--card-bg);animation:slideDown .3s ease-out}.mode-details .mode-stats-grid{background:rgba(var(--btn-primary-rgb),.1);border:1px solid rgba(var(--btn-primary-rgb),.2);border-radius:12px;padding:16px;margin-bottom:20px}.mode-features-tips-row{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-top:20px}.mode-features,.mode-tips{background:var(--card-bg);padding:16px;border-radius:12px;border:1px solid var(--card-border)}.mode-features h4,.mode-tips h4{margin:0 0 12px;color:var(--text);font-size:1rem;font-weight:700;text-align:center}.mode-features ul,.mode-tips ul{margin:0;padding-left:20px;color:var(--text)}.mode-features li,.mode-tips li{margin-bottom:6px;font-size:.9rem;line-height:1.4}.mode-tips li{color:var(--muted)}@media (max-width: 1024px){.mode-stats-grid{gap:10px}.stat-value{font-size:.75rem;padding:6px 4px;min-height:32px}.stat-label{font-size:.75rem}.mode-features-tips-row{gap:20px}}@media (max-width: 768px){.game-mode-instructions{margin-bottom:16px}.mode-header{padding:16px}.mode-title-row{flex-direction:column;gap:12px;text-align:center}.mode-stats-grid{grid-template-columns:repeat(2,1fr);gap:12px;max-width:100%}.mode-stats-grid.with-multiplier{grid-template-columns:repeat(3,1fr)}.stat-value .mobile-text{display:inline}.stat-value .desktop-text{display:none}.mode-features-tips-row{grid-template-columns:1fr;gap:16px}.mode-details{padding:16px}.mode-features li,.mode-tips li{font-size:.85rem}.setup-prompt{padding:20px 16px}.setup-prompt-content h3{font-size:1.2rem}.setup-actions .btn{padding:14px 24px;font-size:1rem}}@media (max-width: 480px){.mode-stats-grid{grid-template-columns:repeat(2,1fr);gap:8px;justify-items:center}.mode-stats-grid.with-multiplier{grid-template-columns:repeat(3,1fr)}.stat-item{max-width:100%;min-width:0}.stat-value{font-size:.7rem;padding:8px 4px;min-height:36px;word-break:break-word;white-space:normal;line-height:1.1}.mode-icon{font-size:1.3rem}.mode-title h3{font-size:1.1rem}.mode-features,.mode-tips{padding:12px}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}*{transition:background-color .3s ease,color .3s ease,border-color .3s ease,box-shadow .3s ease}:root{--background: #f8fafc;--surface: #ffffff;--card-bg: #ffffff;--card-bg-secondary: #f1f5f9;--primary: #4c1d95;--primary-hover: #3c1577;--primary-rgb: 76, 29, 149;--secondary: #1e40af;--secondary-hover: #1d4ed8;--secondary-rgb: 30, 64, 175;--accent: #6366f1;--accent-hover: #4f46e5;--text-primary: #0f172a;--text-secondary: #334155;--text-muted: #64748b;--text-contrast: #ffffff;--border-muted: #e2e8f0;--card-border: #e2e8f0;--card-shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--success: #059669;--warning: #d97706;--danger: #dc2626;--bg: var(--background);--text: var(--text-primary);--text-light: var(--text-secondary);--muted: var(--text-muted);--border: var(--border-muted);--btn-primary: var(--primary);--btn-primary-hover: var(--primary-hover);--btn-secondary: var(--secondary);--btn-secondary-hover: var(--secondary-hover);--gradient-primary: linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);--gradient-secondary: linear-gradient(135deg, var(--secondary) 0%, var(--accent) 100%);--gradient-brand: linear-gradient(135deg, var(--primary) 0%, var(--accent) 100%)}[data-theme=dark]{--background: #0f172a;--surface: #1e293b;--card-bg: #1e293b;--card-bg-secondary: #334155;--primary: #7c3aed;--primary-hover: #8b5cf6;--primary-rgb: 124, 58, 237;--secondary: #3b82f6;--secondary-hover: #60a5fa;--secondary-rgb: 59, 130, 246;--accent: #8b5cf6;--accent-hover: #a78bfa;--text-primary: #f1f5f9;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--text-contrast: #0f172a;--border-muted: #334155;--card-border: #334155;--card-shadow: 0 4px 6px -1px rgba(0, 0, 0, .3), 0 2px 4px -2px rgba(0, 0, 0, .3);--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--bg: var(--background);--text: var(--text-primary);--text-light: var(--text-secondary);--muted: var(--text-muted);--border: var(--border-muted);--btn-primary: var(--primary);--btn-primary-hover: var(--primary-hover);--btn-secondary: var(--secondary);--btn-secondary-hover: var(--secondary-hover);--gradient-primary: linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);--gradient-secondary: linear-gradient(135deg, var(--secondary) 0%, var(--accent) 100%);--gradient-brand: linear-gradient(135deg, var(--primary) 0%, var(--accent) 100%)}.app-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:16px;padding:20px;box-shadow:var(--card-shadow);transition:all .3s ease;color:var(--text)}.app-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px -5px #0000001a,0 8px 10px -6px #0000001a}.header{position:relative;z-index:100;display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;background:var(--gradient-primary);color:#fff;border-radius:20px;padding:24px;box-shadow:0 8px 32px #667eea5e;transition:all .3s ease}.header.sticky{position:sticky;top:0}.header .title{color:#fff}.header .small-muted{color:#fffc}.nav-buttons,.auth-buttons{display:flex;gap:6px;align-items:center;flex-shrink:0}.responsive-btn{padding:8px 12px;font-size:.85rem;white-space:nowrap;min-width:fit-content;flex-shrink:0}.responsive-btn .btn-icon{display:inline;margin-right:3px}.responsive-btn .btn-text{display:inline}.header .row{display:flex;align-items:center;gap:8px;flex-wrap:nowrap;overflow:hidden}@media (max-width: 768px){.nav-buttons,.auth-buttons{gap:4px}.responsive-btn{padding:8px 10px;font-size:.8rem;min-width:36px}.responsive-btn .btn-text{display:none}.responsive-btn .btn-icon{margin-right:0;font-size:.9rem}.header .row{gap:6px}}@media (max-width: 480px){.header{padding:10px 12px}.title{flex:1;min-width:0}.title-text{font-size:1rem!important}.game-subtitle{display:none}.nav-buttons,.auth-buttons{gap:1px;flex-shrink:0}.responsive-btn{padding:6px 8px;font-size:.7rem;min-width:30px}.responsive-btn .btn-icon{font-size:.8rem}.header .row{gap:2px;flex-shrink:0}.btn.primary,.btn.secondary{padding:6px 8px;font-size:.7rem;min-width:30px}}@media (max-width: 360px){.header{padding:8px 10px}.title-text{font-size:.9rem!important}.responsive-btn{padding:1px 2px;font-size:.5rem;min-width:20px}.responsive-btn .btn-icon{font-size:.6rem}.header .row{gap:1px}}.controls{display:flex;gap:16px;align-items:center;margin-bottom:24px;flex-wrap:wrap;justify-content:center;color:var(--text)}.scoreboard{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;background:var(--card-bg);color:var(--text);border:1px solid var(--card-border);border-radius:16px;padding:20px;box-shadow:var(--card-shadow);position:relative;overflow:hidden}.scoreboard-content{display:flex;align-items:center;gap:32px;width:100%}.score-section{display:flex;flex-direction:column;align-items:center;gap:4px}.score-value{font-weight:700;font-size:2rem;color:var(--text);transition:all .3s ease}.score-value.score-animate{transform:scale(1.1);color:var(--accent);text-shadow:0 0 10px var(--accent)}.best-score-value{font-weight:700;font-size:1.5rem;color:var(--text);position:relative;transition:all .3s ease}[data-theme=dark] .best-score-value{color:#f1f5f9;text-shadow:0 1px 3px rgba(0,0,0,.3)}[data-theme=light] .best-score-value{color:#4c1d95;font-weight:800}[data-theme=light] .scoreboard{color:#fff}[data-theme=light] .scoreboard .best-score-value{color:#fff;-webkit-text-fill-color:white;text-shadow:0 1px 3px rgba(0,0,0,.2)}.best-score-value.new-best-animate{animation:bestScoreCelebration 2s ease}.celebration{position:absolute;top:-10px;right:-20px;font-size:1.2rem;animation:celebrationBounce 2s ease}.timer-section{margin-left:auto}@keyframes bestScoreCelebration{0%,to{transform:scale(1)}25%{transform:scale(1.2) rotate(-5deg)}50%{transform:scale(1.1) rotate(5deg)}75%{transform:scale(1.15) rotate(-2deg)}}@keyframes celebrationBounce{0%,to{transform:scale(0);opacity:0}20%{transform:scale(1.2);opacity:1}40%{transform:scale(.9);opacity:1}60%{transform:scale(1.1);opacity:1}80%{transform:scale(1);opacity:1}}.scoreboard .small-muted{color:var(--muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.scoreboard .small-muted{color:var(--muted)}.small-muted{font-size:.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.badge{background:var(--gradient-accent);color:#fff;padding:6px 12px;border-radius:12px;font-size:.875rem;font-weight:700;box-shadow:0 4px 14px #f093fb63;animation:pulse 2s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.timer{background:var(--gradient-accent);color:#fff;font-weight:700;font-size:.875rem;padding:8px 16px;border-radius:12px;box-shadow:0 4px 14px #f093fb63;animation:timerPulse 1s infinite}@keyframes timerPulse{0%,to{opacity:1}50%{opacity:.7}}.countdown-section{display:flex;flex-direction:column;align-items:center;gap:4px}.countdown-timer{background:var(--gradient-primary);color:#fff;font-weight:700;font-size:1rem;padding:8px 16px;border-radius:12px;box-shadow:0 4px 14px rgba(var(--primary-rgb),.5);transition:all .3s ease}.countdown-urgent{background:linear-gradient(135deg,#ef4444,#dc2626);animation:urgentPulse .5s ease-in-out infinite}.lives-section{display:flex;flex-direction:column;align-items:center;gap:4px}.lives-counter{font-size:1.1rem;font-weight:700;display:flex;align-items:center;gap:4px;padding:8px 12px;border-radius:12px;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 4px 14px #ef444480}.lives-critical{animation:urgentPulse .8s ease-in-out infinite}.lives-text{margin-left:8px;color:#fff;font-weight:700}@keyframes urgentPulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.8}}.streak-master-status{margin:16px 0;background:linear-gradient(135deg,#7c3aed,#a855f7);color:#fff;border:none}.streak-header{text-align:center;margin-bottom:16px}.streak-header h3{margin:0 0 8px;font-size:1.2rem;font-weight:700}.streak-warning{font-size:.9rem;font-weight:600;background:#ef444433;border:1px solid rgba(239,68,68,.3);border-radius:8px;padding:6px 12px;animation:urgentPulse 2s ease-in-out infinite}.streak-progress{margin-bottom:16px}.overall-progress,.current-round{margin-bottom:12px}.progress-label,.round-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;font-size:.9rem;font-weight:600}.round-number{font-weight:700;color:#fbbf24}.round-score{font-weight:700;color:#34d399}.progress-bar{height:8px;background:#fff3;border-radius:4px;overflow:hidden}.progress-fill{height:100%;border-radius:4px;transition:width .3s ease}.progress-fill.overall{background:linear-gradient(90deg,#fbbf24,#f59e0b)}.progress-fill.current{background:linear-gradient(90deg,#34d399,#10b981);animation:pulse 1s ease-in-out infinite}.streak-rounds{display:flex;justify-content:center;gap:8px;flex-wrap:wrap}.round-indicator{display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px;border-radius:8px;transition:all .3s ease;min-width:40px}.round-indicator.completed{background:#22c55e33;border:1px solid rgba(34,197,94,.4)}.round-indicator.current{background:#fbbf2433;border:1px solid rgba(251,191,36,.4);animation:pulse 1.5s ease-in-out infinite}.round-indicator.pending{background:#9ca3af33;border:1px solid rgba(156,163,175,.3);opacity:.7}.round-label{font-size:.75rem;font-weight:700}.btn{background:var(--primary);color:var(--text-contrast);border:none;padding:12px 20px;border-radius:12px;font-weight:600;cursor:pointer;transition:all .3s ease;font-size:.875rem;text-transform:uppercase;letter-spacing:.025em;position:relative;overflow:hidden;box-shadow:0 4px 15px rgba(var(--primary-rgb),.4)}.btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.btn:hover:before{left:100%}.btn:hover{background:var(--primary-hover);transform:translateY(-2px);box-shadow:0 8px 25px -5px rgba(var(--primary-rgb),.6)}.btn.primary{background:var(--gradient-primary);box-shadow:0 4px 15px rgba(var(--primary-rgb),.5)}.btn.secondary{background:var(--secondary);color:var(--text-contrast);box-shadow:0 4px 15px rgba(var(--secondary-rgb),.4)}.btn.secondary:hover{background:var(--secondary-hover);box-shadow:0 8px 25px -5px rgba(var(--secondary-rgb),.6)}.card-grid{display:grid;gap:20px;margin-bottom:24px;padding:20px;background:var(--card-bg);border-radius:20px;box-shadow:var(--card-shadow)}.card-grid[data-cards="5"]{grid-template-columns:repeat(5,1fr);max-width:600px;margin:0 auto}.card-grid[data-cards="10"]{grid-template-columns:repeat(5,1fr);max-width:800px;margin:0 auto}.card-grid[data-cards="15"]{grid-template-columns:repeat(5,1fr);max-width:1000px;margin:0 auto}.card-grid[data-cards="20"]{grid-template-columns:repeat(5,1fr)}.card-grid[data-cards="30"]{grid-template-columns:repeat(6,1fr)}.card-grid[data-cards="6"]{grid-template-columns:repeat(3,1fr);max-width:500px;margin:0 auto}.card-grid[data-cards="7"]{grid-template-columns:repeat(4,1fr);max-width:600px;margin:0 auto}.card-grid[data-cards="8"]{grid-template-columns:repeat(4,1fr);max-width:650px;margin:0 auto}.card-grid[data-cards="9"]{grid-template-columns:repeat(3,1fr);max-width:600px;margin:0 auto}.card-grid[data-cards="11"]{grid-template-columns:repeat(4,1fr);max-width:750px;margin:0 auto}.card-grid[data-cards="12"]{grid-template-columns:repeat(4,1fr);max-width:800px;margin:0 auto}.card-grid[data-cards="25"]{grid-template-columns:repeat(5,1fr);max-width:1000px;margin:0 auto}.card{background:var(--card-bg);border:2px solid var(--card-border);border-radius:16px;padding:8px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);max-width:150px;max-height:150px;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;color:var(--text);perspective:1000px;transform-style:preserve-3d}.card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:var(--gradient-primary);opacity:0;transition:opacity .3s ease;border-radius:14px}.card:hover:before{opacity:.1}.card:active{transform:translateY(-2px) scale(.98)}.card-clicked{animation:cardFlip .6s ease-in-out}.card-wrong{animation:cardShake .5s ease-in-out;border-color:var(--danger)!important;background:#ef44441a!important}.card-correct{animation:cardSuccess .4s ease-in-out;border-color:var(--success)!important;background:#22c55e1a!important}@keyframes cardFlip{0%{transform:rotateY(0) scale(1)}50%{transform:rotateY(90deg) scale(1.05)}to{transform:rotateY(0) scale(1)}}@keyframes cardShake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-8px) rotate(-2deg)}20%,40%,60%,80%{transform:translate(8px) rotate(2deg)}}@keyframes cardSuccess{0%{transform:scale(1)}50%{transform:scale(1.1) rotate(5deg)}to{transform:scale(1)}}.card:focus{outline:3px solid var(--btn-primary);outline-offset:2px}.card img{width:100%;height:100%;object-fit:cover;border-radius:12px;transition:transform .3s ease;position:relative;z-index:1}.card:hover img{transform:scale(1.05)}.card-error{color:var(--muted);text-align:center;font-size:.875rem;position:relative;z-index:1}.stage-selector{margin-bottom:24px;color:var(--text)}.stage-buttons{display:flex;gap:12px;justify-content:center}.stage-buttons .stage-btn{min-width:120px;position:relative}.stage-buttons .stage-btn.primary{background:var(--gradient-success);box-shadow:0 4px 15px #4facfebf}.genre-selector{margin-bottom:24px}.genre-header{text-align:center;margin-bottom:16px}.genre-header h3{margin:0 0 4px;font-size:1.125rem;font-weight:700;color:var(--text)}.genre-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;max-width:600px;margin:0 auto}.genre-btn{min-height:44px;font-size:.8rem}.menu-content{max-height:80vh;overflow-y:auto}.menu-section{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border)}.menu-section:last-child{border-bottom:none}.menu-section h3{margin:0 0 12px;font-size:1rem;font-weight:700;color:var(--text);text-transform:uppercase;letter-spacing:.025em}@media (max-width: 1024px){.card-grid[data-cards="5"]{grid-template-columns:repeat(3,1fr)}.card-grid[data-cards="10"],.card-grid[data-cards="15"],.card-grid[data-cards="20"]{grid-template-columns:repeat(4,1fr)}.card-grid[data-cards="30"]{grid-template-columns:repeat(5,1fr)}.card-grid{gap:16px;padding:16px}.controls{flex-direction:column;align-items:center}.header{padding:20px;margin-bottom:20px}.scoreboard{padding:16px;margin-bottom:20px}.genre-grid{grid-template-columns:repeat(2,1fr)}.card{max-width:120px;max-height:120px}}@media (max-width: 768px){.card-grid[data-cards="5"]{grid-template-columns:repeat(3,1fr)}.card-grid[data-cards="10"],.card-grid[data-cards="15"],.card-grid[data-cards="20"],.card-grid[data-cards="30"]{grid-template-columns:repeat(4,1fr)}.card-grid{gap:16px;padding:16px}.controls{flex-direction:column;align-items:center}.header{padding:20px;margin-bottom:20px}.scoreboard{padding:16px;margin-bottom:20px}.genre-grid{grid-template-columns:repeat(2,1fr)}.card{max-width:100px;max-height:100px}}@media (max-width: 480px){.card-grid[data-cards="5"],.card-grid[data-cards="10"],.card-grid[data-cards="15"],.card-grid[data-cards="20"],.card-grid[data-cards="30"]{grid-template-columns:repeat(3,1fr)}.app{padding:16px}.header{flex-direction:column;gap:16px;text-align:center}.card{max-width:80px;max-height:80px}}.app:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at 20% 50%,rgba(59,130,246,.1) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(16,185,129,.1) 0%,transparent 50%),radial-gradient(circle at 40% 80%,rgba(251,191,36,.1) 0%,transparent 50%);pointer-events:none;z-index:-1;animation:particleFloat 20s ease-in-out infinite}@keyframes particleFloat{0%,to{transform:translate(0) rotate(0);opacity:.6}33%{transform:translate(30px,-30px) rotate(120deg);opacity:.8}66%{transform:translate(-20px,20px) rotate(240deg);opacity:.4}}.card:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 12px 40px -4px #00000040;border-color:var(--btn-primary)}.card:hover:after{content:"";position:absolute;top:-2px;left:-2px;right:-2px;bottom:-2px;background:linear-gradient(45deg,var(--primary),var(--accent),var(--primary));border-radius:18px;z-index:-1;opacity:.7;filter:blur(6px)}.loading-spinner{display:inline-block;width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s ease-in-out infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-state{text-align:center;padding:40px 20px;color:var(--danger)}.success-state{text-align:center;padding:40px 20px;color:var(--success)}.game-mode-selector{background:var(--card-bg);border:1px solid var(--card-border);border-radius:20px;padding:24px;margin-bottom:24px;box-shadow:var(--card-shadow);color:var(--text)}.mode-section,.difficulty-section{margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--border)}.mode-section:last-of-type,.difficulty-section:last-of-type{border-bottom:none}.section-title{font-size:1.125rem;font-weight:700;margin:0 0 16px;color:var(--text);display:flex;align-items:center;gap:8px}.mode-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:16px}.mode-btn{background:var(--card-bg);border:2px solid var(--card-border);border-radius:12px;padding:16px;cursor:pointer;transition:all .3s ease;text-align:left;color:var(--text);position:relative;overflow:hidden}.mode-btn:hover:not(.disabled){border-color:var(--btn-primary);transform:translateY(-2px);box-shadow:0 8px 25px -5px #3b82f64d}.mode-btn.active{border-color:var(--success);background:#22c55e0d;box-shadow:0 4px 15px #22c55e4d}.mode-btn.disabled{opacity:.6;cursor:not-allowed;transform:none!important}.mode-icon{font-size:1.5rem;margin-bottom:8px}.mode-name{font-weight:700;font-size:1rem;margin-bottom:4px;color:var(--text)}.mode-description{font-size:.875rem;color:var(--muted);line-height:1.4}.difficulty-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.difficulty-btn{background:var(--card-bg);border:2px solid var(--card-border);border-radius:12px;padding:12px;cursor:pointer;transition:all .3s ease;text-align:center;color:var(--text);position:relative}.difficulty-btn:hover:not(.disabled){transform:translateY(-2px);box-shadow:0 8px 25px -5px #0003}.difficulty-btn.active{border-color:var(--success);background:var(--success);color:var(--text-contrast);box-shadow:0 4px 15px #22c55e66;transform:translateY(-2px)}.difficulty-btn.active .difficulty-level,.difficulty-btn.active .difficulty-stats,.difficulty-btn.active .difficulty-description{color:var(--text-contrast)}.difficulty-btn.active .stat{background:#fff3;color:var(--text-contrast)}.difficulty-btn.disabled{opacity:.6;cursor:not-allowed;transform:none!important}.difficulty-btn.difficulty-1:not(.active){border-color:#22c55e}.difficulty-btn.difficulty-2:not(.active){border-color:#3b82f6}.difficulty-btn.difficulty-3:not(.active){border-color:#f59e0b}.difficulty-btn.difficulty-4:not(.active){border-color:#ef4444}.difficulty-btn.difficulty-5:not(.active){border-color:#8b5cf6}.difficulty-level{font-weight:700;font-size:.875rem;margin-bottom:6px;text-transform:uppercase;letter-spacing:.025em}.difficulty-stats{font-size:.75rem;color:var(--muted);margin-bottom:4px;display:flex;flex-direction:column;gap:2px}.stat{background:#6b72801a;padding:2px 6px;border-radius:4px;font-weight:600}.difficulty-description{font-size:.7rem;color:var(--muted);line-height:1.3}.current-config{background:var(--gradient-primary);background:#3b82f60d;border:1px solid rgba(59,130,246,.2);border-radius:12px;padding:16px;color:var(--text)}.current-config h4{margin:0 0 8px;font-size:.875rem;font-weight:700;color:var(--text);text-transform:uppercase;letter-spacing:.025em}.config-display{font-weight:600;margin-bottom:12px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.config-separator{color:var(--muted);font-weight:400}.config-features{display:flex;flex-wrap:wrap;gap:6px}.feature-tag{background:#3b82f626;color:var(--btn-primary);font-size:.75rem;font-weight:600;padding:4px 8px;border-radius:6px;border:1px solid rgba(59,130,246,.2)}.score-summary{margin:24px 0}.score-item{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding:8px 0}.score-label{font-size:1rem;color:var(--muted);font-weight:600}.score-value{font-size:1.5rem;font-weight:700;color:var(--text);transition:all .3s ease}.score-value.new-best{color:var(--success);text-shadow:0 0 10px var(--success);animation:newBestPulse 2s ease infinite}.new-record{text-align:center;font-size:1.2rem;font-weight:700;color:var(--success);background:#22c55e1a;border:2px solid var(--success);border-radius:12px;padding:12px;margin-top:16px;animation:recordCelebration 2s ease infinite}@keyframes newBestPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes recordCelebration{0%,to{transform:scale(1);box-shadow:0 0 #22c55e80}50%{transform:scale(1.02);box-shadow:0 0 20px #22c55e4d}}.controls button{position:relative;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}.controls button:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(var(--btn-primary-rgb),.3)}.controls button:active{transform:translateY(0);transition:transform .1s}.controls button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.controls button:hover:before{left:100%}.btn-large{background:linear-gradient(135deg,var(--btn-primary),var(--btn-primary-dark));position:relative;overflow:hidden}.btn-large:after{content:"";position:absolute;top:50%;left:50%;width:0;height:0;background:#fff3;border-radius:50%;transform:translate(-50%,-50%);transition:width .6s,height .6s}.btn-large:hover:after{width:300px;height:300px}.btn-large:active{transform:scale(.98)}.scoreboard{position:relative;overflow:hidden}.scoreboard:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:conic-gradient(from 0deg,transparent,rgba(var(--accent-rgb),.05),transparent);animation:scoreboardRotate 10s linear infinite;z-index:-1}@keyframes scoreboardRotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.score-item{transition:all .3s ease}.score-item:hover{transform:translate(5px);background:rgba(var(--accent-rgb),.05);border-radius:8px;padding:8px 12px}.card-grid{position:relative;overflow:hidden}.card-grid:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 80%,rgba(var(--primary-rgb),.1) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(var(--accent-rgb),.1) 0%,transparent 50%),radial-gradient(circle at 40% 40%,rgba(var(--success-rgb),.05) 0%,transparent 50%);animation:backgroundPulse 8s ease-in-out infinite;pointer-events:none;z-index:-1}@keyframes backgroundPulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}.card{transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(255,255,255,.1),transparent);opacity:0;transition:opacity .3s ease;pointer-events:none;z-index:1}.card:hover:before{opacity:1}.card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 15px 35px #0003}.card:active{transform:translateY(-4px) scale(1.01);transition:transform .1s}.btn-primary:disabled{position:relative;overflow:hidden}.btn-primary:disabled:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:loading 2s infinite}@keyframes loading{0%{left:-100%}to{left:100%}}.theme-toggle{transition:all .4s cubic-bezier(.4,0,.2,1)}.theme-toggle:hover{transform:rotate(180deg)}.game-over{animation:modalSlideIn .5s cubic-bezier(.4,0,.2,1)}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-50px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.brain-clip-iconic{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:4px;transition:all .2s ease}.clickable-title{cursor:pointer;border-radius:8px;padding:4px 8px;margin:-4px -8px}.clickable-title:hover{background:#ffffff1a;transform:scale(1.02)}.clickable-title:active{transform:scale(.98)}.clickable-title:focus{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}.brain-icon{font-size:1.5rem;animation:brainBounce 3s ease-in-out infinite}.title-text{font-size:1.2rem;font-weight:800;color:var(--text);text-shadow:0 1px 3px rgba(0,0,0,.1);letter-spacing:.5px}.title-accent{font-size:1.2rem;color:gold;animation:sparkle 1.5s ease-in-out infinite;filter:drop-shadow(0 0 3px rgba(255,215,0,.5));margin-left:2px}.game-subtitle{margin-top:2px}@keyframes brainBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}@keyframes sparkle{0%,to{opacity:.8;transform:scale(1) rotate(0)}50%{opacity:1;transform:scale(1.3) rotate(180deg)}}.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;width:100%;max-width:100%;box-sizing:border-box}.app{position:relative;overflow:hidden}.app:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(circle at 25% 25%,rgba(var(--primary-rgb),.02) 1px,transparent 1px),radial-gradient(circle at 75% 75%,rgba(var(--accent-rgb),.02) 1px,transparent 1px);background-size:50px 50px;animation:particleFloat 20s linear infinite;pointer-events:none;z-index:-1}@keyframes particleFloat{0%{background-position:0% 0%,0% 0%}to{background-position:100% 100%,-100% -100%}}[data-theme=light] .app-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:1px solid rgba(255,255,255,.2)}[data-theme=light] .app-card .small-muted{color:#fffc}[data-theme=light] .scoreboard{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;border:1px solid rgba(255,255,255,.2)}[data-theme=light] .scoreboard .small-muted{color:#fffc}[data-theme=light] .card-grid{background:linear-gradient(135deg,#4facfe,#00f2fe);border:1px solid rgba(255,255,255,.2)}[data-theme=light] .game-mode-selector{background:linear-gradient(135deg,#ff9a9e,#fecfef);border:1px solid rgba(255,255,255,.3);color:var(--text)}[data-theme=light] .stage-selector{background:linear-gradient(135deg,#ffecd2,#fcb69f);border-radius:16px;padding:20px;border:1px solid rgba(255,255,255,.3);box-shadow:var(--card-shadow);margin-bottom:24px}.scoreboard-actions{margin-top:12px;display:flex;justify-content:center}.leaderboard-btn{padding:6px 12px;font-size:.8rem;border-radius:16px;transition:all .3s ease;border:1px solid var(--btn-primary);background:rgba(var(--btn-primary-rgb),.1);color:var(--btn-primary)}.leaderboard-btn:hover{background:var(--btn-primary);color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px rgba(var(--btn-primary-rgb),.3)}.menu-actions{display:flex;gap:12px;flex-direction:column}.menu-btn{width:100%;justify-content:center;align-items:center;display:flex;gap:8px}.scoreboard-content{display:flex;justify-content:space-between;align-items:center;gap:16px;width:100%}.best-score-section{margin-left:auto}.timer-section{flex-shrink:0}html,body{margin:0;padding:0;width:100%;overflow-x:hidden;box-sizing:border-box}*{box-sizing:border-box}html,body,#root{height:100%;width:100%}body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial;background:var(--bg);color:var(--text);margin:0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.35;width:100%;max-width:100%}.app{width:100%;max-width:1200px;margin:0 auto;padding:2rem;box-sizing:border-box}.row{display:flex;gap:12px;align-items:center}.center{display:flex;align-items:center;justify-content:center}.small{font-size:.85rem;opacity:.9}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Roboto Mono,monospace}.menu-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000bf;display:flex;justify-content:center;align-items:center;z-index:100;animation:fadeIn .2s ease}.menu-content{background:var(--card-bg);color:var(--text);padding:2rem;border-radius:1rem;max-width:400px;width:90%;box-shadow:var(--card-shadow);animation:slideIn .3s ease}.menu-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.menu-header h2{margin:0;font-size:1.5rem;font-weight:700}.current-status{background:var(--card-bg);border:1px solid var(--border);border-radius:8px;padding:12px;margin-bottom:8px}.status-item{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.status-item:last-child{margin-bottom:0}.status-label{font-size:.875rem;color:var(--muted);font-weight:600}.status-value{font-size:.875rem;color:var(--text);font-weight:700}.menu-section{margin-bottom:1.5rem}.menu-section h3{margin:0 0 12px;font-size:1rem;font-weight:700;color:var(--text);text-transform:uppercase;letter-spacing:.025em;display:flex;align-items:center;gap:8px}.genre-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:8px;max-width:100%}.genre-btn,.stage-btn{font-size:.8rem;padding:8px 12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.menu-btn{width:100%;margin-bottom:.5rem}.stage-buttons{display:flex;gap:.5rem}.stage-buttons .stage-btn{flex:1}.start-stop-container{display:flex;justify-content:center;margin:1.5rem 0}.start-stop-btn{font-size:1.1rem;font-weight:700;padding:1rem 2rem;border-radius:.75rem;border:none;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.05em;min-width:150px}.start-stop-btn.start{background:var(--success);color:#fff;box-shadow:0 4px 12px #22c55e4d}.start-stop-btn.start:hover{background:#16a34a;transform:translateY(-2px);box-shadow:0 6px 16px #22c55e66}.start-stop-btn.stop{background:var(--danger);color:#fff;box-shadow:0 4px 12px #ef44444d}.start-stop-btn.stop:hover{background:#dc2626;transform:translateY(-2px);box-shadow:0 6px 16px #ef444466}.start-stop-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.card-grid.disabled{opacity:.6;pointer-events:none;filter:grayscale(.3)}.card-grid.disabled .card{cursor:default}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.game-over-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000bf;display:flex;justify-content:center;align-items:center;z-index:1000}.game-over-card{background:var(--card-bg);color:var(--text);padding:2rem;border-radius:1rem;text-align:center;max-width:400px;width:90%;box-shadow:var(--card-shadow);animation:popIn .4s ease}.game-over-title{font-size:2rem;margin-bottom:1rem}.scores{margin:1rem 0}.final-score,.best-score{font-size:1.2rem;margin:.3rem 0}.game-over-actions{display:flex;justify-content:space-around;margin-top:1.5rem}.btn{padding:.6rem 1.2rem;border:none;border-radius:.6rem;cursor:pointer;font-size:1rem;transition:.2s ease}.retry-btn{background:var(--success);color:#fff}.stage-btn{background:var(--btn-primary);color:#fff}.btn:hover{opacity:.85}.btn.small{padding:6px 12px;font-size:.85rem;border-radius:6px}.btn.small.secondary{padding:4px 8px;font-size:.8rem}.btn.primary{background:var(--primary);color:#fff}.btn.secondary{background:var(--secondary);color:var(--text-color);border:1px solid var(--border-color)}@keyframes popIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.ai-game-results{margin-bottom:20px;padding:20px;border:2px solid var(--primary);border-radius:12px;background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%)}.ai-game-results h3{color:#fff!important;font-size:1.2rem;font-weight:700}.ai-scores{display:grid;grid-template-columns:1fr 1fr;gap:15px}.score-item.winner{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-radius:8px;padding:12px;border:2px solid #047857}.score-item.loser{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border-radius:8px;padding:12px;border:2px solid #b91c1c;opacity:.8}.winner-icon{margin-left:8px;font-size:1.2rem}.score-item.winner .score-label,.score-item.loser .score-label{color:#ffffffe6}.score-item.winner .score-value,.score-item.loser .score-value{color:#fff;font-weight:700}.card-grid.ai-thinking{opacity:.7;pointer-events:none}.ai-turn-overlay{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1000;background:#000c;color:#fff;padding:20px 30px;border-radius:12px;font-size:1.2rem;font-weight:600;text-align:center;animation:fadeIn .3s ease-in-out}.ai-turn-message{display:flex;align-items:center;justify-content:center;gap:10px}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.8)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}
