.about-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0a1ebf;display:flex;align-items:center;justify-content:center;z-index:1000;animation:aboutFadeIn .2s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}@keyframes aboutFadeIn{0%{opacity:0}to{opacity:1}}.about-modal{background:#fff;border-radius:20px;width:90%;max-width:720px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 25px 80px #0006;animation:aboutSlideUp .3s ease-out;overflow:hidden}@keyframes aboutSlideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.about-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid #e2e8f0;background:var(--gradient-primary, linear-gradient(135deg, #818cf8, #6366f1))}.about-header h2{margin:0;font-size:1.2rem;color:#fff;font-weight:700;display:flex;align-items:center;gap:.5rem}.about-header h2:before{content:"♟️"}.about-close-btn{width:32px;height:32px;border:none;background:#ffffff26;border-radius:8px;font-size:1.1rem;color:#ffffffe6;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.about-close-btn:hover{background:#ffffff40;color:#fff;transform:scale(1.05)}.about-close-btn:focus-visible{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}.about-close-btn:active{transform:scale(.95)}.about-content{flex:1;overflow-y:auto;padding:1.5rem}.about-section{margin-bottom:1.75rem;padding-bottom:1.75rem;border-bottom:1px solid #e2e8f0}.about-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.about-section h3{font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;color:#64748b;margin:0 0 1rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.about-app-info{display:flex;align-items:center;justify-content:center;margin-bottom:1rem;padding:1rem;background:linear-gradient(145deg,#f8fafc,#f1f5f9);border-radius:12px}.about-app-icon{width:100%;max-width:280px;height:auto;object-fit:contain;filter:drop-shadow(0 4px 12px rgba(0,0,0,.15))}.about-app-details{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:.75rem}.about-app-details h3{margin:0 0 .25rem;font-size:1.2rem;color:#1f2937;font-weight:700;text-transform:none;letter-spacing:normal}.about-version{font-size:.75rem;color:var(--color-primary, #818cf8);font-weight:600;background:#818cf81a;padding:.2rem .6rem;border-radius:20px;display:inline-block}.about-description{font-size:.875rem;color:#4b5563;line-height:1.65;margin:0}.about-features{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.4rem}.about-feature-item{display:grid;grid-template-columns:36px 1fr;align-items:center;padding:.6rem .9rem;background:linear-gradient(145deg,#f8fafc,#f1f5f9);border-radius:8px;transition:all .2s ease;border:1px solid transparent}.about-feature-item:hover{background:linear-gradient(145deg,#f1f5f9,#e2e8f0);border-color:#818cf833;transform:translate(4px)}.about-feature-icon{font-size:1.1rem;text-align:left;opacity:.9}.about-feature-text{display:flex;align-items:baseline;gap:.4rem}.about-feature-text strong{color:#1f2937;font-weight:600;font-size:.9rem}.about-feature-text span{color:#64748b;font-size:.8rem}.about-acknowledgment{background:linear-gradient(145deg,#f8fafc,#f1f5f9);border-radius:10px;padding:.9rem 1rem;margin-bottom:.6rem;border-left:3px solid var(--color-primary, #818cf8);transition:all .2s ease}.about-acknowledgment:hover{border-left-color:#6366f1}.about-acknowledgment:last-child{margin-bottom:0}.about-acknowledgment h4{margin:0 0 .4rem;color:#1f2937;font-size:.9rem;font-weight:600}.about-acknowledgment p{margin:0 0 .4rem;font-size:.8rem;color:#4b5563;line-height:1.5}.about-acknowledgment p:last-child{margin-bottom:0}.about-acknowledgment a{color:var(--color-primary, #818cf8);text-decoration:none;font-weight:500;transition:color .2s ease}.about-acknowledgment a:hover{color:#6366f1;text-decoration:underline}.about-citation{font-size:.75rem!important;color:#64748b!important;padding:.6rem .8rem;background:#fff;border-radius:6px;margin-top:.6rem;line-height:1.5}.about-citation em{color:#1f2937;font-style:italic;font-weight:500}.about-citation a{color:var(--color-primary, #818cf8);text-decoration:none;font-weight:500;transition:color .2s ease}.about-citation a:hover{color:#6366f1;text-decoration:underline}.about-license{margin-bottom:.75rem;padding:.6rem .9rem;background:linear-gradient(145deg,#f8fafc,#f1f5f9);border-radius:8px;border-left:3px solid #10b981}.about-license h4{margin:0 0 .2rem;color:#1f2937;font-size:.9rem;font-weight:600}.about-license p{margin:0;font-size:.8rem;color:#64748b}.about-license-group{margin-bottom:.75rem}.about-license-group:last-child{margin-bottom:0}.about-license-group h4{margin:0 0 .4rem;color:#64748b;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.about-license-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.2rem}.about-license-list li{display:grid;grid-template-columns:110px 1fr auto;align-items:center;gap:.4rem;font-size:.75rem;color:#64748b;padding:.35rem .6rem;background:linear-gradient(145deg,#f8fafc,#f1f5f9);border-radius:5px;transition:all .15s ease}.about-license-list li:hover{background:linear-gradient(145deg,#f1f5f9,#e2e8f0)}.about-license-list li strong{color:#374151;font-weight:600;font-size:.75rem}.about-dep-desc{color:#64748b;font-size:.7rem}.about-dep-license{color:var(--color-primary, #818cf8);font-size:.65rem;font-weight:600;background:#818cf81a;padding:.1rem .4rem;border-radius:8px;white-space:nowrap}.about-links{display:flex;justify-content:center;align-items:center;gap:.75rem;padding-top:.25rem}.about-link{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;background:var(--gradient-primary, linear-gradient(135deg, #818cf8, #6366f1));color:#fff;text-decoration:none;border-radius:8px;font-size:.8rem;font-weight:600;transition:all .2s ease;box-shadow:0 2px 8px #818cf84d}.about-link:hover{transform:translateY(-2px);box-shadow:0 4px 12px #818cf866}.about-link-secondary{background:#fff;color:var(--color-primary, #818cf8);border:2px solid rgba(129,140,248,.3);box-shadow:none}.about-link-secondary:hover{background:#818cf80d;border-color:var(--color-primary, #818cf8);box-shadow:0 2px 8px #818cf826}.about-correax{display:flex;justify-content:center;padding-top:1rem;margin-top:.5rem;border-top:1px solid #e2e8f0}.correax-brand-link{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.25rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;border-radius:12px;text-decoration:none;transition:all .2s ease}.correax-brand-link:hover{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border-color:#0078d4;box-shadow:0 4px 12px #0078d426;transform:translateY(-2px)}.correax-logo-about{width:32px;height:32px}.correax-brand-text{display:flex;flex-direction:column;gap:.1rem}.correax-name{font-size:.85rem;font-weight:600;color:#1e293b}.correax-tagline{font-size:.7rem;color:#64748b}.about-content::-webkit-scrollbar{width:6px}.about-content::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.about-content::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.about-content::-webkit-scrollbar-thumb:hover{background:#94a3b8}@media(max-width:600px){.about-modal{width:95%;max-height:90vh;border-radius:16px}.about-content{padding:1rem}.about-license-list li{grid-template-columns:1fr auto}.about-dep-desc{display:none}.about-links{flex-direction:column;gap:.5rem}.about-link{width:100%;justify-content:center}.about-feature-text{flex-direction:column;gap:.1rem}}.help-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0a1ebf;display:flex;align-items:center;justify-content:center;z-index:1000;animation:helpFadeIn .2s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}@keyframes helpFadeIn{0%{opacity:0}to{opacity:1}}.help-modal{background:#fff;border-radius:20px;width:90%;max-width:800px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 25px 80px #0006;animation:helpSlideUp .3s ease-out;overflow:hidden}@keyframes helpSlideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.help-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid #e2e8f0;background:var(--gradient-primary, linear-gradient(135deg, #818cf8, #6366f1))}.help-header h2{margin:0;font-size:1.2rem;color:#fff;font-weight:700;display:flex;align-items:center;gap:.5rem}.help-header h2:before{content:"❓"}.help-close-btn{width:32px;height:32px;border:none;background:#ffffff26;border-radius:8px;font-size:1.1rem;color:#ffffffe6;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.help-close-btn:hover{background:#ffffff40;color:#fff;transform:scale(1.05)}.help-close-btn:focus-visible{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}.help-close-btn:active{transform:scale(.95)}.help-content{flex:1;overflow-y:auto;padding:1.5rem}.help-section{margin-bottom:1.75rem;padding-bottom:1.5rem;border-bottom:1px solid #e2e8f0}.help-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.help-section h3{margin:0 0 1rem;font-size:1.1rem;color:#1a202c;font-weight:700}.help-intro{color:#4a5568;line-height:1.6;margin:0}.help-intro-spaced{margin-bottom:.5rem}.help-hint{display:inline-flex;align-items:center;gap:.25rem;margin:0 0 1rem;padding:.4rem .75rem;background:linear-gradient(135deg,#818cf81a,#6366f11a);border-radius:8px;font-size:.85rem;color:var(--color-primary, #818cf8);font-weight:500}.help-prompts{display:flex;flex-wrap:wrap;gap:.5rem}.help-prompts code{display:inline-block;padding:.4rem .75rem;background:#fff;border:1px solid #e2e8f0;border-radius:20px;font-family:inherit;font-size:.85rem;color:#4a5568;transition:all .15s ease}.help-prompts code.clickable{cursor:pointer;-webkit-user-select:none;user-select:none}.help-prompts code.clickable:hover{background:var(--color-primary, #818cf8);border-color:var(--color-primary, #818cf8);color:#fff;transform:translateY(-1px);box-shadow:0 2px 8px #818cf84d}.help-prompts code.clickable:focus-visible{outline:2px solid var(--color-primary, #818cf8);outline-offset:2px}.help-prompts code.clickable:active{transform:translateY(0);box-shadow:0 1px 4px #818cf84d}.help-feature{background:#f7fafc;border-radius:12px;padding:1rem 1.25rem;margin-bottom:1rem}.help-feature:last-child{margin-bottom:0}.help-feature-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.help-feature-icon{font-size:1.25rem}.help-feature h4{margin:0;font-size:1rem;color:#2d3748;font-weight:600}.help-feature>p{color:#4a5568;margin:0 0 .75rem;line-height:1.5}.help-details{margin:0;padding-left:1.25rem;color:#4a5568}.help-details li{margin-bottom:.4rem;line-height:1.5}.help-details li:last-child{margin-bottom:0}.help-details strong{color:#2d3748}.help-shortcuts{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:.75rem}.help-shortcut{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background:#f7fafc;border-radius:8px}.help-shortcut kbd{display:inline-flex;align-items:center;justify-content:center;min-width:2rem;padding:.25rem .5rem;background:#fff;border:1px solid #cbd5e0;border-radius:6px;font-family:SF Mono,Monaco,Consolas,monospace;font-size:.8rem;color:#4a5568;box-shadow:0 1px 2px #0000000d}.help-shortcut span{color:#4a5568;font-size:.9rem}.help-tips{margin:0;padding-left:1.25rem;color:#4a5568}.help-tips li{margin-bottom:.75rem;line-height:1.6}.help-tips li:last-child{margin-bottom:0}.help-tips strong{color:var(--color-primary, #818cf8)}.help-content::-webkit-scrollbar{width:8px}.help-content::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.help-content::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:4px}.help-content::-webkit-scrollbar-thumb:hover{background:#a0aec0}@media(max-width:640px){.help-modal{width:95%;max-height:90vh;border-radius:16px}.help-header{padding:1rem 1.25rem}.help-content{padding:1.25rem}.help-shortcuts{grid-template-columns:1fr}}.news-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0a1ebf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.news-modal{background:var(--bg-card);border-radius:var(--radius-xl);width:90%;max-width:900px;max-height:85vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);animation:slideUp .3s ease-out;overflow:hidden;transition:background .3s ease}.news-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-light);background:var(--primary-gradient)}.news-header h2{margin:0;font-size:1.3rem;font-weight:700;color:#fff;display:flex;align-items:center;gap:.5rem}.news-header h2 span{font-size:1.4rem}.news-close-btn{width:36px;height:36px;border:none;background:#ffffff26;border-radius:var(--radius-sm);font-size:1.25rem;color:#fff;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.news-close-btn:hover{background:#ffffff40;transform:scale(1.05)}.news-close-btn:focus-visible{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}.news-close-btn:active{transform:scale(.95)}.news-tabs{display:flex;flex-wrap:wrap;gap:.5rem;padding:1rem 1.5rem;border-bottom:1px solid var(--border-light)}.news-tab{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-card);border:1px solid var(--border-light);border-radius:20px;color:var(--text-secondary);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.news-tab:hover{border-color:var(--primary-color);color:var(--text-primary);transform:translateY(-1px)}.news-tab.active{background:var(--primary-gradient);border-color:transparent;color:#fff;box-shadow:0 2px 8px #818cf84d}.news-tab:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.news-tab .count{font-size:.7rem;padding:2px 6px;background:#00000026;border-radius:10px}.news-content{flex:1;overflow-y:auto;padding:1.5rem}.news-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:5rem 1.5rem;color:var(--text-secondary)}.news-spinner{width:48px;height:48px;border:3px solid var(--border-light);border-top-color:var(--primary-color);border-right-color:var(--accent-color);border-radius:50%;animation:spin .9s cubic-bezier(.4,0,.2,1) infinite;margin-bottom:1.25rem}.news-loading p{font-size:.95rem;color:var(--text-secondary);animation:pulse 1.5s ease-in-out infinite}.news-error{text-align:center;padding:4rem 1.5rem;color:var(--text-secondary)}.news-error .error-icon{font-size:3.5rem;margin-bottom:1.25rem;opacity:.6}.news-error p{margin:.5rem 0;font-size:.95rem}.news-error p:first-of-type{color:var(--text-primary);font-weight:500}.news-empty{text-align:center;padding:5rem 1.5rem;color:var(--text-secondary)}.news-empty .empty-icon{font-size:4rem;margin-bottom:1.25rem;opacity:.4}.news-empty p{font-size:.95rem;color:var(--text-secondary)}.news-retry-btn{margin-top:1.25rem;padding:.75rem 1.5rem;background:var(--primary-gradient);border:none;border-radius:var(--radius-md);color:#fff;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 15px #818cf833}.news-retry-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #818cf84d}.news-retry-btn:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.news-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;animation:fadeInUp .4s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.news-card{background:var(--bg-light);border:1px solid transparent;border-radius:var(--radius-md);overflow:hidden;transition:all .2s ease;cursor:pointer}.news-card:hover{border-color:var(--primary-color);transform:translateY(-4px);box-shadow:var(--shadow-md)}.news-card:active{transform:translateY(-2px)}.news-card-thumbnail{width:100%;height:150px;object-fit:cover;background:#0000004d;transition:transform .4s ease}.news-card:hover .news-card-thumbnail{transform:scale(1.03)}.news-card-thumbnail.placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:linear-gradient(135deg,#4a9eff26,#805ad526);position:relative;overflow:hidden}.news-card-thumbnail.placeholder:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(45deg,transparent 40%,rgba(255,255,255,.03) 50%,transparent 60%);background-size:200% 200%;animation:shimmer 3s infinite linear}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.news-card-thumbnail.placeholder .placeholder-icon{font-size:2.8rem;opacity:.85;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));transition:transform .3s ease}.news-card:hover .placeholder-icon{transform:scale(1.1)}.news-card-thumbnail.placeholder .placeholder-label{font-size:.7rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-secondary);font-weight:600}.placeholder-broadcast{background:linear-gradient(135deg,#ff6b6b33,#ff9f4326)!important}.placeholder-top_game{background:linear-gradient(135deg,#48dbfb33,#5ac8fa26)!important}.placeholder-streamer{background:linear-gradient(135deg,#9146ff33,#ba78ff26)!important}.placeholder-article{background:linear-gradient(135deg,#64c86433,#96dc9626)!important}.news-card-body{padding:1rem}.news-card-category{display:inline-flex;align-items:center;gap:4px;font-size:.7rem;color:var(--primary-color);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.8px;font-weight:600}.news-card-title{margin:0 0 .5rem;font-size:1rem;font-weight:600;color:var(--text-primary);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.news-card-description{margin:0 0 .75rem;font-size:.85rem;color:var(--text-secondary);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.news-card-meta{display:flex;align-items:center;justify-content:space-between;font-size:.8rem;color:var(--text-muted);padding-top:.75rem;border-top:1px solid var(--border-light);margin-top:auto}.news-card-source{display:flex;align-items:center;gap:4px}.news-card-time{opacity:.7}.broadcast-status{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:12px;font-size:.72rem;font-weight:600;letter-spacing:.5px;margin-bottom:8px}.broadcast-status.live{background:linear-gradient(135deg,#ff3b3040,#ff6b6b33);color:#ff6b6b;box-shadow:0 0 12px #ff3b304d}.broadcast-status.live:before{content:"";width:7px;height:7px;background:#ff3b30;border-radius:50%;animation:livePulse 1.2s ease-in-out infinite;box-shadow:0 0 8px #ff3b30}@keyframes livePulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.85)}}.broadcast-status.upcoming{background:#ffc10726;color:#ffd54f}.broadcast-status.upcoming:before{content:"⏰";font-size:.7rem}.broadcast-status.finished{background:#9e9e9e26;color:#aaa}.game-players{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.game-player{display:flex;align-items:center;gap:6px;font-size:.9rem}.game-player .piece{font-size:1rem}.game-player .rating{color:var(--text-secondary);font-size:.8rem}.streamer-live{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background:#ff3b3033;border-radius:10px;font-size:.75rem;font-weight:500;color:#ff3b30}.streamer-live:before{content:"";width:6px;height:6px;background:#ff3b30;border-radius:50%;animation:pulse 1.5s infinite}.streamer-viewers{font-size:.8rem;color:var(--text-secondary)}.news-footer{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-top:1px solid var(--border-light);color:var(--text-muted);font-size:.85rem}.news-footer span{display:flex;align-items:center;gap:6px}.news-refresh-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-light);border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease}.news-refresh-btn:hover{border-color:var(--primary-color);color:var(--primary-color);transform:translateY(-1px)}.news-refresh-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.news-refresh-btn .refresh-icon{font-size:1rem;transition:transform .3s ease}.news-refresh-btn:hover .refresh-icon{transform:rotate(45deg)}.news-refresh-btn.refreshing .refresh-icon{animation:spin .8s linear infinite}@media(max-width:600px){.news-modal{width:100%;max-height:100vh;border-radius:0;margin:0}.news-header{padding:16px}.news-header h2{font-size:1.25rem}.news-tabs{padding:12px 16px;gap:8px}.news-tab{padding:8px 14px;font-size:.85rem}.news-content{padding:12px 16px}.news-grid{grid-template-columns:1fr;gap:14px}.news-card-thumbnail{height:130px}.news-footer{padding:12px 16px;flex-direction:column;gap:12px;text-align:center}.news-refresh-btn{width:100%;justify-content:center}}.avatar{position:relative;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;overflow:visible;flex-shrink:0}.avatar-sm{width:40px;height:40px}.avatar-md{width:56px;height:56px}.avatar-lg{width:80px;height:80px}.avatar-inner{width:100%;height:100%;border-radius:inherit;overflow:hidden;position:relative;z-index:1;box-shadow:0 4px 12px #00000026;transition:transform .3s ease}.avatar-svg{width:100%;height:100%;display:block}.avatar-glow{position:absolute;top:-6px;right:-6px;bottom:-6px;left:-6px;border-radius:50%;opacity:0;z-index:0;transition:opacity .4s ease;pointer-events:none}.avatar-coach .avatar-glow{background:radial-gradient(circle,rgba(139,92,246,.5) 0%,transparent 70%)}.avatar-opponent .avatar-glow{background:radial-gradient(circle,rgba(167,139,250,.5) 0%,transparent 70%)}.avatar-animated .avatar-glow{opacity:1;animation:softGlow 3s ease-in-out infinite}@keyframes softGlow{0%,to{opacity:.4;transform:scale(1)}50%{opacity:.7;transform:scale(1.08)}}.avatar:hover .avatar-inner{transform:scale(1.05)}.avatar-coach.avatar-animated .avatar-eye-shine{animation:eyeSparkle 3s ease-in-out infinite}@keyframes eyeSparkle{0%,to{opacity:.95}50%{opacity:.6}}.avatar-coach.avatar-animated .avatar-glasses{animation:glassesFloat 4s ease-in-out infinite}@keyframes glassesFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-.5px)}}.avatar-coach.avatar-animated .avatar-sparkle path{animation:sparkleRotate 2s ease-in-out infinite}.avatar-coach.avatar-animated .avatar-sparkle path:nth-child(2){animation-delay:.5s}@keyframes sparkleRotate{0%,to{opacity:.5;transform:scale(1) rotate(0)}50%{opacity:1;transform:scale(1.3) rotate(20deg)}}.avatar-coach.mood-thinking .thinking-indicator{animation:fadeInUp .3s ease-out}.avatar-coach.mood-thinking .think-piece{animation:pieceFloat 2s ease-in-out infinite}@keyframes pieceFloat{0%,to{transform:translateY(0);opacity:.8}50%{transform:translateY(-2px);opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.avatar-coach.mood-happy.avatar-animated .avatar-inner,.avatar-coach.mood-excited.avatar-animated .avatar-inner{animation:happyPop .5s ease-out}.avatar-coach.mood-happy .avatar-svg ellipse[fill="url(#cheekBlush)"],.avatar-coach.mood-excited .avatar-svg ellipse[fill="url(#cheekBlush)"]{animation:blushPulse 2s ease-in-out infinite}@keyframes blushPulse{0%,to{opacity:1}50%{opacity:.7}}.avatar-coach.mood-thinking .avatar-brows{animation:browThink 3s ease-in-out infinite}@keyframes browThink{0%,to{transform:translateY(0)}50%{transform:translateY(-1px)}}@keyframes happyPop{0%{transform:scale(1)}50%{transform:scale(1.08)}to{transform:scale(1)}}.avatar-opponent.avatar-animated .avatar-visor{animation:visorPulse 4s ease-in-out infinite}@keyframes visorPulse{0%,to{fill:#1a1a2e}50%{fill:#1e1e38}}.avatar-opponent.avatar-animated .robot-eye{animation:eyeGlow 2s ease-in-out infinite}@keyframes eyeGlow{0%,to{opacity:1;filter:drop-shadow(0 0 4px rgba(167,139,250,.6))}50%{opacity:.85;filter:drop-shadow(0 0 8px rgba(167,139,250,.9))}}.avatar-opponent.avatar-animated .antenna-orb{animation:antennaPulse 2s ease-in-out infinite}.avatar-opponent.avatar-animated .antenna-core{animation:antennaCore 2s ease-in-out infinite}@keyframes antennaPulse{0%,to{opacity:1;filter:drop-shadow(0 0 3px rgba(139,92,246,.5))}50%{opacity:.9;filter:drop-shadow(0 0 8px rgba(139,92,246,.8))}}@keyframes antennaCore{0%,to{fill:#c4b5fd}50%{fill:#e9e3ff}}.avatar-opponent.avatar-animated .status-led{animation:ledBlink 2.5s ease-in-out infinite}@keyframes ledBlink{0%,to{fill:#4ade80;filter:drop-shadow(0 0 3px #4ade80)}50%{fill:#86efac;filter:drop-shadow(0 0 6px #4ade80)}}.avatar-opponent.mood-thinking .processing-dots .dot-1{animation:processDot 1s ease-in-out infinite}.avatar-opponent.mood-thinking .processing-dots .dot-2{animation:processDot 1s ease-in-out infinite .2s}.avatar-opponent.mood-thinking .processing-dots .dot-3{animation:processDot 1s ease-in-out infinite .4s}@keyframes processDot{0%,to{opacity:.4;transform:scale(.8)}50%{opacity:1;transform:scale(1.3)}}.avatar-opponent.mood-thinking .robot-eye{animation:scanPulse .8s ease-in-out infinite}@keyframes scanPulse{0%,to{opacity:1;transform:scaleY(1)}50%{opacity:.7;transform:scaleY(.6)}}.avatar.mood-excited.avatar-animated .avatar-inner{animation:excitedWiggle .4s ease-in-out 2}@keyframes excitedWiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-3deg)}75%{transform:rotate(3deg)}}.avatar.mood-concerned.avatar-animated .avatar-inner{animation:concernedPulse .4s ease-in-out}@keyframes concernedPulse{0%,to{transform:scale(1)}50%{transform:scale(.98)}}.avatar.mood-thinking .avatar-glow{opacity:.8;animation:thinkingGlow 1.5s ease-in-out infinite}@keyframes thinkingGlow{0%,to{opacity:.6;transform:scale(1)}50%{opacity:.9;transform:scale(1.1)}}.elo-estimation{background:linear-gradient(135deg,#faf5ff,#f5f3ff);border-radius:12px;border:1px solid rgba(139,92,246,.2);padding:1rem;margin-top:.75rem;animation:fadeInUp .3s ease-out}.elo-estimation-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.elo-estimation-header h3{margin:0;font-size:1rem;color:#5b21b6;display:flex;align-items:center;gap:.5rem}.elo-estimation-controls{display:flex;align-items:center;gap:.5rem}.moves-count{font-size:.75rem;color:#7c3aed;background:#8b5cf61a;padding:.25rem .5rem;border-radius:12px}.clear-history-btn{background:none;border:none;cursor:pointer;padding:.25rem;font-size:.875rem;opacity:.6;transition:opacity .2s}.clear-history-btn:hover{opacity:1}.elo-estimation-prompt{text-align:center;padding:1rem}.elo-estimation-prompt p{margin:0 0 .75rem;color:#6b7280;font-size:.875rem}.estimate-button{background:linear-gradient(135deg,#7c3aed,#6d28d9);color:#fff;border:none;padding:.625rem 1.25rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.estimate-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #7c3aed4d}.estimate-button:disabled{opacity:.5;cursor:not-allowed}.estimate-button:focus-visible{outline:2px solid #7c3aed;outline-offset:2px}.elo-loading{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1.5rem;color:#7c3aed}.loading-spinner{width:24px;height:24px;border:3px solid rgba(124,58,237,.2);border-top-color:#7c3aed;border-radius:50%;animation:spin 1s linear infinite}.elo-error{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#fef2f2;border-radius:8px;color:#dc2626;font-size:.875rem}.elo-result{display:flex;flex-direction:column;gap:.75rem}.elo-main{display:flex;flex-direction:column;align-items:center;padding:1.25rem;border-radius:12px;background:#fff;box-shadow:0 2px 8px #0000000d;transition:all .2s ease}.elo-main:hover{transform:translateY(-2px);box-shadow:0 4px 16px #7c3aed26}.elo-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;color:#6b7280}.elo-value{font-size:2.75rem;font-weight:800;line-height:1.2;animation:countUp .5s ease-out}@keyframes countUp{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.elo-confidence{font-size:.75rem;color:#6b7280;margin-top:.25rem}.elo-novice .elo-value{color:#6b7280}.elo-intermediate .elo-value{color:#16a34a}.elo-club .elo-value{color:#2563eb}.elo-advanced .elo-value{color:#7c3aed}.elo-expert .elo-value{color:#dc2626}.skill-description{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#fff;border-radius:10px;font-size:.875rem;box-shadow:0 1px 4px #0000000a;transition:all .2s ease}.skill-description:hover{box-shadow:0 2px 8px #00000014}.skill-icon{font-size:1.25rem}.skill-text{color:#374151;font-weight:500}.match-rates{background:#fff;border-radius:10px;padding:.75rem;box-shadow:0 1px 4px #0000000a}.match-rates h4{margin:0 0 .625rem;font-size:.7rem;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;gap:.375rem}.match-rates h4:before{content:"🎯";font-size:.8rem}.rates-grid{display:flex;flex-direction:column;gap:.625rem}.rate-item{display:grid;grid-template-columns:70px 1fr 45px;align-items:center;gap:.5rem}.rate-model{font-size:.75rem;font-weight:600;color:#374151}.rate-bar-container{height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.rate-bar{height:100%;background:linear-gradient(90deg,#7c3aed,#a78bfa);border-radius:4px;transition:width .8s cubic-bezier(.4,0,.2,1);animation:barGrow .8s ease-out}@keyframes barGrow{0%{width:0!important}}.rate-value{font-size:.75rem;font-weight:600;color:#7c3aed;text-align:right}.improvement-tip{display:flex;align-items:flex-start;gap:.5rem;padding:.75rem;background:linear-gradient(135deg,#fefce8,#fef9c3);border-radius:10px;border:1px solid rgba(234,179,8,.15);font-size:.85rem;transition:all .2s ease}.improvement-tip:hover{box-shadow:0 2px 8px #eab30826}.tip-icon{font-size:1rem;flex-shrink:0}.tip-text{color:#92400e;line-height:1.4}.reanalyze-button{background:transparent;color:#7c3aed;border:1px solid rgba(124,58,237,.3);padding:.5rem 1rem;border-radius:8px;font-size:.8rem;cursor:pointer;transition:all .2s}.reanalyze-button:hover:not(:disabled){background:#7c3aed1a;border-color:#7c3aed}.reanalyze-button:disabled{opacity:.5;cursor:not-allowed}.elo-badge-container{position:relative;z-index:9999}.elo-badge-btn{display:flex;align-items:center;gap:.35rem;background:linear-gradient(135deg,#f5f3ff,#ede9fe);border:1px solid rgba(139,92,246,.3);border-radius:20px;padding:.35rem .75rem;cursor:pointer;transition:all .2s ease;font-size:.875rem;font-weight:500;color:#5b21b6}.elo-badge-btn:hover{background:linear-gradient(135deg,#ede9fe,#ddd6fe);border-color:#8b5cf680;transform:translateY(-1px)}.elo-badge-btn.active{background:linear-gradient(135deg,#ddd6fe,#c4b5fd);border-color:#7c3aed}.elo-badge-btn:focus-visible{outline:2px solid rgba(139,92,246,.5);outline-offset:2px}.elo-badge-icon{font-size:1rem}.elo-badge-value{font-weight:700;font-size:.9rem}.elo-badge-count{font-size:.75rem;background:#8b5cf633;padding:.1rem .4rem;border-radius:10px}.elo-badge-btn.elo-novice{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:#d9770666;color:#92400e}.elo-badge-btn.elo-intermediate{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-color:#10b98166;color:#065f46}.elo-badge-btn.elo-club{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-color:#3b82f666;color:#1e40af}.elo-badge-btn.elo-advanced{background:linear-gradient(135deg,#f5f3ff,#ddd6fe);border-color:#8b5cf666;color:#5b21b6}.elo-badge-btn.elo-expert{background:linear-gradient(135deg,#fce7f3,#fbcfe8);border-color:#db277766;color:#9d174d}.elo-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:320px;background:#fff;border-radius:12px;box-shadow:0 10px 40px #00000026,0 2px 10px #0000001a;border:1px solid rgba(139,92,246,.2);z-index:9999;animation:dropdownSlide .2s ease-out;overflow:hidden}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.elo-dropdown-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:linear-gradient(135deg,#f5f3ff,#ede9fe);border-bottom:1px solid rgba(139,92,246,.1)}.elo-dropdown-header h4{margin:0;font-size:.95rem;color:#5b21b6}.elo-dropdown-close{background:none;border:none;font-size:1.25rem;color:#9ca3af;cursor:pointer;padding:0;line-height:1}.elo-dropdown-close:hover{color:#6b7280}.elo-status-bar{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;background:#fafafa;border-bottom:1px solid #f0f0f0}.elo-moves-tracked{font-size:.75rem;color:#7c3aed;background:#8b5cf61a;padding:.25rem .5rem;border-radius:10px}.elo-clear-btn{background:none;border:none;font-size:.75rem;color:#9ca3af;cursor:pointer;padding:.25rem .5rem;border-radius:4px;transition:all .2s}.elo-clear-btn:hover{background:#ef44441a;color:#dc2626}.elo-prompt{padding:1.5rem 1rem;text-align:center}.elo-prompt p{margin:0 0 1rem;color:#6b7280;font-size:.875rem}.elo-estimate-btn{background:linear-gradient(135deg,#7c3aed,#6d28d9);color:#fff;border:none;padding:.6rem 1.25rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.elo-estimate-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #7c3aed4d}.elo-loading{padding:1.5rem;text-align:center;color:#6b7280;display:flex;flex-direction:column;align-items:center;gap:.75rem}.elo-spinner{width:24px;height:24px;border:3px solid rgba(139,92,246,.2);border-top-color:#7c3aed;border-radius:50%;animation:spin .8s linear infinite}.elo-error{padding:1rem;background:#fef2f2;color:#dc2626;display:flex;justify-content:space-between;align-items:center;font-size:.875rem}.elo-retry-btn{background:#dc2626;color:#fff;border:none;padding:.35rem .75rem;border-radius:4px;font-size:.75rem;cursor:pointer}.elo-results{padding:1rem}.elo-main-display{text-align:center;padding:1rem;border-radius:10px;margin-bottom:1rem}.elo-main-display.elo-novice{background:linear-gradient(135deg,#fef3c7,#fde68a)}.elo-main-display.elo-intermediate{background:linear-gradient(135deg,#d1fae5,#a7f3d0)}.elo-main-display.elo-club{background:linear-gradient(135deg,#dbeafe,#bfdbfe)}.elo-main-display.elo-advanced{background:linear-gradient(135deg,#f5f3ff,#ddd6fe)}.elo-main-display.elo-expert{background:linear-gradient(135deg,#fce7f3,#fbcfe8)}.elo-number{font-size:2rem;font-weight:800;line-height:1.2}.elo-label{font-size:.875rem;font-weight:600;margin-top:.25rem}.elo-confidence{font-size:.75rem;opacity:.8;margin-top:.35rem}.elo-description{display:flex;align-items:flex-start;gap:.5rem;padding:.75rem;background:#f9fafb;border-radius:8px;font-size:.8rem;color:#4b5563;margin-bottom:1rem}.elo-desc-icon{flex-shrink:0}.elo-match-rates{margin-bottom:1rem}.elo-match-rates h5{margin:0 0 .5rem;font-size:.75rem;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.elo-rate-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.4rem}.elo-rate-label{width:60px;font-size:.7rem;color:#6b7280}.elo-rate-bar-bg{flex:1;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.elo-rate-bar-fill{height:100%;background:linear-gradient(90deg,#7c3aed,#a78bfa);border-radius:4px;transition:width .5s ease-out;width:0%}.elo-rate-bar-fill.elo-rate-0{width:0%}.elo-rate-bar-fill.elo-rate-10{width:10%}.elo-rate-bar-fill.elo-rate-20{width:20%}.elo-rate-bar-fill.elo-rate-30{width:30%}.elo-rate-bar-fill.elo-rate-40{width:40%}.elo-rate-bar-fill.elo-rate-50{width:50%}.elo-rate-bar-fill.elo-rate-60{width:60%}.elo-rate-bar-fill.elo-rate-70{width:70%}.elo-rate-bar-fill.elo-rate-80{width:80%}.elo-rate-bar-fill.elo-rate-90{width:90%}.elo-rate-bar-fill.elo-rate-100{width:100%}.elo-rate-value{width:36px;font-size:.7rem;color:#4b5563;text-align:right;font-weight:500}.elo-tip{display:flex;align-items:flex-start;gap:.5rem;padding:.6rem;background:#fef3c7;border-radius:6px;font-size:.75rem;color:#92400e;margin-bottom:1rem}.elo-tip-icon{flex-shrink:0}.elo-reanalyze-btn{width:100%;background:#f3f4f6;color:#4b5563;border:1px solid #e5e7eb;padding:.5rem;border-radius:6px;font-size:.8rem;cursor:pointer;transition:all .2s}.elo-reanalyze-btn:hover:not(:disabled){background:#e5e7eb;color:#374151}.elo-reanalyze-btn:disabled{opacity:.5;cursor:not-allowed}.elo-history-btn{width:100%;background:linear-gradient(135deg,#ede9fe,#ddd6fe);color:#5b21b6;border:1px solid rgba(139,92,246,.3);padding:.5rem;border-radius:6px;font-size:.8rem;cursor:pointer;transition:all .2s;margin-top:.5rem;display:flex;align-items:center;justify-content:center;gap:.5rem}.elo-history-btn:hover{background:linear-gradient(135deg,#ddd6fe,#c4b5fd);border-color:#8b5cf680;transform:translateY(-1px);box-shadow:0 2px 8px #8b5cf633}.elo-history-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.elo-history-content{background:var(--surface-color, #1a1a2e);border-radius:16px;max-width:600px;width:100%;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px #00000080}.elo-history-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-color, rgba(255, 255, 255, .1))}.elo-history-header h2{margin:0;font-size:1.5rem;color:var(--text-color, #fff)}.elo-history-header .close-btn{background:none;border:none;color:var(--text-secondary, #888);font-size:1.5rem;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s}.elo-history-header .close-btn:hover{background:#ffffff1a;color:var(--text-color, #fff)}.elo-history-loading,.elo-history-error,.elo-history-empty{padding:40px 24px;text-align:center;color:var(--text-secondary, #888)}.elo-history-error{color:#ff6b6b}.elo-history-empty .hint{font-size:.85rem;margin-top:12px;opacity:.7}.elo-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding:20px 24px}.elo-stat-card{background:var(--card-bg, rgba(255, 255, 255, .05));border-radius:12px;padding:16px;text-align:center}.elo-stat-card.current{grid-column:span 3;background:linear-gradient(135deg,#6366f133,#8b5cf633);border:1px solid rgba(99,102,241,.3)}.stat-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary, #888);margin-bottom:8px}.stat-value{font-size:1.5rem;font-weight:700;color:var(--text-color, #fff)}.elo-stat-card.current .stat-value{font-size:2.5rem}.stat-tier{font-size:.9rem;font-weight:600;margin-top:4px}.stat-value.positive{color:#4ade80}.stat-value.negative{color:#f87171}.trend-icon{margin-left:4px}.elo-history-list{padding:20px 24px;border-top:1px solid var(--border-color, rgba(255, 255, 255, .1))}.elo-history-list h3{margin:0 0 16px;font-size:1rem;color:var(--text-color, #fff)}.history-entries{display:flex;flex-direction:column;gap:8px}.history-entry{display:flex;align-items:center;gap:16px;padding:12px 16px;background:var(--card-bg, rgba(255, 255, 255, .03));border-radius:8px;transition:background .2s}.history-entry:hover{background:var(--card-hover, rgba(255, 255, 255, .06))}.entry-elo{font-size:1.25rem;font-weight:700;min-width:60px}.entry-details{display:flex;align-items:center;gap:12px;flex:1;font-size:.85rem;color:var(--text-secondary, #888)}.entry-date{margin-left:auto}@media(max-width:480px){.elo-stats-grid{grid-template-columns:repeat(2,1fr)}.elo-stat-card.current{grid-column:span 2}.entry-details{flex-wrap:wrap;gap:8px}}.blunder-warning{position:absolute;top:10px;left:50%;transform:translate(-50%);z-index:100;max-width:350px;width:90%;padding:12px 16px;border-radius:12px;background:#1a1a2e;box-shadow:0 8px 32px #0006;animation:slideIn .3s ease-out}[data-theme=light] .blunder-warning{background:#fff;box-shadow:0 8px 32px #00000026}@keyframes slideIn{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.blunder-warning.risk-critical{border:2px solid #dc2626;background:linear-gradient(135deg,#450a0a,#1a1a2e)}.blunder-warning.risk-high{border:2px solid #f59e0b;background:linear-gradient(135deg,#451a03,#1a1a2e)}.blunder-warning.risk-moderate{border:2px solid #3b82f6;background:linear-gradient(135deg,#172554,#1a1a2e)}[data-theme=light] .blunder-warning.risk-critical{background:linear-gradient(135deg,#fef2f2,#fee2e2)}[data-theme=light] .blunder-warning.risk-high{background:linear-gradient(135deg,#fffbeb,#fef3c7)}[data-theme=light] .blunder-warning.risk-moderate{background:linear-gradient(135deg,#eff6ff,#dbeafe)}[data-theme=light] .warning-title{color:#1f2937}[data-theme=light] .warning-message{color:#374151}[data-theme=light] .warning-concerns{color:#6b7280}[data-theme=light] .warning-footer{color:#6b7280;border-top-color:#0000001a}[data-theme=light] .dismiss-btn{color:#9ca3af}[data-theme=light] .dismiss-btn:hover{background:#0000000d;color:#374151}[data-theme=light] .risk-critical .think-time{color:#dc2626}[data-theme=light] .risk-high .think-time{color:#d97706}[data-theme=light] .risk-moderate .think-time{color:#2563eb}.warning-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.warning-icon{font-size:1.25rem}.warning-title{font-weight:700;font-size:.95rem;color:var(--text-color, #fff);flex:1}.dismiss-btn{background:none;border:none;color:var(--text-secondary, #888);font-size:1rem;cursor:pointer;padding:2px 6px;border-radius:4px;transition:all .2s}.dismiss-btn:hover{background:#ffffff1a;color:var(--text-color, #fff)}.warning-message{margin:0 0 8px;font-size:.85rem;color:var(--text-color, #fff);line-height:1.4}.warning-concerns{margin:0 0 8px;padding-left:20px;font-size:.8rem;color:var(--text-secondary, #888)}.warning-concerns li{margin-bottom:4px}.warning-footer{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-secondary, #888);padding-top:8px;border-top:1px solid var(--border-color, rgba(255, 255, 255, .1))}.think-time{font-weight:600}.risk-critical .think-time{color:#fca5a5}.risk-high .think-time{color:#fcd34d}.risk-moderate .think-time{color:#93c5fd}.config-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0a1ebf;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.config-page{background:var(--bg-card);border-radius:20px;width:90%;max-width:640px;max-height:85vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);animation:slideUp .3s ease-out;overflow:hidden;transition:background .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.config-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid #e2e8f0;background:var(--gradient-primary, linear-gradient(135deg, #818cf8, #6366f1))}.config-header h2{margin:0;font-size:1.3rem;color:#fff;font-weight:700}.config-close{width:36px;height:36px;border:none;background:#ffffff26;border-radius:10px;font-size:1.25rem;color:#fff;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.config-close:hover{background:#ffffff40;transform:scale(1.05)}.config-close:focus-visible{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}.config-close:active{transform:scale(.95)}.config-content{flex:1;overflow-y:auto;padding:1.5rem}.config-section{margin-bottom:1.75rem;padding-bottom:1.75rem;border-bottom:1px solid var(--border-light)}.config-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.config-section h3{font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin:0 0 1rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.theme-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:.75rem}.color-scheme-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.color-scheme-option{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:1rem .75rem;border:2px solid var(--border-light);border-radius:12px;background:var(--bg-card);cursor:pointer;transition:all .2s ease}.color-scheme-option:hover{border-color:var(--color-primary, #818cf8);transform:translateY(-2px)}.color-scheme-option.active{border-color:var(--color-primary, #818cf8);background:#818cf80d;box-shadow:0 0 0 3px #818cf826}.color-scheme-option:focus-visible{outline:2px solid var(--color-primary, #818cf8);outline-offset:2px}.color-scheme-icon{font-size:1.5rem;line-height:1}.color-scheme-name{font-size:.8rem;font-weight:600;color:var(--text-primary)}.theme-option{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.75rem;border:2px solid var(--border-light);border-radius:12px;background:var(--bg-card);cursor:pointer;transition:all .2s ease}.theme-option:hover{border-color:var(--color-primary, #818cf8);transform:translateY(-2px)}.theme-option.active{border-color:var(--color-primary, #818cf8);background:#818cf80d;box-shadow:0 0 0 3px #818cf826}.theme-preview{display:grid;grid-template-columns:1fr 1fr;width:48px;height:48px;border-radius:6px;overflow:hidden;box-shadow:0 2px 8px #00000026}.preview-square{width:24px;height:24px}.theme-name{font-size:.75rem;font-weight:600;color:var(--text-primary)}.piece-style-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.6rem}.piece-style-option{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:.6rem .4rem;border:2px solid var(--border-light);border-radius:10px;background:var(--bg-card);cursor:pointer;transition:all .2s ease}.piece-style-option:hover{border-color:var(--color-primary, #818cf8);transform:translateY(-2px)}.piece-style-option.active{border-color:var(--color-primary, #818cf8);background:#818cf80d;box-shadow:0 0 0 3px #818cf826}.piece-preview{width:40px;height:40px;display:flex;align-items:center;justify-content:center}.piece-preview-img{width:36px;height:36px;object-fit:contain}.piece-style-name{font-size:.7rem;font-weight:600;color:var(--text-primary);text-align:center}.notation-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.notation-option{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:1rem;border:2px solid var(--border-light);border-radius:12px;background:var(--bg-card);cursor:pointer;transition:all .2s ease}.notation-option:hover{border-color:var(--color-primary, #818cf8);transform:translateY(-2px)}.notation-option.active{border-color:var(--color-primary, #818cf8);background:#818cf80d;box-shadow:0 0 0 3px #818cf826}.notation-name{font-size:.9rem;font-weight:600;color:var(--text-primary)}.notation-example{font-size:.75rem;color:var(--text-secondary);font-family:SF Mono,Monaco,Consolas,monospace;background:var(--bg-light);padding:.25rem .5rem;border-radius:4px}.config-option{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:var(--bg-light);border-radius:12px;margin-bottom:.75rem}.config-option:last-child{margin-bottom:0}.config-option.disabled{opacity:.5;pointer-events:none}.config-label{display:flex;flex-direction:column;gap:.25rem}.config-label span:first-child{font-weight:600;color:var(--text-primary);font-size:.95rem}.config-description{font-size:.8rem;color:var(--text-secondary)}.toggle-switch{width:52px;height:28px;border-radius:14px;background:#cbd5e1;border:none;padding:2px;cursor:pointer;transition:background .3s ease;position:relative}.toggle-switch.active{background:var(--gradient-primary, linear-gradient(135deg, #818cf8, #6366f1))}.toggle-slider{display:block;width:24px;height:24px;background:#fff;border-radius:50%;box-shadow:0 2px 4px #0003;transition:transform .3s ease}.toggle-switch.active .toggle-slider{transform:translate(24px)}.toggle-switch:focus-visible{outline:2px solid var(--color-primary, #818cf8);outline-offset:2px}.slider-container{display:flex;align-items:center;gap:.75rem}.config-slider{width:120px;height:6px;border-radius:3px;background:var(--border-light);-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.config-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--gradient-primary, linear-gradient(135deg, #818cf8, #6366f1));box-shadow:0 2px 6px #818cf866;cursor:pointer;transition:transform .15s ease}.config-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.config-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--gradient-primary, linear-gradient(135deg, #818cf8, #6366f1));box-shadow:0 2px 6px #818cf866;cursor:pointer;border:none}.slider-value{font-size:.85rem;font-weight:600;color:var(--color-primary, #818cf8);min-width:50px;text-align:right}.about-section{background:var(--bg-light);padding:1.25rem;border-radius:12px;border:1px solid var(--border-light)}.about-content{text-align:center}.about-title{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:.75rem}.about-title .app-icon{font-size:1.5rem}.about-title .app-name{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.version-badge{background:var(--gradient-primary, linear-gradient(135deg, #818cf8, #6366f1));color:#fff;font-size:.65rem;font-weight:600;padding:.2rem .5rem;border-radius:20px;text-transform:uppercase;letter-spacing:.5px}.about-description{color:var(--text-secondary);font-size:.875rem;line-height:1.5;margin-bottom:1rem}.about-links{margin-bottom:1rem}.github-link{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#24292e;color:#fff;text-decoration:none;border-radius:8px;font-size:.85rem;font-weight:500;transition:all .2s ease}.github-link:hover{background:#1a1f24;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.github-link svg{flex-shrink:0}.about-footer{display:flex;align-items:center;justify-content:center;gap:.5rem;flex-wrap:wrap;padding-top:.75rem;border-top:1px solid var(--border-light)}.about-copyright{color:#94a3b8;font-size:.75rem}.about-divider{color:#cbd5e1;font-size:.75rem}.about-credits{color:#94a3b8;font-size:.75rem}.section-description{font-size:.85rem;color:var(--text-secondary);margin-bottom:1rem;line-height:1.4}.toggle-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:var(--bg-light);border-radius:10px;margin-bottom:1rem}.toggle-label{display:flex;flex-direction:column;gap:.125rem}.toggle-label span:first-child{font-weight:600;color:var(--text-primary);font-size:.9rem}.toggle-hint{font-size:.75rem;color:var(--text-secondary)}.elo-selector{margin-top:.5rem}.elo-label{display:block;font-weight:600;color:var(--text-primary);font-size:.85rem;margin-bottom:.5rem}.elo-slider-container{background:var(--bg-light);border-radius:12px;padding:1rem;margin-bottom:.75rem}.elo-slider-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.elo-current-value{font-size:1.5rem;font-weight:700;color:var(--color-primary, #818cf8)}.elo-skill-level{font-size:.875rem;font-weight:500;color:var(--text-secondary);background:var(--bg-card);padding:.25rem .75rem;border-radius:20px;border:1px solid var(--border-light)}.elo-slider{width:100%;height:8px;border-radius:4px;background:linear-gradient(90deg,#10b981,#f59e0b,#ef4444);outline:none;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}.elo-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:24px;height:24px;border-radius:50%;background:#fff;border:3px solid var(--color-primary, #818cf8);cursor:pointer;box-shadow:0 2px 8px #00000026;transition:transform .15s ease,box-shadow .15s ease}.elo-slider::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 4px 12px #818cf84d}.elo-slider::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:#fff;border:3px solid var(--color-primary, #818cf8);cursor:pointer;box-shadow:0 2px 8px #00000026}.elo-slider-labels{display:flex;justify-content:space-between;margin-top:.5rem;font-size:.75rem;color:#94a3b8;font-weight:500}.elo-presets{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.elo-presets-label{font-size:.75rem;color:var(--text-secondary);margin-right:.25rem}.elo-preset-btn{padding:.375rem .625rem;border:1px solid var(--border-light);border-radius:6px;background:var(--bg-card);cursor:pointer;font-size:.75rem;font-weight:600;color:var(--text-secondary);transition:all .15s ease}.elo-preset-btn:hover{border-color:var(--color-primary, #818cf8);color:var(--color-primary, #818cf8);background:#f0f4ff}.elo-preset-btn.active{border-color:var(--color-primary, #818cf8);background:var(--color-primary, #818cf8);color:#fff}.elo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.elo-option{padding:.625rem .5rem;border:2px solid var(--border-light);border-radius:10px;background:var(--bg-card);cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;gap:.25rem}.elo-option:hover{border-color:var(--color-primary, #818cf8);background:#f0f4ff}.elo-option.active{border-color:var(--color-primary, #818cf8);background:linear-gradient(135deg,#ede9fe,#ddd6fe)}.elo-value{font-weight:700;font-size:.85rem;color:var(--text-primary)}.elo-option.active .elo-value{color:var(--color-primary, #818cf8)}.elo-desc{font-size:.65rem;color:var(--text-secondary);text-align:center}.personality-selector{margin-top:1rem}.personality-selector .config-label{margin-bottom:.75rem}.personality-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.personality-option{padding:.875rem;border:2px solid var(--border-light);border-radius:12px;background:var(--bg-card);cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;gap:.375rem;text-align:center}.personality-option:hover{border-color:var(--color-primary, #818cf8);background:#f0f4ff;transform:translateY(-2px)}.personality-option.active{border-color:var(--color-primary, #818cf8);background:linear-gradient(135deg,#ede9fe,#ddd6fe);box-shadow:0 4px 12px #818cf840}.personality-emoji{font-size:1.5rem;line-height:1}.personality-name{font-weight:700;font-size:.9rem;color:var(--text-primary)}.personality-option.active .personality-name{color:var(--color-primary, #818cf8)}.personality-desc{font-size:.7rem;color:var(--text-secondary);line-height:1.3}.personality-option.active .personality-desc{color:#5b21b6}.config-footer{padding:1rem 1.5rem;border-top:1px solid #e2e8f0;display:flex;justify-content:flex-end}.config-footer .btn{min-width:100px}@media(max-width:600px){.config-page{width:95%;max-height:90vh}.config-option{flex-direction:column;align-items:flex-start;gap:.75rem}.slider-container{width:100%}.config-slider{flex:1}}.puzzle-panel{display:flex;flex-direction:column;gap:1rem;padding:1.25rem;background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-light);box-shadow:var(--shadow-md);transition:background .3s ease,border-color .3s ease}.puzzle-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:.75rem;border-bottom:1px solid var(--border-light)}.puzzle-header h3{margin:0;color:var(--text-primary);font-size:1.1rem;font-weight:600}.puzzle-score{display:flex;gap:1rem;font-size:.9rem;font-weight:600}.score-solved{color:var(--success-light)}.score-failed{color:var(--error-color)}.puzzle-info{background:var(--bg-light);border-radius:var(--radius-md);padding:1rem;border-left:4px solid var(--primary-color);transition:border-color .3s ease,background .3s ease}.puzzle-info.status-solved{border-left-color:var(--success-color)}.puzzle-info.status-failed{border-left-color:var(--error-color)}.puzzle-goal{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;margin-bottom:.75rem;background:var(--bg-light);border-radius:var(--radius-md);border:1px solid var(--border-light);box-shadow:var(--shadow-sm)}.goal-icon{font-size:1.5rem;line-height:1}.goal-text{font-size:1rem;font-weight:600;color:var(--text-primary);line-height:1.4}.puzzle-rating{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.rating-label{color:var(--text-secondary);font-size:.85rem}.rating-value{font-weight:700;color:var(--primary-color);font-size:1.15rem}.puzzle-themes{display:flex;flex-wrap:wrap;gap:.25rem;margin-bottom:.5rem}.theme-badge{background:var(--bg-light);color:var(--text-secondary);padding:.2rem .5rem;border-radius:var(--radius-sm);font-size:.7rem;font-weight:500;border:1px solid var(--border-light)}.puzzle-status{font-weight:600;margin-bottom:.25rem}.puzzle-status.status-solved{color:var(--success-color)}.puzzle-status.status-failed{color:var(--error-color)}.puzzle-status.status-playing{color:var(--primary-color)}.puzzle-hint{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;margin-top:.5rem;background:var(--bg-light);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.85rem;font-weight:500;border:1px solid var(--border-light)}.puzzle-controls{display:flex;flex-direction:column;gap:.75rem}.rating-range label,.theme-filter label{display:block;color:#888;font-size:.8rem;margin-bottom:.25rem}.rating-inputs{display:flex;align-items:center;gap:.5rem}.rating-inputs input{width:70px;padding:.4rem;background:var(--bg-light);border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.9rem;text-align:center}.rating-inputs input:focus{outline:none;border-color:var(--primary-color)}.rating-inputs span{color:var(--text-secondary);font-size:.85rem}.theme-filter select{width:100%;padding:.4rem;background:var(--bg-light);border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.9rem;cursor:pointer}.theme-filter select:focus{outline:none;border-color:var(--primary-color)}.puzzle-actions{display:flex;gap:.5rem}.puzzle-actions .btn-primary,.puzzle-actions .btn-secondary{flex:1;padding:.65rem 1rem;border:none;border-radius:10px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1)}.puzzle-actions .btn-primary{background:var(--primary-gradient);color:#fff;box-shadow:var(--shadow-sm)}.puzzle-actions .btn-primary:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-2px);box-shadow:var(--shadow-md)}.puzzle-actions .btn-primary:disabled{opacity:.6;cursor:not-allowed}.puzzle-actions .btn-secondary{background:var(--bg-light);color:var(--text-primary);border:1px solid var(--border-light)}.puzzle-actions .btn-secondary:hover{border-color:var(--primary-color);color:var(--primary-color)}.puzzle-actions .btn-primary:focus-visible,.puzzle-actions .btn-secondary:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.puzzle-error{background:var(--bg-light);color:var(--error-color);padding:.5rem;border-radius:var(--radius-sm);font-size:.85rem;text-align:center;border:1px solid var(--border-light)}.puzzle-stats{color:var(--text-muted);text-align:center;padding-top:.5rem;border-top:1px solid var(--border-light)}.puzzle-instructions{background:var(--bg-light);border-radius:var(--radius-md);padding:1rem 1.25rem;border:1px solid var(--border-light)}.puzzle-instructions h4{display:flex;align-items:center;gap:.5rem;color:var(--text-primary);margin:0 0 .75rem;font-size:.95rem;font-weight:600;padding-bottom:.5rem;border-bottom:1px solid var(--border-light)}.puzzle-instructions h4:before{content:"📖";font-size:1rem}.puzzle-instructions ol{margin:0;padding-left:0;list-style:none;counter-reset:instructions}.puzzle-instructions li{display:flex;align-items:flex-start;gap:.75rem;padding:.5rem 0;color:var(--text-primary);font-size:.9rem;line-height:1.4;border-bottom:1px solid var(--border-light);counter-increment:instructions}.puzzle-instructions li:last-child{border-bottom:none;padding-bottom:0}.puzzle-instructions li:before{content:counter(instructions);display:flex;align-items:center;justify-content:center;min-width:1.5rem;height:1.5rem;background:var(--primary-gradient);color:#fff;font-size:.75rem;font-weight:700;border-radius:50%;flex-shrink:0}.filters-toggle{display:flex;justify-content:space-between;align-items:center;width:100%;padding:.75rem 1rem;background:#6366f11a;border:1px solid var(--border-light);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease}.filters-toggle:hover{border-color:var(--primary-color);color:var(--primary-color)}.toggle-icon{font-size:.75rem;opacity:.7}.puzzle-filters{display:flex;flex-direction:column;gap:1rem;padding:1rem;background:var(--bg-light);border-radius:var(--radius-md);border:1px solid var(--border-light)}.filter-section{display:flex;flex-direction:column;gap:.5rem}.filter-section>label{color:var(--text-secondary);font-size:.8rem;font-weight:500}.filter-header{display:flex;justify-content:space-between;align-items:center}.filter-header label{color:var(--text-secondary);font-size:.8rem;font-weight:500}.difficulty-badge{font-size:.75rem;font-weight:700;padding:.2rem .5rem;border-radius:var(--radius-sm);background:var(--bg-light)}.difficulty-badge.difficulty-beginner{color:var(--success-color)}.difficulty-badge.difficulty-easy{color:var(--success-light)}.difficulty-badge.difficulty-medium{color:var(--warning-color)}.difficulty-badge.difficulty-hard{color:#f97316}.difficulty-badge.difficulty-expert{color:var(--error-color)}.difficulty-badge.difficulty-master{color:#dc2626}.rating-presets{display:flex;flex-wrap:wrap;gap:.35rem}.preset-btn{flex:1;min-width:70px;padding:.4rem .5rem;font-size:.7rem;font-weight:600;border:1px solid var(--border-light);border-radius:var(--radius-sm);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.preset-btn:hover{border-color:var(--primary-color);color:var(--primary-color)}.preset-btn.active{background:var(--primary-gradient);border-color:transparent;color:#fff}.preset-btn.preset-beginner.active{background:var(--success-color)}.preset-btn.preset-easy.active{background:var(--success-light)}.preset-btn.preset-medium.active{background:var(--warning-color)}.preset-btn.preset-hard.active{background:#f97316}.preset-btn.preset-expert.active{background:var(--error-color)}.preset-btn.preset-master.active{background:#dc2626}.rating-custom{display:flex;flex-direction:column;gap:.5rem}.rating-slider-container{position:relative;height:24px;display:flex;align-items:center}.rating-slider{position:absolute;width:100%;height:6px;background:transparent;-webkit-appearance:none;-moz-appearance:none;appearance:none;pointer-events:none}.rating-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--primary-color);cursor:pointer;pointer-events:all;border:2px solid #fff;box-shadow:var(--shadow-sm)}.rating-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--primary-color);cursor:pointer;pointer-events:all;border:2px solid #fff;box-shadow:var(--shadow-sm)}.rating-slider:first-child::-webkit-slider-runnable-track{background:linear-gradient(to right,#10b981,#22c55e 15%,#f59e0b,#f97316,#ef4444 75%,#dc2626);height:6px;border-radius:3px}.rating-slider:first-child::-moz-range-track{background:linear-gradient(to right,#10b981,#22c55e 15%,#f59e0b,#f97316,#ef4444 75%,#dc2626);height:6px;border-radius:3px}.rating-values{display:flex;align-items:center;justify-content:center;gap:.5rem}.rating-values input{width:65px;padding:.35rem .5rem;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.85rem;text-align:center}.rating-values input:focus{outline:none;border-color:var(--primary-color)}.rating-values span{color:var(--text-secondary);font-size:.8rem}.category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:.4rem}.category-btn{display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:.5rem .3rem;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.category-btn:hover{border-color:var(--primary-color);color:var(--primary-color);transform:translateY(-1px)}.category-btn.active{background:var(--primary-gradient);border-color:transparent;color:#fff}.cat-icon{font-size:1.1rem}.cat-label{font-size:.65rem;font-weight:500;text-align:center;line-height:1.2;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.theme-select{width:100%;padding:.5rem .75rem;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.85rem;cursor:pointer}.theme-select:focus{outline:none;border-color:var(--primary-color)}.active-filters{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem;padding-top:.5rem;border-top:1px solid var(--border-light)}.filters-label{color:var(--text-muted);font-size:.75rem}.filter-tag{display:inline-flex;align-items:center;gap:.3rem;padding:.25rem .5rem;background:var(--bg-light);border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.75rem}.filter-tag button{display:flex;align-items:center;justify-content:center;width:14px;height:14px;padding:0;background:var(--bg-card);border:none;border-radius:50%;color:var(--text-secondary);font-size:.7rem;cursor:pointer;transition:background .2s ease}.filter-tag button:hover{background:var(--primary-color);color:#fff}.openings-simple{display:flex;flex-direction:column;background:var(--bg-card);color:var(--text-primary);overflow:hidden;transition:background .3s ease}.openings-loading,.openings-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:200px;color:var(--text-secondary)}.openings-loading .spinner{font-size:3rem;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.openings-error button{margin-top:1rem;padding:.5rem 1rem;background:var(--primary-gradient);border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer;transition:all .2s ease}.openings-error button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #818cf84d}.openings-search{padding:1rem 1.25rem;border-bottom:1px solid var(--border-light)}.openings-search input{width:100%;padding:.75rem 1rem;background:var(--bg-light);border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.95rem;box-sizing:border-box;transition:all .2s ease}.openings-search input::placeholder{color:var(--text-muted)}.openings-search input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #818cf826}.openings-tabs{display:flex;flex-wrap:wrap;gap:.5rem;padding:1rem 1.25rem;border-bottom:1px solid var(--border-light)}.openings-tabs button{padding:.5rem 1rem;background:var(--bg-card);border:1px solid var(--border-light);border-radius:20px;color:var(--text-secondary);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;-webkit-user-select:none;user-select:none}.openings-tabs button:hover{border-color:var(--primary-color);color:var(--text-primary);transform:translateY(-1px)}.openings-tabs button.active{background:var(--primary-gradient);border-color:transparent;color:#fff;box-shadow:0 2px 8px #818cf84d}.openings-tabs button:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.openings-count{padding:.5rem 1.25rem;font-size:.8rem;color:var(--text-muted);border-bottom:1px solid var(--border-light)}.openings-list{flex:1;overflow-y:auto;padding:.75rem 1rem}.openings-empty{text-align:center;padding:3rem 1.5rem;color:var(--text-secondary)}.openings-empty button{margin-top:1rem;padding:.5rem 1rem;background:var(--primary-gradient);border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer;transition:all .2s ease}.openings-empty button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #818cf84d}.opening-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;margin-bottom:.5rem;background:var(--bg-light);border:1px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease;-webkit-user-select:none;user-select:none}.opening-item:hover{background:#818cf814;border-color:var(--primary-color);transform:translate(4px)}.opening-item:active{transform:scale(.98)}.opening-eco{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--primary-gradient);border-radius:var(--radius-sm);font-weight:700;font-size:.75rem;color:#fff;flex-shrink:0;box-shadow:0 2px 6px #818cf84d;transition:transform .15s ease,box-shadow .15s ease}.opening-item:hover .opening-eco{transform:scale(1.05);box-shadow:0 4px 12px #818cf866}.opening-info{flex:1;min-width:0}.openings-simple .opening-name{font-weight:600;font-size:.95rem;color:var(--text-primary);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .15s ease}.openings-simple .opening-item:hover .opening-name{color:var(--primary-color)}.opening-description{font-size:.8rem;color:var(--text-secondary);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-style:italic}.opening-meta{font-size:.75rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:SF Mono,Consolas,monospace;letter-spacing:.3px}.opening-arrow{color:var(--text-muted);font-size:1.25rem;transition:all .2s ease;opacity:0}.opening-item:hover .opening-arrow{color:var(--primary-color);opacity:1;transform:translate(4px)}.puzzle-info-panel{background:linear-gradient(145deg,#1e1e3f,#1a1a2e);border-radius:16px;padding:1rem;margin-bottom:.75rem;border:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:.75rem}.puzzle-info-panel.status-solved{border-color:#10b98166;background:linear-gradient(145deg,#1a2e1a,#1a1a2e)}.puzzle-info-panel.status-failed{border-color:#ef444466;background:linear-gradient(145deg,#2e1a1a,#1a1a2e)}.puzzle-header{display:flex;justify-content:space-between;align-items:center}.puzzle-title-section{display:flex;align-items:center;gap:.5rem}.puzzle-icon{font-size:1.25rem}.puzzle-title{font-size:1rem;font-weight:700;color:#fff}.puzzle-score{display:flex;align-items:center;gap:.5rem;background:#0000004d;padding:.35rem .6rem;border-radius:20px}.score-item{display:flex;align-items:center;gap:.25rem;font-weight:600;font-size:.85rem}.score-item.solved{color:#34d399}.score-item.failed{color:#f87171}.score-icon{font-size:.9rem}.score-divider{color:#ffffff4d;font-weight:300}.puzzle-status-banner{display:flex;align-items:center;gap:.5rem;padding:.6rem .75rem;border-radius:10px;background:#8b5cf626;border:1px solid rgba(139,92,246,.25)}.puzzle-status-banner.playing{background:#3b82f626;border-color:#3b82f640}.puzzle-status-banner.solved{background:#10b98126;border-color:#10b9814d}.puzzle-status-banner.failed{background:#ef444426;border-color:#ef44444d}.puzzle-status-banner.empty{background:#64748b26;border-color:#64748b40}.puzzle-status-banner.loading{background:#fbbf2426;border-color:#fbbf2440}.status-icon{font-size:1.1rem}.status-text{color:#e0e0e0;font-size:.9rem;font-weight:500}.puzzle-details{display:flex;flex-direction:column;gap:.5rem}.puzzle-rating{display:flex;align-items:center;gap:.5rem}.rating-icon{font-size:1rem}.rating-value{font-size:1.1rem;font-weight:700;color:#fbbf24}.difficulty-badge{padding:.2rem .5rem;border-radius:12px;font-size:.7rem;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.5px}.puzzle-themes{display:flex;flex-wrap:wrap;gap:.35rem}.theme-tag{display:inline-flex;align-items:center;gap:.3rem;background:#8b5cf626;color:#c4b5fd;padding:.25rem .5rem;border-radius:8px;font-size:.75rem;font-weight:500;border:1px solid rgba(139,92,246,.2)}.theme-icon{font-size:.85rem}.puzzle-progress{display:flex;flex-direction:column;gap:.35rem}.progress-label{display:flex;justify-content:space-between;font-size:.75rem;color:#fff9}.progress-count{font-weight:600;color:#c4b5fd}.progress-bar{height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#8b5cf6,#a78bfa);border-radius:3px;transition:width .3s ease}.puzzle-actions{display:flex;gap:.5rem;margin-top:.25rem}.puzzle-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.6rem 1rem;border:none;border-radius:10px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease}.puzzle-btn.primary{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;box-shadow:0 4px 12px #8b5cf64d}.puzzle-btn.primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #8b5cf666}.puzzle-btn.primary:disabled{opacity:.7;cursor:not-allowed;transform:none}.puzzle-btn.secondary{background:#ffffff1a;color:#e0e0e0;border:1px solid rgba(255,255,255,.15)}.puzzle-btn.secondary:hover{background:#ffffff26}.btn-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.puzzle-hint{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:linear-gradient(135deg,#fbbf2426,#f59e0b1a);border-radius:10px;border:1px solid rgba(251,191,36,.25);box-shadow:0 2px 8px #fbbf241a}.hint-icon{font-size:1.25rem;filter:drop-shadow(0 2px 4px rgba(251,191,36,.3))}.hint-text{color:#fef3c7;font-size:.9rem;font-weight:600;line-height:1.4;text-shadow:0 1px 2px rgba(0,0,0,.2)}@media(max-width:600px){.puzzle-panel{padding:.75rem}.puzzle-title{font-size:.9rem}.puzzle-status-banner{padding:.5rem}.status-text{font-size:.8rem}}.opening-info-bar{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;background:linear-gradient(135deg,#1e3a5f,#2d4a6f);border-bottom:2px solid #4a90d9;gap:.75rem;min-height:44px}.opening-info-bar.learning{background:linear-gradient(135deg,#1a4d1a,#2a5d2a);border-bottom-color:#4caf50}.opening-info-bar.empty{background:linear-gradient(135deg,#2a2a2a,#3a3a3a);border-bottom-color:#555}.opening-info-left{display:flex;align-items:center;gap:.5rem;flex:0 1 auto;min-width:0;max-width:200px}.opening-eco-badge{background:#4a90d9;color:#fff;padding:.15rem .4rem;border-radius:4px;font-size:.7rem;font-weight:700;font-family:Courier New,monospace;letter-spacing:.5px;flex-shrink:0}.opening-info-bar.learning .opening-eco-badge{background:#4caf50}.opening-name{font-size:.8rem;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.opening-title{font-size:.85rem;color:#aaa}.opening-learning-controls{display:flex;align-items:center;gap:.3rem;flex:1 1 auto;justify-content:center}.opening-ctrl-btn{background:#ffffff26;border:1px solid rgba(255,255,255,.2);color:#fff;width:32px;height:32px;border-radius:6px;cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.opening-ctrl-btn:hover:not(:disabled){background:#4caf5066;border-color:#4caf50;transform:scale(1.05)}.opening-ctrl-btn:disabled{opacity:.3;cursor:not-allowed}.opening-ctrl-btn:focus-visible{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}.opening-ctrl-btn.play-btn{background:#4caf504d;border-color:#4caf50;width:38px;height:38px;font-size:1rem}.opening-ctrl-btn.play-btn:hover:not(:disabled){background:#4caf5080}.opening-move-indicator{margin-left:.5rem;font-size:.85rem;font-weight:600;color:#fff;font-family:Courier New,monospace;white-space:nowrap}.opening-move-count{margin-left:.3rem;font-size:.7rem;color:#fff9;font-weight:400}.opening-info-center{display:flex;align-items:center;gap:.4rem;flex-shrink:0}.opening-category-tag{background:#4a90d94d;color:#8cc4ff;padding:.15rem .5rem;border-radius:10px;font-size:.7rem;font-weight:500}.opening-info-bar.learning .opening-category-tag{background:#4caf504d;color:#a5d6a7}.opening-tag{background:#ffffff1a;color:#ccc;padding:.1rem .4rem;border-radius:8px;font-size:.65rem;text-transform:capitalize}.opening-info-right{display:flex;align-items:center;gap:.3rem;flex-shrink:0}.opening-btn-library,.opening-btn-clear{background:#ffffff1a;border:none;color:#ccc;padding:.25rem .5rem;border-radius:4px;cursor:pointer;font-size:.8rem;transition:all .15s ease}.opening-btn-library:hover{background:#4a90d94d;color:#fff}.opening-btn-clear:hover{background:#fff3;color:#fff}.opening-info-bar.empty .opening-btn-library{background:#4a90d9;color:#fff;padding:.3rem .6rem}.opening-info-bar.empty .opening-btn-library:hover{background:#5aa0e9}@media(max-width:900px){.opening-info-bar{flex-wrap:wrap;gap:.5rem}.opening-info-left{max-width:150px}.opening-learning-controls{order:3;flex-basis:100%;padding-top:.3rem}}@media(max-width:600px){.opening-info-bar{padding:.4rem .5rem}.opening-name{font-size:.7rem;max-width:100px}.opening-ctrl-btn{width:28px;height:28px;font-size:.8rem}.opening-ctrl-btn.play-btn{width:32px;height:32px}.opening-category-tag{display:none}}.move-popularity{background:var(--bg-secondary, #1e1e2e);border-radius:8px;padding:12px;margin:8px 0;font-size:14px}.move-popularity.compact{background:transparent;padding:4px 0;margin:0;display:flex;align-items:center;flex-wrap:wrap;gap:4px;font-size:12px}.popularity-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.popularity-title{font-weight:600;color:var(--text-primary, #e0e0e0)}.popularity-meta{font-size:12px;color:var(--text-secondary, #888)}.popularity-moves{display:flex;flex-direction:column;gap:8px}.popularity-move-item{cursor:pointer;padding:6px 8px;border-radius:6px;transition:background-color .15s ease}.popularity-move-item:hover{background:var(--bg-hover, rgba(255, 255, 255, .05))}.move-row{display:flex;align-items:center;gap:10px}.move-san-large{font-family:var(--font-mono, monospace);font-weight:600;font-size:15px;color:var(--text-primary, #e0e0e0);min-width:40px}.move-bar-container{flex:1;height:8px;background:var(--bg-tertiary, rgba(255, 255, 255, .1));border-radius:4px;overflow:hidden}.move-bar{height:100%;border-radius:4px;transition:width .3s ease;width:var(--bar-width, 0%);background-color:var(--bar-color, #22c55e)}.move-stats{font-size:12px;color:var(--text-secondary, #888);min-width:100px;text-align:right}.win-rates{display:flex;gap:12px;margin-top:4px;padding-left:50px;font-size:11px}.win-rate{display:flex;align-items:center;gap:2px}.win-rate.white{color:var(--color-white-win, #f0f0f0)}.win-rate.draw{color:var(--color-draw, #888)}.win-rate.black{color:var(--color-black-win, #4a4a4a)}.popularity-label{color:var(--text-secondary, #888);font-size:11px}.popularity-move.compact{display:inline-flex;align-items:center;gap:4px;cursor:pointer;padding:2px 6px;border-radius:4px;transition:background-color .15s ease}.popularity-move.compact:hover{background:var(--bg-hover, rgba(255, 255, 255, .1))}.popularity-move.compact .move-san{font-family:var(--font-mono, monospace);font-weight:600;color:var(--text-primary, #e0e0e0)}.popularity-move.compact .move-percent{font-size:11px;font-weight:500;color:var(--popularity-color, inherit)}.popularity-move.compact .separator{color:var(--text-tertiary, #555);margin:0 2px}.popularity-opening{display:flex;align-items:center;gap:8px;margin-top:10px;padding-top:10px;border-top:1px solid var(--border-color, rgba(255, 255, 255, .1))}.opening-eco{background:var(--accent-primary, #6366f1);color:#fff;padding:2px 6px;border-radius:4px;font-size:11px;font-weight:600}.opening-name{font-size:12px;color:var(--text-secondary, #aaa)}.popularity-loading,.popularity-error,.popularity-empty{font-size:12px;color:var(--text-tertiary, #666);font-style:italic}.popularity-error{color:var(--color-warning, #f59e0b)}.correax-logo-container{display:flex;align-items:center;gap:8px}.correax-logo-text{font-weight:600;color:#0078d4;font-family:Segoe UI,Inter,system-ui,sans-serif}.correax-logo-text-sm{font-size:14px}.correax-logo-text-md{font-size:16px}.correax-logo-text-lg{font-size:20px}.correax-logo-text-xl{font-size:24px}.site-footer{width:100%;background:#0f172ae6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid rgba(255,255,255,.1);padding:1rem 1.5rem}.footer-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:1.5rem;flex-wrap:wrap}.site-footer-full .footer-content{justify-content:space-between}.site-footer-full .footer-brand-section{display:flex;align-items:center;gap:1rem}.footer-brand{display:flex;align-items:center;text-decoration:none;transition:opacity .2s ease}.footer-brand:hover{opacity:.8}.footer-tagline{color:#fff9;font-size:.875rem;margin:0;font-style:italic}.footer-nav{display:flex;align-items:center;gap:.75rem}.footer-nav a{color:#ffffffb3;text-decoration:none;font-size:.875rem;transition:color .2s ease}.footer-nav a:hover{color:#0078d4}.nav-separator{color:#ffffff4d}.footer-copyright{color:#ffffff80;font-size:.75rem}.site-footer-minimal .footer-content{justify-content:center;gap:1rem}@media(max-width:640px){.site-footer-full .footer-content{flex-direction:column;text-align:center;gap:1rem}.site-footer-full .footer-brand-section{flex-direction:column;gap:.5rem}}.splash-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;display:flex;flex-direction:column;background:var(--gradient-bg);overflow:hidden;transition:opacity .5s ease}.splash-screen:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--gradient-mesh);pointer-events:none}.splash-screen.fade-out{opacity:0;pointer-events:none}.splash-main{flex:1;display:flex;align-items:center;justify-content:center;position:relative}.splash-bg{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none;z-index:0}.floating-piece{position:absolute;width:3rem;height:3rem;opacity:.1;animation:float 25s ease-in-out infinite;filter:drop-shadow(0 0 12px rgba(139,92,246,.3)) drop-shadow(0 0 24px rgba(139,92,246,.12)) brightness(1.15) saturate(.4)}.piece-1{top:10%;left:8%;animation-delay:0s;width:3.5rem;height:3.5rem}.piece-2{top:25%;right:12%;animation-delay:-4s;width:3rem;height:3rem}.piece-3{bottom:30%;left:12%;animation-delay:-8s;width:2.5rem;height:2.5rem}.piece-4{top:60%;right:8%;animation-delay:-12s;width:3rem;height:3rem}.piece-5{bottom:15%;left:20%;animation-delay:-16s;width:2.5rem;height:2.5rem}.piece-6{bottom:20%;right:20%;animation-delay:-20s;width:2rem;height:2rem}@keyframes float{0%,to{transform:translateY(0) rotate(0);opacity:.08}50%{transform:translateY(-20px) rotate(5deg);opacity:.12}}.splash-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:2rem;padding:2rem;animation:fadeInUp .8s ease-out;max-width:500px;text-align:center}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.splash-logo{display:flex;flex-direction:column;align-items:center}.logo-icon{width:280px;height:280px;display:flex;align-items:center;justify-content:center;animation:gentlePulse 4s ease-in-out infinite}.logo-alex-img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 10px 40px rgba(139,92,246,.25))}@keyframes gentlePulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.splash-text{display:flex;flex-direction:column;align-items:center;gap:.5rem}.splash-title{font-size:2.75rem;font-weight:800;letter-spacing:-.02em;margin:0;line-height:1.2}.title-alex{background:linear-gradient(135deg,#fcd34d,#f59e0b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.title-chess{color:#fff}.splash-tagline{font-size:1.1rem;color:#c4b5fd80;margin:0;font-weight:400;letter-spacing:.01em}.splash-auth{display:flex;flex-direction:column;align-items:center;gap:1.5rem;margin-top:1rem}.splash-login{display:flex;flex-direction:column;align-items:center;gap:1rem}.splash-signin-btn{display:flex;align-items:center;gap:.75rem;padding:.9rem 2rem;font-size:1rem;font-weight:600;color:#fff;background:var(--gradient-primary);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-normal);box-shadow:var(--shadow-primary)}.splash-signin-btn:hover:not(:disabled){transform:translateY(-3px);box-shadow:var(--shadow-primary-hover),var(--glow-primary)}.splash-signin-btn:active:not(:disabled){transform:translateY(-1px)}.splash-signin-btn:disabled{opacity:.7;cursor:not-allowed}.microsoft-icon{width:20px;height:20px}.signin-hint{font-size:.85rem;color:#c4b5fd59;margin:0}.splash-welcome{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem 2rem;background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-lg);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow)}.welcome-message{font-size:1.25rem;color:#fff;margin:0}.welcome-message strong{color:var(--color-primary)}.welcome-subtitle{font-size:.95rem;color:#c4b5fd73;margin:0}.splash-signout-btn{padding:.5rem 1rem;font-size:.8rem;font-weight:500;color:#c4b5fd99;background:transparent;border:1px solid rgba(139,92,246,.15);border-radius:8px;cursor:pointer;transition:all .2s ease;margin-top:.5rem}.splash-signout-btn:hover{color:#fff;background:#ff646433;border-color:#ff646466}.splash-auth-error{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1rem 1.5rem;background:#f4433614;border:1px solid rgba(244,67,54,.2);border-radius:var(--radius-md);max-width:350px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.splash-auth-error .error-text{font-size:.9rem;color:#ff8a80;text-align:center;line-height:1.4}.splash-auth-error .error-retry-btn{padding:.5rem 1.25rem;font-size:.85rem;font-weight:600;color:#fff;background:#818cf8cc;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.splash-auth-error .error-retry-btn:hover{background:#818cf8}.splash-version{font-size:.75rem;color:#8b5cf640;margin-top:1rem}@media(max-width:600px){.splash-content{padding:1.5rem;gap:1.5rem}.logo-icon{width:200px;height:200px}.splash-title{font-size:2rem}.splash-tagline{font-size:1rem}.splash-signin-btn{padding:.8rem 1.5rem;font-size:.95rem}}.game-manager-modal{background:var(--bg-primary, #0f0f1a);border-radius:12px;width:90%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080;border:1px solid var(--border-color, #2a2a3e)}.game-manager-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-color, #2a2a3e)}.game-manager-header h2{margin:0;font-size:1.25rem;color:var(--text-primary, #e0e0e0)}.game-manager-tabs{display:flex;border-bottom:1px solid var(--border-color, #2a2a3e);padding:0 16px}.tab-btn{background:none;border:none;padding:12px 16px;color:var(--text-secondary, #a0a0a0);cursor:pointer;font-size:14px;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .2s,border-color .2s}.tab-btn:hover{color:var(--text-primary, #e0e0e0)}.tab-btn.active{color:var(--accent-color, #8b5cf6);border-bottom-color:var(--accent-color, #8b5cf6)}.game-manager-content{padding:20px;overflow-y:auto;flex:1}.tab-content{display:flex;flex-direction:column;gap:16px}.tab-description{color:var(--text-secondary, #a0a0a0);margin:0;font-size:14px}.save-form{display:flex;gap:12px}.save-form input{flex:1;padding:10px 14px;background:var(--bg-secondary, #1a1a2e);border:1px solid var(--border-color, #2a2a3e);border-radius:8px;color:var(--text-primary, #e0e0e0);font-size:14px}.save-form input:focus{outline:none;border-color:var(--accent-color, #8b5cf6)}.primary-btn{padding:10px 20px;background:var(--accent-color, #8b5cf6);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s,transform .1s}.primary-btn:hover:not(:disabled){background:var(--accent-hover, #7c3aed)}.primary-btn:active:not(:disabled){transform:scale(.98)}.primary-btn:disabled{opacity:.5;cursor:not-allowed}.secondary-btn{padding:10px 20px;background:var(--bg-secondary, #1a1a2e);color:var(--text-primary, #e0e0e0);border:1px solid var(--border-color, #2a2a3e);border-radius:8px;cursor:pointer;font-size:14px;transition:background-color .2s,border-color .2s}.secondary-btn:hover:not(:disabled){background:var(--bg-tertiary, #252540);border-color:var(--text-secondary, #a0a0a0)}.secondary-btn:disabled{opacity:.5;cursor:not-allowed}.current-game-preview,.export-preview{background:var(--bg-secondary, #1a1a2e);border-radius:8px;padding:12px;border:1px solid var(--border-color, #2a2a3e)}.current-game-preview h4,.export-preview h4{margin:0 0 8px;font-size:13px;color:var(--text-secondary, #a0a0a0)}.current-game-preview pre,.export-preview pre{margin:0;font-family:Fira Code,Monaco,monospace;font-size:12px;color:var(--text-primary, #e0e0e0);white-space:pre-wrap;word-break:break-word;max-height:150px;overflow-y:auto}.saved-games-list{display:flex;flex-direction:column;gap:8px}.saved-game-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background:var(--bg-secondary, #1a1a2e);border-radius:8px;border:1px solid var(--border-color, #2a2a3e)}.saved-game-info{display:flex;flex-direction:column;gap:4px}.saved-game-name{font-weight:500;color:var(--text-primary, #e0e0e0)}.saved-game-meta{font-size:12px;color:var(--text-secondary, #a0a0a0)}.saved-game-actions{display:flex;gap:8px}.load-btn{padding:6px 16px;background:var(--accent-color, #8b5cf6);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:13px;transition:background-color .2s}.load-btn:hover{background:var(--accent-hover, #7c3aed)}.delete-btn{padding:6px 10px;background:transparent;color:var(--text-secondary, #a0a0a0);border:1px solid var(--border-color, #2a2a3e);border-radius:6px;cursor:pointer;font-size:13px;transition:background-color .2s,color .2s,border-color .2s}.delete-btn:hover{background:#ef44441a;color:#ef4444;border-color:#ef4444}.import-options{display:flex;gap:12px}.file-input-hidden{display:none}textarea{width:100%;padding:12px;background:var(--bg-secondary, #1a1a2e);border:1px solid var(--border-color, #2a2a3e);border-radius:8px;color:var(--text-primary, #e0e0e0);font-family:Fira Code,Monaco,monospace;font-size:12px;resize:vertical;min-height:120px}textarea:focus{outline:none;border-color:var(--accent-color, #8b5cf6)}.export-actions{display:flex;gap:12px}.error-message{padding:10px 14px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#ef4444;font-size:14px}.success-message{padding:10px 14px;background:#22c55e1a;border:1px solid rgba(34,197,94,.3);border-radius:8px;color:#22c55e;font-size:14px}.hint{font-size:13px;color:var(--text-secondary, #a0a0a0);font-style:italic;margin:0}.empty-state{text-align:center;padding:40px 20px;color:var(--text-secondary, #a0a0a0)}[data-theme=light] .game-manager-modal{background:var(--bg-primary, #ffffff)}[data-theme=light] .tab-btn{color:var(--text-secondary, #666)}[data-theme=light] .tab-btn.active{color:var(--accent-color, #7c3aed)}[data-theme=light] .save-form input,[data-theme=light] textarea,[data-theme=light] .current-game-preview,[data-theme=light] .export-preview,[data-theme=light] .saved-game-item{background:var(--bg-secondary, #f5f5f5)}@media(max-width:600px){.game-manager-modal{width:95%;max-height:90vh}.game-manager-tabs{padding:0 8px}.tab-btn{padding:10px 12px;font-size:13px}.save-form,.export-actions{flex-direction:column}}.auth-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:authFadeIn .2s ease-out}@keyframes authFadeIn{0%{opacity:0}to{opacity:1}}.auth-modal{background:linear-gradient(145deg,#1e1e2e,#2a2a3e);border-radius:20px;padding:2rem;width:100%;max-width:420px;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 25px 50px -12px #00000080,0 0 0 1px #ffffff1a;animation:authSlideUp .3s ease-out}@keyframes authSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.auth-modal-close{position:absolute;top:1rem;right:1rem;width:32px;height:32px;border:none;border-radius:8px;background:#ffffff1a;color:#94a3b8;font-size:1rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.auth-modal-close:hover{background:#ffffff26;color:#fff}.auth-modal-header{text-align:center;margin-bottom:1.5rem}.auth-logo{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:1rem}.auth-logo-icon{font-size:2rem;filter:drop-shadow(0 2px 4px rgba(129,140,248,.3))}.auth-logo-text{font-size:1.5rem;font-weight:700;background:var(--gradient-primary, linear-gradient(135deg, #818cf8, #6366f1));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-modal-header h2{font-size:1.5rem;font-weight:700;color:#fff;margin:0 0 .5rem}.auth-subtitle{color:#94a3b8;font-size:.9rem;margin:0}.auth-message{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-radius:10px;margin-bottom:1rem;font-size:.85rem;font-weight:500}.auth-message-icon{flex-shrink:0}.auth-error{background:#ef444426;border:1px solid rgba(239,68,68,.3);color:#fca5a5}.auth-success{background:#22c55e26;border:1px solid rgba(34,197,94,.3);color:#86efac}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-field{display:flex;flex-direction:column;gap:.4rem}.auth-field label{font-size:.85rem;font-weight:600;color:#cbd5e1}.auth-field input{width:100%;padding:.75rem 1rem;border:2px solid rgba(255,255,255,.1);border-radius:10px;background:#0003;color:#fff;font-size:.95rem;transition:all .2s ease;outline:none}.auth-field input::placeholder{color:#64748b}.auth-field input:focus{border-color:var(--color-primary, #818cf8);background:#0000004d;box-shadow:0 0 0 3px #818cf833}.auth-field input:disabled{opacity:.6;cursor:not-allowed}.auth-field-error{font-size:.75rem;color:#fca5a5}.auth-password-wrapper{position:relative;display:flex;align-items:center}.auth-password-wrapper input{padding-right:2.5rem}.auth-password-toggle{position:absolute;right:.75rem;background:none;border:none;font-size:1rem;cursor:pointer;padding:.25rem;opacity:.7;transition:opacity .2s}.auth-password-toggle:hover{opacity:1}.auth-password-requirements{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.25rem}.auth-password-requirements span{font-size:.7rem;padding:.2rem .5rem;border-radius:4px;background:#ffffff1a;color:#64748b;transition:all .2s ease}.auth-password-requirements span.met{background:#22c55e33;color:#86efac}.auth-submit{width:100%;padding:.85rem 1.5rem;border:none;border-radius:10px;background:var(--gradient-primary, linear-gradient(135deg, #818cf8, #6366f1));color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:.5rem}.auth-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #818cf866}.auth-submit:active:not(:disabled){transform:translateY(0)}.auth-submit:disabled{opacity:.7;cursor:not-allowed}.auth-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:authSpin .8s linear infinite}@keyframes authSpin{to{transform:rotate(360deg)}}.auth-forgot-link{align-self:flex-end;background:none;border:none;color:var(--color-primary, #818cf8);font-size:.85rem;cursor:pointer;padding:0;margin-top:-.5rem}.auth-forgot-link:hover{text-decoration:underline}.auth-back-link{background:none;border:none;color:#94a3b8;font-size:.9rem;cursor:pointer;padding:.5rem;margin-top:.5rem;transition:color .2s}.auth-back-link:hover{color:#fff}.auth-divider{display:flex;align-items:center;gap:1rem;margin:1.5rem 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#ffffff1a}.auth-divider span{color:#64748b;font-size:.8rem;white-space:nowrap}.auth-social{display:flex;gap:.75rem}.auth-social-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.7rem .5rem;border:1px solid rgba(255,255,255,.15);border-radius:10px;background:#ffffff0d;color:#cbd5e1;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s ease}.auth-social-btn:hover:not(:disabled){background:#ffffff1a;border-color:#ffffff40}.auth-social-btn:disabled{opacity:.5;cursor:not-allowed}.auth-social-btn svg{flex-shrink:0}.auth-switch{text-align:center;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.1);color:#94a3b8;font-size:.9rem}.auth-switch button{background:none;border:none;color:var(--color-primary, #818cf8);font-weight:600;cursor:pointer;padding:0;margin-left:.25rem}.auth-switch button:hover{text-decoration:underline}.auth-terms{font-size:.75rem;color:#64748b;text-align:center;line-height:1.5}.auth-terms a{color:var(--color-primary, #818cf8);text-decoration:none}.auth-terms a:hover{text-decoration:underline}.auth-modal-modern{max-width:400px;text-align:center}.auth-providers{display:flex;flex-direction:column;gap:.75rem;margin:1.5rem 0}.auth-provider-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.9rem 1.5rem;border:1px solid rgba(255,255,255,.15);border-radius:12px;background:#ffffff0d;color:#fff;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease}.auth-provider-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #00000040}.auth-provider-btn:active:not(:disabled){transform:translateY(0)}.auth-provider-btn:disabled{opacity:.6;cursor:not-allowed}.auth-provider-icon{flex-shrink:0}.auth-provider-microsoft{background:linear-gradient(135deg,#2f2f2f,#1a1a1a);border-color:#ffffff1a}.auth-provider-microsoft:hover:not(:disabled){background:linear-gradient(135deg,#3a3a3a,#252525);border-color:#fff3}.auth-provider-google{background:#fff;color:#3c4043;border-color:#dadce0}.auth-provider-google:hover:not(:disabled){background:#f8f9fa;border-color:#c6c6c6}.auth-provider-github{background:linear-gradient(135deg,#24292e,#1a1c1f);border-color:#ffffff1a}.auth-provider-github:hover:not(:disabled){background:linear-gradient(135deg,#2f363d,#24292e);border-color:#fff3}.auth-provider-apple{background:#000;border-color:#ffffff1a}.auth-provider-apple:hover:not(:disabled){background:#1a1a1a;border-color:#fff3}.auth-provider-note{margin-top:.75rem;font-size:.85rem;color:#fff9;text-align:center;font-style:italic}.auth-microsoft-section{margin:2rem 0}.auth-microsoft-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem 1.5rem;border:none;border-radius:12px;background:linear-gradient(135deg,#2f2f2f,#1a1a1a);color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #0000004d,inset 0 1px #ffffff1a}.auth-microsoft-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #0006,inset 0 1px #ffffff26;background:linear-gradient(135deg,#3a3a3a,#252525)}.auth-microsoft-btn:active:not(:disabled){transform:translateY(0)}.auth-microsoft-btn:disabled{opacity:.6;cursor:not-allowed}.auth-microsoft-icon{flex-shrink:0}.auth-microsoft-hint{margin-top:.75rem;font-size:.8rem;color:#64748b}.auth-benefits{background:#0003;border-radius:12px;padding:1.25rem;margin:1.5rem 0;text-align:left}.auth-benefits h3{font-size:.85rem;font-weight:600;color:#94a3b8;margin:0 0 .75rem;text-transform:uppercase;letter-spacing:.5px}.auth-benefits ul{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.auth-benefits li{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:#cbd5e1}.auth-benefit-icon{font-size:1rem}.auth-modal-modern .auth-terms{margin-top:1rem;font-size:.75rem;color:#64748b}.auth-modal-modern .auth-terms a{color:#818cf8;text-decoration:none}.auth-modal-modern .auth-terms a:hover{text-decoration:underline}@media(max-width:480px){.auth-modal{padding:1.5rem;border-radius:16px}.auth-modal-header h2{font-size:1.3rem}.auth-logo-icon{font-size:1.75rem}.auth-logo-text{font-size:1.3rem}.auth-social{flex-direction:column}.auth-social-btn{padding:.8rem}.auth-benefits ul{grid-template-columns:1fr}}.user-menu{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:.625rem;padding:.375rem .875rem .375rem .5rem;border:1px solid rgba(255,255,255,.1);border-radius:12px;background:#ffffff14;color:#fff;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.user-menu-trigger:hover{background:#ffffff1f;border-color:#fff3}.user-menu-trigger:focus-visible{outline:2px solid rgba(129,140,248,.5);outline-offset:2px}.user-menu-trigger .username{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-chevron{font-size:.625rem;opacity:.7;transition:transform .2s ease;margin-left:.25rem}.user-menu-trigger[aria-expanded=true] .user-menu-chevron{transform:rotate(180deg)}.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--gradient-primary, linear-gradient(135deg, #818cf8, #6366f1));display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#fff;letter-spacing:-.02em;position:relative;flex-shrink:0;box-shadow:0 2px 8px #818cf84d,inset 0 1px #fff3}.user-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.user-avatar:after{content:"";position:absolute;bottom:0;right:0;width:10px;height:10px;background:#10b981;border:2px solid rgba(26,26,46,.9);border-radius:50%;box-shadow:0 1px 3px #0000004d}.user-menu-header .user-avatar{width:44px;height:44px;font-size:1rem}.user-menu-header .user-avatar:after{width:12px;height:12px;border-width:2.5px}.user-menu-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:240px;background:#1e1e2ef2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:.5rem;box-shadow:0 16px 48px #0006,0 0 0 1px #ffffff0d;animation:userMenuSlideIn .2s ease-out;z-index:1001;overflow:hidden}@keyframes userMenuSlideIn{0%{opacity:0;transform:translateY(-8px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.user-menu-header{display:flex;align-items:center;gap:.875rem;padding:.875rem;background:#ffffff08;border-radius:12px;margin-bottom:.5rem}.user-menu-info{display:flex;flex-direction:column;min-width:0;flex:1}.user-menu-name{font-weight:600;color:#fff;font-size:.95rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.3}.user-menu-email{font-size:.75rem;color:#ffffff80;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:2px}.user-menu-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem .875rem;border:none;border-radius:10px;background:transparent;color:#ffffffd9;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease;text-align:left;position:relative}.user-menu-item:hover{background:#ffffff14;color:#fff;transform:translate(2px)}.user-menu-item:focus-visible{outline:none;background:#818cf826;box-shadow:inset 0 0 0 1px #818cf84d}.user-menu-item:active{transform:translate(2px) scale(.98)}.user-menu-item-icon{font-size:1.1rem;width:1.5rem;text-align:center;flex-shrink:0}.user-menu-item:after{content:"›";position:absolute;right:.75rem;opacity:0;transform:translate(-4px);transition:all .15s ease;font-size:1.1rem;font-weight:300}.user-menu-item:hover:after{opacity:.5;transform:translate(0)}.user-menu-item.danger{color:#fca5a5}.user-menu-item.danger:hover{background:#ef44441f;color:#fca5a5}.user-menu-item.danger:focus-visible{background:#ef444426;box-shadow:inset 0 0 0 1px #ef44444d}.user-menu-item.danger:after{content:none}.user-menu-divider{height:1px;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.1) 20%,rgba(255,255,255,.1) 80%,transparent 100%);margin:.5rem 0}.sign-in-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:none;border-radius:10px;background:var(--gradient-primary, linear-gradient(135deg, #818cf8, #6366f1));color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #818cf84d}.sign-in-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #818cf866}.sign-in-btn:active{transform:translateY(0)}@media(max-width:600px){.user-menu-trigger .username{display:none}.user-menu-trigger{padding:.375rem}.user-menu-chevron{display:none}.user-menu-dropdown{min-width:220px;right:-.5rem}}.profile-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem;animation:fadeIn .2s ease-out}.profile-modal{background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;width:100%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 25px 50px #00000080;border:1px solid rgba(255,255,255,.1);animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.profile-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.profile-modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:#fff}.profile-modal-close{background:none;border:none;color:#fff9;font-size:1.75rem;cursor:pointer;padding:0;line-height:1;transition:color .2s}.profile-modal-close:hover{color:#fff}.profile-tabs{display:flex;gap:.25rem;padding:.75rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.profile-tab{padding:.625rem 1rem;background:transparent;border:none;color:#fff9;font-size:.9rem;font-weight:500;cursor:pointer;border-radius:8px;transition:all .2s}.profile-tab:hover{background:#ffffff0d;color:#fff}.profile-tab.active{background:#818cf833;color:var(--color-primary, #818cf8)}.profile-modal-content{flex:1;overflow-y:auto;padding:1.5rem}.profile-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;gap:1rem;color:#fff9}.profile-loading .spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--color-primary, #818cf8);border-radius:50%;animation:spin 1s linear infinite}.profile-message{padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem}.profile-message.error{background:#ef444433;color:#fca5a5;border:1px solid rgba(239,68,68,.3)}.profile-message.success{background:#22c55e33;color:#86efac;border:1px solid rgba(34,197,94,.3)}.profile-section{display:flex;flex-direction:column;gap:1.25rem}.profile-form-group{display:flex;flex-direction:column;gap:.5rem}.profile-form-group label{font-size:.875rem;font-weight:500;color:#fffc}.profile-form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media(max-width:480px){.profile-form-row{grid-template-columns:1fr}}.profile-input,.profile-select,.profile-textarea{padding:.75rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.15);border-radius:8px;color:#fff;font-size:.9rem;transition:all .2s}.profile-input:focus,.profile-select:focus,.profile-textarea:focus{outline:none;border-color:var(--color-primary, #818cf8);background:#818cf81a}.profile-input::placeholder,.profile-textarea::placeholder{color:#ffffff4d}.profile-input.disabled{opacity:.5;cursor:not-allowed}.profile-select{cursor:pointer}.profile-select option{background:#1a1a2e;color:#fff}.profile-textarea{resize:vertical;min-height:80px}.profile-hint{font-size:.75rem;color:#fff6}.avatar-preview-section{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.1)}.avatar-preview{width:100px;height:100px;border-radius:50%;overflow:hidden;background:var(--gradient-primary, linear-gradient(135deg, #818cf8, #6366f1));display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #818cf84d}.avatar-preview img{width:100%;height:100%;object-fit:cover}.avatar-preview .avatar-initials{font-size:2.5rem;font-weight:600;color:#fff}.avatar-selection{display:flex;flex-direction:column;gap:.75rem}.avatar-selection label{font-size:.875rem;font-weight:500;color:#fffc}.avatar-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:.5rem}@media(max-width:480px){.avatar-grid{grid-template-columns:repeat(4,1fr)}}.avatar-option{aspect-ratio:1;padding:.25rem;background:#ffffff0d;border:2px solid transparent;border-radius:12px;cursor:pointer;transition:all .2s}.avatar-option img{width:100%;height:100%;border-radius:8px}.avatar-option:hover{background:#ffffff1a;border-color:#fff3;transform:scale(1.05)}.avatar-option.selected{border-color:var(--color-primary, #818cf8);background:#818cf833}.avatar-clear-btn{padding:.625rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.15);border-radius:8px;color:#ffffffb3;font-size:.875rem;cursor:pointer;transition:all .2s}.avatar-clear-btn:hover{background:#ffffff1a;color:#fff}.profile-modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1.25rem 1.5rem;border-top:1px solid rgba(255,255,255,.1)}.profile-btn{padding:.75rem 1.5rem;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.profile-btn.secondary{background:transparent;border:1px solid rgba(255,255,255,.2);color:#fffc}.profile-btn.secondary:hover{background:#ffffff0d;border-color:#ffffff4d;color:#fff}.profile-btn.primary{background:var(--gradient-primary, linear-gradient(135deg, #818cf8, #6366f1));border:none;color:#fff}.profile-btn.primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #818cf866}.profile-btn.primary:disabled{opacity:.5;cursor:not-allowed}.toast-container{position:fixed;bottom:20px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:10px;max-width:400px;pointer-events:none}.toast{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:8px;background:var(--bg-secondary, #1a1a2e);color:var(--text-primary, #e0e0e0);box-shadow:0 4px 12px #0000004d;pointer-events:auto;min-width:280px;font-size:14px;border-left:4px solid}.toast-enter{animation:toast-slide-in .3s ease-out forwards}.toast-exit{animation:toast-slide-out .3s ease-in forwards}@keyframes toast-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes toast-slide-out{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}.toast-success{border-left-color:#22c55e;background:linear-gradient(135deg,#22c55e26,#22c55e0d)}.toast-success .toast-icon{color:#22c55e}.toast-error{border-left-color:#ef4444;background:linear-gradient(135deg,#ef444426,#ef44440d)}.toast-error .toast-icon{color:#ef4444}.toast-info{border-left-color:#3b82f6;background:linear-gradient(135deg,#3b82f626,#3b82f60d)}.toast-info .toast-icon{color:#3b82f6}.toast-warning{border-left-color:#f59e0b;background:linear-gradient(135deg,#f59e0b26,#f59e0b0d)}.toast-warning .toast-icon{color:#f59e0b}.toast-icon{font-size:18px;font-weight:700;flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#ffffff1a}.toast-message{flex:1;line-height:1.4}.toast-close{background:none;border:none;color:var(--text-secondary, #a0a0a0);cursor:pointer;font-size:20px;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s,color .2s;flex-shrink:0}.toast-close:hover{background:#ffffff1a;color:var(--text-primary, #e0e0e0)}[data-theme=light] .toast{background:var(--bg-secondary, #f5f5f5);color:var(--text-primary, #1a1a1a);box-shadow:0 4px 12px #00000026}[data-theme=light] .toast-success{background:linear-gradient(135deg,#22c55e1a,#22c55e08)}[data-theme=light] .toast-error{background:linear-gradient(135deg,#ef44441a,#ef444408)}[data-theme=light] .toast-info{background:linear-gradient(135deg,#3b82f61a,#3b82f608)}[data-theme=light] .toast-warning{background:linear-gradient(135deg,#f59e0b1a,#f59e0b08)}[data-theme=light] .toast-close:hover{background:#0000000d}@media(max-width:480px){.toast-container{top:20px;bottom:auto;left:20px;right:20px;max-width:none}.toast{min-width:auto}@keyframes toast-slide-in{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes toast-slide-out{0%{transform:translateY(0);opacity:1}to{transform:translateY(-100%);opacity:0}}}.toolbar{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1.25rem;background:#0806188c;-webkit-backdrop-filter:blur(24px) saturate(1.2);backdrop-filter:blur(24px) saturate(1.2);border-bottom:1px solid rgba(139,92,246,.1);flex-shrink:0;position:relative;z-index:100;box-shadow:0 1px #ffffff08,0 4px 30px #0003}.mode-tabs{display:flex;gap:2px;background:#0000004d;padding:3px;border-radius:var(--radius-md);border:1px solid rgba(139,92,246,.06)}.mode-tab:hover{background:#8b5cf614;color:var(--color-text-primary)}.mode-tab.active{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-primary),inset 0 1px #ffffff26}.mode-tab:active{transform:scale(.95);background:#8b5cf62e;color:var(--color-text-primary)}.mode-tab.active:active{transform:scale(.95);background:linear-gradient(135deg,#6366f1,#6d28d9);box-shadow:inset 0 2px 4px #0000004d}.toolbar-btn:active{transform:scale(.98)}.toolbar-action-btn:active:not(:disabled){transform:scale(.98)}.sign-in-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:none;border-radius:var(--radius-sm);background:var(--gradient-primary);color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:all var(--transition-normal);box-shadow:var(--shadow-primary)}.sign-in-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-primary-hover)}.sign-in-btn:focus-visible{outline:2px solid rgba(129,140,248,.5);outline-offset:2px}.sign-in-btn:active:not(:disabled){transform:translateY(0)}.sign-in-btn:disabled{opacity:.7;cursor:not-allowed}.sign-in-btn-icon{font-size:1rem}@media(max-width:600px){.sign-in-btn{padding:.5rem .75rem}.sign-in-btn span:not(.sign-in-btn-icon){display:none}}.app-bg .floating-piece{position:absolute;font-size:4rem;opacity:.06;animation:float 20s ease-in-out infinite;color:#fff}.app-bg .piece-1{top:10%;left:5%;animation-delay:0s;font-size:5rem}.app-bg .piece-2{top:20%;right:10%;animation-delay:-3s;font-size:4rem}.app-bg .piece-3{bottom:30%;left:15%;animation-delay:-5s;font-size:3.5rem}.app-bg .piece-4{top:60%;right:5%;animation-delay:-8s;font-size:4.5rem}.app-bg .piece-5{bottom:15%;left:5%;animation-delay:-2s;font-size:3rem}.app-bg .piece-6{top:40%;left:8%;animation-delay:-10s;font-size:2.5rem}.app-bg .piece-7{bottom:25%;right:15%;animation-delay:-7s;font-size:5rem}.app-bg .piece-8{top:5%;right:25%;animation-delay:-4s;font-size:3rem}.app-bg .piece-9{top:75%;left:25%;animation-delay:-12s;font-size:3.5rem}.app-bg .piece-10{top:15%;left:40%;animation-delay:-6s;font-size:2.5rem}.app-bg .piece-11{bottom:10%;right:30%;animation-delay:-9s;font-size:4rem}.app-bg .piece-12{top:50%;right:20%;animation-delay:-14s;font-size:2rem}.app-bg .piece-13{bottom:40%;left:35%;animation-delay:-11s;font-size:3rem}.app-bg .piece-14{top:30%;right:35%;animation-delay:-16s;font-size:4.5rem}.app-bg .piece-15{bottom:5%;left:45%;animation-delay:-13s;font-size:3.5rem}.app-bg .piece-16{top:85%;right:8%;animation-delay:-18s;font-size:2.5rem}.main-container{display:flex;justify-content:center;align-items:flex-start;gap:1.5rem;padding:1rem;flex:1;overflow:hidden;position:relative;z-index:1}.chat-column{display:flex;flex-direction:column;width:360px;min-width:300px;max-width:400px;height:calc(100vh - 80px);background:var(--glass-bg-panel);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--glass-border);box-shadow:var(--glass-shadow)}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.board-wrapper{position:relative;border-radius:var(--radius-lg);box-shadow:0 8px 32px #0006,0 0 0 1px var(--glass-border)}.board-ctrl-btn{padding:.5rem .75rem;border:1px solid var(--glass-border);border-radius:var(--radius-sm);background:var(--glass-bg);color:var(--color-text-secondary);font-size:.8rem;font-weight:500;cursor:pointer;transition:all var(--transition-normal);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.board-ctrl-btn:hover:not(:disabled){background:var(--glass-bg-hover);color:var(--color-text-primary);transform:translateY(-1px)}.board-ctrl-btn.primary:hover{box-shadow:var(--shadow-primary)}.moves-strip{display:flex;flex-wrap:wrap;gap:.25rem;max-width:480px;max-height:200px;overflow-y:auto;padding:.5rem;background:#00000040;border-radius:var(--radius-sm);border:1px solid var(--glass-border)}.move-chip{padding:.2rem .4rem;background:var(--glass-bg);border-radius:var(--radius-xs);font-size:.75rem;color:var(--color-text-secondary);font-family:SF Mono,Monaco,monospace;cursor:pointer;transition:all .15s ease;-webkit-user-select:none;user-select:none}.move-chip:hover{background:var(--glass-bg-hover);color:var(--color-text-primary);transform:translateY(-1px)}.move-chip.latest{background:#818cf866;color:#fff;font-weight:600}.game-status{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--glass-bg-panel);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-sm);color:#fff;font-weight:600;border:1px solid var(--glass-border)}.game-status.checkmate{background:linear-gradient(135deg,#f59e0b,#d97706)}.game-status.draw{background:#fff3}.computer-thinking{display:flex;align-items:center;gap:.5rem;padding:.4rem .8rem;background:#8b5cf626;border:1px solid rgba(139,92,246,.2);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:.85rem}.computer-thinking .thinking-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.header{display:none}.left-column::-webkit-scrollbar-thumb{background:#818cf84d;border-radius:10px}.controls-section::-webkit-scrollbar-thumb{background:#818cf84d;border-radius:3px}.moves-compact .move-item.latest{background:var(--gradient-primary, linear-gradient(135deg, #818cf8, #6366f1));color:#fff;border-color:transparent;font-weight:600;animation:pulse-subtle 2s ease-in-out infinite}.openings-btn:active{transform:translateY(0);box-shadow:0 2px 8px #10b9814d}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-close-btn:active{transform:scale(.95)}.openings-modal .openings-list{flex:1;max-height:none;width:100%;height:400px;max-height:400px;overflow-y:scroll}.controls-modal .controls-section h2{display:none}.puzzle-modal{background:var(--bg-card, #1e293b);border-radius:20px;width:90%;max-width:640px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-lg),0 0 0 1px #ffffff1a;animation:modalSlideUp .3s cubic-bezier(.4,0,.2,1);transition:background .3s ease}.setup-modal{background:var(--bg-card, #1e293b);border-radius:20px;width:90%;max-width:640px;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-lg),0 0 0 1px #ffffff1a;animation:modalSlideUp .3s cubic-bezier(.4,0,.2,1);transition:background .3s ease}@media(max-width:1024px){.container{grid-template-columns:1fr}.board-wrapper{max-width:500px;margin:0 auto}.app{padding:1rem;max-height:none;overflow:auto}.container{grid-template-columns:1fr;height:auto;max-height:none;gap:1rem}.controls-section{max-height:none;order:1}.board-section{order:0;justify-self:center}.board-wrapper{max-width:480px}.analysis-section{max-height:none;overflow-y:visible;order:2}.header h1{font-size:2rem}.mode-selector{flex-direction:row}.action-buttons{flex-direction:row;flex-wrap:wrap}.action-buttons .btn{flex:1;min-width:80px}}@media(max-width:768px){.app{padding:0;overflow-y:auto;overflow-x:hidden;max-height:none}.toolbar{padding:.4rem .5rem;flex-wrap:wrap;gap:.25rem}.toolbar-left{gap:.25rem}.app-logo{width:28px;height:28px}.app-title{font-size:.95rem;display:none}.toolbar-btn{width:36px;height:36px;font-size:1rem;padding:0}.toolbar-btn .btn-icon{font-size:1rem}.toolbar-btn .btn-label{display:none}.toolbar-divider{height:20px;margin:0 .15rem}.toolbar-select{font-size:.7rem;padding:.3rem .4rem;max-width:100px}.color-toggle .color-btn{width:28px;height:28px;font-size:.95rem}.container{display:flex;flex-direction:column;height:auto;max-height:none;padding:.5rem;gap:.75rem}.board-section{order:0;width:100%;display:flex;justify-content:center;align-items:center;padding:0}.board-wrapper{width:100%;max-width:calc(100vw - 1rem);aspect-ratio:1}.board-container{width:100%;height:100%}.controls-section{order:1;width:100%;max-height:none;padding:.75rem}.mode-selector{display:flex;flex-wrap:nowrap;overflow-x:auto;gap:.25rem;padding:.25rem;scrollbar-width:none}.mode-selector::-webkit-scrollbar{display:none}.mode-btn{flex:0 0 auto;padding:.4rem .6rem;font-size:.7rem;white-space:nowrap}.mode-btn .mode-icon{font-size:.9rem}.action-buttons{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.action-buttons .btn{padding:.6rem .5rem;font-size:.75rem;min-height:44px}.analysis-section{order:2;width:100%;max-height:none;overflow:visible;padding:.75rem}.chat-section{max-height:300px}.chat-messages{max-height:200px}.chat-input-container{flex-direction:column;gap:.5rem}.chat-input-container input{width:100%}.chat-input-container button{width:100%;min-height:44px}.move-history{display:flex;flex-wrap:wrap;gap:.25rem;max-height:120px;overflow-y:auto}.move-item{padding:.3rem .5rem;font-size:.75rem;min-height:32px}.opening-info{padding:.5rem;font-size:.8rem}.puzzle-info-card{padding:.75rem}.puzzle-info-card h3{font-size:.9rem}.analysis-card{padding:.75rem}.analysis-card h3{font-size:.85rem}.dual-analysis-panel{flex-direction:column;gap:.75rem}.dual-analysis-panel .engine-column{width:100%}.modal-overlay{padding:.5rem}.modal-content{max-width:100%;max-height:90vh;border-radius:var(--radius-lg)}.modal-header h2{font-size:1.1rem}.modal-body{padding:1rem}.config-page,.config-section{padding:.75rem}.config-section h3{font-size:.9rem}.skill-selector{gap:.3rem}.skill-btn{padding:.4rem .6rem;font-size:.7rem;min-height:40px}.app-bg .floating-piece{display:none}.openings-panel{max-height:300px}.opening-item{padding:.5rem}.opening-item .opening-name{font-size:.8rem}.news-modal,.news-item{padding:.75rem}.news-item h3{font-size:.9rem}.help-page,.help-section{padding:.75rem}.elo-badge{font-size:.7rem;padding:.2rem .4rem}.coaching-results{padding:.75rem}.coaching-tip{padding:.5rem;font-size:.8rem}}@media(max-width:480px){.toolbar{padding:.3rem}.toolbar-left{flex:1;min-width:0}.toolbar-right{flex-wrap:wrap;justify-content:flex-end}.toolbar-btn{width:32px;height:32px}.container{padding:.25rem;gap:.5rem}.board-wrapper{max-width:calc(100vw - .5rem)}.controls-section,.analysis-section{padding:.5rem;border-radius:var(--radius-md)}.mode-btn{padding:.35rem .5rem;font-size:.65rem}.action-buttons .btn{padding:.5rem;font-size:.7rem}.chat-messages{max-height:150px}.move-history{max-height:100px}.modal-content{border-radius:var(--radius-md)}.modal-header,.modal-body{padding:.75rem}}:root{--color-primary: #818cf8;--color-primary-light: #a5b4fc;--color-primary-dark: #6366f1;--color-accent: #c084fc;--color-accent-warm: #f0abfc;--color-bg-dark-1: #050411;--color-bg-dark-2: #0a0820;--color-bg-dark-3: #0f0c2e;--color-bg-surface: rgba(255, 255, 255, .025);--color-bg-surface-hover: rgba(255, 255, 255, .05);--color-text-primary: rgba(237, 233, 254, .95);--color-text-secondary: rgba(196, 181, 253, .65);--color-text-muted: rgba(167, 139, 250, .42);--color-success: #6ee7b7;--color-success-dark: #34d399;--color-warning: #fcd34d;--color-warning-dark: #fbbf24;--color-danger: #fca5a5;--color-danger-dark: #f87171;--color-info: #93c5fd;--color-info-dark: #60a5fa;--bg-secondary: rgba(255, 255, 255, .06);--bg-hover: rgba(255, 255, 255, .1);--border-color: rgba(139, 92, 246, .2);--text-primary: rgba(237, 233, 254, .95);--text-secondary: rgba(196, 181, 253, .65);--glass-bg: rgba(255, 255, 255, .05);--glass-bg-hover: rgba(255, 255, 255, .09);--glass-bg-strong: rgba(255, 255, 255, .12);--glass-bg-panel: rgba(8, 6, 24, .72);--glass-border: rgba(139, 92, 246, .12);--glass-border-hover: rgba(139, 92, 246, .22);--glass-blur: blur(24px);--glass-blur-strong: blur(48px);--glass-shadow: 0 8px 32px rgba(0, 0, 0, .35), inset 0 1px 0 rgba(255, 255, 255, .04);--glass-shadow-lg: 0 16px 48px rgba(0, 0, 0, .45), inset 0 1px 0 rgba(255, 255, 255, .06);--glass-shadow-glow: 0 8px 32px rgba(0, 0, 0, .35), 0 0 80px rgba(129, 140, 248, .05);--gradient-primary: linear-gradient(135deg, #818cf8 0%, #7c3aed 100%);--gradient-bg: linear-gradient(160deg, #050411 0%, #0a0820 45%, #0f0c2e 100%);--gradient-bg-dark: linear-gradient(135deg, #030210 0%, #050411 100%);--gradient-mesh: radial-gradient(ellipse at 15% 50%, rgba(99, 102, 241, .07) 0%, transparent 55%), radial-gradient(ellipse at 85% 25%, rgba(192, 132, 252, .04) 0%, transparent 45%), radial-gradient(ellipse at 50% 85%, rgba(129, 140, 248, .03) 0%, transparent 50%);--gradient-success: linear-gradient(135deg, #34d399 0%, #10b981 100%);--gradient-warning: linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%);--gradient-danger: linear-gradient(135deg, #f87171 0%, #ef4444 100%);--gradient-info: linear-gradient(135deg, #60a5fa 0%, #3b82f6 100%);--gradient-gold: linear-gradient(135deg, #fcd34d 0%, #fbbf24 100%);--gradient-cyan: linear-gradient(135deg, #67e8f9 0%, #22d3ee 100%);--gradient-violet: linear-gradient(135deg, #c084fc 0%, #a855f7 100%);--radius-xs: 6px;--radius-sm: 10px;--radius-md: 14px;--radius-lg: 18px;--radius-xl: 24px;--radius-full: 50%;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .08);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .15);--shadow-md: 0 4px 16px rgba(0, 0, 0, .2);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .25);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .3);--shadow-primary: 0 4px 20px rgba(129, 140, 248, .2);--shadow-primary-hover: 0 8px 30px rgba(129, 140, 248, .3);--shadow-success: 0 4px 16px rgba(110, 231, 183, .2);--shadow-danger: 0 4px 16px rgba(252, 165, 165, .2);--glow-primary: 0 0 40px rgba(129, 140, 248, .1);--glow-success: 0 0 30px rgba(110, 231, 183, .1);--glow-accent: 0 0 30px rgba(192, 132, 252, .08);--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono", "SF Mono", Monaco, Consolas, monospace;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--transition-bounce: .4s cubic-bezier(.34, 1.56, .64, 1);--z-dropdown: 100;--z-sticky: 200;--z-modal-backdrop: 300;--z-modal: 400;--z-popover: 500;--z-tooltip: 600;--z-toast: 700;--toolbar-height: 64px;--toolbar-bg: var(--glass-bg);--chat-bubble-bg: var(--glass-bg);--chat-input-bg: rgba(255, 255, 255, .06);--board-light-square: #f0d9b5;--board-dark-square: #b58863;--board-highlight: rgba(255, 255, 0, .4);--card-bg: var(--glass-bg);--card-border: var(--glass-border)}[data-theme=light]{--color-bg-dark-1: #f0f0f8;--color-bg-dark-2: #e8e8f4;--color-bg-dark-3: #ffffff;--color-bg-surface: rgba(0, 0, 0, .03);--color-bg-surface-hover: rgba(0, 0, 0, .06);--color-text-primary: rgba(0, 0, 0, .9);--color-text-secondary: rgba(0, 0, 0, .65);--color-text-muted: rgba(0, 0, 0, .45);--bg-secondary: rgba(0, 0, 0, .04);--bg-hover: rgba(0, 0, 0, .08);--border-color: rgba(0, 0, 0, .12);--text-primary: rgba(0, 0, 0, .9);--text-secondary: rgba(0, 0, 0, .6);--gradient-bg: linear-gradient(135deg, #f0f0f8 0%, #e8e8f4 50%, #ffffff 100%);--glass-bg: rgba(255, 255, 255, .5);--glass-bg-hover: rgba(255, 255, 255, .65);--glass-bg-strong: rgba(255, 255, 255, .7);--glass-bg-panel: rgba(255, 255, 255, .5);--glass-border: rgba(0, 0, 0, .08);--glass-border-hover: rgba(0, 0, 0, .15);--glass-shadow: 0 8px 32px rgba(0, 0, 0, .08), inset 0 1px 0 rgba(255, 255, 255, .8);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .05);--shadow-md: 0 4px 16px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .1);--toolbar-bg: var(--glass-bg);--chat-bubble-bg: rgba(0, 0, 0, .03);--chat-input-bg: rgba(0, 0, 0, .05);--card-bg: var(--glass-bg);--card-border: var(--glass-border)}.app-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--gradient-bg)}.app-loading .loading-content{display:flex;flex-direction:column;align-items:center;gap:1rem;color:#fffc}.app-loading .loading-spinner{width:48px;height:48px;border:3px solid rgba(255,255,255,.1);border-top-color:#0078d4;border-radius:50%;animation:spin 1s linear infinite}.app{min-height:100vh;max-height:100vh;padding:0;overflow:hidden;display:flex;flex-direction:column;animation:fadeIn .4s ease-out;background:var(--gradient-bg);position:relative}.app:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--gradient-mesh);pointer-events:none;z-index:0}.app-bg{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none;z-index:0}.app-bg .floating-piece{position:absolute;width:4rem;height:4rem;opacity:.1;animation:float 25s ease-in-out infinite;filter:drop-shadow(0 0 16px rgba(129,140,248,.6)) drop-shadow(0 0 32px rgba(129,140,248,.3)) brightness(1.3) saturate(.5)}.app-bg .piece-1{top:10%;left:5%;animation-delay:0s;width:5rem;height:5rem}.app-bg .piece-2{top:20%;right:10%;animation-delay:-3s;width:4rem;height:4rem}.app-bg .piece-3{bottom:30%;left:15%;animation-delay:-5s;width:3.5rem;height:3.5rem}.app-bg .piece-4{top:60%;right:5%;animation-delay:-8s;width:4.5rem;height:4.5rem}.app-bg .piece-5{bottom:15%;left:5%;animation-delay:-2s;width:3rem;height:3rem}.app-bg .piece-6{top:40%;left:8%;animation-delay:-10s;width:2.5rem;height:2.5rem}.app-bg .piece-7{bottom:25%;right:15%;animation-delay:-7s;width:5rem;height:5rem}.app-bg .piece-8{top:5%;right:25%;animation-delay:-4s;width:3rem;height:3rem}.app-bg .piece-9{top:75%;left:25%;animation-delay:-12s;width:3.5rem;height:3.5rem}.app-bg .piece-10{top:15%;left:40%;animation-delay:-6s;width:2.5rem;height:2.5rem}.app-bg .piece-11{bottom:10%;right:30%;animation-delay:-9s;width:4rem;height:4rem}.app-bg .piece-12{top:50%;right:20%;animation-delay:-14s;width:2rem;height:2rem}.app-bg .piece-13{bottom:40%;left:35%;animation-delay:-11s;width:3rem;height:3rem}.app-bg .piece-14{top:30%;right:35%;animation-delay:-16s;width:4.5rem;height:4.5rem}.app-bg .piece-15{bottom:5%;left:45%;animation-delay:-13s;width:3.5rem;height:3.5rem}.app-bg .piece-16{top:85%;right:8%;animation-delay:-18s;width:2.5rem;height:2.5rem}@keyframes float{0%,to{transform:translateY(0) rotate(0) scale(1);opacity:.06}25%{transform:translateY(-35px) rotate(5deg) scale(1.02);opacity:.1}50%{transform:translateY(-18px) rotate(-3deg) scale(.98);opacity:.06}75%{transform:translateY(-28px) rotate(3deg) scale(1.01);opacity:.08}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.toolbar{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1.25rem;background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-bottom:1px solid var(--glass-border);flex-shrink:0;position:relative;z-index:100;box-shadow:0 4px 24px #00000026,inset 0 1px #ffffff0d}.toolbar-left{display:flex;align-items:center;gap:.5rem}.app-logo{flex-shrink:0;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.app-title{font-size:1.2rem;font-weight:700;color:var(--color-text-primary);margin:0;letter-spacing:-.02em;text-shadow:0 1px 8px rgba(0,0,0,.2)}.toolbar-center{display:flex;align-items:center}.mode-tabs{display:flex;gap:.25rem;background:#00000040;padding:4px;border-radius:var(--radius-md);border:1px solid rgba(255,255,255,.06)}.mode-tab{padding:.5rem 1.125rem;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--color-text-secondary);font-size:.85rem;font-weight:600;cursor:pointer;transition:all var(--transition-normal);letter-spacing:-.01em}.mode-tab:hover{background:#ffffff1a;color:#fff}.mode-tab.active{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-primary)}.mode-tab:focus-visible{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}.toolbar-right{display:flex;align-items:center;gap:.5rem}.toolbar-btn{width:40px;height:40px;border:none;border-radius:var(--radius-sm);background:var(--glass-bg);color:var(--color-text-secondary);font-size:1.1rem;cursor:pointer;transition:all var(--transition-normal);display:flex;align-items:center;justify-content:center;border:1px solid transparent}.toolbar-btn:hover{background:var(--glass-bg-hover);color:var(--color-text-primary);border-color:var(--glass-border);transform:translateY(-1px);box-shadow:var(--glass-shadow)}.toolbar-btn:focus-visible{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}.toolbar-btn:active{transform:scale(.95);background:#8b5cf61f;border-color:var(--glass-border)}.toolbar-play-controls{display:flex;align-items:center;gap:.5rem;margin-left:.75rem}.toolbar-divider{width:1px;height:24px;background:#fff3;margin:0 .25rem}.color-toggle{display:flex;background:#0003;border-radius:8px;padding:.15rem}.color-toggle .color-btn{width:32px;height:32px;border:none;border-radius:6px;background:transparent;font-size:1.1rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.color-toggle .color-btn:hover{background:#ffffff1a}.color-toggle .color-btn.active{background:#fff;box-shadow:0 2px 6px #00000026}.toolbar-select{padding:.4rem .6rem;border:none;border-radius:8px;background:#0003;color:#fff;font-size:.8rem;font-weight:500;cursor:pointer;outline:none}.toolbar-select:hover{background:#0000004d}.toolbar-select option{background:#1a1a2e;color:#fff}.toolbar-action-btn{height:36px;padding:0 14px;border:1px solid var(--glass-border);border-radius:var(--radius-sm);background:var(--glass-bg);color:var(--color-text-secondary);font-size:.85rem;font-weight:600;cursor:pointer;transition:all var(--transition-normal);display:flex;align-items:center;justify-content:center;gap:6px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.toolbar-action-btn .btn-icon{font-size:1rem}.toolbar-action-btn .btn-label{font-size:.8rem}.toolbar-action-btn:hover:not(:disabled){background:var(--gradient-primary);color:#fff;border-color:transparent;box-shadow:var(--shadow-primary);transform:translateY(-1px)}.toolbar-action-btn:focus-visible{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}.toolbar-action-btn:active:not(:disabled){transform:scale(.95);background:var(--gradient-primary);color:#fff;box-shadow:inset 0 2px 4px #0000004d}.toolbar-action-btn:disabled{opacity:.5;cursor:not-allowed}.btn-spinner-small{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.main-container{display:flex;justify-content:center;gap:1.25rem;padding:1rem 1.5rem;flex:1;min-height:0;overflow:hidden;position:relative;z-index:1}.board-column{display:flex;flex-direction:column;align-items:center;gap:.75rem;flex-shrink:0}.board-wrapper{position:relative;border-radius:var(--radius-md);box-shadow:0 2px 4px #0000004d,0 12px 40px #00000080,0 0 0 1px #8b5cf614}.board-controls{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}.board-ctrl-btn{padding:.5rem .85rem;border:1px solid var(--glass-border);border-radius:var(--radius-sm);background:var(--glass-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:var(--color-text-secondary);font-size:.8rem;font-weight:500;cursor:pointer;transition:all var(--transition-normal)}.board-ctrl-btn:hover:not(:disabled){background:var(--glass-bg-hover);border-color:var(--glass-border-hover);color:var(--color-text-primary);transform:translateY(-1px)}.board-ctrl-btn:active:not(:disabled){transform:translateY(0);background:#8b5cf626;border-color:var(--glass-border-hover);color:var(--color-text-primary)}.board-ctrl-btn:disabled{opacity:.5;cursor:not-allowed}.board-ctrl-btn.primary{background:var(--gradient-primary);border-color:transparent;color:#fff}.board-ctrl-btn.primary:hover{box-shadow:var(--shadow-primary);transform:translateY(-1px)}.board-ctrl-btn.primary:active{transform:translateY(0);box-shadow:inset 0 2px 4px #0000004d}.board-ctrl-btn:focus-visible{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}.moves-strip{display:flex;flex-wrap:wrap;gap:.25rem;max-width:480px;max-height:200px;overflow-y:auto;padding:.5rem;background:var(--glass-bg);border-radius:var(--radius-sm);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.move-chip{padding:.2rem .5rem;background:var(--glass-bg);border-radius:var(--radius-xs);font-size:.75rem;color:var(--color-text-secondary);font-family:var(--font-mono);cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none;border:1px solid transparent}.move-chip:hover{background:#ffffff40;color:#fff;transform:translateY(-1px)}.move-chip:active{transform:translateY(0)}.move-chip.latest{background:#818cf840;color:#fff;font-weight:600;border-color:#8b5cf64d;box-shadow:0 0 8px #8b5cf626}.move-chip.future{opacity:.4;background:#ffffff0d}.move-chip.future:hover{opacity:.7}.move-chip .move-num{color:#ffffff80;margin-right:.15rem}.chat-column{display:flex;flex-direction:column;background:var(--glass-bg-panel);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-lg);box-shadow:var(--glass-shadow);border:1px solid var(--glass-border);overflow:hidden;min-height:0;max-height:100%;width:100%;max-width:600px;flex-shrink:1}.openings-panel-inline{max-height:300px;overflow-y:auto;border-bottom:1px solid var(--border-light)}.openings-modal{background:var(--glass-bg-panel);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);width:90%;max-width:600px;max-height:80vh;overflow:hidden;box-shadow:var(--glass-shadow-lg);border:1px solid var(--glass-border);animation:modalSlideIn .3s ease-out;display:flex;flex-direction:column}.openings-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--glass-border);background:var(--gradient-success);color:#fff}.openings-modal-header h2{font-size:1.1rem;font-weight:600;margin:0}.openings-modal .openings-simple{height:auto;max-height:none}.openings-modal .openings-list{height:400px;max-height:400px;overflow-y:scroll}.controls-modal{background:var(--glass-bg-panel);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);width:90%;max-width:400px;max-height:85vh;overflow-y:auto;box-shadow:var(--glass-shadow-lg);border:1px solid var(--glass-border);animation:modalSlideIn .3s ease-out}.controls-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--glass-border);background:var(--gradient-primary);color:#fff;border-radius:var(--radius-xl) var(--radius-xl) 0 0}.controls-modal-header h2{font-size:1.1rem;font-weight:600;margin:0}.controls-modal .controls-section{padding:1rem}.controls-modal .controls-section h2,.header{display:none}.left-column::-webkit-scrollbar{width:5px}.left-column::-webkit-scrollbar-track{background:transparent}.left-column::-webkit-scrollbar-thumb{background:#818cf866;border-radius:10px}.controls-section{background:var(--glass-bg-panel);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-lg);padding:1.25rem;box-shadow:var(--glass-shadow);border:1px solid var(--glass-border);height:fit-content;animation:slideInLeft .5s ease-out}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.controls-section::-webkit-scrollbar{width:5px}.controls-section::-webkit-scrollbar-thumb{background:#818cf866;border-radius:3px}.controls-section h2{font-size:1rem;color:var(--color-text-primary);margin:0 0 1.15rem;padding-bottom:.7rem;border-bottom:1px solid var(--glass-border);font-weight:700;display:flex;align-items:center;gap:.5rem}.control-group{margin-bottom:1.25rem;padding-bottom:1.25rem;border-bottom:1px solid var(--glass-border)}.control-group:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.control-group.coach-display,.control-group.opponent-display{border-radius:14px;border:none!important;border-bottom:none!important;padding:0 1rem!important;height:88px;box-sizing:border-box;display:flex!important;align-items:center!important;justify-content:flex-start;margin-bottom:1.25rem}.coach-display{background:linear-gradient(145deg,#7c3aed,#6d28d9)}.coach-display .coach-header,.opponent-display .opponent-header{display:flex;align-items:center;gap:.75rem;margin-bottom:0;padding-bottom:0;border-bottom:none}.coach-info,.opponent-info{display:flex;flex-direction:column;gap:.15rem}.coach-name,.opponent-name{color:#fff;font-weight:700;font-size:.95rem}.coach-status{color:#e9d5ff;font-size:.75rem;font-weight:500}.opponent-display{background:linear-gradient(145deg,#0d9488,#0f766e)}.opponent-level{color:#99f6e4;font-size:.75rem;font-weight:500}.control-group>label{display:block;font-size:.7rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.action-buttons{display:flex;flex-direction:column;gap:.5rem}.action-buttons .btn{width:100%;padding:.7rem .75rem;font-size:.8rem;display:flex;align-items:center;justify-content:center;gap:.4rem}.action-row{display:flex;gap:.5rem}.action-row .btn{flex:1}.btn-toggle{width:100%;padding:.55rem .75rem;border:1px solid var(--glass-border);border-radius:10px;background:var(--glass-bg);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);color:var(--color-text-secondary);position:relative;overflow:hidden;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.btn-toggle:hover{border-color:var(--color-primary);background:var(--glass-bg-hover);color:var(--color-text-primary);transform:translateY(-1px)}.btn-toggle.active{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-color:transparent;box-shadow:0 4px 12px #10b98159;transform:translateY(-1px)}.moves-compact{display:flex;flex-wrap:wrap;gap:.3rem;max-height:120px;overflow-y:auto;padding:.5rem;background:var(--glass-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:10px;font-family:SF Mono,Consolas,monospace;font-size:.72rem;border:1px solid var(--glass-border)}.moves-compact .move-item{padding:.2rem .4rem;background:var(--glass-bg);border-radius:5px;border:1px solid var(--glass-border);color:var(--color-text-secondary);transition:all .2s ease}.moves-compact .move-item:hover{background:var(--glass-bg-hover);border-color:var(--glass-border-hover);color:var(--color-text-primary)}.moves-compact .move-item.latest{background:var(--gradient-primary);color:#fff;border-color:transparent;font-weight:600;animation:pulse-subtle 2s ease-in-out infinite}@keyframes pulse-subtle{0%,to{box-shadow:0 0 #818cf866}50%{box-shadow:0 0 0 4px #818cf800}}.moves-compact .move-num{color:var(--color-text-muted);margin-right:3px;font-weight:500}.moves-compact .move-item.latest .move-num{color:#fffc}.moves-section label{display:flex;align-items:center;gap:.35rem}.openings-btn{width:100%;padding:14px 18px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:14px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 14px #10b98159;margin-top:1rem;display:flex;align-items:center;justify-content:center;gap:.5rem}.openings-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #10b98173;background:linear-gradient(135deg,#34d399,#10b981)}.openings-btn:active{transform:translateY(0);background:linear-gradient(135deg,#059669,#047857);box-shadow:inset 0 2px 4px #0000004d}.openings-inline-panel{margin-top:.75rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:14px;border:1px solid rgba(0,0,0,.08);max-height:400px;overflow-y:auto;box-shadow:inset 0 1px 3px #0000000d}.openings-inline-panel .openings-panel{background:transparent;box-shadow:none;padding:.5rem}.openings-inline-panel .openings-header{display:none}.openings-inline-panel .openings-filters{padding:.5rem;gap:.5rem}.openings-inline-panel .opening-card{padding:.6rem .75rem;margin-bottom:.4rem}.openings-inline-panel .opening-name{font-size:.8rem}.openings-inline-panel .opening-eco{font-size:.65rem;padding:.15rem .35rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#060414b3;-webkit-backdrop-filter:var(--glass-blur-strong);backdrop-filter:var(--glass-blur-strong);display:flex;align-items:center;justify-content:center;z-index:1000;animation:modalFadeIn .25s ease-out}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.openings-modal{background:var(--glass-bg-panel);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);width:90%;max-width:640px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--glass-shadow-lg);border:1px solid var(--glass-border);animation:modalSlideUp .3s cubic-bezier(.4,0,.2,1);transition:background var(--transition-slow)}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(30px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.openings-modal-header{display:flex;justify-content:space-between;align-items:center;padding:18px 24px;background:linear-gradient(135deg,#10b981,#059669);color:#fff}.openings-modal-header h2{margin:0;font-size:1.2rem;font-weight:700;display:flex;align-items:center;gap:.5rem;text-shadow:0 1px 3px rgba(0,0,0,.2)}.modal-close-btn{background:var(--glass-bg);border:1px solid var(--glass-border);color:#fff;width:34px;height:34px;border-radius:var(--radius-sm);font-size:1.4rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-normal);line-height:1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.modal-close-btn:hover{background:var(--glass-bg-hover);border-color:var(--glass-border-hover);transform:scale(1.05)}.modal-close-btn:focus-visible{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}.modal-close-btn:active{transform:scale(.92);background:#8b5cf626}.openings-modal .openings-panel{flex:1;overflow:hidden;display:flex;flex-direction:column}.openings-modal .openings-header{display:none}.openings-modal .openings-filters{padding:12px 16px}.openings-modal .openings-content{flex:1;display:flex;overflow:hidden}.openings-modal .openings-list{flex:1;max-height:none;width:100%}.openings-modal .opening-details{flex:1;max-height:none;overflow-y:auto}.puzzle-modal{background:var(--glass-bg-panel);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);width:90%;max-width:640px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--glass-shadow-lg);border:1px solid var(--glass-border);animation:modalSlideUp .3s cubic-bezier(.4,0,.2,1);transition:background var(--transition-slow)}.puzzle-modal-header{display:flex;justify-content:space-between;align-items:center;padding:18px 24px;background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff}.puzzle-modal-header h2{margin:0;font-size:1.2rem;font-weight:700}.puzzle-modal .puzzle-panel{flex:1;overflow-y:auto;padding:0;background:transparent;border-radius:0}.puzzle-modal .puzzle-header{display:none}.puzzle-modal .puzzle-filters{max-height:none}.setup-modal{background:var(--glass-bg-panel);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);width:90%;max-width:640px;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--glass-shadow-lg);border:1px solid var(--glass-border);animation:modalSlideUp .3s cubic-bezier(.4,0,.2,1);transition:background var(--transition-slow)}.setup-modal.compact{max-width:420px}.setup-modal-header{display:flex;justify-content:space-between;align-items:center;padding:18px 24px;color:#fff}.setup-modal-header.play{background:linear-gradient(135deg,#f59e0b,#d97706)}.setup-modal-header.analyze{background:linear-gradient(135deg,#3b82f6,#2563eb)}.setup-modal-header.puzzle{background:linear-gradient(135deg,#a855f7,#7c3aed)}.setup-modal-header h2{margin:0;font-size:1.2rem;font-weight:700;display:flex;align-items:center;gap:.5rem;text-shadow:0 1px 3px rgba(0,0,0,.2)}.setup-modal-body{padding:24px;display:flex;flex-direction:column;gap:20px}.setup-section label{display:block;color:var(--text-secondary);font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:12px}.color-selector-large{display:grid;grid-template-columns:1fr 1fr;gap:12px}.color-option{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:14px;padding:16px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:8px;transition:all .2s ease}.color-option:hover{background:var(--bg-hover);border-color:var(--border-color)}.color-option.active{background:#f59e0b26;border-color:#f59e0b;box-shadow:0 0 20px #f59e0b33}.color-option:focus-visible{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}.color-piece{font-size:2.5rem;line-height:1}.color-label{font-size:1rem;font-weight:700;color:var(--text-primary)}.color-hint{font-size:.75rem;color:var(--text-secondary)}.difficulty-selector{display:flex;flex-direction:column;gap:8px}.difficulty-option{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:10px;padding:12px 16px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:all .2s ease}.difficulty-option:hover{background:var(--bg-hover);border-color:var(--border-color)}.difficulty-option.active{background:#f59e0b26;border-color:#f59e0b}.difficulty-option:focus-visible{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}.difficulty-label{font-size:.95rem;font-weight:600;color:var(--text-primary)}.difficulty-desc{font-size:.8rem;color:var(--text-secondary)}.setup-info{display:flex;flex-direction:column;gap:12px}.info-item{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--bg-secondary);border-radius:10px;color:var(--text-primary);font-size:.95rem}.info-icon{font-size:1.3rem}.puzzle-stats-preview{display:flex;gap:16px;justify-content:center;padding-top:8px}.puzzle-stats-preview .stat-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 24px;background:var(--bg-secondary);border-radius:10px}.puzzle-stats-preview .stat-value{font-size:1.5rem;font-weight:700}.puzzle-stats-preview .stat-item.solved .stat-value{color:#10b981}.puzzle-stats-preview .stat-item.failed .stat-value{color:#ef4444}.puzzle-stats-preview .stat-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.setup-modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;background:var(--bg-secondary);border-top:1px solid var(--border-color)}.setup-cancel-btn{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);padding:10px 20px;border-radius:10px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease}.setup-cancel-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.setup-cancel-btn:focus-visible{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}.setup-start-btn{border:none;color:#fff;padding:10px 24px;border-radius:10px;font-size:.95rem;font-weight:700;cursor:pointer;transition:all .2s ease}.setup-start-btn.play{background:linear-gradient(135deg,#f59e0b,#d97706)}.setup-start-btn.play:hover{background:linear-gradient(135deg,#fbbf24,#f59e0b);transform:translateY(-1px);box-shadow:0 4px 15px #f59e0b4d}.setup-start-btn.analyze{background:linear-gradient(135deg,#3b82f6,#2563eb)}.setup-start-btn.analyze:hover{background:linear-gradient(135deg,#60a5fa,#3b82f6);transform:translateY(-1px);box-shadow:0 4px 15px #3b82f64d}.setup-start-btn.puzzle{background:linear-gradient(135deg,#a855f7,#7c3aed)}.setup-start-btn.puzzle:hover{background:linear-gradient(135deg,#c084fc,#a855f7);transform:translateY(-1px);box-shadow:0 4px 15px #a855f74d}.setup-start-btn.secondary{background:linear-gradient(135deg,#6b7280,#4b5563)}.setup-start-btn.secondary:hover{background:linear-gradient(135deg,#9ca3af,#6b7280);transform:translateY(-1px);box-shadow:0 4px 15px #6b72804d}.setup-start-btn:focus-visible{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}.board-section{display:flex;flex-direction:column;gap:.5rem;height:fit-content;align-self:start;animation:scaleIn .5s ease-out}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.board-wrapper{background:#0003;padding:.625rem;border-radius:var(--radius-lg);box-shadow:var(--glass-shadow-lg);border:1px solid var(--glass-border);position:relative;transition:box-shadow var(--transition-slow),transform var(--transition-slow);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.board-wrapper:hover{box-shadow:var(--glass-shadow-glow)}.flip-board-btn{margin-top:.75rem;padding:.6rem 1.25rem;background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid rgba(129,140,248,.15);border-radius:10px;font-size:.85rem;font-weight:600;color:var(--color-primary);cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%}.flip-board-btn:hover{background:var(--gradient-primary);color:#fff;border-color:transparent;transform:translateY(-2px);box-shadow:var(--shadow-primary)}.flip-board-btn:active{transform:translateY(0);background:linear-gradient(135deg,#6366f1,#6d28d9);color:#fff;border-color:transparent;box-shadow:inset 0 2px 4px #0000004d}.flip-board-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.chess-arrows-overlay{position:absolute;top:.625rem;left:.625rem;pointer-events:none;z-index:10}.controls{display:none}.btn{padding:.7rem 1rem;border:none;border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;cursor:pointer;transition:all var(--transition-normal);flex:1;min-width:-webkit-fill-available;min-width:fit-content;white-space:nowrap;position:relative;overflow:hidden;letter-spacing:-.01em}.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 ease}.btn:hover:before{left:100%}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.btn:disabled:before{display:none}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-primary)}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-primary-hover)}.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:inset 0 2px 4px #0000004d;background:linear-gradient(135deg,#6366f1,#6d28d9)}.btn-secondary{background:var(--glass-bg);color:var(--color-primary);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.btn-secondary:hover:not(:disabled){background:var(--gradient-primary);color:#fff;border-color:transparent;transform:translateY(-2px);box-shadow:var(--shadow-primary)}.btn-secondary:active:not(:disabled){transform:translateY(0);background:linear-gradient(135deg,#6366f1,#6d28d9);color:#fff;border-color:transparent;box-shadow:inset 0 2px 4px #0000004d}.btn-analyze{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 12px #3b82f659}.btn-analyze:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #3b82f673}.btn-analyze:active:not(:disabled){transform:translateY(0);background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:inset 0 2px 4px #0000004d}.btn-coach{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;box-shadow:0 4px 12px #8b5cf659}.btn-coach:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #8b5cf673}.btn-coach:active:not(:disabled){transform:translateY(0);background:linear-gradient(135deg,#7c3aed,#6d28d9);box-shadow:inset 0 2px 4px #0000004d}.btn-icon{font-size:1rem}.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.analysis-section{background:var(--glass-bg-panel);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);padding:1.25rem;border-radius:var(--radius-lg);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);max-height:calc(100vh - 140px);overflow:hidden;display:flex;flex-direction:column;animation:slideInRight .5s ease-out}.analysis-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--glass-border);flex-shrink:0}.analysis-header h2{color:var(--color-text-primary);font-size:1.1rem;font-weight:700;margin:0;display:flex;align-items:center;gap:.5rem}.btn-clear-chat{background:#ef44441a;border:none;border-radius:8px;padding:.4rem .6rem;cursor:pointer;transition:all .2s ease;font-size:.9rem}.btn-clear-chat:hover{background:#ef444433}.chat-container{flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(129,140,248,.3) transparent;display:flex;flex-direction:column;gap:.75rem;padding:.75rem;min-height:0}.chat-container::-webkit-scrollbar{width:4px}.chat-container::-webkit-scrollbar-track{background:transparent}.chat-container::-webkit-scrollbar-thumb{background:#818cf84d;border-radius:4px}.chat-container::-webkit-scrollbar-thumb:hover{background:#818cf880}.chat-message{border-radius:var(--radius-md);padding:.875rem 1rem;animation:slideInMessage .25s ease-out;transition:all var(--transition-normal);background:var(--glass-bg);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.chat-message:hover{background:var(--glass-bg-hover);border-color:var(--glass-border-hover)}@keyframes slideInMessage{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.chat-message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.6rem;font-size:.7rem}.chat-timestamp{color:#94a3b8;font-weight:500;font-size:.65rem}.chat-move-number{background:var(--gradient-primary);color:#fff;padding:.15rem .45rem;border-radius:10px;font-weight:600;font-size:.65rem;box-shadow:0 1px 3px #818cf84d}.chat-message-analysis{border-left:3px solid rgba(96,165,250,.6);background:#3b82f60f}.chat-message-coaching{border-left:3px solid rgba(192,132,252,.6);background:#8b5cf60f}.chat-message-dual-analysis{border-left:3px solid transparent;border-image:linear-gradient(180deg,#8b5cf699,#3b82f699) 1;background:#6366f10d}[data-theme=dark] .chat-message,.chat-message{background:var(--glass-bg);border:1px solid var(--glass-border);box-shadow:none}[data-theme=light] .chat-message{background:#ffffff80;border:1px solid rgba(0,0,0,.06);box-shadow:0 1px 3px #0000000a}[data-theme=dark] .chat-message-analysis{background:#3b82f61a}[data-theme=light] .chat-message-analysis{background:#3b82f60f}[data-theme=dark] .chat-message-coaching{background:#8b5cf61a}[data-theme=light] .chat-message-coaching{background:#8b5cf60f}[data-theme=dark] .chat-message-dual-analysis{background:linear-gradient(145deg,#1e1b4b,#172554)}[data-theme=light] .chat-message-dual-analysis{background:linear-gradient(145deg,#faf5ff,#eff6ff)}.chat-message-loading{background:var(--glass-bg);border-left:3px solid var(--color-primary)}[data-theme=dark] .chat-message-loading{background:#6366f11f}[data-theme=light] .chat-message-loading{background:linear-gradient(145deg,#f0f9ff,#e0f2fe)}.chat-message-user{border-left:3px solid #10b981;margin-left:1rem}[data-theme=dark] .chat-message-user{background:linear-gradient(145deg,#064e3b,#065f46)}[data-theme=light] .chat-message-user{background:linear-gradient(145deg,#ecfdf5,#d1fae5)}.chat-message-coach-reply{border-left:3px solid #f59e0b}[data-theme=dark] .chat-message-coach-reply{background:linear-gradient(145deg,#78350f,#92400e)}[data-theme=light] .chat-message-coach-reply{background:linear-gradient(145deg,#fff7ed,#ffedd5)}.chat-message-system{border-left:3px solid #0ea5e9}[data-theme=dark] .chat-message-system{background:linear-gradient(145deg,#0c4a6e,#164e63)}[data-theme=light] .chat-message-system{background:linear-gradient(145deg,#f0f9ff,#e0f2fe)}[data-theme=dark] .system-message{color:#7dd3fc}[data-theme=light] .system-message{color:#0369a1}.system-message{line-height:1.6;font-size:.875rem}[data-theme=dark] .system-message h2{color:#bae6fd}[data-theme=light] .system-message h2{color:#0c4a6e}.system-message h2{margin:0 0 .6rem;font-size:1rem;display:flex;align-items:center;gap:.4rem}.system-message p{margin:0 0 .4rem;color:#374151}.system-message p:last-child{margin-bottom:0}.system-message strong{color:#0369a1}.system-message em{color:#64748b;font-style:italic;font-size:.8rem}.system-message ul,.system-message ol{margin:.4rem 0;padding-left:1.25rem}.system-message li{margin:.2rem 0}.system-message hr{border:none;height:1px;background:linear-gradient(90deg,transparent,#bae6fd,transparent);margin:.6rem 0}.user-message{color:#065f46;font-weight:500;font-size:.875rem;display:flex;align-items:flex-start;gap:.5rem}.user-label{font-weight:700;color:#059669;font-size:.8rem;white-space:nowrap}.chat-message-coach-reaction{border-left-color:#8b5cf6!important;background:linear-gradient(to right,#f5f3ff,#fff)!important;padding:.5rem .75rem!important}.coach-reaction-message{display:flex;align-items:center;gap:.5rem}.coach-reaction-message .reaction-content{color:#6d28d9;font-size:.875rem;font-style:italic;line-height:1.4}@media(prefers-color-scheme:dark){.chat-message-coach-reaction{background:linear-gradient(to right,#1e1b4b,#1f2937)!important;border-left-color:#a78bfa!important}.coach-reaction-message .reaction-content{color:#c4b5fd}}.coach-reply{color:#92400e;display:flex;flex-direction:column}.coach-reply .coach-label{font-weight:700;display:inline-flex;align-items:center;gap:.4rem;margin-bottom:.6rem;font-size:.85rem;color:#d97706;background:linear-gradient(135deg,#fef3c7,#fde68a);padding:.25rem .6rem;border-radius:12px;width:fit-content;box-shadow:0 1px 2px #d9770626}.coach-reply-content{color:#374151;line-height:1.65;font-size:.875rem}.coach-reply-content p{margin:0 0 .6rem}.coach-reply-content p:last-child{margin-bottom:0}.coach-reply-content h1,.coach-reply-content h2,.coach-reply-content h3,.coach-reply-content h4{color:#1f2937;margin:.75rem 0 .4rem;font-weight:700;line-height:1.4}.coach-reply-content h1:first-child,.coach-reply-content h2:first-child,.coach-reply-content h3:first-child,.coach-reply-content h4:first-child{margin-top:0}.coach-reply-content h1{font-size:1.05rem;border-bottom:2px solid #f59e0b;padding-bottom:.35rem}.coach-reply-content h2{font-size:.95rem;border-bottom:1px solid #fde68a;padding-bottom:.25rem}.coach-reply-content h3{font-size:.875rem;color:#4b5563}.coach-reply-content h4{font-size:.825rem;color:#6b7280}.coach-reply-content ul,.coach-reply-content ol{margin:.4rem 0;padding-left:1.25rem}.coach-reply-content li{margin:.25rem 0;padding-left:.15rem}.coach-reply-content li::marker{color:#f59e0b}.coach-reply-content ol li::marker{color:#f59e0b;font-weight:600}.coach-reply-content li>ul,.coach-reply-content li>ol{margin:.15rem 0}.coach-reply-content strong{color:#7c3aed;font-weight:600}.coach-reply-content em{color:#64748b;font-style:italic}.coach-reply-content code{background:linear-gradient(135deg,#fef3c7,#fde68a);padding:.1rem .35rem;border-radius:4px;font-family:SF Mono,Consolas,Courier New,monospace;font-size:.85em;color:#b45309;font-weight:600;border:1px solid #fcd34d}.coach-reply-content pre{background:linear-gradient(135deg,#1e293b,#0f172a);padding:.65rem .9rem;border-radius:8px;overflow-x:auto;margin:.6rem 0;border:1px solid #334155}.coach-reply-content pre code{background:transparent;padding:0;border:none;color:#e2e8f0;font-weight:500;font-size:.8rem;line-height:1.5}.coach-reply-content blockquote{margin:.6rem 0;padding:.5rem .8rem;background:linear-gradient(135deg,#fef9c3,#fef08a);border-left:3px solid #eab308;border-radius:0 6px 6px 0;color:#854d0e;font-style:normal;font-size:.825rem}.coach-reply-content blockquote p{margin:0}.coach-reply-content blockquote strong{color:#713f12}.coach-reply-content hr{border:none;height:1px;background:linear-gradient(90deg,transparent,#fde68a,transparent);margin:.75rem 0}.coach-reply-content table{width:100%;border-collapse:collapse;margin:.75rem 0;font-size:.85rem}.coach-reply-content th,.coach-reply-content td{padding:.5rem .6rem;text-align:left;border:1px solid #e5e7eb}.coach-reply-content th{background:linear-gradient(135deg,#fff7ed,#ffedd5);font-weight:600;color:#9a3412}.coach-reply-content tr:nth-child(2n) td{background:#fefce8}.coach-reply-content a{color:#ea580c;text-decoration:none;font-weight:500;border-bottom:1px dashed #ea580c;transition:all .2s ease}.coach-reply-content a:hover{color:#c2410c;border-bottom-style:solid}.stockfish-toggle-container{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background:var(--glass-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-top:1px solid var(--glass-border)}.stockfish-toggle-btn{display:flex;align-items:center;gap:.4rem;padding:.5rem .85rem;border:1px solid var(--glass-border);border-radius:20px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s ease;background:var(--glass-bg);color:var(--color-text-secondary);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.stockfish-toggle-btn:hover{border-color:var(--color-primary);background:var(--glass-bg-hover);color:var(--color-text-primary);transform:translateY(-1px)}.stockfish-toggle-btn.active{background:linear-gradient(135deg,#22c55e,#16a34a);border-color:#16a34a;color:#fff;box-shadow:0 2px 8px #22c55e4d}.stockfish-toggle-btn.active:hover{background:linear-gradient(135deg,#16a34a,#15803d)}.stockfish-status{font-size:.75rem;color:#16a34a;font-weight:500;padding:.25rem .5rem;background:#22c55e1a;border-radius:8px}.chat-input-container{display:flex;gap:.5rem;padding:.75rem;background:var(--glass-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-top:1px solid var(--glass-border);border-radius:0 0 var(--radius-lg) var(--radius-lg);flex-shrink:0}.chat-input{flex:1;padding:.7rem 1rem;border:1px solid var(--glass-border);border-radius:var(--radius-sm);font-size:.85rem;transition:all var(--transition-normal);background:var(--glass-bg);color:var(--color-text-primary);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.chat-input:focus{outline:none;border-color:#818cf866;box-shadow:0 0 0 3px #818cf814;background:#ffffff0d}.chat-input:disabled{background:#0f0c2e80;cursor:not-allowed;opacity:.5}.chat-input::placeholder{color:var(--color-text-muted);font-size:.8rem}.chat-send-btn{width:40px;height:40px;border:none;border-radius:var(--radius-sm);background:var(--gradient-primary);color:#fff;font-size:1.1rem;cursor:pointer;transition:all var(--transition-normal);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-primary)}.chat-send-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-primary-hover)}.chat-send-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.chat-send-btn:active:not(:disabled){transform:translateY(0);box-shadow:inset 0 2px 4px #0000004d;background:linear-gradient(135deg,#6366f1,#6d28d9)}.chat-send-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.loading-indicator{display:flex;align-items:center;gap:.6rem;color:var(--color-primary);font-weight:500;font-size:.85rem;padding:.3rem 0}.loading-indicator .spinner{border-color:#818cf840;border-top-color:var(--color-primary);width:16px;height:16px}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.analysis-section::-webkit-scrollbar{width:6px}.analysis-section::-webkit-scrollbar-track{background:transparent;margin:8px 0}.analysis-section::-webkit-scrollbar-thumb{background:#818cf866;border-radius:3px}.analysis-section::-webkit-scrollbar-thumb:hover{background:#818cf899}.analysis-section h2{color:#1f2937;margin-bottom:1rem;font-size:1.3rem;font-weight:700;display:flex;align-items:center;gap:.5rem}.analysis-section h2:before{content:"";display:inline-block;width:4px;height:1.2em;background:var(--gradient-primary);border-radius:2px}.analysis-result{display:flex;flex-direction:column;gap:.75rem}.analysis-item{display:flex;justify-content:space-between;align-items:center;padding:.875rem 1rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:10px;border:1px solid rgba(0,0,0,.04);transition:all .2s ease}.analysis-item:hover{background:linear-gradient(135deg,#f1f5f9,#e2e8f0)}.label{font-weight:600;color:#64748b;font-size:.9rem}.value{font-size:1.1rem;font-weight:700;color:#1e293b}.value.positive{color:#059669}.value.negative{color:#dc2626}.status-badge{padding:.5rem 1rem;border-radius:10px;text-align:center;font-weight:600;font-size:.85rem;display:inline-flex;align-items:center;gap:.4rem;box-shadow:0 2px 8px #00000014}.status-badge.check{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#b45309;border:1px solid rgba(245,158,11,.3)}.status-badge.checkmate{background:linear-gradient(135deg,#fecaca,#fca5a5);color:#b91c1c;border:1px solid rgba(239,68,68,.3);animation:checkmate-pulse 1.5s ease-in-out infinite}.status-badge.stalemate{background:linear-gradient(135deg,#e5e7eb,#d1d5db);color:#374151;border:1px solid rgba(107,114,128,.2)}.dual-analysis-result{display:flex;flex-direction:column;gap:.75rem;animation:fadeInUp .3s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.dual-analysis-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:.5rem;border-bottom:1px solid rgba(0,0,0,.08)}.dual-title{font-weight:700;font-size:1rem;color:#1e293b}.match-badge{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;transition:all .2s ease}.match-badge.match{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#047857;box-shadow:0 2px 8px #22c55e33}.match-badge.different{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#d97706;box-shadow:0 2px 8px #f59e0b33}.dual-analysis-columns{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.analysis-column{padding:.75rem;border-radius:12px;display:flex;flex-direction:column;gap:.5rem;transition:all .2s ease}.analysis-column:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.analysis-column.optimal{background:linear-gradient(135deg,#ede9fe,#ddd6fe);border:1px solid rgba(139,92,246,.25)}.analysis-column.human{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border:1px solid rgba(59,130,246,.25)}.analysis-column.human.unavailable{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border:1px solid rgba(100,116,139,.25);opacity:.75}.analysis-column .maia-unavailable{text-align:center;padding:1rem .5rem}.analysis-column .unavailable-message{color:#64748b;font-size:.8rem;line-height:1.4}.match-badge.warning{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;font-size:.7rem}.column-header{display:flex;flex-direction:column;align-items:center;padding-bottom:.5rem;border-bottom:1px solid rgba(0,0,0,.08);margin-bottom:.25rem;position:relative}.arrow-indicator{position:absolute;top:0;right:0;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;color:#fff;box-shadow:0 2px 4px #00000026}.arrow-indicator.stockfish{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.arrow-indicator.maia{background:linear-gradient(135deg,#3b82f6,#2563eb)}.engine-icon{font-size:1.25rem;margin-bottom:.125rem}.engine-name{font-weight:700;font-size:.9rem;color:#1e293b}.engine-subtitle{font-size:.7rem;color:#64748b;font-weight:500}.analysis-column .analysis-item{padding:.5rem .625rem;background:#fff9;font-size:.85rem;border-radius:8px;transition:all .15s ease}.analysis-column .analysis-item:hover{background:#ffffffd9}.analysis-column .label{font-size:.75rem}.analysis-column .value{font-size:.9rem}.analysis-column .move-value{font-family:SF Mono,Monaco,Inconsolata,monospace;background:#0000000d;padding:.125rem .375rem;border-radius:4px}.coaching-insight{display:flex;align-items:flex-start;gap:.5rem;padding:.75rem;border-radius:10px;transition:all .2s ease}.coaching-insight:hover{box-shadow:0 2px 8px #eab30826}.coaching-insight.rich{flex-direction:column;padding:1.25rem;border-radius:16px}.coaching-insight.rich:hover{box-shadow:0 6px 16px #0003}.coaching-insight.rich .insight-icon{font-size:1.5rem;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1));flex-shrink:0}.coaching-insight.rich .insight-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.coaching-insight .insight-content{display:flex;flex-direction:column;gap:.25rem;flex:1}.coaching-insight .insight-label{margin:0;font-size:1rem;font-weight:700;letter-spacing:-.01em}.insight-icon{font-size:1rem;flex-shrink:0}.coaching-insight .coaching-markdown{font-size:.85rem;line-height:1.5}.coaching-insight .coaching-markdown p{margin:.5rem 0}.coaching-insight .coaching-markdown p:first-child{margin-top:0}.coaching-insight .coaching-markdown p:last-child{margin-bottom:0}.coaching-insight.rich .coaching-markdown{font-size:.9rem;line-height:1.6}.coaching-insight.rich .coaching-markdown ul,.coaching-insight.rich .coaching-markdown ol{margin:.5rem 0;padding-left:1.25rem}.coaching-insight.rich .coaching-markdown li{margin:.25rem 0}.coaching-insight.rich .coaching-markdown li::marker{color:#22c55e}[data-theme=dark] .coaching-insight,.coaching-insight{background:linear-gradient(135deg,#1e293b,#1a2332);border:1px solid rgba(234,179,8,.3)}[data-theme=light] .coaching-insight{background:linear-gradient(135deg,#fefce8,#fef9c3);border:1px solid rgba(234,179,8,.2)}[data-theme=dark] .coaching-insight.rich,.coaching-insight.rich{background:linear-gradient(145deg,#0f172a,#0a1f1f);border:1px solid rgba(34,197,94,.2);border-left:4px solid #22c55e;box-shadow:0 2px 8px #0003}[data-theme=light] .coaching-insight.rich{background:linear-gradient(145deg,#fff,#f0fdf4);border:1px solid rgba(0,0,0,.06);border-left:4px solid #22c55e;box-shadow:0 2px 8px #0000000a}[data-theme=dark] .coaching-insight .insight-label,.coaching-insight .insight-label{color:#e2e8f0}[data-theme=light] .coaching-insight .insight-label{color:#374151}[data-theme=dark] .coaching-insight .coaching-markdown,.coaching-insight .coaching-markdown{color:#fbbf24}[data-theme=light] .coaching-insight .coaching-markdown{color:#713f12}[data-theme=dark] .coaching-insight .coaching-markdown code,.coaching-insight .coaching-markdown code{background:#eab30826;border-color:#eab3084d;color:#fbbf24}[data-theme=light] .coaching-insight .coaching-markdown code{background:#b453091a;border-color:#b4530933;color:#b45309}[data-theme=dark] .coaching-insight .coaching-markdown strong,.coaching-insight .coaching-markdown strong{color:#fef3c7}[data-theme=light] .coaching-insight .coaching-markdown strong{color:#78350f}[data-theme=dark] .coaching-insight.rich .coaching-markdown,.coaching-insight.rich .coaching-markdown{color:#86efac}[data-theme=light] .coaching-insight.rich .coaching-markdown{color:#14532d}[data-theme=dark] .coaching-insight.rich .coaching-markdown code,.coaching-insight.rich .coaching-markdown code{background:#22c55e26;border-color:#22c55e4d;color:#4ade80}[data-theme=light] .coaching-insight.rich .coaching-markdown code{background:#1665341a;border-color:#16653433;color:#166534}[data-theme=dark] .coaching-insight.rich .coaching-markdown strong,.coaching-insight.rich .coaching-markdown strong{color:#bbf7d0}[data-theme=light] .coaching-insight.rich .coaching-markdown strong{color:#14532d}.game-status{padding:.75rem 1.25rem;background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;border-radius:12px;text-align:center;font-weight:600;font-size:.95rem;margin-bottom:.75rem;border:1px solid rgba(245,158,11,.2);box-shadow:0 2px 8px #f59e0b26;animation:statusPulse 2s ease-in-out infinite}@keyframes statusPulse{0%,to{box-shadow:0 2px 8px #f59e0b26}50%{box-shadow:0 4px 16px #f59e0b40}}@keyframes checkmate-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.placeholder{text-align:center;padding:2rem 1.75rem;color:#64748b;background:linear-gradient(145deg,#f8fafc,#f1f5f9);border-radius:16px;border:2px dashed #e2e8f0;transition:all .3s ease}.placeholder:hover{border-color:#cbd5e1;background:linear-gradient(145deg,#f1f5f9,#e8ecf3)}.placeholder h3{margin:0 0 .6rem;font-size:1.15rem;color:#374151;font-weight:700}.placeholder p{margin:0;line-height:1.65;font-size:.88rem}.placeholder p strong{color:var(--color-primary)}.placeholder-hint{margin-top:.75rem!important;font-size:.8rem!important;color:#94a3b8!important;padding:.5rem .75rem;background:#818cf814;border-radius:8px;display:inline-block}.error-box{padding:1rem 1.25rem;background:linear-gradient(145deg,#fee2e2,#fecaca);color:#991b1b;border-radius:12px;margin-bottom:1rem;border-left:4px solid #dc2626;animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-5px)}40%,80%{transform:translate(5px)}}.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--gradient-primary);padding:2rem}.error-content{background:#fff;border-radius:20px;padding:3rem;text-align:center;max-width:500px;box-shadow:0 25px 50px #00000040}.error-icon{font-size:4rem;display:block;margin-bottom:1rem}.error-content h2{color:#1a1a2e;margin-bottom:.5rem}.error-content p{color:#666;margin-bottom:1.5rem}.error-details{text-align:left;margin-bottom:1.5rem}.error-details summary{cursor:pointer;color:var(--color-primary);font-weight:500}.error-details pre{background:#f5f5f5;padding:1rem;border-radius:8px;overflow-x:auto;font-size:.85rem;color:#dc2626;margin-top:.5rem}.reset-button{background:var(--gradient-primary);color:#fff;border:none;padding:.75rem 2rem;border-radius:var(--radius-md);font-size:1rem;cursor:pointer;transition:transform .2s,box-shadow .2s}.reset-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #818cf866}.modal-error .modal-error-content{text-align:center;padding:2rem}.modal-error .error-icon{font-size:3rem;display:block;margin-bottom:1rem}.modal-error h2{color:var(--text-primary);margin-bottom:.5rem;font-size:1.25rem}.modal-error p{color:var(--text-secondary);margin-bottom:1.5rem}.modal-error .error-details{text-align:left;margin-bottom:1.5rem}.modal-error .error-details summary{cursor:pointer;color:var(--primary-color);font-weight:500}.modal-error .error-details pre{background:var(--bg-light);padding:1rem;border-radius:8px;overflow-x:auto;font-size:.85rem;color:#dc2626;margin-top:.5rem}.warning-box{padding:.75rem;background:#fef3c7;color:#92400e;border-radius:6px;margin-top:1rem;font-size:.9rem;border-left:3px solid #f59e0b}.coaching-result{background:var(--glass-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:1.5rem;border-radius:var(--radius-lg);margin-bottom:1rem;box-shadow:var(--glass-shadow);border:1px solid var(--glass-border);animation:fadeInUp .4s ease-out}[data-theme=light] .coaching-result{background:#fff9;box-shadow:0 4px 24px #0000000d;border:1px solid rgba(0,0,0,.06)}.coach-info h3{color:#f1f5f9}[data-theme=light] .coach-info h3{color:#1f2937}.coaching-card{background:#0f172a;border:1px solid rgba(255,255,255,.1)}[data-theme=light] .coaching-card{background:#fff;border:1px solid rgba(0,0,0,.06)}.best-move-card{background:linear-gradient(145deg,var(--color-bg-dark-3) 0%,var(--color-bg-dark-2) 100%)}[data-theme=light] .best-move-card{background:linear-gradient(145deg,#fff,#f0fdf4)}.best-move-display{background:linear-gradient(145deg,#0a1f1f,#0c2820);border:1px solid rgba(5,150,105,.3)}[data-theme=light] .best-move-display{background:linear-gradient(145deg,#ecfdf5,#d1fae5);border:1px solid rgba(5,150,105,.15)}.assessment-card{background:linear-gradient(145deg,var(--color-bg-dark-3) 0%,rgba(18,10,40,.9) 100%)}[data-theme=light] .assessment-card{background:linear-gradient(145deg,#fff,#faf5ff)}.card-header h4{color:var(--color-text-primary)}[data-theme=light] .card-header h4{color:#374151}.coaching-markdown{color:#cbd5e1d9}[data-theme=light] .coaching-markdown{color:#4b5563}.eval-bar-container{background:linear-gradient(135deg,#1e293b,#0f172a);border:1px solid rgba(255,255,255,.1)}[data-theme=light] .eval-bar-container{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid rgba(0,0,0,.05)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.coach-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--glass-border)}.coach-avatar{font-size:1.75rem;background:var(--gradient-primary);border-radius:var(--radius-md);width:52px;height:52px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-primary)}.coach-info h3{margin:0;font-size:1.2rem;color:#1f2937;font-weight:700;letter-spacing:-.01em}.coach-subtitle{font-size:.8rem;color:#8b5cf6;font-weight:500}.status-badges{display:flex;gap:.5rem;margin-bottom:1rem}.status-badges:empty{display:none}.eval-bar-container{margin-bottom:1.25rem;background:var(--glass-bg);padding:1rem 1.25rem;border-radius:var(--radius-md);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.eval-bar{height:8px;background:linear-gradient(90deg,#fee2e2,#e2e8f0,#dcfce7);border-radius:4px;overflow:hidden;margin-bottom:.75rem;position:relative}.eval-bar-fill{height:100%;border-radius:4px;transition:width .5s cubic-bezier(.4,0,.2,1);position:relative}.eval-bar-fill.positive{background:linear-gradient(90deg,#34d399,#10b981);box-shadow:0 0 8px #10b98166}.eval-bar-fill.negative{background:linear-gradient(90deg,#f87171,#ef4444);box-shadow:0 0 8px #ef444466}.eval-details{display:flex;justify-content:space-between;align-items:center}.eval-value{font-size:1.25rem;font-weight:700;font-family:SF Mono,Consolas,monospace}.eval-value.positive{color:#059669}.eval-value.negative{color:#dc2626}.eval-label{font-size:.8rem;color:#94a3b8;font-weight:500;background:#94a3b81a;padding:.25rem .5rem;border-radius:4px}.coaching-card{background:var(--glass-bg);border-radius:var(--radius-md);padding:1.25rem;margin-bottom:1rem;box-shadow:none;border:1px solid var(--glass-border);transition:all var(--transition-normal);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.coaching-card:hover{background:var(--glass-bg-hover);border-color:var(--glass-border-hover)}.coaching-card:last-of-type{margin-bottom:0}.card-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.card-icon{font-size:1.5rem;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.card-header h4{margin:0;font-size:1rem;color:#374151;font-weight:700;letter-spacing:-.01em}.best-move-card{border-left:4px solid #059669;background:linear-gradient(145deg,#fff,#f0fdf4)}.best-move-display{background:linear-gradient(145deg,#ecfdf5,#d1fae5);padding:1.25rem 1.5rem;border-radius:12px;margin-bottom:1rem;text-align:center;border:1px solid rgba(5,150,105,.15);box-shadow:inset 0 2px 4px #05966914}.move-notation{font-size:2rem;font-weight:700;font-family:SF Mono,Consolas,Courier New,monospace;color:#059669;letter-spacing:3px;text-shadow:0 1px 2px rgba(5,150,105,.15)}.assessment-card{border-left:4px solid #8b5cf6;background:linear-gradient(145deg,#fff,#faf5ff)}.coaching-markdown{color:#4b5563;line-height:1.75;font-size:.95rem}.coaching-markdown h1,.coaching-markdown h2,.coaching-markdown h3,.coaching-markdown h4{color:#1f2937;font-weight:700;margin:1.25rem 0 .75rem;line-height:1.4}.coaching-markdown h1:first-child,.coaching-markdown h2:first-child,.coaching-markdown h3:first-child,.coaching-markdown h4:first-child{margin-top:0}.coaching-markdown h1{font-size:1.25rem;border-bottom:2px solid var(--color-primary);padding-bottom:.5rem}.coaching-markdown h2{font-size:1.1rem;border-bottom:1px solid #e5e7eb;padding-bottom:.4rem}.coaching-markdown h3{font-size:1rem;color:#374151;padding-bottom:.25rem}.coaching-markdown h4{font-size:.95rem;color:#4b5563}.coaching-markdown p{margin:.75rem 0}.coaching-markdown p:first-child{margin-top:0}.coaching-markdown p:last-child{margin-bottom:0}.coaching-markdown ul,.coaching-markdown ol{margin:.75rem 0;padding-left:1.75rem}.coaching-markdown li{margin:.4rem 0;padding-left:.25rem}.coaching-markdown li::marker{color:var(--color-primary)}.coaching-markdown ol li::marker{color:var(--color-primary);font-weight:600}.coaching-markdown li>ul,.coaching-markdown li>ol{margin:.25rem 0}.coaching-markdown strong{color:#1f2937;font-weight:700}.coaching-markdown em{color:#6b7280;font-style:italic}.coaching-markdown code{background:linear-gradient(135deg,#ede9fe,#ddd6fe);padding:.2rem .6rem;border-radius:6px;font-family:SF Mono,Consolas,Courier New,monospace;font-size:.9em;color:#7c3aed;font-weight:600;border:1px solid #c4b5fd;white-space:nowrap}.coaching-markdown pre{background:linear-gradient(135deg,#1e293b,#0f172a);padding:1rem 1.25rem;border-radius:10px;overflow-x:auto;margin:1rem 0;border:1px solid #334155}.coaching-markdown pre code{background:transparent;padding:0;border:none;color:#e2e8f0;font-weight:500;font-size:.9rem;line-height:1.6}.coaching-markdown blockquote{margin:1rem 0;padding:1rem 1.25rem;background:linear-gradient(135deg,#fef9c3,#fef08a);border-left:4px solid #eab308;border-radius:0 12px 12px 0;color:#854d0e;font-style:normal;box-shadow:0 2px 8px #eab30826}.coaching-markdown blockquote:before{content:"💡";margin-right:.5rem}.coaching-markdown blockquote p{margin:0}.coaching-markdown blockquote strong{color:#78350f}.coaching-markdown hr{border:none;height:1px;background:linear-gradient(90deg,transparent,#e5e7eb,transparent);margin:1.5rem 0}.coaching-markdown table{width:100%;border-collapse:collapse;margin:1rem 0;font-size:.9rem}.coaching-markdown th,.coaching-markdown td{padding:.6rem .8rem;text-align:left;border:1px solid #e5e7eb}.coaching-markdown th{background:linear-gradient(135deg,#f8fafc,#f1f5f9);font-weight:600;color:#374151}.coaching-markdown tr:nth-child(2n) td{background:#f9fafb}.coaching-markdown a{color:var(--color-primary);text-decoration:none;font-weight:500;border-bottom:1px dashed var(--color-primary);transition:all .2s ease}.coaching-markdown a:hover{color:#4f46e5;border-bottom-style:solid}.coaching-result h3{margin:0 0 1.5rem;font-size:1.3rem;color:#1f2937}.coaching-section{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid #e5e7eb}.coaching-section:last-of-type{border-bottom:none;padding-bottom:0}.coaching-section h4{margin:0 0 .75rem;font-size:1.1rem;color:#374151;font-weight:600}.coaching-text{margin:0;line-height:1.6;color:#4b5563;font-size:1rem}.analysis-details{background:#f9fafb;padding:1rem;border-radius:6px;margin-top:1rem}.move-history{background:linear-gradient(135deg,#f8fafc,#f1f5f9);padding:1rem;border-radius:10px;margin-bottom:.75rem;border:1px solid rgba(0,0,0,.04)}.move-history h3{margin:0 0 .75rem;font-size:.9rem;color:#64748b;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.moves{display:flex;flex-wrap:wrap;gap:.4rem}.move-item{padding:.35rem .6rem;background:#fff;border-radius:8px;font-family:SF Mono,Consolas,Courier New,monospace;font-size:.8rem;color:#334155;border:1px solid #e2e8f0;transition:all .2s cubic-bezier(.4,0,.2,1);cursor:pointer}.move-item:hover{background:var(--gradient-primary);color:#fff;border-color:transparent;transform:translateY(-1px);box-shadow:0 3px 8px #818cf84d}@media(max-width:1024px){.container{grid-template-columns:1fr}.board-wrapper{max-width:500px;margin:0 auto}}.mode-selector{display:grid;grid-template-columns:repeat(2,1fr);gap:.3rem;background:linear-gradient(145deg,#f1f5f9,#e2e8f0);padding:.3rem;border-radius:12px;box-shadow:inset 0 1px 3px #0000000d}.mode-btn{display:flex;align-items:center;justify-content:center;gap:.3rem;padding:.5rem .4rem;border:none;border-radius:9px;background:transparent;color:#64748b;font-weight:600;font-size:.75rem;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);min-width:0}.mode-btn .mode-icon{font-size:.9rem;flex-shrink:0}.mode-btn .mode-text{font-size:.75rem;white-space:nowrap}.mode-btn:hover{background:#818cf81a;color:var(--color-primary)}.mode-btn.active{background:var(--gradient-primary);color:#fff;box-shadow:0 3px 10px #818cf859;transform:translateY(-1px)}.color-selector{display:flex;gap:.5rem}.color-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.6rem .75rem;border:2px solid #e2e8f0;border-radius:10px;background:#fff;font-weight:600;font-size:.8rem;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1)}.color-btn .color-icon{font-size:1.1rem}.color-btn.white,.color-btn.black{color:#374151}.color-btn:hover{border-color:var(--color-primary);background:#818cf814;transform:translateY(-2px)}.color-btn.active{background:var(--gradient-primary);color:#fff;border-color:transparent;box-shadow:0 4px 12px #818cf859}.skill-select{width:100%;padding:.45rem .6rem;border:2px solid #e2e8f0;border-radius:8px;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s ease;background:#fff}.skill-description{display:block;font-size:.7rem;color:#94a3b8;margin-top:.3rem;font-style:italic}.play-settings{background:#fffffffa;padding:.875rem;border-radius:14px;margin-bottom:.75rem;box-shadow:0 2px 12px #0000000f;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.setting-group{margin-bottom:.6rem}.setting-group:last-child{margin-bottom:0}.setting-group label{display:block;font-weight:600;color:#64748b;margin-bottom:.4rem;font-size:.75rem;text-transform:uppercase;letter-spacing:.5px}.color-selector{display:flex;gap:.35rem}.color-btn{flex:1;padding:.5rem .75rem;border:2px solid #e2e8f0;border-radius:8px;background:#fff;font-weight:600;font-size:.85rem;cursor:pointer;transition:all .2s ease}.color-btn:hover{border-color:var(--color-primary);background:#818cf80d}.color-btn.active{background:var(--gradient-primary);color:#fff;border-color:transparent;box-shadow:0 2px 8px #818cf84d}.skill-select{width:100%;padding:.5rem .75rem;border:2px solid #e2e8f0;border-radius:8px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease;background:#fff}.skill-select:hover{border-color:#cbd5e1}.skill-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #818cf81a}.skill-description{display:block;font-size:.75rem;color:#94a3b8;margin-top:.35rem;font-style:italic}.thinking-indicator{background:linear-gradient(145deg,#eff6ff,#dbeafe);color:#1e40af;padding:.5rem .875rem;border-radius:12px;text-align:center;font-weight:600;font-size:.85rem;border:1px solid rgba(30,64,175,.15);display:flex;align-items:center;justify-content:center;gap:.6rem;box-shadow:0 2px 8px #3b82f626}.thinking-indicator:before{content:"";width:10px;height:10px;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:50%;animation:thinking-pulse 1.2s ease-in-out infinite}@keyframes thinking-pulse{0%,to{transform:scale(1);opacity:1;box-shadow:0 0 #3b82f666}50%{transform:scale(.85);opacity:.6;box-shadow:0 0 0 8px #3b82f600}}.eval-bar-fill.positive{background:linear-gradient(90deg,#059669,#10b981)}.eval-bar-fill.negative{background:linear-gradient(90deg,#dc2626,#ef4444)}@media(max-width:1200px){.container{grid-template-columns:200px auto 1fr;gap:1rem}}@media(max-width:1024px){.app{padding:1rem;max-height:none;overflow:auto}.container{grid-template-columns:1fr;height:auto;max-height:none;gap:1rem}.controls-section{max-height:none;order:1}.board-section{order:0;justify-self:center}.board-wrapper{max-width:480px}.analysis-section{max-height:none;overflow-y:visible;order:2}.header h1{font-size:2rem}.mode-selector{flex-direction:row}.action-buttons{flex-direction:row;flex-wrap:wrap}.action-buttons .btn{flex:1;min-width:80px}}@media(max-width:600px){.color-selector{flex-direction:column}}@media(max-width:768px){.app{padding:0;overflow-y:auto;overflow-x:hidden;max-height:none}.toolbar{padding:.4rem .5rem;flex-wrap:wrap;gap:.25rem}.toolbar-left{gap:.25rem}.app-logo{width:28px;height:28px}.app-title{font-size:.95rem;display:none}.toolbar-btn{width:36px;height:36px;font-size:1rem;padding:0}.toolbar-btn .btn-icon{font-size:1rem}.toolbar-btn .btn-label{display:none}.toolbar-divider{height:20px;margin:0 .15rem}.toolbar-select{font-size:.7rem;padding:.3rem .4rem;max-width:100px}.color-toggle .color-btn{width:28px;height:28px;font-size:.95rem}.container{display:flex;flex-direction:column;height:auto;max-height:none;padding:.5rem;gap:.75rem}.board-section{order:0;width:100%;display:flex;justify-content:center;align-items:center;padding:0}.board-wrapper{width:100%;max-width:calc(100vw - 1rem);aspect-ratio:1}.board-container{width:100%;height:100%}.controls-section{order:1;width:100%;max-height:none;padding:.75rem}.mode-selector{display:flex;flex-wrap:nowrap;overflow-x:auto;gap:.25rem;padding:.25rem;scrollbar-width:none}.mode-selector::-webkit-scrollbar{display:none}.mode-btn{flex:0 0 auto;padding:.4rem .6rem;font-size:.7rem;white-space:nowrap}.mode-btn .mode-icon{font-size:.9rem}.action-buttons{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.action-buttons .btn{padding:.6rem .5rem;font-size:.75rem;min-height:44px}.analysis-section{order:2;width:100%;max-height:none;overflow:visible;padding:.75rem}.chat-section{max-height:300px}.chat-messages{max-height:200px}.chat-input-container{flex-direction:column;gap:.5rem}.chat-input-container input{width:100%}.chat-input-container button{width:100%;min-height:44px}.move-history{display:flex;flex-wrap:wrap;gap:.25rem;max-height:120px;overflow-y:auto}.move-item{padding:.3rem .5rem;font-size:.75rem;min-height:32px}.opening-info{padding:.5rem;font-size:.8rem}.puzzle-info-card{padding:.75rem}.puzzle-info-card h3{font-size:.9rem}.analysis-card{padding:.75rem}.analysis-card h3{font-size:.85rem}.dual-analysis-panel{flex-direction:column;gap:.75rem}.dual-analysis-panel .engine-column{width:100%}.modal-overlay{padding:.5rem}.modal-content{max-width:100%;max-height:90vh;border-radius:12px}.modal-header h2{font-size:1.1rem}.modal-body{padding:1rem}.config-page,.config-section{padding:.75rem}.config-section h3{font-size:.9rem}.skill-selector{gap:.3rem}.skill-btn{padding:.4rem .6rem;font-size:.7rem;min-height:40px}.app-bg .floating-piece{display:none}.openings-panel{max-height:300px}.opening-item{padding:.5rem}.opening-item .opening-name{font-size:.8rem}.news-modal,.news-item{padding:.75rem}.news-item h3{font-size:.9rem}.help-page,.help-section{padding:.75rem}.elo-badge{font-size:.7rem;padding:.2rem .4rem}.coaching-results{padding:.75rem}.coaching-tip{padding:.5rem;font-size:.8rem}}@media(max-width:480px){.toolbar{padding:.3rem}.toolbar-left{flex:1;min-width:0}.toolbar-right{flex-wrap:wrap;justify-content:flex-end}.toolbar-btn{width:32px;height:32px}.container{padding:.25rem;gap:.5rem}.board-wrapper{max-width:calc(100vw - .5rem)}.controls-section,.analysis-section{padding:.5rem;border-radius:8px}.mode-btn{padding:.35rem .5rem;font-size:.65rem}.action-buttons .btn{padding:.5rem;font-size:.7rem}.chat-messages{max-height:150px}.move-history{max-height:100px}.modal-content{border-radius:8px}.modal-header,.modal-body{padding:.75rem}}@media(hover:none)and (pointer:coarse){.toolbar-btn,.mode-btn,.action-buttons .btn,.skill-btn,.color-btn{min-height:44px;min-width:44px}.toolbar-btn:hover,.mode-btn:hover,.btn:hover{transform:none}.toolbar-btn:active,.mode-btn:active,.btn:active{transform:scale(.95);opacity:.8}.board-container,button,input,select{touch-action:manipulation}.chat-messages,.move-history,.openings-panel,.modal-body{scroll-behavior:smooth}}@media(max-width:896px)and (orientation:landscape){.app{overflow-y:auto}.container{flex-direction:row;flex-wrap:wrap;align-items:flex-start}.board-section{order:0;width:50%;flex:0 0 50%}.board-wrapper{max-width:100%;max-height:70vh;aspect-ratio:1}.controls-section{order:1;width:48%;flex:0 0 48%;max-height:70vh;overflow-y:auto}.analysis-section{order:2;width:100%;max-height:none}}@media print{.toolbar,.controls-section,.analysis-section,.app-bg,.modal-overlay{display:none!important}.app{background:#fff;min-height:0}.board-section{width:100%;max-width:600px;margin:0 auto}}:root{--primary-gradient: linear-gradient(135deg, #818cf8, #6366f1);--primary-color: #818cf8;--primary-dark: #6366f1;--accent-color: #6366f1;--success-color: #059669;--success-light: #10b981;--error-color: #dc2626;--warning-color: #f59e0b;--text-primary: #1f2937;--text-secondary: #64748b;--text-muted: #94a3b8;--bg-light: #f8fafc;--bg-card: #ffffff;--border-light: #e2e8f0;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .06);--shadow-md: 0 4px 16px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 40px rgba(0, 0, 0, .15);--shadow-glow: 0 0 20px rgba(129, 140, 248, .3);--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--page-bg: linear-gradient(135deg, #1a1a2e 0%, #16213e 50%, #0f3460 100%)}[data-theme=dark]{--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--bg-light: #1e293b;--bg-card: #0f172a;--border-light: #334155;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 40px rgba(0, 0, 0, .5);--page-bg: linear-gradient(135deg, #0a0a14 0%, #0c1525 50%, #071830 100%)}[data-theme=light]{--text-primary: #1f2937;--text-secondary: #64748b;--text-muted: #94a3b8;--bg-light: #f8fafc;--bg-card: #ffffff;--border-light: #e2e8f0;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .06);--shadow-md: 0 4px 16px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 40px rgba(0, 0, 0, .15);--page-bg: linear-gradient(135deg, #e8ecf4 0%, #d4dce8 50%, #c0d0e0 100%)}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--page-bg);background-attachment:fixed;min-height:100vh;color:var(--text-primary);line-height:1.5;transition:background .3s ease,color .3s ease}#root{max-width:100%;margin:0;padding:0}::selection{background:#818cf84d;color:var(--text-primary)}:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}
