.layout{display:flex;height:100vh;background:var(--bg-primary);transition:background .3s ease}.sidebar{width:70px;color:var(--text-primary);display:flex;flex-direction:column;box-shadow:4px 0 20px #0000001a;position:relative;overflow:hidden}[data-theme=dark] .sidebar{background:#2d2d2f;border-right:1px solid rgba(255,255,255,.08)}[data-theme=light] .sidebar{background:#f5f5f7!important;border-right:1px solid rgba(0,0,0,.05);color:#1d1d1f!important}.sidebar-nav{flex:1;padding:24px 0;position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:8px}.sidebar-nav a{display:flex;align-items:center;justify-content:center;width:48px;height:48px;color:var(--text-secondary);text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);border-radius:10px;position:relative;overflow:hidden}.sidebar-nav a:before{content:"";position:absolute;left:0;top:0;bottom:0;width:0;background:rgba(0,113,227,.1);transition:width .3s ease}.sidebar-nav a:hover:before{width:100%}.sidebar-nav a:hover{background:var(--hover-bg);color:var(--text-primary);transform:scale(1.1)}.sidebar-nav a.active{background:rgba(0,113,227,.12);color:#0071e3}[data-theme=dark] .sidebar-nav a.active{background:rgba(0,113,227,.2);color:#0071e3}.nav-icon{font-size:20px;transition:transform .3s ease;line-height:1}.sidebar-nav a:hover .nav-icon{transform:scale(1.15)}.sidebar-footer{padding:16px 12px;border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:12px;align-items:center;position:relative;z-index:1}.theme-toggle{width:48px;height:48px;padding:0;background:var(--button-bg);border:2px solid var(--border-color);color:var(--text-primary);border-radius:10px;cursor:pointer;font-size:20px;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.theme-toggle:hover{background:var(--hover-bg);border-color:#0071e3}.logout-btn{width:48px;height:48px;padding:0;background:transparent;color:var(--text-primary);border:1px solid var(--border-color);border-radius:10px;cursor:pointer;font-size:20px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.logout-btn:hover{background:var(--hover-bg);border-color:#ff3b30;color:#ff3b30}.logout-btn:active{transform:scale(1.05)}.main-content{flex:1;overflow-y:auto;padding:0 40px 40px;background:var(--bg-primary);transition:background .3s ease}[data-theme=dark]{--bg-primary: #0f0f23;--bg-secondary: #1a1a2e;--sidebar-bg: #16213e;--text-primary: #e0e0e0;--text-secondary: #b0b0b0;--border-color: rgba(255, 255, 255, .1);--hover-bg: rgba(102, 126, 234, .15);--active-bg: rgba(102, 126, 234, .25);--button-bg: #1a1a2e;--card-bg: #1a1a2e;--card-shadow: 0 8px 32px rgba(0, 0, 0, .4)}[data-theme=light]{--bg-primary: #f8f9fa;--bg-secondary: #ffffff;--sidebar-bg: linear-gradient(180deg, #2c3e50 0%, #34495e 100%);--text-primary: #2c3e50;--text-secondary: #7f8c8d;--border-color: rgba(0, 0, 0, .1);--hover-bg: rgba(102, 126, 234, .1);--active-bg: rgba(102, 126, 234, .15);--button-bg: #ffffff;--card-bg: #ffffff;--card-shadow: 0 4px 16px rgba(0, 0, 0, .1)}[data-theme=light] .sidebar-header h1{background:linear-gradient(135deg,#ffffff 0%,#e0e0e0 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}[data-theme=light] .sidebar-nav a{color:#86868b!important}[data-theme=light] .sidebar-nav a:hover{color:#1d1d1f!important;background:rgba(0,113,227,.08)!important}[data-theme=light] .sidebar-nav a.active{background:rgba(0,113,227,.12)!important;color:#0071e3!important}[data-theme=light] .sidebar-nav a:before{background:rgba(0,113,227,.1)!important}[data-theme=light] .sidebar-footer{border-top-color:#0000000d!important}[data-theme=light] .theme-toggle{background:#ffffff!important;border-color:#0000000d!important;color:#1d1d1f!important}[data-theme=light] .theme-toggle:hover{background:rgba(0,113,227,.08)!important;border-color:#0071e3!important;color:#0071e3!important}[data-theme=light] .nav-icon{color:inherit}[data-theme=light] .user-name{color:#86868b!important}.modal-icon{width:56px;height:56px;border-radius:50%;background:#0071e3;display:flex;align-items:center;justify-content:center;color:#fff;font-size:24px}.modal-btn-confirm{background:#0071e3;color:#fff}.modal-btn-confirm:hover{background:#0077ed}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.intro-container{display:flex;flex-direction:column;min-height:100vh;background:var(--bg-primary);position:relative;overflow:hidden;padding:0}.intro-header-bar{display:flex;justify-content:space-between;align-items:center;padding:20px 40px;background:var(--card-bg);-webkit-backdrop-filter:saturate(180%) blur(20px);backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid var(--border-color);position:fixed;top:0;left:0;right:0;z-index:1000;width:100%;box-sizing:border-box}[data-theme=dark] .intro-header-bar{background:rgba(45,45,47,.8)}.header-logo{display:flex;align-items:center;gap:12px;font-size:24px;font-weight:600;color:var(--text-primary)}.logo-icon{font-size:28px}.logo-text{color:var(--text-primary)}.header-actions{display:flex;align-items:center;gap:16px}.header-button{padding:10px 24px;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;text-decoration:none;border:2px solid transparent;display:inline-block;box-shadow:0 2px 8px #0003}.header-button.login-button{background:transparent;color:var(--text-primary);border:none}.header-button.login-button:hover{color:#0071e3}.header-button.register-button{background:#0071e3;color:#fff;border:none}.header-button.register-button:hover{background:#0077ed}.header-button.play-button{background:#0071e3;color:#fff;border:none}.header-button.play-button:hover{background:#0077ed}.theme-toggle-intro{width:44px;height:44px;border-radius:50%;background:transparent;border:1px solid var(--border-color);color:var(--text-primary);font-size:20px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;padding:0}.theme-toggle-intro:hover{background:rgba(0,113,227,.08);border-color:#0071e3;color:#0071e3}[data-theme=dark] .theme-toggle-intro{border-color:#ffffff1a;color:#f5f5f7}[data-theme=dark] .theme-toggle-intro:hover{background:rgba(0,113,227,.15);border-color:#0071e3;color:#0071e3}.intro-main{flex:1;position:relative;z-index:1;padding-top:80px}.hero-section{min-height:70vh;display:flex;align-items:center;justify-content:center;padding:80px 20px;position:relative}.hero-content{max-width:900px;width:100%;text-align:center;animation:slide-up .6s ease}.hero-title{font-size:72px;font-weight:600;color:var(--text-primary);margin:0 0 24px;letter-spacing:-2px;line-height:1.1}.hero-subtitle{font-size:28px;color:var(--text-primary);font-weight:400;margin:0 0 20px}.hero-description{font-size:21px;color:var(--text-secondary);font-weight:400;line-height:1.5;max-width:700px;margin:0 auto 40px}.hero-actions{display:flex;justify-content:center;gap:16px}.hero-button{padding:12px 22px;background:#0071e3;color:#fff;border:none;border-radius:22px;font-size:17px;font-weight:400;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden}.hero-button:hover{background:#0077ed}.hero-button:active{transform:scale(.98)}.section-container{max-width:1200px;width:100%;margin:0 auto;padding:0 20px}.features-section{padding:100px 0;background:var(--bg-secondary)}.section-title{font-size:48px;font-weight:600;text-align:center;margin:0 0 16px;color:var(--text-primary);letter-spacing:-1px}.section-subtitle{font-size:21px;color:var(--text-secondary);text-align:center;margin:0 0 50px}.intro-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:30px;margin-top:50px}.feature-card{background:var(--card-bg);padding:40px 30px;border-radius:18px;box-shadow:var(--card-shadow);border:1px solid var(--border-color);text-align:center;transition:all .3s ease;animation:fade-in .8s ease}[data-theme=dark] .feature-card{border-color:#ffffff1f}.feature-card:nth-child(1){animation-delay:.1s}.feature-card:nth-child(2){animation-delay:.2s}.feature-card:nth-child(3){animation-delay:.3s}.feature-card:nth-child(4){animation-delay:.4s}.feature-card:nth-child(5){animation-delay:.5s}.feature-card:nth-child(6){animation-delay:.6s}.feature-card:nth-child(7){animation-delay:.7s}.feature-card:nth-child(8){animation-delay:.8s}@keyframes fade-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.feature-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.feature-icon{font-size:48px;margin-bottom:20px;color:var(--text-primary);display:flex;align-items:center;justify-content:center}.feature-card h3{font-size:22px;font-weight:600;color:var(--text-primary);margin:0 0 12px}.feature-card p{font-size:17px;color:var(--text-secondary);margin:0;line-height:1.5}.statistics-section{padding:80px 0;background:var(--card-bg)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:40px;max-width:1000px;margin:0 auto}.stat-item{text-align:center;padding:30px 20px}.stat-icon{font-size:48px;color:#0071e3;margin-bottom:20px;display:flex;justify-content:center}.stat-number{font-size:48px;font-weight:600;color:var(--text-primary);margin-bottom:8px;line-height:1}.stat-label{font-size:17px;color:var(--text-secondary);font-weight:400}.demo-section{padding:100px 0;background:var(--bg-secondary)}.demo-placeholder{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:40px;margin-top:50px}.demo-card{background:transparent;border-radius:0;padding:0;text-align:center;border:none;box-shadow:none;transition:all .3s ease}.demo-card:hover{transform:translateY(-8px)}.demo-card p{font-size:17px;color:var(--text-secondary);margin:20px 0 0;font-weight:500}.demo-screenshot{background:var(--card-bg);border-radius:12px;overflow:hidden;box-shadow:var(--card-shadow);border:1px solid var(--border-color);transition:all .3s ease}[data-theme=dark] .demo-screenshot{border-color:#ffffff1f}.demo-card:hover .demo-screenshot{box-shadow:0 12px 48px #00000029}.screenshot-header{background:var(--bg-secondary);padding:12px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid rgba(0,0,0,.05)}.screenshot-dots{display:flex;gap:6px}.screenshot-dots span{width:12px;height:12px;border-radius:50%;background:#d1d1d6}.screenshot-dots span:nth-child(1){background:#ff5f57}.screenshot-dots span:nth-child(2){background:#ffbd2e}.screenshot-dots span:nth-child(3){background:#28ca42}.screenshot-title{font-size:13px;color:var(--text-secondary);font-weight:500}.chess-board-mockup{display:grid;grid-template-columns:repeat(8,1fr);aspect-ratio:1;padding:20px;background:var(--bg-secondary)}.board-square{aspect-ratio:1;display:flex;align-items:center;justify-content:center;position:relative}.board-square.light{background:#f0d9b5}.board-square.dark{background:#b58863}.demo-piece{width:70%;height:70%;object-fit:contain}.analysis-mockup{padding:20px;background:var(--card-bg);min-height:300px;display:flex;flex-direction:column;gap:16px}.analysis-board{display:flex;justify-content:center}.mini-board{width:120px;height:120px;background:linear-gradient(135deg,#f0d9b5 25%,#b58863 25%,#b58863 50%,#f0d9b5 50%,#f0d9b5 75%,#b58863 75%,#b58863);background-size:30px 30px;border-radius:8px;border:2px solid #e0e0e0}.analysis-moves{display:flex;flex-direction:column;gap:8px;padding:12px;background:var(--bg-secondary);border-radius:8px}.move-item{font-size:14px;color:var(--text-secondary);padding:8px 12px;border-radius:6px;font-family:Courier New,monospace}.move-item.active{background:#0071e3;color:#fff;font-weight:600}.analysis-quality{padding:16px;background:var(--bg-secondary);border-radius:8px;text-align:center}.quality-badge{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.quality-text{font-size:13px;color:var(--text-secondary);line-height:1.4}.friends-mockup{padding:20px;background:var(--card-bg);min-height:300px;display:flex;flex-direction:column;gap:12px}.friend-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-secondary);border-radius:10px}.friend-avatar{width:44px;height:44px;border-radius:50%;background:#0071e3;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:18px;flex-shrink:0}.friend-info{flex:1;text-align:left}.friend-name{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.friend-status{font-size:13px;color:var(--text-secondary)}.friend-status.online{color:#28ca42}.friend-status.offline{color:var(--text-secondary)}.challenge-btn{padding:8px 16px;background:#0071e3;color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.challenge-btn:hover:not(:disabled){background:#0077ed}.challenge-btn:disabled{background:#d1d1d6;color:var(--text-secondary);cursor:not-allowed}.how-it-works-section{padding:100px 0;background:var(--card-bg)}.steps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:40px;margin-top:50px}.step-item{text-align:center;position:relative;padding:20px}.step-number{position:absolute;top:-10px;left:50%;transform:translate(-50%);width:40px;height:40px;background:#0071e3;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:600;z-index:1}.step-icon{font-size:48px;color:#0071e3;margin:20px 0;display:flex;justify-content:center}.step-item h3{font-size:22px;font-weight:600;color:var(--text-primary);margin:0 0 12px}.step-item p{font-size:17px;color:var(--text-secondary);margin:0;line-height:1.5}.tech-section{padding:100px 0;background:var(--bg-secondary)}.tech-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:30px;margin-top:50px}.tech-item{background:var(--card-bg);padding:30px 20px;border-radius:18px;text-align:center;border:1px solid var(--border-color);box-shadow:0 2px 8px #00000014;transition:all .3s ease}.tech-item:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.tech-name{font-size:24px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.tech-desc{font-size:15px;color:var(--text-secondary)}.testimonials-section{padding:100px 0;background:var(--card-bg)}.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:30px;margin-top:50px}.testimonial-card{background:var(--bg-secondary);padding:40px 30px;border-radius:18px;border:1px solid var(--border-color);transition:all .3s ease}.testimonial-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.testimonial-stars{display:flex;gap:4px;margin-bottom:20px;color:gold;font-size:18px}.testimonial-text{font-size:17px;color:var(--text-primary);line-height:1.6;margin:0 0 20px;font-style:italic}.testimonial-author{font-size:15px;color:var(--text-secondary);font-weight:500}.quick-start-section{padding:100px 0;background:var(--bg-secondary)}.guide-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:30px;margin-top:50px}.guide-step{background:var(--card-bg);padding:30px;border-radius:18px;border:1px solid var(--border-color);box-shadow:0 2px 8px #00000014;transition:all .3s ease}.guide-step:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.guide-step-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.guide-check{font-size:24px;color:#0071e3;flex-shrink:0}.guide-step-header h3{font-size:22px;font-weight:600;color:var(--text-primary);margin:0}.guide-step p{font-size:17px;color:var(--text-secondary);margin:0;line-height:1.5;padding-left:36px}.faq-section{padding:100px 0;background:var(--card-bg)}.faq-list{max-width:800px;margin:50px auto 0}.faq-item{border-bottom:1px solid rgba(0,0,0,.1);margin-bottom:20px}.faq-question{width:100%;display:flex;justify-content:space-between;align-items:center;padding:24px 0;background:transparent;border:none;text-align:left;cursor:pointer;font-size:20px;font-weight:500;color:var(--text-primary);transition:color .2s ease}.faq-question:hover{color:#0071e3}.faq-icon{font-size:20px;color:var(--text-secondary);transition:transform .3s ease;flex-shrink:0;margin-left:20px}.faq-icon.open{transform:rotate(180deg)}.faq-answer{padding:0 0 24px;animation:slide-down .3s ease}.faq-answer p{font-size:17px;color:var(--text-secondary);line-height:1.6;margin:0}@keyframes slide-down{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.newsletter-section{padding:100px 0;background:var(--bg-secondary)}.newsletter-form{display:flex;gap:12px;max-width:500px;margin:50px auto 0;flex-wrap:wrap;justify-content:center}.newsletter-input{flex:1;min-width:250px;padding:14px 20px;border:1px solid var(--border-color);border-radius:22px;font-size:17px;color:var(--text-primary);background:var(--card-bg);transition:all .2s ease}.newsletter-input:focus{outline:none;border-color:#0071e3;box-shadow:0 0 0 4px #0071e31a}.newsletter-button{padding:14px 28px;background:#0071e3;color:#fff;border:none;border-radius:22px;font-size:17px;font-weight:400;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px}.newsletter-button:hover{background:#0077ed}.newsletter-button:active{transform:scale(.98)}.contact-section{padding:100px 0;background:var(--card-bg)}.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:40px;margin-top:50px}.contact-item{text-align:center;padding:40px 30px;background:var(--bg-secondary);border-radius:18px;border:1px solid var(--border-color);transition:all .3s ease}.contact-item:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.contact-icon{font-size:48px;color:#0071e3;margin-bottom:20px;display:flex;justify-content:center}.contact-item h3{font-size:22px;font-weight:600;color:var(--text-primary);margin:0 0 12px}.contact-item p{font-size:17px;color:var(--text-secondary);margin:0 0 20px}.contact-link{color:#0071e3;text-decoration:none;font-size:17px;font-weight:500;display:inline-flex;align-items:center;gap:8px;transition:all .2s ease}.contact-link:hover{color:#0077ed;text-decoration:underline}.download-section{padding:100px 0;text-align:center;background:var(--card-bg)}.download-buttons{display:flex;gap:20px;justify-content:center;flex-wrap:wrap}.download-button{display:flex;flex-direction:column;align-items:center;gap:12px;padding:24px 32px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:18px;cursor:pointer;transition:all .3s ease;min-width:140px;position:relative;box-shadow:0 2px 8px #00000014}.download-button:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f;border-color:var(--border-color)}.download-button.recommended{border-color:#0071e3;background:var(--bg-secondary)}.download-button.recommended:hover{box-shadow:0 8px 24px #0071e326;background:#f0f0f2}.download-icon{width:40px;height:40px;flex-shrink:0;object-fit:contain}.download-label{font-size:17px;font-weight:400;color:var(--text-primary)}.download-badge{position:absolute;top:-8px;right:-8px;background:#0071e3;color:#fff;font-size:11px;font-weight:500;padding:4px 10px;border-radius:12px;box-shadow:0 2px 8px #0071e34d;text-transform:uppercase;letter-spacing:.5px}.intro-footer{background:var(--bg-secondary);border-top:1px solid rgba(0,0,0,.1);padding:40px 20px;position:relative;z-index:1}.footer-content{max-width:1200px;width:100%;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:24px}.footer-logo{display:flex;align-items:center;gap:12px;font-size:20px;font-weight:600;color:var(--text-primary)}.footer-logo .logo-icon{font-size:24px}.footer-logo .logo-text{color:var(--text-primary)}.footer-links{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:center}.footer-link{color:#424245;text-decoration:none;font-weight:400;font-size:15px;transition:all .2s ease}.footer-link:hover{color:#0071e3;text-decoration:underline}.footer-separator{color:var(--text-secondary);font-size:16px}.footer-copyright{text-align:center}.footer-copyright p{color:var(--text-secondary);font-size:12px;margin:0}@media (max-width: 768px){.intro-title{font-size:48px}.intro-subtitle{font-size:18px}.intro-features{grid-template-columns:1fr;gap:20px}.feature-card{padding:30px 20px}.intro-header-bar{padding:16px 20px;flex-wrap:wrap;gap:12px}.header-logo{font-size:20px}.logo-icon{font-size:28px}.header-actions{gap:12px}.header-button{padding:8px 16px;font-size:14px}.theme-toggle-intro{width:40px;height:40px;font-size:18px}.hero-section{min-height:60vh;padding:60px 20px}.hero-title{font-size:48px}.hero-subtitle{font-size:22px}.hero-description{font-size:16px}.hero-button{padding:16px 36px;font-size:16px}.features-section,.download-section,.statistics-section,.demo-section,.how-it-works-section,.tech-section,.testimonials-section,.quick-start-section,.faq-section,.newsletter-section,.contact-section{padding:60px 0}.section-title{font-size:32px}.section-subtitle{font-size:16px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:30px}.stat-number,.stat-icon{font-size:36px}.demo-placeholder{grid-template-columns:1fr;gap:30px}.chess-board-mockup{padding:15px}.demo-piece{width:60%;height:60%}.analysis-mockup,.friends-mockup{min-height:250px;padding:16px}.mini-board{width:100px;height:100px}.friend-item{padding:10px}.friend-avatar{width:40px;height:40px;font-size:16px}.challenge-btn{padding:6px 12px;font-size:12px}.steps-grid{grid-template-columns:1fr;gap:30px}.step-number{width:36px;height:36px;font-size:18px}.step-icon{font-size:36px}.tech-grid{grid-template-columns:repeat(2,1fr)}.testimonials-grid,.guide-steps{grid-template-columns:1fr}.guide-step p{padding-left:0}.contact-grid{grid-template-columns:1fr}.newsletter-form{flex-direction:column;align-items:stretch}.newsletter-input{min-width:auto;width:100%}.newsletter-button{width:100%;justify-content:center}.download-buttons{flex-direction:column;align-items:stretch}.download-button{width:100%;min-width:auto;padding:20px 24px}.download-icon{width:36px;height:36px}.download-label{font-size:16px}}.auth-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:#ffffff;position:relative;overflow:hidden}[data-theme=dark] .auth-container{background:#1d1d1f}.back-button-auth{position:absolute;top:24px;left:24px;width:44px;height:44px;border-radius:50%;background:transparent;border:1px solid rgba(0,0,0,.1);color:#1d1d1f;font-size:20px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;z-index:10}[data-theme=dark] .back-button-auth{border-color:#ffffff1a;color:#f5f5f7}.back-button-auth:hover{background:rgba(0,113,227,.08);border-color:#0071e3;color:#0071e3}.theme-toggle-auth{position:absolute;top:24px;right:24px;width:44px;height:44px;border-radius:50%;background:transparent;border:1px solid rgba(0,0,0,.1);color:#1d1d1f;font-size:20px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;z-index:10}[data-theme=dark] .theme-toggle-auth{border-color:#ffffff1a;color:#f5f5f7}.theme-toggle-auth:hover{background:rgba(0,113,227,.08);border-color:#0071e3;color:#0071e3}.auth-card{background:var(--card-bg);padding:48px;border-radius:18px;box-shadow:0 2px 8px #00000014;width:100%;max-width:420px;position:relative;z-index:1;border:1px solid var(--border-color);animation:slide-up .5s ease}@keyframes slide-up{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.auth-card h1{text-align:center;margin:0 0 12px;font-size:36px;font-weight:600;color:var(--text-primary)}.auth-card h2{text-align:center;margin:0 0 36px;color:var(--text-primary);font-weight:700;font-size:26px}.form-group{margin-bottom:24px}.form-group label{display:block;margin-bottom:10px;color:var(--text-primary);font-weight:600;font-size:14px}.form-group input{width:100%;padding:14px 16px;border:2px solid var(--border-color);border-radius:10px;font-size:15px;transition:all .3s ease;box-sizing:border-box;background:var(--bg-secondary);color:var(--text-primary)}.auth-button{width:100%;padding:16px;background:#0071e3;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:12px}.auth-button:hover{background:#0077ed}.auth-button:active{transform:translateY(-1px)}.error-message{background:rgba(231,76,60,.15);color:#e74c3c;padding:12px;border-radius:8px;margin-bottom:20px;font-size:14px;text-align:center;border:1px solid rgba(231,76,60,.3)}.auth-link{text-align:center;margin-top:24px;color:var(--text-secondary);font-size:14px}.auth-link a{color:#0071e3;text-decoration:none;font-weight:600;transition:all .2s ease}.auth-link a:hover{text-decoration:underline;color:#0077ed}.chess-board{display:flex;align-items:center;gap:12px}.board-container{display:flex;flex-direction:column;align-items:center}.file-labels{display:flex;width:720px;justify-content:space-around;padding:6px 0}.file-label{width:65px;text-align:center;font-weight:700;color:var(--text-secondary);font-size:14px}.rank-labels{display:flex;flex-direction:column;justify-content:space-around;height:520px}.rank-label{height:65px;display:flex;align-items:center;font-weight:700;color:var(--text-secondary);font-size:14px}.board-grid{display:grid;grid-template-columns:repeat(8,65px);grid-template-rows:repeat(8,65px);border:4px solid var(--border-color);box-shadow:0 8px 32px #0000004d,0 0 0 1px #ffffff1a;border-radius:8px;overflow:hidden;background:var(--bg-secondary)}.square{width:65px;height:65px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;position:relative}.square.light{background-color:#f0d9b5}.square.dark{background-color:#b58863}[data-theme=dark] .square.light{background-color:#eeeed2}[data-theme=dark] .square.dark{background-color:#769656}[data-theme=light] .square.light{background-color:#f0d9b5}[data-theme=light] .square.dark{background-color:#b58863}.square:hover{filter:brightness(1.2);transform:scale(1.05);z-index:10;box-shadow:0 4px 12px #0000004d}.square.selected{background:linear-gradient(135deg,#ffd54f 0%,#ffb300 100%)!important;box-shadow:inset 0 0 0 3px #ff6f00,0 0 20px #ffd70099;z-index:20;animation:pulse 1.5s ease infinite}@keyframes pulse{0%,to{box-shadow:inset 0 0 0 3px #ff6f00,0 0 20px #ffd70099}50%{box-shadow:inset 0 0 0 3px #ff6f00,0 0 30px #ffd700cc}}.square:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:rgba(102,126,234,.2);transform:translate(-50%,-50%);transition:width .3s ease,height .3s ease}.square:hover:before{width:40px;height:40px}.piece-container{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.piece{width:90%;height:90%;object-fit:contain;-webkit-user-select:none;user-select:none;pointer-events:none;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));transition:all .3s ease}.piece.checkmated{filter:drop-shadow(0 0 15px rgba(255,0,0,.8)) drop-shadow(0 0 30px rgba(255,0,0,.6)) drop-shadow(0 2px 4px rgba(0,0,0,.3));animation:checkmatePulse 1s ease-in-out infinite}@keyframes checkmatePulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}.square.checkmated-king{background:linear-gradient(135deg,rgba(255,0,0,.3) 0%,rgba(220,20,60,.4) 100%)!important;box-shadow:inset 0 0 20px #ff000080,0 0 30px #f006;animation:checkmateSquarePulse 1.5s ease-in-out infinite}@keyframes checkmateSquarePulse{0%,to{box-shadow:inset 0 0 20px #ff000080,0 0 30px #f006}50%{box-shadow:inset 0 0 30px #ff0000b3,0 0 50px #f009}}.badge{position:absolute;top:-8px;right:-8px;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;z-index:100;animation:badgeAppear .5s ease-out;box-shadow:0 4px 12px #0006}@keyframes badgeAppear{0%{transform:scale(0) rotate(-180deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}.winner-badge-icon{background:linear-gradient(135deg,#ffd700 0%,#ffed4e 100%);border:2px solid #ffaa00}.loser-badge-icon{background:linear-gradient(135deg,#666 0%,#333 100%);border:2px solid #444}.square-move-quality-badge{position:absolute;top:-8px;right:-8px;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:150;animation:badgeAppear .5s ease-out;box-shadow:0 4px 12px #0006,0 0 20px #fff3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:2px solid rgba(255,255,255,.3)}.square.move-quality-brilliant .square-move-quality-badge{background:linear-gradient(135deg,rgba(255,215,0,.9) 0%,rgba(255,223,0,.85) 100%);border-color:#ffd70099}.square.move-quality-great .square-move-quality-badge{background:linear-gradient(135deg,rgba(76,175,80,.9) 0%,rgba(76,175,80,.85) 100%);border-color:#4caf5099}.square.move-quality-good .square-move-quality-badge{background:linear-gradient(135deg,rgba(33,150,243,.9) 0%,rgba(33,150,243,.85) 100%);border-color:#2196f399}.square.move-quality-inaccuracy .square-move-quality-badge{background:linear-gradient(135deg,rgba(255,152,0,.9) 0%,rgba(255,152,0,.85) 100%);border-color:#ff980099}.square.move-quality-mistake .square-move-quality-badge{background:linear-gradient(135deg,rgba(255,87,34,.9) 0%,rgba(255,87,34,.85) 100%);border-color:#ff572299}.square.move-quality-blunder .square-move-quality-badge{background:linear-gradient(135deg,rgba(244,67,54,.9) 0%,rgba(244,67,54,.85) 100%);border-color:#f4433699}.square-move-quality-icon{width:24px!important;height:24px!important;color:#fff;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}.square-move-quality-icon.brilliant{color:#fff;filter:drop-shadow(0 0 8px rgba(255,215,0,.8)) drop-shadow(0 2px 4px rgba(0,0,0,.5));animation:sparkle 2s ease-in-out infinite}.square-move-quality-icon.great,.square-move-quality-icon.good,.square-move-quality-icon.inaccuracy,.square-move-quality-icon.mistake,.square-move-quality-icon.blunder{color:#fff}@keyframes sparkle{0%,to{filter:drop-shadow(0 0 8px rgba(255,215,0,.8)) drop-shadow(0 2px 4px rgba(0,0,0,.5))}50%{filter:drop-shadow(0 0 16px rgba(255,215,0,1)) drop-shadow(0 0 24px rgba(255,215,0,.6)) drop-shadow(0 2px 4px rgba(0,0,0,.5))}}.square.move-quality-brilliant{background:linear-gradient(135deg,rgba(255,215,0,.15) 0%,rgba(255,223,0,.1) 100%)!important;box-shadow:inset 0 0 0 2px #ffd70066,0 0 20px #ffd7004d}.square.move-quality-great{background:linear-gradient(135deg,rgba(76,175,80,.12) 0%,rgba(76,175,80,.08) 100%)!important;box-shadow:inset 0 0 0 2px #4caf504d}.square.move-quality-good{background:linear-gradient(135deg,rgba(33,150,243,.1) 0%,rgba(33,150,243,.06) 100%)!important;box-shadow:inset 0 0 0 2px #2196f34d}.square.move-quality-inaccuracy{background:linear-gradient(135deg,rgba(255,152,0,.1) 0%,rgba(255,152,0,.06) 100%)!important;box-shadow:inset 0 0 0 2px #ff98004d}.square.move-quality-mistake{background:linear-gradient(135deg,rgba(255,87,34,.12) 0%,rgba(255,87,34,.08) 100%)!important;box-shadow:inset 0 0 0 2px #ff572266}.square.move-quality-blunder{background:linear-gradient(135deg,rgba(244,67,54,.15) 0%,rgba(244,67,54,.1) 100%)!important;box-shadow:inset 0 0 0 2px #f4433680,0 0 15px #f4433633}.chess-board.board-large .square-move-quality-badge{width:42px;height:42px;top:-10px;right:-10px}.chess-board.board-large .square-move-quality-icon{width:28px!important;height:28px!important}.chess-board.board-small .square-move-quality-badge{width:28px;height:28px;top:-6px;right:-6px}.chess-board.board-small .square-move-quality-icon{width:18px!important;height:18px!important}.square:hover .piece{transform:scale(1.1)}.move-indicator{position:absolute;top:50%;left:50%;width:20px;height:20px;border-radius:50%;background:rgba(102,126,234,.6);transform:translate(-50%,-50%);z-index:3;pointer-events:none}.chess-board.board-large .move-indicator{width:30px;height:30px}.chess-board.board-small .move-indicator{width:12px;height:12px}.capture-indicator{position:absolute;top:0;left:0;right:0;bottom:0;border:4px solid rgba(255,0,0,.6);border-radius:50%;z-index:4;pointer-events:none;box-sizing:border-box}.chess-board.board-large .capture-indicator{border-width:5px}.chess-board.board-small .capture-indicator{border-width:3px}.square.possible-move{background-color:#667eea26!important}.square.possible-move.light{background-color:#667eea33!important}.square.possible-move.dark{background-color:#667eea40!important}[data-theme=dark] .board-grid{border-color:#fff3}[data-theme=light] .board-grid{border-color:#2c3e50}.chess-board.board-large .file-labels{width:720px;padding:6px 0;height:24px}.chess-board.board-large .file-label{width:90px;font-size:14px}.chess-board.board-large .rank-labels{height:720px}.chess-board.board-large .rank-label{height:90px;font-size:16px}.chess-board.board-large .board-grid{grid-template-columns:repeat(8,90px);grid-template-rows:repeat(8,90px);border-width:5px}.chess-board.board-large .square{width:90px;height:90px}.chess-board.board-large .square:hover:before{width:60px;height:60px}.chess-board.board-small .file-labels{width:400px;padding:4px 0}.chess-board.board-small .file-label{width:50px;font-size:12px}.chess-board.board-small .rank-labels{height:400px}.chess-board.board-small .rank-label{height:50px;font-size:12px}.chess-board.board-small .board-grid{grid-template-columns:repeat(8,50px);grid-template-rows:repeat(8,50px);border-width:3px}.chess-board.board-small .square{width:50px;height:50px}.chess-board.board-small .square:hover:before{width:30px;height:30px}.play-page{max-width:100%;margin:0;padding:0;min-height:calc(100vh - 80px);overflow-y:auto;overflow-x:hidden}.game-selection-container{max-width:1200px;margin:0 auto;padding:40px 20px;min-height:calc(100vh - 80px);display:flex;flex-direction:column;align-items:center;justify-content:center}.selection-header{text-align:center;margin-bottom:48px}.selection-header h1{margin:0 0 12px;font-size:42px;font-weight:600;color:var(--text-primary)}.selection-header p{font-size:18px;color:var(--text-secondary);margin:0}.game-types-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;width:100%;max-width:1000px;margin-bottom:48px}.game-type-card{background:var(--card-bg);border:2px solid var(--border-color);border-radius:16px;padding:32px;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;box-shadow:var(--card-shadow)}.game-type-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:#0071e3;transform:scaleX(0);transition:transform .3s ease}.game-type-card:hover:before{transform:scaleX(1)}.game-type-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f;border-color:#0071e3}.game-type-card.selected{border-color:#0071e3;background:rgba(0,113,227,.05);box-shadow:0 8px 24px #0071e31f}.game-type-card.selected:before{transform:scaleX(1)}.game-type-icon{font-size:48px;margin-bottom:20px;transition:transform .3s ease}.game-type-card:hover .game-type-icon{transform:scale(1.1) rotate(5deg)}.game-type-content{display:flex;flex-direction:column;gap:8px}.game-type-content h3{margin:0;font-size:24px;font-weight:700;color:var(--text-primary)}.game-type-content p{margin:0;font-size:15px;color:var(--text-secondary);line-height:1.5}.game-type-meta{margin-top:8px;font-size:13px;font-weight:600;color:#0071e3;padding:6px 12px;background:rgba(0,113,227,.1);border-radius:20px;width:fit-content}.game-type-card.selected .game-type-meta{background:rgba(0,113,227,.15)}.selected-indicator{position:absolute;top:16px;right:16px;width:32px;height:32px;border-radius:50%;background:#0071e3;color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700}.start-game-section{display:flex;justify-content:center;width:100%;max-width:1000px}.start-game-btn{padding:18px 48px;background:#0071e3;color:#fff;border:none;border-radius:8px;font-size:18px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:12px}.start-game-btn:hover:not(:disabled){background:#0077ed}.start-game-btn:active:not(:disabled){transform:translateY(0)}.start-game-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.start-game-btn svg{font-size:20px}.game-container{display:grid;grid-template-columns:1fr 380px;gap:24px;height:100%;max-width:1600px;margin:0 auto}.board-section{display:flex;flex-direction:column;gap:0;background:var(--card-bg);border-radius:12px;padding:8px 16px 16px;box-shadow:var(--card-shadow);border:1px solid var(--border-color);overflow:visible}.player-bar{display:flex;flex-direction:column;padding:12px 16px;background:var(--bg-secondary);border-radius:8px;margin-bottom:0;gap:8px;transition:all .3s ease}.player-bar.active-turn{border:2px solid #0071e3;box-shadow:0 0 20px #0071e34d;background:linear-gradient(135deg,var(--bg-secondary) 0%,rgba(0,113,227,.05) 100%)}.player-bar.top-player{margin-bottom:0;border-radius:8px 8px 0 0;padding-bottom:8px;position:relative;z-index:2}.player-bar.bottom-player{margin-bottom:0;margin-top:0;border-radius:0 0 8px 8px}.player-main-row{display:flex;align-items:center;justify-content:space-between;gap:16px}.player-info-bar{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.player-avatar-small{width:40px;height:40px;border-radius:50%;background:#0071e3;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.player-name-rating{display:flex;align-items:center;gap:8px}.player-name-bar{font-size:16px;font-weight:700;color:var(--text-primary)}.player-rating-bar{font-size:13px;color:var(--text-secondary);font-weight:500}.player-secondary-row{display:flex;align-items:center;justify-content:flex-start;gap:12px;padding-left:52px;min-height:26px}.captured-pieces-bar{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.captured-icon{width:18px;height:18px;object-fit:contain;filter:drop-shadow(0 1px 2px rgba(0,0,0,.2))}.material-points{padding:4px 10px;border-radius:12px;font-size:13px;font-weight:700;font-family:Courier New,monospace}.material-points.positive{background:rgba(76,175,80,.2);color:#4caf50;border:1px solid rgba(76,175,80,.3)}.material-points.negative{background:rgba(244,67,54,.2);color:#f44336;border:1px solid rgba(244,67,54,.3)}.clock{font-size:24px;font-weight:700;font-family:Courier New,monospace;padding:8px 16px;border-radius:6px;border:2px solid var(--border-color);min-width:80px;text-align:center;letter-spacing:1px;flex-shrink:0}.clock.white-clock{background:var(--card-bg);color:var(--text-primary);border-color:var(--border-color)}[data-theme=light] .clock.white-clock,[data-theme=dark] .clock.white-clock{background:#ffffff;color:#333;border-color:#ddd}.clock.black-clock{background:var(--button-bg);color:var(--text-primary);border-color:var(--border-color)}[data-theme=light] .clock.black-clock,[data-theme=dark] .clock.black-clock{background:#2c3e50;color:#fff;border-color:#1a252f}.board-wrapper{display:flex;align-items:center;justify-content:center;padding:8px;background:var(--bg-secondary);border-radius:0;min-height:720px;position:relative;z-index:1}.game-info-container{display:flex;flex-direction:column;gap:16px;overflow-y:auto;padding-right:8px;max-height:calc(100vh - 80px)}.game-info-container::-webkit-scrollbar{width:6px}.game-info-container::-webkit-scrollbar-thumb{background:rgba(0,113,227,.5);border-radius:10px}.game-status-bar{background:linear-gradient(135deg,var(--card-bg) 0%,rgba(0,113,227,.05) 100%);border-radius:14px;padding:14px 18px;box-shadow:0 2px 12px #00000014,0 1px 3px #0000001f;border:1px solid rgba(0,113,227,.15);display:flex;justify-content:space-between;align-items:center;gap:20px;position:relative;z-index:10;min-height:56px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease}.game-status-bar:hover{box-shadow:0 4px 16px #0000001f,0 2px 6px #00000029;border-color:#0071e340}.status-text{font-weight:600;color:var(--text-primary);font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0;letter-spacing:.2px;display:flex;align-items:center;gap:8px}.review-mode-text{display:flex;align-items:center;gap:8px;flex-wrap:nowrap}.review-label{font-weight:700;color:var(--text-primary);text-transform:uppercase;font-size:13px;letter-spacing:.5px}.review-separator{color:var(--text-secondary);font-weight:400}.evaluating-indicator{margin-left:8px;display:inline-flex;align-items:center;color:var(--accent-color);font-size:14px}.review-move-info{color:var(--text-secondary);font-weight:500}.game-controls-bar{display:flex;gap:10px;align-items:center;position:relative;z-index:100;flex-shrink:0}.control-btn-small{padding:0;border:1.5px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);border-radius:8px;cursor:pointer;font-weight:600;font-size:13px;transition:all .25s cubic-bezier(.4,0,.2,1);pointer-events:auto!important;-webkit-user-select:none;user-select:none;display:inline-flex;align-items:center;justify-content:center;gap:6px;white-space:nowrap;position:relative;z-index:100;-webkit-tap-highlight-color:transparent;min-width:38px;width:38px;height:38px;flex-shrink:0;overflow:hidden}.control-btn-small.text-btn{padding:0 14px;min-width:auto;width:auto;gap:8px}.control-btn-small.text-btn span{font-size:13px;font-weight:600}.control-btn-small svg{width:16px;height:16px}.control-btn-small:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.control-btn-small:hover{background:var(--hover-bg);border-color:#0071e3;color:#0071e3;transform:translateY(-1px);box-shadow:0 4px 8px #0071e333}.control-btn-small:active{transform:translateY(0);box-shadow:0 2px 4px #0071e326}.control-btn-small.abort-btn{background:linear-gradient(135deg,rgba(255,152,0,.12) 0%,rgba(255,152,0,.08) 100%);border-color:#ff980066;color:#ff9800}.control-btn-small.abort-btn:hover{background:linear-gradient(135deg,rgba(255,152,0,.22) 0%,rgba(255,152,0,.15) 100%);border-color:#ff9800;color:#ff9800;box-shadow:0 4px 12px #ff98004d}.control-btn-small.resign-btn{background:linear-gradient(135deg,rgba(244,67,54,.1) 0%,rgba(244,67,54,.06) 100%);border-color:#f443364d;color:#f44336}.control-btn-small.resign-btn:hover{background:linear-gradient(135deg,rgba(244,67,54,.2) 0%,rgba(244,67,54,.12) 100%);border-color:#f44336;color:#f44336;box-shadow:0 4px 12px #f443364d}.control-btn-small.draw-btn{background:linear-gradient(135deg,rgba(0,113,227,.1) 0%,rgba(0,113,227,.06) 100%);border-color:#0071e34d;color:#0071e3}.control-btn-small.draw-btn:hover{background:linear-gradient(135deg,rgba(0,113,227,.2) 0%,rgba(0,113,227,.12) 100%);border-color:#0071e3;color:#0071e3;box-shadow:0 4px 12px #0071e34d}.control-btn-small.exit-review-btn{background:rgba(244,67,54,.1);border-color:#f44336;color:#f44336;padding:0 12px;min-width:auto;width:auto}.control-btn-small.exit-review-btn:hover{background:rgba(244,67,54,.2);border-color:#d32f2f;color:#d32f2f}.move-history-panel{background:var(--card-bg);border-radius:12px;box-shadow:var(--card-shadow);border:1px solid var(--border-color);overflow:hidden}.panel-tabs{display:flex;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.tab-btn{flex:1;padding:12px;border:none;background:transparent;color:var(--text-secondary);font-weight:600;font-size:14px;cursor:pointer;transition:all .2s ease;border-bottom:2px solid transparent}.tab-btn.active{color:#0071e3;border-bottom-color:#0071e3;background:var(--card-bg)}.tab-btn:hover{background:var(--hover-bg)}.move-history-content{padding:16px;min-height:300px;max-height:400px;overflow-y:auto}.starting-position{text-align:center;color:var(--text-secondary);font-style:italic;padding:40px 20px;font-size:14px}.move-list-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:4px;font-family:Courier New,monospace}.move-item{padding:8px 12px;border-radius:4px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px}.move-item.white-move{background:var(--bg-secondary);color:var(--text-primary)}.move-item.black-move{background:var(--bg-secondary);color:var(--text-secondary)}.move-item:hover{background:var(--hover-bg)}.move-item.current-move{background:rgba(0,113,227,.2);border:2px solid #0071e3;font-weight:700}.move-number{color:var(--text-secondary);margin-right:4px;flex-shrink:0}.move-notation{color:var(--text-primary);flex:1}.move-quality-icon{font-size:16px;flex-shrink:0;margin-left:auto;transition:transform .2s ease}.move-quality-icon:hover{transform:scale(1.2)}.move-quality-icon.brilliant{color:gold;filter:drop-shadow(0 0 3px rgba(255,215,0,.6));animation:sparkle 2s ease-in-out infinite}.move-quality-icon.great{color:#4caf50;filter:drop-shadow(0 0 2px rgba(76,175,80,.5))}.move-quality-icon.good{color:#2196f3;filter:drop-shadow(0 0 2px rgba(33,150,243,.4))}.move-quality-icon.inaccuracy{color:#ff9800;filter:drop-shadow(0 0 2px rgba(255,152,0,.4))}.move-quality-icon.mistake{color:#f44336;filter:drop-shadow(0 0 2px rgba(244,67,54,.4))}.move-quality-icon.blunder{color:#d32f2f;filter:drop-shadow(0 0 3px rgba(211,47,47,.6));animation:pulse 1.5s ease-in-out infinite}.move-item.quality-brilliant{background:linear-gradient(135deg,rgba(255,215,0,.15) 0%,rgba(255,215,0,.05) 100%);border-left:3px solid #ffd700}.move-item.quality-great{background:linear-gradient(135deg,rgba(76,175,80,.12) 0%,rgba(76,175,80,.04) 100%);border-left:3px solid #4caf50}.move-item.quality-good{background:linear-gradient(135deg,rgba(33,150,243,.1) 0%,rgba(33,150,243,.03) 100%);border-left:3px solid #2196f3}.move-item.quality-inaccuracy{background:linear-gradient(135deg,rgba(255,152,0,.1) 0%,rgba(255,152,0,.03) 100%);border-left:3px solid #ff9800}.move-item.quality-mistake{background:linear-gradient(135deg,rgba(244,67,54,.12) 0%,rgba(244,67,54,.04) 100%);border-left:3px solid #f44336}.move-item.quality-blunder{background:linear-gradient(135deg,rgba(211,47,47,.15) 0%,rgba(211,47,47,.05) 100%);border-left:3px solid #d32f2f}@keyframes sparkle{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.material-advantage-panel{background:var(--card-bg);border-radius:12px;padding:16px;box-shadow:var(--card-shadow);border:1px solid var(--border-color);text-align:center}.advantage-label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.advantage-value{font-size:32px;font-weight:800;font-family:Courier New,monospace;letter-spacing:1px}.advantage-value.white-advantage{color:#4caf50}.advantage-value.black-advantage{color:#f44336}.evaluation-bar-panel{background:var(--card-bg);border-radius:12px;padding:16px;box-shadow:var(--card-shadow);border:1px solid var(--border-color);margin-bottom:16px}.evaluation-bar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.evaluation-bar-label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.evaluation-bar-value{font-size:16px;font-weight:700;font-family:Courier New,monospace;letter-spacing:.5px}.evaluation-bar-value.white-advantage{color:#4caf50}.evaluation-bar-value.black-advantage{color:#f44336}.evaluation-bar-value.equal{color:var(--text-secondary)}.evaluation-bar-container{width:100%;height:24px;background:#000;border-radius:12px;overflow:hidden;position:relative;border:1px solid var(--border-color)}.evaluation-bar{width:100%;height:100%;display:flex;position:relative;background:#000}.evaluation-bar-fill{height:100%;background:#ffffff;transition:width .3s ease;min-width:0;border-radius:12px 0 0 12px}.chat-panel{background:var(--card-bg);border-radius:12px;box-shadow:var(--card-shadow);border:1px solid var(--border-color);display:flex;flex-direction:column;height:400px;overflow:hidden}.chat-header{padding:16px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.chat-header h3{margin:0;font-size:16px;font-weight:700;color:var(--text-primary)}.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-thumb{background:rgba(0,113,227,.5);border-radius:10px}.chat-empty{text-align:center;color:var(--text-secondary);font-style:italic;padding:40px 20px;font-size:14px}.chat-message{padding:10px 12px;border-radius:8px;background:var(--bg-secondary);border:1px solid var(--border-color);transition:all .2s ease}.chat-message.own-message{background:rgba(0,113,227,.1);border-color:#0071e34d;align-self:flex-end;max-width:80%}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;gap:12px}.message-user{font-weight:700;font-size:13px;color:var(--text-primary)}.message-time{font-size:11px;color:var(--text-secondary);font-weight:500}.message-text{font-size:14px;color:var(--text-primary);line-height:1.4;word-wrap:break-word}.chat-input-form{display:flex;gap:8px;padding:12px;border-top:1px solid var(--border-color);background:var(--bg-secondary)}.chat-input{flex:1;padding:10px 14px;border:1px solid var(--border-color);border-radius:8px;background:var(--card-bg);color:var(--text-primary);font-size:14px;transition:all .2s ease}.chat-input:focus{outline:none;border-color:#0071e3;box-shadow:0 0 0 3px #0071e31a}.chat-send-btn{padding:10px 20px;background:#0071e3;color:#fff;border:none;border-radius:8px;font-weight:700;font-size:14px;cursor:pointer;transition:all .2s ease}.chat-send-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0071e366}.chat-send-btn:active{transform:translateY(0)}.promotion-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.75);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10001;animation:fadeIn .2s ease}.promotion-modal{background:var(--card-bg);border-radius:16px;box-shadow:0 20px 60px #00000080,0 0 0 1px #ffffff1a;border:2px solid var(--border-color);padding:24px;animation:slideUp .3s ease;min-width:300px}.promotion-modal-header{text-align:center;margin-bottom:20px}.promotion-modal-header h3{margin:0;font-size:18px;font-weight:700;color:var(--text-primary)}.promotion-pieces{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}.promotion-piece-btn{background:var(--card-bg);border:2px solid var(--border-color);border-radius:12px;padding:12px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;width:80px;height:80px;box-shadow:0 4px 12px #0003}.promotion-piece-btn:hover{transform:translateY(-4px) scale(1.05);border-color:var(--accent-color);box-shadow:0 8px 24px #0071e366;background:linear-gradient(135deg,rgba(0,113,227,.1) 0%,rgba(118,75,162,.1) 100%)}.promotion-piece-btn:active{transform:translateY(-2px) scale(1.02)}.promotion-piece-image{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.move-explanation-panel{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;display:flex;flex-direction:column;height:100%;max-height:600px;box-shadow:var(--card-shadow);overflow:hidden}.move-explanation-header{padding:16px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.move-explanation-header h3{margin:0;font-size:16px;font-weight:700;color:var(--text-primary)}.move-explanation-content{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column}.move-explanation-content::-webkit-scrollbar{width:6px}.move-explanation-content::-webkit-scrollbar-thumb{background:rgba(0,113,227,.5);border-radius:10px}.move-explanation-empty{text-align:center;color:var(--text-secondary);font-style:italic;padding:40px 20px;font-size:14px}.move-explanation-text{color:var(--text-primary);font-size:14px;line-height:1.6;white-space:pre-wrap}.move-explanation-text p{margin:0 0 8px}.move-explanation-text p:last-child{margin-bottom:0}@media (max-width: 1400px){.game-container{grid-template-columns:1fr 350px;gap:20px}}@media (max-width: 1200px){.game-container{grid-template-columns:1fr;height:auto}.game-info-container{max-height:none;order:-1}.board-section{order:1}.game-types-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.75);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease}.modal-container{background:var(--card-bg);border-radius:16px;box-shadow:0 20px 60px #00000080,0 0 0 1px #ffffff1a;border:1px solid var(--border-color);width:90%;max-width:420px;animation:slideUp .3s ease;overflow:hidden}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;flex-direction:column;align-items:center;padding:24px 24px 16px;gap:12px}.modal-icon{width:56px;height:56px;border-radius:50%;background:rgba(255,152,0,.15);display:flex;align-items:center;justify-content:center;color:#ff9800;font-size:28px;border:2px solid rgba(255,152,0,.3)}.modal-title{font-size:22px;font-weight:700;color:var(--text-primary);margin:0;text-align:center}.modal-body{padding:0 24px 24px}.modal-message{color:var(--text-secondary);font-size:15px;line-height:1.6;text-align:center;margin:0}.modal-footer{display:flex;gap:12px;padding:16px 24px;border-top:1px solid var(--border-color);background:var(--bg-secondary)}.modal-btn{flex:1;padding:12px 24px;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease}.modal-btn-cancel{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.modal-btn-cancel:hover{background:var(--hover-bg);border-color:var(--text-secondary)}.modal-btn-confirm{background:#0071e3;color:#fff;box-shadow:0 4px 12px #0071e34d}.modal-btn-confirm:hover{transform:translateY(-1px);box-shadow:0 6px 16px #0071e366}.modal-btn-confirm:active{transform:translateY(0)}.game-end-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.85);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .3s ease}.game-end-modal{background:var(--card-bg);border-radius:20px;padding:40px;max-width:500px;width:90%;box-shadow:0 20px 60px #00000080,0 0 0 1px #ffffff1a;animation:slideUp .4s ease;border:2px solid var(--border-color)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.game-end-content{text-align:center;display:flex;flex-direction:column;align-items:center;gap:20px}.game-end-icon{font-size:80px;animation:iconBounce .6s ease;margin-bottom:10px}.checkmate-icon{filter:drop-shadow(0 0 20px rgba(255,215,0,.8))}.stalemate-icon{filter:drop-shadow(0 0 20px rgba(150,150,150,.8))}@keyframes iconBounce{0%{transform:scale(0) rotate(-180deg)}60%{transform:scale(1.2) rotate(10deg)}to{transform:scale(1) rotate(0)}}.game-end-title{font-size:36px;font-weight:800;margin:0;color:var(--text-primary);text-transform:uppercase;letter-spacing:2px}.game-end-winner{font-size:24px;font-weight:600;margin:0;color:var(--accent-color);text-shadow:0 2px 10px rgba(0,113,227,.5)}.game-end-reason{font-size:16px;color:var(--text-secondary);margin:10px 0;padding:12px 20px;background:var(--bg-secondary);border-radius:10px;border:1px solid var(--border-color)}.game-end-buttons{display:flex;gap:12px;width:100%;margin-top:20px}.game-end-btn{flex:1;padding:14px 20px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:8px;color:#fff}.game-end-btn.primary{background:#0071e3;box-shadow:0 4px 15px #0071e366}.game-end-btn.primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0071e399}.game-end-btn.secondary{background:var(--bg-secondary);color:var(--text-primary);border:2px solid var(--border-color)}.game-end-btn.secondary:hover{background:var(--hover-bg);border-color:var(--accent-color);transform:translateY(-2px)}.game-end-btn:active{transform:translateY(0)}.game-configuration-container{max-width:900px;margin:0 auto;padding:20px 20px 40px;min-height:100%;position:relative;overflow-x:hidden}.config-header{text-align:center;position:sticky;top:0;background:var(--bg-primary);padding:20px 0;z-index:10;border-bottom:1px solid var(--border-color);margin-bottom:24px}.back-button{position:absolute;left:0;top:0;display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);cursor:pointer;font-size:14px;font-weight:600;transition:all .2s ease}.back-button:hover{background:var(--hover-bg);border-color:#0071e3;color:#0071e3}.config-header h1{margin:0 0 12px;font-size:36px}.config-header p{color:var(--text-secondary);font-size:16px;margin:0}.config-content{display:flex;flex-direction:column;gap:32px;overflow-x:hidden;width:100%}.config-section{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;padding:24px;box-shadow:var(--card-shadow);width:100%;box-sizing:border-box;overflow-x:hidden}.config-label{display:flex;align-items:center;gap:12px;margin-bottom:20px;font-size:18px;font-weight:700;color:var(--text-primary)}.config-label svg{font-size:20px;color:#0071e3}.time-controls-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.time-control-btn{padding:16px 12px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:10px;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;gap:6px}.time-control-btn:hover{border-color:#0071e3;transform:translateY(-2px)}.time-control-btn.active{background:linear-gradient(135deg,rgba(0,113,227,.15) 0%,rgba(118,75,162,.15) 100%);border-color:#0071e3;box-shadow:0 4px 12px #0071e333}.time-value{font-size:18px;font-weight:700;color:var(--text-primary)}.time-desc{font-size:12px;color:var(--text-secondary)}.rated-toggle{display:grid;grid-template-columns:1fr 1fr;gap:12px}.rated-option{padding:20px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:10px;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;gap:8px}.rated-option:hover{border-color:#0071e3;transform:translateY(-2px)}.rated-option.active{background:linear-gradient(135deg,rgba(0,113,227,.15) 0%,rgba(118,75,162,.15) 100%);border-color:#0071e3;box-shadow:0 4px 12px #0071e333}.rated-option svg{font-size:24px;color:#fbbf24}.rated-option span{font-size:16px;font-weight:700;color:var(--text-primary)}.rated-option small{font-size:12px;color:var(--text-secondary)}.friend-search-container{margin-bottom:16px}.friend-search-input{width:100%;padding:12px 16px;border:2px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:14px;transition:all .2s ease}.friend-search-input:focus{outline:none;border-color:#0071e3;box-shadow:0 0 0 3px #0071e31a}.friend-search-input::placeholder{color:var(--text-secondary)}.friends-list-config{display:flex;flex-direction:column;gap:12px;overflow:visible}.no-friends-found{text-align:center;padding:32px 20px;color:var(--text-secondary);font-size:14px;font-style:italic}.loading-friends{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;gap:12px;color:var(--text-secondary);font-size:14px}.loading-friends svg{font-size:24px;color:var(--text-secondary)}.no-friends{text-align:center;padding:40px 20px;color:var(--text-secondary);font-size:14px}.no-friends p{margin:0;line-height:1.6}.friend-item{padding:16px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:10px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:16px;text-align:left;width:100%;box-sizing:border-box;position:relative;overflow:hidden}.friend-item:hover{border-color:#0071e3;background:rgba(0,113,227,.05)}.friend-item.selected{background:linear-gradient(135deg,rgba(0,113,227,.15) 0%,rgba(118,75,162,.15) 100%);border-color:#0071e3;box-shadow:0 4px 12px #0071e333}.friend-avatar-small{width:48px;height:48px;border-radius:50%;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.friend-info{flex:1;display:flex;flex-direction:column;gap:4px}.friend-name{font-size:16px;font-weight:700;color:var(--text-primary)}.friend-rating{font-size:13px;color:var(--text-secondary)}.friend-status{font-size:13px;font-weight:600;padding:6px 12px;border-radius:6px;background:var(--bg-primary);border:1px solid var(--border-color)}.friend-status.online{color:#10b981;border-color:#10b9814d}.color-selection{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.color-option{padding:20px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:10px;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;gap:12px}.color-option:hover{border-color:#0071e3;transform:translateY(-2px)}.color-option.active{background:linear-gradient(135deg,rgba(0,113,227,.15) 0%,rgba(118,75,162,.15) 100%);border-color:#0071e3;box-shadow:0 4px 12px #0071e333}.color-preview{width:60px;height:60px;border-radius:8px;border:2px solid var(--border-color);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700}.white-preview{background:#f3f4f6;color:#374151}.black-preview{background:#1f2937;color:#f9fafb}.random-preview{background:linear-gradient(135deg,#f3f4f6 0%,#1f2937 100%);color:#fff}.color-option span{font-size:14px;font-weight:600;color:var(--text-primary)}.bots-list{display:flex;flex-direction:column;gap:12px;max-height:400px;overflow-y:auto}.bot-item{padding:16px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:10px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:16px;text-align:left}.bot-item:hover{border-color:#0071e3;transform:translate(4px)}.bot-item.selected{background:linear-gradient(135deg,rgba(0,113,227,.15) 0%,rgba(118,75,162,.15) 100%);border-color:#0071e3;box-shadow:0 4px 12px #0071e333}.bot-icon{font-size:32px;flex-shrink:0}.bot-info{flex:1;display:flex;flex-direction:column;gap:4px}.bot-name{font-size:16px;font-weight:700;color:var(--text-primary)}.bot-details{font-size:13px;color:var(--text-secondary)}.config-footer{margin-top:24px;display:flex;justify-content:center}.start-game-config-btn{padding:16px 48px;background:#0071e3;color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:12px;box-shadow:0 4px 15px #0071e366}.start-game-config-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #0071e380}.start-game-config-btn:disabled{opacity:.5;cursor:not-allowed}.waiting-container{display:flex;align-items:center;justify-content:center;height:100%;padding:40px 20px}.waiting-content{text-align:center;max-width:500px}.waiting-icon{font-size:64px;margin-bottom:24px;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.waiting-content h2{margin:0 0 16px;font-size:28px;color:var(--text-primary)}.waiting-content p{color:var(--text-secondary);font-size:16px;margin-bottom:32px;line-height:1.6}.loading-spinner{width:48px;height:48px;border:4px solid var(--border-color);border-top-color:#0071e3;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 32px}@keyframes spin{to{transform:rotate(360deg)}}.cancel-request-btn{padding:12px 32px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.cancel-request-btn:hover{background:var(--hover-bg);border-color:#0071e3;color:#0071e3}.friends-page{max-width:900px;margin:0 auto;padding-top:40px}.friends-page h1{margin:0 0 32px;font-size:36px;font-weight:600;color:var(--text-primary)}.section{background:var(--card-bg);border-radius:16px;padding:28px;margin-bottom:28px;box-shadow:var(--card-shadow);border:1px solid var(--border-color);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:fade-in .4s ease}@keyframes fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.section h2{margin:0 0 24px;color:var(--text-primary);font-size:22px;font-weight:700}.friend-list{display:flex;flex-direction:column;gap:16px}.friend-card{display:flex;justify-content:space-between;align-items:center;padding:20px;background:var(--bg-secondary);border-radius:12px;transition:all .3s ease;border:1px solid var(--border-color);position:relative;overflow:hidden}.friend-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:#0071e3;transform:scaleY(0);transition:transform .3s ease}.friend-card:hover:before{transform:scaleY(1)}.friend-card:hover{background:var(--hover-bg);transform:translate(8px);box-shadow:0 4px 12px #0000001a}.friend-info{display:flex;align-items:center;gap:16px}.friend-avatar{width:56px;height:56px;border-radius:50%;background:#0071e3;color:#fff;display:flex;align-items:center;justify-content:center;font-size:28px;transition:transform .3s ease}.friend-card:hover .friend-avatar{transform:scale(1.1) rotate(5deg)}.friend-name{font-size:18px;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:10px}.status-indicator{font-size:12px;font-weight:600;padding:4px 8px;border-radius:12px;text-transform:uppercase;letter-spacing:.5px}.status-indicator.online{color:#4caf50;background:rgba(76,175,80,.15)}.status-indicator.playing{color:#2196f3;background:rgba(33,150,243,.15)}.status-indicator.offline{color:var(--text-secondary);background:rgba(128,128,128,.15)}.friend-rating{font-size:14px;color:var(--text-secondary);margin-top:4px;font-weight:500}.last-seen{font-size:12px;color:var(--text-secondary);margin-top:4px}.friend-actions{display:flex;gap:8px;flex-wrap:wrap}.friend-actions button{padding:10px 18px;border:none;border-radius:8px;cursor:pointer;font-size:13px;font-weight:700;transition:all .3s ease;position:relative;overflow:hidden}.friend-actions button:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:rgba(255,255,255,.2);transform:translate(-50%,-50%);transition:width .4s,height .4s}.friend-actions button:hover:before{width:200px;height:200px}.btn-challenge{background:linear-gradient(135deg,#4caf50 0%,#45a049 100%);color:#fff;box-shadow:0 4px 12px #4caf504d}.btn-challenge:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4caf5066}.btn-message{background:linear-gradient(135deg,#2196f3 0%,#0b7dda 100%);color:#fff;box-shadow:0 4px 12px #2196f34d}.btn-message:hover{transform:translateY(-2px);box-shadow:0 6px 20px #2196f366}.btn-accept{background:linear-gradient(135deg,#4caf50 0%,#45a049 100%);color:#fff;box-shadow:0 4px 12px #4caf504d}.btn-accept:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4caf5066}.btn-decline{background:linear-gradient(135deg,#f44336 0%,#da190b 100%);color:#fff;box-shadow:0 4px 12px #f443364d}.btn-decline:hover{transform:translateY(-2px);box-shadow:0 6px 20px #f4433666}.btn-remove{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-remove:hover{background:rgba(244,67,54,.1);border-color:#f44336;color:#f44336}.search-section{display:flex;gap:12px}.search-input{flex:1;padding:14px 18px;border:2px solid var(--border-color);border-radius:10px;font-size:14px;background:var(--bg-secondary);color:var(--text-primary);transition:all .3s ease}.search-input:focus{outline:none;border-color:#0071e3;box-shadow:0 0 0 4px #0071e31a;transform:translateY(-1px)}.btn-search{padding:14px 28px;background:#0071e3;color:#fff;border:none;border-radius:10px;cursor:pointer;font-weight:700;transition:all .3s ease;box-shadow:0 4px 12px #0071e34d}.btn-search:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0071e366}.btn-search:active{transform:translateY(0)}.btn-search:disabled{opacity:.6;cursor:not-allowed}.btn-search:disabled:hover{transform:translateY(0);box-shadow:0 4px 12px #0071e34d}.btn-add{padding:10px 20px;background:#0071e3;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:14px;transition:all .3s ease;box-shadow:0 2px 8px #0071e34d}.btn-add:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0071e366}.btn-add:active{transform:translateY(0)}.search-results{margin-top:24px}.search-error{margin-top:12px;color:#f44336;font-size:14px;padding:8px 12px;background:rgba(244,67,54,.1);border-radius:8px;border:1px solid rgba(244,67,54,.3)}.history-page{max-width:1000px;margin:0 auto;padding-top:40px}.history-page h1{margin:0 0 32px;font-size:36px;font-weight:600;color:var(--text-primary)}.stats-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:24px;margin-bottom:36px}.stat-card{background:var(--card-bg);border-radius:16px;padding:28px;text-align:center;box-shadow:var(--card-shadow);border:1px solid var(--border-color);transition:all .3s ease;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,transparent,currentColor,transparent);transform:translate(-100%);transition:transform .6s ease}.stat-card:hover:before{transform:translate(100%)}.stat-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0003}.stat-card.win{border-top:4px solid #4caf50;color:#4caf50}.stat-card.loss{border-top:4px solid #f44336;color:#f44336}.stat-card.draw{border-top:4px solid #ff9800;color:#ff9800}.stat-value{font-size:42px;font-weight:800;color:var(--text-primary);margin-bottom:10px;font-family:Courier New,monospace}.stat-label{font-size:13px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;font-weight:700}.filters{display:flex;gap:12px;margin-bottom:28px;flex-wrap:wrap}.filters button{padding:12px 24px;border:2px solid var(--border-color);background:var(--card-bg);color:var(--text-secondary);border-radius:10px;cursor:pointer;font-weight:700;font-size:14px;transition:all .3s ease;position:relative;overflow:hidden}.filters button:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:rgba(0,113,227,.1);transform:translate(-50%,-50%);transition:width .4s,height .4s}.filters button:hover:before{width:200px;height:200px}.filters button:hover{border-color:#0071e3;color:#0071e3;transform:translateY(-2px)}.filters button.active{background:#0071e3;border-color:#0071e3;color:#fff;box-shadow:0 4px 12px #0071e366}.no-games{text-align:center;padding:60px 20px;color:var(--text-secondary);font-size:16px}.games-list{display:flex;flex-direction:column;gap:20px}.game-card{background:var(--card-bg);border-radius:16px;padding:24px;box-shadow:var(--card-shadow);border-left:5px solid var(--border-color);border:1px solid var(--border-color);transition:all .3s ease;position:relative;overflow:hidden}.game-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:linear-gradient(180deg,currentColor 0%,transparent 100%);transition:width .3s ease}.game-card:hover:before{width:8px}.game-card:hover{transform:translate(8px);box-shadow:0 8px 24px #0003}.game-card.win{border-left-color:#4caf50;color:#4caf50}.game-card.loss{border-left-color:#f44336;color:#f44336}.game-card.draw{border-left-color:#ff9800;color:#ff9800}.game-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.game-opponent{display:flex;align-items:center;gap:14px}.opponent-icon{font-size:28px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.opponent-name{font-size:20px;font-weight:700;color:var(--text-primary)}.rating-change{padding:6px 12px;border-radius:8px;font-size:13px;font-weight:800;margin-left:12px}.game-card.win .rating-change{background:rgba(76,175,80,.15);color:#4caf50}.game-card.loss .rating-change{background:rgba(244,67,54,.15);color:#f44336}.game-card.draw .rating-change{background:rgba(255,152,0,.15);color:#ff9800}.result-badge{padding:8px 20px;border-radius:20px;font-size:14px;font-weight:800;text-transform:uppercase;letter-spacing:.5px}.result-badge.win{background:rgba(76,175,80,.15);color:#4caf50;border:1px solid rgba(76,175,80,.3)}.result-badge.loss{background:rgba(244,67,54,.15);color:#f44336;border:1px solid rgba(244,67,54,.3)}.result-badge.draw{background:rgba(255,152,0,.15);color:#ff9800;border:1px solid rgba(255,152,0,.3)}.game-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:20px;padding:20px;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-color)}.detail-item{display:flex;gap:10px;align-items:center}.detail-label{font-weight:700;color:var(--text-secondary);font-size:13px;text-transform:uppercase;letter-spacing:.5px}.detail-value{color:var(--text-primary);font-weight:600}.game-actions{display:flex;gap:12px}.game-actions button{padding:10px 20px;border:none;border-radius:10px;cursor:pointer;font-size:14px;font-weight:700;transition:all .3s ease;position:relative;overflow:hidden}.game-actions button:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:rgba(255,255,255,.2);transform:translate(-50%,-50%);transition:width .4s,height .4s}.game-actions button:hover:before{width:200px;height:200px}.btn-view{background:linear-gradient(135deg,#2196f3 0%,#0b7dda 100%);color:#fff;box-shadow:0 4px 12px #2196f34d}.btn-view:hover{transform:translateY(-2px);box-shadow:0 6px 20px #2196f366}.btn-analyze{background:linear-gradient(135deg,#9c27b0 0%,#7b1fa2 100%);color:#fff;box-shadow:0 4px 12px #9c27b04d}.btn-analyze:hover{transform:translateY(-2px);box-shadow:0 6px 20px #9c27b066}.account-page{max-width:1200px;margin:0 auto;padding-top:40px}.account-page h1{margin:0 0 32px;font-size:36px;font-weight:600;color:var(--text-primary)}.account-container{display:grid;grid-template-columns:300px 1fr;gap:28px}.profile-card{background:var(--card-bg);border-radius:20px;padding:32px;text-align:center;box-shadow:var(--card-shadow);border:1px solid var(--border-color);margin-bottom:24px;position:relative;overflow:hidden}.profile-card:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(0,113,227,.1) 1px,transparent 1px);background-size:30px 30px;animation:pattern-move 20s linear infinite}@keyframes pattern-move{0%{transform:translate(0)}to{transform:translate(30px,30px)}}.profile-avatar{width:110px;height:110px;border-radius:50%;background:#0071e3;color:#fff;display:flex;align-items:center;justify-content:center;font-size:54px;margin:0 auto 20px;position:relative;z-index:1;transition:transform .3s ease}.profile-card:hover .profile-avatar{transform:scale(1.05) rotate(5deg)}.profile-name{font-size:22px;font-weight:700;color:var(--text-primary);margin-bottom:20px;position:relative;z-index:1}.profile-rating{display:flex;flex-direction:column;gap:6px;position:relative;z-index:1}.rating-label{font-size:12px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;font-weight:700}.rating-value{font-size:36px;font-weight:800;color:#0071e3}.tab-nav{background:var(--card-bg);border-radius:16px;padding:8px;box-shadow:var(--card-shadow);display:flex;flex-direction:column;gap:6px;border:1px solid var(--border-color)}.tab-nav button{padding:14px 18px;border:none;background:transparent;text-align:left;border-radius:10px;cursor:pointer;font-weight:700;color:var(--text-secondary);transition:all .3s ease;font-size:15px;position:relative;overflow:hidden}.tab-nav button:before{content:"";position:absolute;left:0;top:0;bottom:0;width:0;background:rgba(0,113,227,.1);transition:width .3s ease}.tab-nav button:hover:before{width:100%}.tab-nav button:hover{background:var(--hover-bg);color:var(--text-primary);transform:translate(4px)}.tab-nav button.active{background:rgba(0,113,227,.12);color:#0071e3;border-left:3px solid #0071e3}.account-content{background:var(--card-bg);border-radius:20px;padding:40px;box-shadow:var(--card-shadow);border:1px solid var(--border-color);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.tab-content h2{margin:0 0 28px;color:var(--text-primary);font-size:28px;font-weight:800}.form-section{display:flex;flex-direction:column;gap:24px}.form-group{display:flex;flex-direction:column;gap:10px}.form-group label{font-weight:700;color:var(--text-primary);font-size:14px;text-transform:uppercase;letter-spacing:.5px}.form-group input{padding:14px 18px;border:2px solid var(--border-color);border-radius:12px;font-size:15px;transition:all .3s ease;background:var(--bg-secondary);color:var(--text-primary)}.form-group input:focus{outline:none;border-color:#0071e3;box-shadow:0 0 0 4px #0071e31a}.form-group input[readonly]{background:var(--bg-secondary);cursor:not-allowed;opacity:.7}.form-group small{font-size:12px;color:var(--text-secondary)}.btn-save{padding:14px 32px;background:#0071e3;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;align-self:flex-start;transition:all .2s ease;font-size:15px}.btn-save:hover{background:#0077ed}.btn-save:active{transform:translateY(0)}.settings-section{display:flex;flex-direction:column;gap:24px}.setting-item{display:flex;justify-content:space-between;align-items:center;padding:24px;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-color);transition:all .3s ease}.setting-item:hover{background:var(--hover-bg);transform:translate(4px)}.setting-label{font-weight:700;color:var(--text-primary);margin-bottom:6px;font-size:15px}.setting-description{font-size:13px;color:var(--text-secondary)}.toggle{position:relative;display:inline-block;width:54px;height:28px}.toggle input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--border-color);transition:.4s;border-radius:28px}.slider:before{position:absolute;content:"";height:22px;width:22px;left:3px;bottom:3px;background-color:#fff;transition:.4s;border-radius:50%;box-shadow:0 2px 4px #0003}.toggle input:checked+.slider{background:#0071e3}.toggle input:checked+.slider:before{transform:translate(26px)}.select-input{padding:12px 16px;border:2px solid var(--border-color);border-radius:10px;font-size:14px;background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;min-width:180px;transition:all .3s ease;font-weight:600}.select-input:focus{outline:none;border-color:#0071e3;box-shadow:0 0 0 4px #0071e31a}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:24px;margin-bottom:36px}.stat-box{background:var(--bg-secondary);border-radius:16px;padding:28px;text-align:center;border:1px solid var(--border-color);transition:all .3s ease}.stat-box:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0003}.stat-box.win{border-top:4px solid #4caf50}.stat-box.loss{border-top:4px solid #f44336}.stat-box.draw{border-top:4px solid #ff9800}.stat-icon{font-size:36px;margin-bottom:12px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.stat-number{font-size:40px;font-weight:800;color:var(--text-primary);margin-bottom:6px;font-family:Courier New,monospace}.stat-text{font-size:13px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;font-weight:700}.win-rate{margin-bottom:36px}.win-rate h3{margin:0 0 16px;color:var(--text-primary);font-size:20px;font-weight:700}.win-rate-bar{width:100%;height:32px;background:var(--bg-secondary);border-radius:16px;overflow:hidden;margin-bottom:12px;border:2px solid var(--border-color);position:relative}.win-rate-fill{height:100%;background:linear-gradient(90deg,#4caf50 0%,#8bc34a 100%);transition:width .6s ease;border-radius:14px;position:relative;overflow:hidden}.win-rate-fill:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{left:-100%}to{left:100%}}.win-rate-text{font-size:24px;font-weight:800;color:var(--text-primary);text-align:center;font-family:Courier New,monospace}.rating-history h3{margin:0 0 20px;color:var(--text-primary);font-size:20px;font-weight:700}.rating-chart{background:var(--bg-secondary);border-radius:16px;padding:32px;min-height:240px;border:1px solid var(--border-color);display:flex;flex-direction:column;align-items:center;justify-content:center}.chart-placeholder{text-align:center;color:var(--text-secondary);margin-bottom:24px;font-size:16px;font-weight:600}.chart-dummy{display:flex;align-items:flex-end;justify-content:space-around;height:180px;width:100%;gap:12px;padding:0 20px}.chart-bar{flex:1;background:#0071e3;border-radius:6px 6px 0 0;min-height:20px;transition:all .3s ease;position:relative;overflow:hidden}.chart-bar:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 3s infinite}.chart-bar:hover{opacity:.8;transform:scaleY(1.05)}@media (max-width: 900px){.account-container{grid-template-columns:1fr}}*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #ffffff;--bg-secondary: #f5f5f7;--sidebar-bg: #f5f5f7;--text-primary: #1d1d1f;--text-secondary: #86868b;--border-color: rgba(0, 0, 0, .05);--hover-bg: rgba(0, 113, 227, .08);--active-bg: rgba(0, 113, 227, .12);--button-bg: #ffffff;--card-bg: #fafafa;--card-shadow: 0 2px 8px rgba(0, 0, 0, .08);--accent-color: #0071e3}[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f5f5f7;--sidebar-bg: #f5f5f7;--text-primary: #1d1d1f;--text-secondary: #86868b;--border-color: rgba(0, 0, 0, .05);--hover-bg: rgba(0, 113, 227, .08);--active-bg: rgba(0, 113, 227, .12);--button-bg: #ffffff;--card-bg: #fafafa;--card-shadow: 0 2px 8px rgba(0, 0, 0, .08);--accent-color: #0071e3}[data-theme=dark]{--bg-primary: #1d1d1f;--bg-secondary: #2d2d2f;--sidebar-bg: #2d2d2f;--text-primary: #f5f5f7;--text-secondary: #86868b;--border-color: rgba(255, 255, 255, .08);--hover-bg: rgba(0, 113, 227, .15);--active-bg: rgba(0, 113, 227, .2);--button-bg: #2d2d2f;--card-bg: #323234;--card-shadow: 0 4px 16px rgba(0, 0, 0, .3);--accent-color: #0071e3}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-primary);color:var(--text-primary);transition:background .3s ease,color .3s ease;overflow-x:hidden;margin:0;padding:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh;width:100vw;background:var(--bg-primary)}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:10px}::-webkit-scrollbar-thumb{background:#0071e3;border-radius:10px;border:2px solid var(--bg-secondary)}::-webkit-scrollbar-thumb:hover{background:#0077ed}*{transition-property:background-color,border-color,color;transition-duration:.2s;transition-timing-function:ease}h1{font-size:36px;font-weight:600;color:var(--text-primary);margin-bottom:32px;letter-spacing:-.5px}h2{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:20px}h3{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:16px}
