.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}.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}.config-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.config-page{background:#fff;border-radius:20px;width:90%;max-width:500px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 25px 80px #0000004d;animation:slideUp .3s ease-out;overflow:hidden}@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:linear-gradient(145deg,#f8fafc,#f1f5f9)}.config-header h2{margin:0;font-size:1.3rem;color:#1f2937;font-weight:700}.config-close{width:36px;height:36px;border:none;background:transparent;border-radius:10px;font-size:1.25rem;color:#64748b;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.config-close:hover{background:#fee2e2;color:#dc2626}.config-content{flex:1;overflow-y:auto;padding:1.5rem}.config-section{margin-bottom:1.75rem;padding-bottom:1.75rem;border-bottom:1px solid #e2e8f0}.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:#64748b;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}.theme-option{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.75rem;border:2px solid #e2e8f0;border-radius:12px;background:#fff;cursor:pointer;transition:all .2s ease}.theme-option:hover{border-color:#667eea;transform:translateY(-2px)}.theme-option.active{border-color:#667eea;background:#667eea0d;box-shadow:0 0 0 3px #667eea26}.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:#374151}.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 #e2e8f0;border-radius:10px;background:#fff;cursor:pointer;transition:all .2s ease}.piece-style-option:hover{border-color:#667eea;transform:translateY(-2px)}.piece-style-option.active{border-color:#667eea;background:#667eea0d;box-shadow:0 0 0 3px #667eea26}.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:#374151;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 #e2e8f0;border-radius:12px;background:#fff;cursor:pointer;transition:all .2s ease}.notation-option:hover{border-color:#667eea;transform:translateY(-2px)}.notation-option.active{border-color:#667eea;background:#667eea0d;box-shadow:0 0 0 3px #667eea26}.notation-name{font-size:.9rem;font-weight:600;color:#374151}.notation-example{font-size:.75rem;color:#64748b;font-family:SF Mono,Monaco,Consolas,monospace;background:#f1f5f9;padding:.25rem .5rem;border-radius:4px}.config-option{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:linear-gradient(145deg,#f8fafc,#f1f5f9);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:#1f2937;font-size:.95rem}.config-description{font-size:.8rem;color:#64748b}.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:linear-gradient(135deg,#667eea,#764ba2)}.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)}.slider-container{display:flex;align-items:center;gap:.75rem}.config-slider{width:120px;height:6px;border-radius:3px;background:#e2e8f0;-moz-appearance:none;appearance:none;-webkit-appearance:none;cursor:pointer}.config-slider::-webkit-slider-thumb{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 6px #667eea66;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:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 6px #667eea66;cursor:pointer;border:none}.slider-value{font-size:.85rem;font-weight:600;color:#667eea;min-width:50px;text-align:right}.about-section{background:linear-gradient(145deg,#f8fafc,#f1f5f9);padding:1.25rem;border-radius:12px;border:1px solid #e2e8f0}.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:#1f2937}.version-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:.65rem;font-weight:600;padding:.2rem .5rem;border-radius:20px;text-transform:uppercase;letter-spacing:.5px}.about-description{color:#4b5563;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 #e2e8f0}.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:#64748b;margin-bottom:1rem;line-height:1.4}.toggle-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#f8fafc;border-radius:10px;margin-bottom:1rem}.toggle-label{display:flex;flex-direction:column;gap:.125rem}.toggle-label span:first-child{font-weight:600;color:#1f2937;font-size:.9rem}.toggle-hint{font-size:.75rem;color:#64748b}.elo-selector{margin-top:.5rem}.elo-label{display:block;font-weight:600;color:#374151;font-size:.85rem;margin-bottom:.5rem}.elo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.elo-option{padding:.625rem .5rem;border:2px solid #e2e8f0;border-radius:10px;background:#fff;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;gap:.25rem}.elo-option:hover{border-color:#667eea;background:#f0f4ff}.elo-option.active{border-color:#667eea;background:linear-gradient(135deg,#ede9fe,#ddd6fe)}.elo-value{font-weight:700;font-size:.85rem;color:#1f2937}.elo-option.active .elo-value{color:#667eea}.elo-desc{font-size:.65rem;color:#64748b;text-align:center}.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:linear-gradient(180deg,#1e1e3f,#1a1a2e);border-radius:16px;border:1px solid rgba(255,255,255,.08);box-shadow:0 4px 24px #0000001a}.puzzle-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:.75rem;border-bottom:1px solid rgba(255,255,255,.08)}.puzzle-header h3{margin:0;color:#e0e0e0;font-size:1.1rem;font-weight:600}.puzzle-score{display:flex;gap:1rem;font-size:.9rem;font-weight:600}.score-solved{color:#34d399}.score-failed{color:#f87171}.puzzle-info{background:#00000040;border-radius:12px;padding:1rem;border-left:4px solid #8b5cf6;transition:border-color .3s ease}.puzzle-info.status-solved{border-left-color:#10b981}.puzzle-info.status-failed{border-left-color:#ef4444}.puzzle-rating{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.rating-label{color:#9ca3af;font-size:.85rem}.rating-value{font-weight:700;color:#fbbf24;font-size:1.15rem;text-shadow:0 1px 3px rgba(251,191,36,.2)}.puzzle-themes{display:flex;flex-wrap:wrap;gap:.25rem;margin-bottom:.5rem}.theme-badge{background:#8b5cf626;color:#c4b5fd;padding:.2rem .5rem;border-radius:8px;font-size:.7rem;font-weight:500;border:1px solid rgba(139,92,246,.2)}.puzzle-status{font-weight:600;margin-bottom:.25rem}.puzzle-status.status-solved{color:#22c55e}.puzzle-status.status-failed{color:#ef4444}.puzzle-status.status-playing{color:#6366f1}.puzzle-hint{color:#888;font-size:.8rem}.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:#0f0f1a;border:1px solid #3a3a5e;border-radius:.25rem;color:#e0e0e0;font-size:.9rem;text-align:center}.rating-inputs input:focus{outline:none;border-color:#6366f1}.rating-inputs span{color:#666;font-size:.85rem}.theme-filter select{width:100%;padding:.4rem;background:#0f0f1a;border:1px solid #3a3a5e;border-radius:.25rem;color:#e0e0e0;font-size:.9rem;cursor:pointer}.theme-filter select:focus{outline:none;border-color:#6366f1}.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:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;box-shadow:0 4px 12px #8b5cf64d}.puzzle-actions .btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#a78bfa,#8b5cf6);transform:translateY(-2px);box-shadow:0 6px 20px #8b5cf666}.puzzle-actions .btn-primary:disabled{opacity:.6;cursor:not-allowed}.puzzle-actions .btn-secondary{background:#ffffff0d;color:#e0e0e0;border:1px solid rgba(255,255,255,.1)}.puzzle-actions .btn-secondary:hover{background:#ffffff1a;border-color:#fff3}.puzzle-error{background:#ef44441a;color:#f87171;padding:.5rem;border-radius:.25rem;font-size:.85rem;text-align:center}.puzzle-stats{color:#666;text-align:center;padding-top:.5rem;border-top:1px solid #2a2a4e}.puzzle-instructions{background:#0f0f1a;border-radius:.5rem;padding:.75rem}.puzzle-instructions h4{color:#e0e0e0;margin:0 0 .5rem;font-size:.9rem}.puzzle-instructions ol{margin:0;padding-left:1.25rem;color:#888;font-size:.85rem}.puzzle-instructions li{margin-bottom:.25rem}.openings-simple{display:flex;flex-direction:column;background:#1a1a2e;color:#fff;overflow:hidden}.openings-loading,.openings-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:200px;color:#ffffffb3}.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:#8b5cf6;border:none;border-radius:6px;color:#fff;cursor:pointer}.openings-search{padding:12px;border-bottom:1px solid rgba(255,255,255,.1)}.openings-search input{width:100%;padding:10px 14px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;font-size:14px;box-sizing:border-box}.openings-search input::placeholder{color:#ffffff80}.openings-search input:focus{outline:none;border-color:#8b5cf6}.openings-tabs{display:flex;flex-wrap:wrap;gap:6px;padding:12px;border-bottom:1px solid rgba(255,255,255,.1)}.openings-tabs button{padding:6px 12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.15);border-radius:16px;color:#ffffffb3;font-size:12px;cursor:pointer;transition:all .2s;white-space:nowrap}.openings-tabs button:hover{background:#ffffff1a;color:#fff}.openings-tabs button.active{background:#8b5cf6;border-color:#8b5cf6;color:#fff}.openings-count{padding:8px 12px;font-size:12px;color:#ffffff80;border-bottom:1px solid rgba(255,255,255,.05)}.openings-list{flex:1;overflow-y:auto;padding:8px}.openings-empty{text-align:center;padding:40px 20px;color:#ffffff80}.openings-empty button{margin-top:12px;padding:8px 16px;background:#8b5cf633;border:1px solid rgba(139,92,246,.4);border-radius:6px;color:#fff;cursor:pointer}.opening-item{display:flex;align-items:center;gap:12px;padding:12px;margin-bottom:6px;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:10px;cursor:pointer;transition:all .15s}.opening-item:hover{background:#8b5cf626;border-color:#8b5cf666;transform:translate(4px)}.opening-eco{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#8b5cf6,#6366f1);border-radius:8px;font-weight:700;font-size:12px;flex-shrink:0}.opening-info{flex:1;min-width:0}.opening-name{font-weight:600;font-size:14px;color:#fff;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.opening-meta{font-size:12px;color:#ffffff80;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.opening-arrow{color:#ffffff4d;font-size:18px;transition:all .15s}.opening-item:hover .opening-arrow{color:#8b5cf6;transform:translate(4px)}.puzzle-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-panel.status-solved{border-color:#10b98166;background:linear-gradient(145deg,#1a2e1a,#1a1a2e)}.puzzle-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:.5rem;padding:.5rem .75rem;background:#fbbf241a;border-radius:8px;border:1px solid rgba(251,191,36,.2)}.hint-icon{font-size:1rem}.hint-text{color:#fcd34d;font-size:.8rem;font-weight:500}@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.empty{background:linear-gradient(135deg,#2a2a2a,#3a3a3a);border-bottom-color:#555}.opening-info-left{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}.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-name{font-size:.85rem;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.opening-title{font-size:.85rem;color:#aaa}.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-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:#f443364d;color:#ff6b6b}.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: 768px){.opening-info-bar{padding:.4rem .5rem}.opening-info-center{display:none}.opening-name{font-size:.75rem}}.splash-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);overflow:hidden;transition:opacity .5s ease}.splash-screen.fade-out{opacity:0;pointer-events:none}.splash-bg{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none}.floating-piece{position:absolute;font-size:4rem;opacity:.08;animation:float 20s ease-in-out infinite;color:#fff}.piece-1{top:10%;left:5%;animation-delay:0s;font-size:5rem}.piece-2{top:20%;right:10%;animation-delay:-3s;font-size:4rem}.piece-3{bottom:30%;left:15%;animation-delay:-5s;font-size:3.5rem}.piece-4{top:60%;right:5%;animation-delay:-8s;font-size:4.5rem}.piece-5{bottom:15%;left:5%;animation-delay:-2s;font-size:3rem}.piece-6{top:40%;left:8%;animation-delay:-10s;font-size:2.5rem}.piece-7{bottom:25%;right:15%;animation-delay:-7s;font-size:5rem}.piece-8{top:5%;right:25%;animation-delay:-4s;font-size:3rem}@keyframes float{0%,to{transform:translateY(0) rotate(0);opacity:.08}25%{transform:translateY(-30px) rotate(5deg);opacity:.12}50%{transform:translateY(-15px) rotate(-3deg);opacity:.08}75%{transform:translateY(-25px) rotate(3deg);opacity:.1}}.splash-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:2.5rem;padding:2rem;animation:fadeInUp .8s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.splash-logo{display:flex;flex-direction:column;align-items:center;gap:.75rem}.logo-icon{position:relative;width:100px;height:100px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:24px;box-shadow:0 20px 60px #667eea66,0 0 0 1px #ffffff1a inset;animation:pulse 3s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 20px 60px #667eea66,0 0 0 1px #ffffff1a inset}50%{box-shadow:0 25px 70px #667eea80,0 0 0 1px #ffffff26 inset}}.logo-piece{font-size:3.5rem;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.3)}.logo-sparkle{position:absolute;top:-5px;right:-5px;font-size:1.5rem;color:gold;animation:sparkle 2s ease-in-out infinite}@keyframes sparkle{0%,to{opacity:1;transform:scale(1) rotate(0)}50%{opacity:.6;transform:scale(.9) rotate(10deg)}}.splash-title{font-size:3.5rem;font-weight:800;letter-spacing:-.02em;margin:0}.title-chess{color:#fff}.title-coach{background:linear-gradient(135deg,#667eea,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.splash-tagline{font-size:1.25rem;color:#fff9;margin:0;font-weight:500}.splash-features{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;max-width:450px}.feature-item{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:#ffffff0d;border-radius:12px;border:1px solid rgba(255,255,255,.08);transition:all .3s ease;cursor:pointer;font-family:inherit;text-align:left}.feature-item:hover{background:#ffffff14;border-color:#667eea4d;transform:translateY(-2px)}.feature-item.selected{background:#667eea33;border-color:#667eea99;box-shadow:0 0 20px #667eea4d}.feature-item.selected .feature-text{color:#fff}.feature-icon{font-size:1.5rem}.feature-text{color:#ffffffe6;font-size:.95rem;font-weight:500}.splash-hint{font-size:.85rem;color:#fff6;margin:-.5rem 0 0}.splash-enter-btn{display:flex;align-items:center;gap:.75rem;padding:1rem 2.5rem;font-size:1.15rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50px;cursor:pointer;transition:all .3s ease;box-shadow:0 10px 40px #667eea66,0 0 #667eea80;animation:buttonGlow 2s ease-in-out infinite}@keyframes buttonGlow{0%,to{box-shadow:0 10px 40px #667eea66,0 0 #667eea80}50%{box-shadow:0 15px 50px #667eea80,0 0 0 8px #667eea1a}}.splash-enter-btn:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 15px 50px #667eea80,0 0 #667eea80}.splash-enter-btn:active{transform:translateY(-1px) scale(.98)}.btn-text{letter-spacing:.02em}.btn-icon{font-size:1.25rem;transition:transform .3s ease}.splash-enter-btn:hover .btn-icon{transform:translate(5px)}.splash-footer{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:#fff6}.separator{color:#fff3}@media (max-width: 600px){.splash-title{font-size:2.5rem}.logo-icon{width:80px;height:80px}.logo-piece{font-size:2.75rem}.splash-features{grid-template-columns:1fr;max-width:280px}.splash-enter-btn{padding:.9rem 2rem;font-size:1.05rem}}.app{min-height:100vh;max-height:100vh;padding:0;overflow:hidden;display:flex;flex-direction:column;animation:fadeIn .4s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.toolbar{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.15);flex-shrink:0}.toolbar-left{display:flex;align-items:center}.app-title{font-size:1.25rem;font-weight:700;color:#fff;margin:0;text-shadow:0 1px 8px rgba(0,0,0,.2)}.toolbar-center{display:flex;align-items:center}.mode-tabs{display:flex;gap:.25rem;background:#0003;padding:.25rem;border-radius:10px}.mode-tab{padding:.5rem 1rem;border:none;border-radius:8px;background:transparent;color:#ffffffb3;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease}.mode-tab:hover{background:#ffffff1a;color:#fff}.mode-tab.active{background:#fff;color:#667eea;box-shadow:0 2px 8px #00000026}.toolbar-right{display:flex;align-items:center;gap:.5rem}.toolbar-btn{width:40px;height:40px;border:none;border-radius:10px;background:#ffffff26;color:#fff;font-size:1.1rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.toolbar-btn:hover{background:#ffffff40;transform:scale(1.05)}.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 12px;border:none;border-radius:8px;background:#0003;color:#fffc;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:6px}.toolbar-action-btn .btn-icon{font-size:1rem}.toolbar-action-btn .btn-label{font-size:.8rem}.toolbar-action-btn:hover:not(:disabled){background:#fff;color:#667eea;box-shadow:0 2px 8px #00000026}.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:grid;grid-template-columns:auto 1fr;gap:1rem;padding:1rem;flex:1;min-height:0;overflow:hidden}.board-column{display:flex;flex-direction:column;align-items:center;gap:.75rem}.board-wrapper{position:relative;border-radius:12px;box-shadow:0 8px 32px #0000004d}.board-controls{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}.board-ctrl-btn{padding:.5rem .75rem;border:none;border-radius:8px;background:#ffffff26;color:#fff;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s ease}.board-ctrl-btn:hover:not(:disabled){background:#ffffff40}.board-ctrl-btn:disabled{opacity:.5;cursor:not-allowed}.board-ctrl-btn.primary{background:linear-gradient(135deg,#667eea,#764ba2)}.board-ctrl-btn.primary:hover{box-shadow:0 4px 12px #667eea66}.moves-strip{display:flex;flex-wrap:wrap;gap:.25rem;max-width:480px;max-height:60px;overflow-y:auto;padding:.5rem;background:#0003;border-radius:8px}.move-chip{padding:.2rem .4rem;background:#ffffff1a;border-radius:4px;font-size:.75rem;color:#fffc;font-family:SF Mono,Monaco,monospace}.move-chip.latest{background:#667eea66;color:#fff}.move-chip .move-num{color:#ffffff80;margin-right:.15rem}.chat-column{display:flex;flex-direction:column;background:#fff;border-radius:16px;box-shadow:0 8px 32px #0000001a;overflow:hidden;min-height:0}.openings-panel-inline{max-height:300px;overflow-y:auto;border-bottom:1px solid #e2e8f0}.openings-modal{background:linear-gradient(145deg,#1e1e3f,#1a1a2e);border-radius:20px;width:90%;max-width:600px;max-height:80vh;overflow:hidden;box-shadow:0 25px 80px #00000080;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 rgba(255,255,255,.1);background:linear-gradient(135deg,#10b981,#059669);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:#fff;border-radius:20px;width:90%;max-width:400px;max-height:85vh;overflow-y:auto;box-shadow:0 25px 80px #0006;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 #e2e8f0;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:20px 20px 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:#667eea66;border-radius:10px}.controls-section{background:#fffffffa;border-radius:20px;padding:1.25rem;box-shadow:0 8px 32px #0000001a,0 0 0 1px #ffffff80;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:#667eea66;border-radius:3px}.controls-section h2{font-size:1rem;color:#1f2937;margin:0 0 1.15rem;padding-bottom:.7rem;border-bottom:2px solid rgba(102,126,234,.12);font-weight:700;display:flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,#1f2937,#4b5563);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.control-group{margin-bottom:1.25rem;padding-bottom:1.25rem;border-bottom:1px solid rgba(0,0,0,.06)}.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:#64748b;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:2px solid #e2e8f0;border-radius:10px;background:#fff;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);color:#64748b;position:relative;overflow:hidden}.btn-toggle:hover{border-color:#667eea;background:#667eea14;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:linear-gradient(145deg,#f8fafc,#f1f5f9);border-radius:10px;font-family:SF Mono,Consolas,monospace;font-size:.72rem;border:1px solid rgba(0,0,0,.05)}.moves-compact .move-item{padding:.2rem .4rem;background:#fff;border-radius:5px;border:1px solid #e2e8f0;transition:all .2s ease}.moves-compact .move-item:hover{background:#f1f5f9;border-color:#cbd5e1}.moves-compact .move-item.latest{background:linear-gradient(135deg,#667eea,#764ba2);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 #667eea66}50%{box-shadow:0 0 0 4px #667eea00}}.moves-compact .move-num{color:#94a3b8;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);box-shadow:0 2px 8px #10b9814d}.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:#0a0a1ebf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);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:linear-gradient(180deg,#1e1e3f,#1a1a2e);border-radius:20px;width:90%;max-width:720px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 25px 80px #0009,0 0 0 1px #ffffff1a,inset 0 1px #ffffff0d;animation:modalSlideUp .3s cubic-bezier(.4,0,.2,1)}@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:#ffffff26;border:1px solid rgba(255,255,255,.2);color:#fff;width:34px;height:34px;border-radius:10px;font-size:1.4rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1);line-height:1}.modal-close-btn:hover{background:#ffffff40;border-color:#fff6;transform:scale(1.05)}.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;max-width:50%;border-right:1px solid rgba(255,255,255,.1)}.openings-modal .opening-details{flex:1;max-height:none;overflow-y:auto}.setup-modal{background:linear-gradient(180deg,#1e1e3f,#1a1a2e);border-radius:20px;width:90%;max-width:480px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 25px 80px #0009,0 0 0 1px #ffffff1a,inset 0 1px #ffffff0d;animation:modalSlideUp .3s cubic-bezier(.4,0,.2,1)}.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:#ffffffb3;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:#ffffff0d;border:2px solid rgba(255,255,255,.1);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:#ffffff14;border-color:#fff3}.color-option.active{background:#f59e0b26;border-color:#f59e0b;box-shadow:0 0 20px #f59e0b33}.color-piece{font-size:2.5rem;line-height:1}.color-label{font-size:1rem;font-weight:700;color:#fff}.color-hint{font-size:.75rem;color:#ffffff80}.difficulty-selector{display:flex;flex-direction:column;gap:8px}.difficulty-option{background:#ffffff0d;border:2px solid rgba(255,255,255,.1);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:#ffffff14;border-color:#fff3}.difficulty-option.active{background:#f59e0b26;border-color:#f59e0b}.difficulty-label{font-size:.95rem;font-weight:600;color:#fff}.difficulty-desc{font-size:.8rem;color:#ffffff80}.setup-info{display:flex;flex-direction:column;gap:12px}.info-item{display:flex;align-items:center;gap:12px;padding:14px 16px;background:#ffffff0d;border-radius:10px;color:#ffffffd9;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:#ffffff0d;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:#ffffff80;text-transform:uppercase;letter-spacing:.05em}.setup-modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;background:#0003;border-top:1px solid rgba(255,255,255,.05)}.setup-cancel-btn{background:transparent;border:1px solid rgba(255,255,255,.2);color:#ffffffb3;padding:10px 20px;border-radius:10px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease}.setup-cancel-btn:hover{background:#ffffff0d;color:#fff}.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}.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:linear-gradient(145deg,#fff,#f8fafc);padding:.625rem;border-radius:20px;box-shadow:0 20px 50px #0000001f,0 4px 12px #0000000f,0 0 0 1px #ffffffe6,inset 0 1px #fff;position:relative;transition:box-shadow .3s ease,transform .3s ease}.board-wrapper:hover{box-shadow:0 25px 60px #00000026,0 6px 16px #00000014,0 0 0 1px #ffffffe6,inset 0 1px #fff}.flip-board-btn{margin-top:.75rem;padding:.6rem 1.25rem;background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid rgba(102,126,234,.15);border-radius:10px;font-size:.85rem;font-weight:600;color:#667eea;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:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.flip-board-btn:active{transform:translateY(0);box-shadow:0 2px 6px #667eea33}.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:12px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);flex:1;min-width:fit-content;white-space:nowrap;position:relative;overflow:hidden}.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:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 12px #667eea59}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #667eea73}.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #667eea4d}.btn-secondary{background:#fffffffa;color:#667eea;border:2px solid rgba(102,126,234,.25);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn-secondary:hover:not(:disabled){background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.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-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-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:#fffffffa;padding:1.25rem;border-radius:20px;box-shadow:0 10px 40px #00000014,0 2px 10px #0000000a,0 0 0 1px #ffffff80;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:2px solid rgba(102,126,234,.15);flex-shrink:0}.analysis-header h2{color:#1f2937;font-size:1.1rem;font-weight:700;margin:0;display:flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,#1f2937,#374151);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.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(102,126,234,.5) transparent;display:flex;flex-direction:column;gap:1rem;padding-right:.5rem}.chat-container::-webkit-scrollbar{width:6px}.chat-container::-webkit-scrollbar-track{background:transparent}.chat-container::-webkit-scrollbar-thumb{background:#667eea66;border-radius:3px}.chat-message{background:linear-gradient(145deg,#f8fafc,#f1f5f9);border-radius:16px;padding:1rem;border:1px solid rgba(0,0,0,.05);animation:slideInMessage .3s ease-out}@keyframes slideInMessage{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chat-message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;font-size:.75rem}.chat-timestamp{color:#94a3b8;font-weight:500}.chat-move-number{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.2rem .5rem;border-radius:12px;font-weight:600;font-size:.7rem}.chat-message-analysis{border-left:4px solid #3b82f6}.chat-message-coaching{border-left:4px solid #8b5cf6}.chat-message-dual-analysis{border-left:4px solid transparent;border-image:linear-gradient(180deg,#8b5cf6,#3b82f6) 1;background:linear-gradient(145deg,#faf5ff,#eff6ff)}.chat-message-loading{background:linear-gradient(145deg,#f0f9ff,#e0f2fe);border-left:4px solid #667eea}.chat-message-user{background:linear-gradient(145deg,#e8f5e9,#c8e6c9);border-left:4px solid #4caf50}.chat-message-coach-reply{background:linear-gradient(145deg,#fff3e0,#ffe0b2);border-left:4px solid #ff9800}.user-message{color:#2e7d32;font-weight:500}.user-label{font-weight:700;margin-right:.5rem}.coach-reply{color:#e65100}.coach-reply .coach-label{font-weight:700;display:block;margin-bottom:.5rem}.coach-reply-content{color:#333;line-height:1.6}.coach-reply-content p{margin:0 0 .75rem}.coach-reply-content p:last-child{margin-bottom:0}.coach-reply-content h1,.coach-reply-content h2,.coach-reply-content h3{color:#1f2937;margin:1rem 0 .5rem;font-size:1rem;font-weight:700}.coach-reply-content h3{font-size:.95rem;color:#4b5563;border-bottom:1px solid #e5e7eb;padding-bottom:.25rem}.coach-reply-content ul,.coach-reply-content ol{margin:.5rem 0;padding-left:1.5rem}.coach-reply-content li{margin:.25rem 0}.coach-reply-content strong{color:#7c3aed;font-weight:600}.coach-reply-content em{color:#6b7280;font-style:italic}.coach-reply-content code{background:#f3f4f6;padding:.1rem .3rem;border-radius:4px;font-family:monospace;font-size:.9em}.chat-input-container{display:flex;gap:.5rem;padding:.75rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-top:1px solid rgba(0,0,0,.1);border-radius:0 0 20px 20px}.chat-input{flex:1;padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:12px;font-size:.9rem;transition:all .3s ease;background:#fff}.chat-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.chat-input:disabled{background:#f1f5f9;cursor:not-allowed}.chat-input::placeholder{color:#94a3b8}.chat-send-btn{width:44px;height:44px;border:none;border-radius:12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:1.2rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.chat-send-btn:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 12px #667eea66}.chat-send-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.loading-indicator{display:flex;align-items:center;gap:.75rem;color:#667eea;font-weight:500;padding:.5rem 0}.loading-indicator .spinner{border-color:#667eea4d;border-top-color:#667eea}@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:#667eea66;border-radius:3px}.analysis-section::-webkit-scrollbar-thumb:hover{background:#667eea99}.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:linear-gradient(135deg,#667eea,#764ba2);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:.6rem 1rem;border-radius:8px;text-align:center;font-weight:700;font-size:.95rem;display:inline-flex;align-items:center;gap:.5rem}.status-badge.check{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#d97706;border:1px solid rgba(245,158,11,.2)}.status-badge.checkmate{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#dc2626;border:1px solid rgba(239,68,68,.2);animation:checkmate-pulse 1s ease-in-out infinite}.status-badge.stalemate{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);color:#4b5563;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;background:linear-gradient(135deg,#fefce8,#fef9c3);border-radius:10px;border:1px solid rgba(234,179,8,.2);transition:all .2s ease}.coaching-insight:hover{box-shadow:0 2px 8px #eab30826}.coaching-insight.rich{flex-direction:column;padding:1rem;background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-color:#22c55e40;position:relative}.coaching-insight.rich:hover{box-shadow:0 4px 12px #22c55e26}.coaching-insight.rich .insight-icon{position:absolute;top:-8px;left:12px;background:#fff;padding:0 4px}.coaching-insight .insight-content{display:flex;flex-direction:column;gap:.25rem;flex:1}.coaching-insight .insight-label{font-size:.75rem;font-weight:600;color:#166534;text-transform:uppercase;letter-spacing:.5px}.insight-icon{font-size:1rem;flex-shrink:0}.insight-text{font-size:.85rem;color:#713f12;line-height:1.5}.coaching-insight.rich .insight-text{color:#14532d;font-size:.9rem;line-height:1.6}.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:#667eea}.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:linear-gradient(135deg,#667eea,#764ba2);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:#667eea;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:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 2rem;border-radius:8px;font-size:1rem;cursor:pointer;transition:transform .2s,box-shadow .2s}.reset-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.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:linear-gradient(145deg,#fff,#f8faff);padding:1.25rem;border-radius:20px;margin-bottom:1rem;box-shadow:0 4px 24px #667eea1f;border:1px solid rgba(102,126,234,.08);animation:fadeInUp .4s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.coach-header{display:flex;align-items:center;gap:.875rem;margin-bottom:1.25rem;padding-bottom:.875rem;border-bottom:1px solid rgba(102,126,234,.1)}.coach-avatar{font-size:1.75rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:14px;width:52px;height:52px;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 16px #667eea4d;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 6px 16px #667eea4d}50%{box-shadow:0 6px 20px #667eea80}}.coach-info h3{margin:0;font-size:1.15rem;color:#1f2937;font-weight:700}.coach-subtitle{font-size:.8rem;color:#64748b}.status-badges{display:flex;gap:.5rem;margin-bottom:1rem}.status-badges:empty{display:none}.eval-bar-container{margin-bottom:1.25rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);padding:.875rem;border-radius:10px;border:1px solid rgba(0,0,0,.04)}.eval-bar{height:6px;background:#e2e8f0;border-radius:3px;overflow:hidden;margin-bottom:.5rem}.eval-bar-fill{height:100%;border-radius:3px;transition:width .5s cubic-bezier(.4,0,.2,1)}.eval-details{display:flex;justify-content:space-between;align-items:center}.eval-value{font-size:1.1rem;font-weight:700}.eval-value.positive{color:#059669}.eval-value.negative{color:#dc2626}.eval-label{font-size:.8rem;color:#94a3b8;font-weight:500}.coaching-card{background:#fff;border-radius:14px;padding:1rem;margin-bottom:.75rem;box-shadow:0 2px 8px #0000000a;border:1px solid rgba(0,0,0,.06);transition:all .25s cubic-bezier(.4,0,.2,1)}.coaching-card:hover{box-shadow:0 8px 20px #0000001a;transform:translateY(-2px)}.coaching-card:last-of-type{margin-bottom:0}.card-header{display:flex;align-items:center;gap:.6rem;margin-bottom:.75rem}.card-icon{font-size:1.35rem;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.card-header h4{margin:0;font-size:.95rem;color:#374151;font-weight:600}.best-move-card{border-left:4px solid #059669;background:linear-gradient(145deg,#fff,#f0fdf4)}.best-move-display{background:linear-gradient(145deg,#ecfdf5,#dcfce7);padding:1rem 1.5rem;border-radius:12px;margin-bottom:.875rem;text-align:center;border:1px solid rgba(5,150,105,.15);box-shadow:inset 0 1px 3px #0596691a}.move-notation{font-size:1.6rem;font-weight:700;font-family:SF Mono,Consolas,Courier New,monospace;color:#059669;letter-spacing:2px;text-shadow:0 1px 2px rgba(5,150,105,.15)}.assessment-card{border-left:4px solid #667eea;background:linear-gradient(145deg,#fff,#f8faff)}.coaching-markdown{color:#4b5563;line-height:1.7}.coaching-markdown h3{font-size:1rem;color:#374151;margin:1.25rem 0 .75rem;font-weight:600;padding-bottom:.5rem;border-bottom:1px solid #e5e7eb}.coaching-markdown h3:first-child{margin-top:0}.coaching-markdown p{margin:.75rem 0;font-size:.95rem}.coaching-markdown ul,.coaching-markdown ol{margin:.75rem 0;padding-left:1.5rem}.coaching-markdown li{margin:.5rem 0;font-size:.95rem}.coaching-markdown strong{color:#1f2937;font-weight:600}.coaching-markdown code{background:#f3f4f6;padding:.15rem .4rem;border-radius:4px;font-size:.9em;color:#667eea}.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:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent;transform:translateY(-1px);box-shadow:0 3px 8px #667eea4d}@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:#667eea1a;color:#667eea}.mode-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 3px 10px #667eea59;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:#667eea;background:#667eea14;transform:translateY(-2px)}.color-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent;box-shadow:0 4px 12px #667eea59}.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:#667eea;background:#667eea0d}.color-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent;box-shadow:0 2px 8px #667eea4d}.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:#667eea;box-shadow:0 0 0 3px #667eea1a}.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}}:root{--primary-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--primary-color: #667eea;--primary-dark: #5a67d8;--accent-color: #764ba2;--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(102, 126, 234, .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}*{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(--primary-gradient);background-attachment:fixed;min-height:100vh;color:var(--text-primary);line-height:1.5}#root{max-width:1440px;margin:0 auto;padding:1.5rem 2rem}::selection{background:#667eea4d;color:var(--text-primary)}:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}
