.ui-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none;z-index:1000;font-family:Nunito,sans-serif}.ui-overlay>*{pointer-events:auto;animation:fadeInSlide .6s cubic-bezier(.4,0,.2,1) both}@keyframes fadeInSlide{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.connection-status{position:absolute;top:20px;right:20px;background:linear-gradient(135deg,#fffffff2,#ffffffd9);padding:18px 22px;border-radius:20px;border:2px solid rgba(255,255,255,.5);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 8px 32px #1f268726,0 2px 8px #0000001a,inset 0 1px #fff9;min-width:220px;transition:all .3s cubic-bezier(.4,0,.2,1)}.connection-status:hover{transform:translateY(-2px);box-shadow:0 12px 40px #1f268733,0 4px 12px #00000026,inset 0 1px #fff9}.status-indicator{display:inline-block;padding:10px 16px;border-radius:25px;font-weight:700;font-size:14px;margin-bottom:10px;transition:all .3s ease;position:relative;overflow:hidden}.status-indicator:before{content:"";position:absolute;top:50%;left:10px;width:8px;height:8px;border-radius:50%;transform:translateY(-50%);animation:pulse 2s ease-in-out infinite}.status-indicator.connected{background:linear-gradient(135deg,#22c55e40,#22c55e26);color:#15803d;border:2px solid rgba(34,197,94,.5);box-shadow:0 2px 8px #22c55e33}.status-indicator.connected:before{background:#22c55e;box-shadow:0 0 10px #22c55e}.status-indicator.disconnected{background:linear-gradient(135deg,#ef444440,#ef444426);color:#dc2626;border:2px solid rgba(239,68,68,.5);box-shadow:0 2px 8px #ef444433}.status-indicator.disconnected:before{background:#ef4444;box-shadow:0 0 10px #ef4444}@keyframes pulse{0%,to{opacity:1;transform:translateY(-50%) scale(1)}50%{opacity:.5;transform:translateY(-50%) scale(1.2)}}.server-status{font-size:12px;color:#8b4513;font-weight:500}.game-stats{position:absolute;top:20px;left:20px;background:linear-gradient(135deg,#fffffff2,#ffffffd9);padding:24px;border-radius:20px;border:2px solid rgba(255,255,255,.5);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 8px 32px #1f268726,0 2px 8px #0000001a,inset 0 1px #fff9;min-width:280px;transition:all .3s cubic-bezier(.4,0,.2,1)}.game-stats:hover{transform:translateY(-2px);box-shadow:0 12px 40px #1f268733,0 4px 12px #00000026,inset 0 1px #fff9}.game-stats h3{margin:0 0 18px;color:#8b4513;font-weight:800;text-align:center;font-size:18px;text-shadow:0 2px 4px rgba(139,69,19,.1);letter-spacing:.5px;background:linear-gradient(135deg,#8b4513,sienna);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-item{display:flex;justify-content:space-between;align-items:center;margin:10px 0;padding:10px 12px;font-size:14px;color:#8b4513;font-weight:600;background:#8b451308;border-radius:12px;transition:all .3s ease;border:1px solid transparent}.stat-item:hover{background:#8b451314;border-color:#8b451326;transform:translate(4px)}.stat-item span:first-child{flex:1}.stat-item span:last-child{font-weight:700;color:#d2691e;min-width:40px;text-align:right}.highlight{color:#ff8c00;font-weight:800;background:linear-gradient(135deg,#ffd7004d,#ff8c0033);padding:4px 10px;border-radius:8px;border:1.5px solid rgba(255,215,0,.5);box-shadow:0 2px 8px #ffd70033;transition:all .3s ease}.highlight:hover{transform:scale(1.05);box-shadow:0 4px 12px #ffd7004d}.ai-controls{position:absolute;bottom:20px;left:20px;background:linear-gradient(135deg,#fffffff2,#ffffffd9);padding:24px;border-radius:20px;border:2px solid rgba(255,255,255,.5);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 8px 32px #1f268726,0 2px 8px #0000001a,inset 0 1px #fff9;min-width:280px;transition:all .3s cubic-bezier(.4,0,.2,1)}.ai-controls:hover{transform:translateY(-2px);box-shadow:0 12px 40px #1f268733,0 4px 12px #00000026,inset 0 1px #fff9}.ai-controls h3{margin:0 0 18px;color:#8b4513;font-weight:800;text-align:center;font-size:18px;text-shadow:0 2px 4px rgba(139,69,19,.1);letter-spacing:.5px;background:linear-gradient(135deg,#8b4513,sienna);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.ai-status,.ai-performance,.training-progress{margin:12px 0;font-size:14px;color:#8b4513;font-weight:600;padding:8px 12px;background:#8b451308;border-radius:10px;transition:all .3s ease}.ai-status:hover,.ai-performance:hover,.training-progress:hover{background:#8b451314}.progress-bar{width:100%;height:10px;background:#8b451326;border-radius:10px;overflow:hidden;margin-top:8px;box-shadow:inset 0 2px 4px #0000001a;position:relative}.progress-bar:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.5),transparent)}.progress-fill{height:100%;background:linear-gradient(90deg,gold,orange,#ff8c00);border-radius:10px;transition:width .5s cubic-bezier(.4,0,.2,1);box-shadow:0 0 10px #ffd70066;position:relative;overflow:hidden}.progress-fill:after{content:"";position:absolute;top:0;left:0;bottom:0;right:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.ai-training-button{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2,#5b3a8f);color:#fff;border:none;border-radius:12px;font-weight:800;font-size:15px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);margin-top:15px;box-shadow:0 4px 15px #667eea66,inset 0 1px #fff3;position:relative;overflow:hidden}.ai-training-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s}.ai-training-button:hover:before{left:100%}.ai-training-button:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 8px 25px #667eea80,inset 0 1px #ffffff4d}.ai-training-button:active{transform:translateY(-1px) scale(1.01)}.ai-training-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.action-controls{position:absolute;bottom:20px;right:20px;background:linear-gradient(135deg,#fffffff2,#ffffffd9);padding:24px;border-radius:20px;border:2px solid rgba(255,255,255,.5);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 8px 32px #1f268726,0 2px 8px #0000001a,inset 0 1px #fff9;min-width:240px;transition:all .3s cubic-bezier(.4,0,.2,1)}.action-controls:hover{transform:translateY(-2px);box-shadow:0 12px 40px #1f268733,0 4px 12px #00000026,inset 0 1px #fff9}.action-controls h3{margin:0 0 18px;color:#8b4513;font-weight:800;text-align:center;font-size:18px;text-shadow:0 2px 4px rgba(139,69,19,.1);letter-spacing:.5px;background:linear-gradient(135deg,#8b4513,sienna);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.action-button{width:100%;padding:14px;background:linear-gradient(135deg,#ff69b4,#ff1493,#c71585);color:#fff;border:none;border-radius:12px;font-weight:800;font-size:15px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 15px #ff149366,inset 0 1px #fff3;position:relative;overflow:hidden}.action-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s}.action-button:hover:not(:disabled):before{left:100%}.action-button:hover:not(:disabled){transform:translateY(-3px) scale(1.02);box-shadow:0 8px 25px #ff149380,inset 0 1px #ffffff4d}.action-button:active:not(:disabled){transform:translateY(-1px) scale(1.01)}.action-button:disabled{opacity:.5;cursor:not-allowed;transform:none;background:linear-gradient(135deg,#ccc,#999);box-shadow:none}.help-text{margin-top:15px;padding:12px 15px;background:linear-gradient(135deg,#ffd7001a,#ffa5000d);border-radius:10px;font-size:13px;color:#8b4513;text-align:center;border:1.5px dashed rgba(255,215,0,.4);font-weight:600;transition:all .3s ease}.help-text:hover{background:linear-gradient(135deg,#ffd70026,#ffa5001a);border-color:#ffd70099;transform:scale(1.02)}@media (max-width: 768px){.ui-overlay{font-size:12px}.game-stats,.ai-controls,.action-controls,.connection-status{min-width:200px;padding:18px}.stat-item{font-size:13px;padding:8px 10px}.game-stats h3,.ai-controls h3,.action-controls h3{font-size:16px}}@media (prefers-reduced-motion: no-preference){.ui-overlay>*{animation-duration:.6s}.status-indicator:before{animation:pulse 2s ease-in-out infinite}.progress-fill:after{animation:shimmer 2s infinite}}.floating-decoration{position:fixed;font-size:2rem;pointer-events:none;z-index:1;opacity:.4;animation:floatAround 8s ease-in-out infinite;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));transition:all .3s ease}.floating-decoration:hover{opacity:.8;transform:scale(1.2)}@keyframes floatAround{0%,to{transform:translate(0) rotate(0)}25%{transform:translate(20px,-20px) rotate(90deg)}50%{transform:translate(-10px,10px) rotate(180deg)}75%{transform:translate(-20px,-10px) rotate(270deg)}}.game-stats:hover:after,.ai-controls:hover:after,.action-controls:hover:after{content:"✨";position:absolute;top:-10px;right:-10px;font-size:1.2rem;animation:sparkleRotate 1s ease-in-out;pointer-events:none}@keyframes sparkleRotate{0%{transform:scale(0) rotate(0);opacity:0}50%{transform:scale(1.5) rotate(180deg);opacity:1}to{transform:scale(0) rotate(360deg);opacity:0}}.stat-item span:first-child{transition:transform .3s ease}.stat-item:hover span:first-child{transform:scale(1.1)}.highlight.level,.highlight.score{animation:glow 2s ease-in-out infinite}@keyframes glow{0%,to{box-shadow:0 2px 8px #ffd70033}50%{box-shadow:0 4px 16px #ffd70066}}@media (prefers-reduced-motion: reduce){.highlight.level,.highlight.score,.floating-decoration{animation:none}.status-indicator:before{animation:none}.progress-fill:after{animation:none}.ui-overlay>*{animation:none}}html,body{height:100%;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow:hidden;background:radial-gradient(ellipse at center,#f8e6e0,#e8d5c8,#d4c4b0);color:#8b4513;-webkit-user-select:none;user-select:none}#root{height:100%;width:100%}.app{position:relative;height:100vh;width:100vw;overflow:hidden}.app:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background-image:radial-gradient(circle at 20% 80%,rgba(255,255,255,.1) 1px,transparent 1px),radial-gradient(circle at 80% 20%,rgba(255,255,255,.1) 1px,transparent 1px),radial-gradient(circle at 40% 40%,rgba(255,255,255,.05) 2px,transparent 2px);background-size:50px 50px,30px 30px,70px 70px;pointer-events:none;z-index:1}.ui-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1000}.ui-panel{pointer-events:auto;background:#fffffff2;border:3px solid #DEB887;border-radius:20px;padding:20px;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);box-shadow:0 10px 30px #0003,inset 0 1px #fff6}.ui-button{background:linear-gradient(135deg,#ff69b4,#ff1493,#dc143c);border:3px solid #FFF;border-radius:25px;padding:12px 24px;color:#fff;font-weight:700;cursor:pointer;font-family:Nunito,sans-serif;font-size:14px;box-shadow:0 6px 20px #ff149366,inset 0 1px #ffffff4d;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.ui-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s}.ui-button:hover{transform:translateY(-3px) scale(1.05);box-shadow:0 12px 30px #ff149399,inset 0 1px #fff6}.ui-button:hover:before{left:100%}.ui-button:active{transform:translateY(-1px) scale(1.02)}.ui-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.ui-button--special{background:linear-gradient(135deg,gold,orange,#ff8c00);box-shadow:0 6px 20px #ffd70066,inset 0 1px #ffffff4d}.ui-button--special:hover{box-shadow:0 12px 30px #ffd70099,inset 0 1px #fff6}.ui-button--mini{width:50px;height:50px;border-radius:50%;border:3px solid #FFF;background:linear-gradient(135deg,#87ceeb,#4169e1);color:#fff;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #0003;transition:all .3s ease;padding:0}.ui-button--mini:hover{transform:translateY(-2px) scale(1.1);box-shadow:0 6px 18px #0000004d}.stats-panel{position:absolute;top:20px;left:20px;min-width:200px}.stat-item{display:flex;align-items:center;margin:8px 0;font-size:16px;font-weight:600}.stat-icon{font-size:20px;margin-right:8px;filter:drop-shadow(1px 1px 2px rgba(0,0,0,.2))}.stat-value{font-weight:800;color:peru;min-width:60px;text-align:right;margin-left:auto}.controls-panel{position:absolute;bottom:20px;right:20px;display:flex;flex-direction:column;gap:12px}.settings-panel{position:absolute;bottom:20px;left:20px;display:flex;gap:10px}.mood-indicator{position:absolute;top:20px;right:20px;min-width:150px}.mood-bar{width:120px;height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden;margin-top:5px}.mood-fill{height:100%;background:linear-gradient(90deg,#ff69b4,#ffb6c1,pink);border-radius:4px;transition:width .3s ease}.loading-screen{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#f8e6e0,#e8d5c8);display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:2000}.loading-spinner{width:60px;height:60px;border:4px solid #DEB887;border-top:4px solid #8B4513;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}.loading-text{font-size:24px;font-weight:700;color:#8b4513;text-align:center;margin-bottom:10px}.loading-subtext{font-size:16px;color:peru;text-align:center}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes yarnFloat{0%,to{transform:translateY(0) rotate(0)}33%{transform:translateY(-10px) rotate(120deg)}66%{transform:translateY(-5px) rotate(240deg)}}@keyframes sparkle{0%,to{opacity:0;transform:scale(0)}50%{opacity:1;transform:scale(1)}}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}.floating-decoration{position:absolute;font-size:24px;animation:yarnFloat 4s ease-in-out infinite;pointer-events:none;z-index:5}.particle{position:absolute;pointer-events:none;border-radius:50%;animation:sparkle 1s ease-out forwards}.particle--yarn{background:radial-gradient(circle,#ff69b4,#ffb6c1)}.particle--sparkle{background:radial-gradient(circle,gold,orange)}.particle--happiness{background:radial-gradient(circle,#87ceeb,#b0e0e6)}@media (max-width: 768px){.stats-panel,.mood-indicator{position:relative;margin:10px}.controls-panel{position:relative;flex-direction:row;justify-content:center;margin:10px}.ui-panel{padding:15px;margin:10px}.stat-item{font-size:14px}.ui-button{padding:10px 20px;font-size:12px}}@media (max-width: 480px){.ui-panel{padding:10px;margin:5px}.controls-panel{flex-wrap:wrap}.ui-button{padding:8px 16px;font-size:11px}}.app *{will-change:transform}.ui-overlay{will-change:opacity}@media (prefers-contrast: high){.ui-panel{border-width:4px;background:#fff}.ui-button{border-width:4px}}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);overflow:hidden}#root{width:100vw;height:100vh}canvas{cursor:grab}canvas:active{cursor:grabbing}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-in{animation:fadeIn .5s ease-in-out}.game-text{font-family:Comic Sans MS,cursive,sans-serif;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.5)}.yarn-text{font-family:Comic Sans MS,cursive,sans-serif;color:#ff69b4;text-shadow:1px 1px 2px rgba(255,182,193,.8),-1px -1px 2px rgba(255,105,180,.6);font-weight:700}
