.loader{justify-content:center;align-items:center;width:100vw;height:100vh;display:flex}.loader-content{flex-direction:column;align-items:center;gap:20px;display:flex}.loader-spinner{border:4px solid #0000001a;border-left-color:var(--color-primary);border-radius:50%;width:50px;height:50px;animation:1s linear infinite loaderSpin}@keyframes loaderSpin{to{transform:rotate(360deg)}}.loader-text{color:var(--color-text);opacity:.55;font-size:clamp(12px,3vw,13px)}.platform-error{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;height:100vh;padding:1rem;display:flex}.platform-error-icon{font-size:3rem}.platform-error-message{margin:0}.platform-error-contact{opacity:.6;margin:0;font-size:.9em}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;justify-content:center;align-items:center;padding:20px;animation:.2s modalFadeIn;display:flex;position:fixed;inset:0}.modal-overlay.closing{animation:.2s forwards modalFadeOut}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalFadeOut{0%{opacity:1}to{opacity:0}}.modal-content{background:#fff;border-radius:16px;width:100%;max-width:500px;padding:40px 40px 20px;animation:.3s modalSlideIn;position:relative;box-shadow:0 8px 32px #0003}.modal-content.closing{animation:.3s modalSlideOut}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes modalSlideOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-20px)}}.modal-close{cursor:pointer;background:0 0;border:1px solid #ddd;border-radius:50%;width:32px;height:32px;padding:0;transition:all .2s;position:absolute;top:4px;right:4px}.modal-close:before,.modal-close:after{content:"";background-color:#999;width:16px;height:2px;transition:background-color .2s;position:absolute;top:50%;left:50%}.modal-close:before{transform:translate(-50%,-50%)rotate(45deg)}.modal-close:after{transform:translate(-50%,-50%)rotate(-45deg)}.modal-close:hover{background:#f5f5f5;border-width:16px;transform:rotate(90deg)}.modal-close:hover:before,.modal-close:hover:after{background-color:#333}.modal-close:active{transform:rotate(90deg)scale(.85)}.modal-title{color:var(--color-text-dark);text-align:center;margin:0 0 16px;font-size:clamp(20px,5vw,24px);font-weight:600}.modal-message{color:var(--color-text-dark);text-align:center;margin:0;font-size:clamp(15px,4vw,18px);font-weight:400;line-height:1.6}.modal-subtitle{color:var(--color-secondary);text-align:center;margin:8px 0 16px;font-size:clamp(18px,4.5vw,20px);font-weight:600}.modal-header{flex-direction:column;margin-bottom:16px;display:flex}.modal-body{margin-bottom:10px;overflow:auto}.modal-footer{border-top:1px solid #00000014;justify-content:center;gap:12px;padding-top:20px;display:flex}.btn{color:var(--color-primary);border:1px solid var(--color-primary);cursor:pointer;background:#fff;border-radius:0;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-size:clamp(14px,3.5vw,16px);font-weight:500;transition:transform .15s,box-shadow .15s,border-color .2s;display:flex;position:relative;box-shadow:0 2px #00000014}.btn:hover{background:var(--color-primary);color:#fff;transform:translateY(-2px);box-shadow:0 4px #00000014}.btn:active{transform:translateY(1px);box-shadow:0 0 #00000014}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:var(--color-primary);color:#fff;border:1px solid var(--color-primary)}.btn-primary:hover{background:var(--color-primary);color:#fff;transform:translateY(-2px);box-shadow:0 4px #0000001f}.btn-primary:active{transform:translateY(1px);box-shadow:0 0 #0000001f}.btn-success{color:#fff;background:linear-gradient(135deg,#4caf50 0%,#764ba2 100%);border:none}.btn-success:hover{color:#fff;background:linear-gradient(135deg,#43a047 0%,#65408b 100%);transform:translateY(-2px);box-shadow:0 4px 12px #4caf5066}.btn-success:active{box-shadow:none;transform:translateY(1px)}.btn-success-secondary{color:#fff;box-shadow:none;background:#fff3;border:1px solid #ffffff80}.btn-success-secondary:hover{color:#fff;background:#ffffff4d;border:1px solid #ffffff80;box-shadow:0 2px 8px #0000001a}.btn-success-secondary:active{box-shadow:none}.btn-danger{color:#fff;background:linear-gradient(135deg,#ef5350 0%,#764ba2 100%);border:none}.btn-danger:hover{color:#fff;background:linear-gradient(135deg,#e53935 0%,#65408b 100%);transform:translateY(-2px);box-shadow:0 4px 12px #e5393566}.btn-danger:active{box-shadow:none;transform:translateY(1px)}.btn-hidden{display:none}.btn-centered{min-width:140px;margin:0 auto}.buttons-group{flex-direction:column;gap:10px;width:100%;display:flex}.buttons-group-centered{flex-shrink:0;max-width:300px;margin-left:auto;margin-right:auto;padding:8px 16px}.game-completed-modal{text-align:center}.game-completed-modal .modal-title{color:#4caf50}.modal-content-goal-reached{box-shadow:none;background:0 0;justify-content:center;max-width:none;padding:0;display:flex}.goal-reached-modal{color:#fff;text-align:center;will-change:transform;background:linear-gradient(135deg,#4caf50 0%,#45a049 100%);border-radius:16px;width:100%;max-width:320px;padding:24px 24px 20px;font-size:clamp(16px,4vw,20px);font-weight:600;animation:.4s ease-out goalReachedPopIn;position:relative;overflow:hidden;box-shadow:0 8px 32px #4caf5080}.goal-reached-modal:before{content:"";z-index:1;pointer-events:none;background:linear-gradient(90deg,#0000,#ffffff4d,#0000);width:100%;height:100%;animation:2s ease-in-out infinite goalReachedShine;position:absolute;top:0;left:-100%}.goal-reached-header,.goal-reached-body,.goal-reached-footer{z-index:2;position:relative}.goal-reached-header{margin-bottom:12px}.goal-reached-body{margin-bottom:16px}.goal-reached-footer{border-top-color:#ffffff4d;padding-top:16px}.goal-reached-message{margin:0}.goal-reached-unlock{background:#fff3;border-radius:8px;padding:10px 16px;font-size:clamp(14px,3.5vw,16px);font-weight:500}.goal-reached-footer .buttons-group .btn{width:100%;font-size:16px;font-weight:600}@keyframes goalReachedPopIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes goalReachedShine{0%{left:-100%}50%,to{left:100%}}.tutorial-intro-title{color:#4caf50;margin-bottom:0}.tutorial-intro-modal{max-width:400px}.tutorial-intro-btn{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none}.tutorial-intro-btn:hover{color:#fff;background:linear-gradient(135deg,#5568d3 0%,#65408b 100%);box-shadow:0 4px 12px #667eea66}.reset-progress-title{color:#e53935}.hamburger{cursor:pointer;z-index:3;background-color:#0000;border:none;outline:none;flex-direction:column;justify-content:space-between;width:24px;height:18px;padding:0;display:flex;position:absolute;top:50%;right:16px;transform:translateY(-50%)}.hamburger:focus-visible{outline-offset:4px;border-radius:2px;outline:2px solid #ffffffb3}.hamburger .bar1,.hamburger .bar2,.hamburger .bar3{background-color:#fff;border-radius:1px;width:24px;height:2px;transition:all .4s}.hamburger.open .bar1{transform:translateY(8px)rotate(-45deg)}.hamburger.open .bar2{opacity:0;transform:scaleX(0)}.hamburger.open .bar3{transform:translateY(-8px)rotate(45deg)}.sidebar{z-index:2;visibility:hidden;background-color:#333;border-radius:0 0 0 12px;flex-direction:column;width:0;height:100vh;padding-top:60px;transition:width .3s,visibility .3s;display:flex;position:fixed;top:0;right:0;overflow:hidden}.sidebar.open{visibility:visible;width:300px}.sidebar-link{color:#fff;flex-shrink:0;align-items:center;gap:10px;width:300px;padding:25px;font-size:22px;text-decoration:none;transition:background-color .3s;display:flex}.sidebar-link:hover{background-color:#575757}.sidebar-link-danger{color:#faa}.sidebar-link-danger:hover{background-color:#4a3333}.sidebar-divider{border:none;border-top:1px solid #575757;width:100%;margin:0}.maze-viewport{flex:1;width:100%;min-height:0;position:relative;overflow:hidden}.maze-viewport.invisible{visibility:hidden}.maze-canvas{image-rendering:crisp-edges;touch-action:none;-webkit-user-select:none;user-select:none;display:block;position:absolute;inset:0}.maze-overlay{transform-origin:0 0;pointer-events:none;will-change:transform;position:absolute;top:0;left:0}.player-square{z-index:10;will-change:transform;filter:drop-shadow(0 0 3px #1e3a8a80);background:#1e3a8a;border-radius:2px;width:20px;height:20px;position:absolute;top:0;left:0}.goal-glow{background:#16a34a;border-radius:2px;width:22px;height:22px;animation:2s ease-in-out infinite goalPulse;position:absolute;top:0;left:0;box-shadow:inset 0 0 2px #0003,0 0 6px #16a34acc}@keyframes goalPulse{0%,to{box-shadow:inset 0 0 2px #0003,0 0 6px #16a34a99,0 0 8px #16a34a66}50%{box-shadow:inset 0 0 10px #0006,0 0 8px #16a34ae6,0 0 12px #16a34a99}}@keyframes finger-hint{0%{opacity:.8;transform:translate(0)}21%{opacity:.8;transform:translate(64px)}27%{opacity:0;transform:translate(64px)}28%{opacity:0;transform:translate(0)}32.5%{opacity:.8;transform:translate(0)}50%{opacity:.8;transform:translate(0)}71%{opacity:.8;transform:translateY(64px)}77%{opacity:0;transform:translateY(64px)}78%{opacity:0;transform:translate(0)}82.5%{opacity:.8;transform:translate(0)}to{opacity:.8;transform:translate(0)}}.tutorial-finger{pointer-events:none;z-index:50;-webkit-user-select:none;user-select:none;filter:drop-shadow(0 2px 4px #0003);will-change:transform;font-size:48px;line-height:1;animation:5.2s ease-in-out infinite finger-hint;position:absolute;top:16px;left:-6px}@keyframes key-press{0%{background:#fff;transform:translateY(0);box-shadow:0 4px #444}2.5%{background:#e8e8e8;transform:translateY(4px);box-shadow:0 0 #444}5%{background:#fff;transform:translateY(0);box-shadow:0 4px #444}to{background:#fff;transform:translateY(0);box-shadow:0 4px #444}}.tutorial-keyboard-anchor{pointer-events:none;z-index:50;padding-top:12px;position:absolute;top:100%;left:50%;transform:translate(-50%)}.tutorial-keyboard{flex-direction:column;align-items:center;gap:6px;display:flex}.tutorial-keyboard-row{gap:6px;display:flex}.tutorial-key{color:#333;-webkit-user-select:none;user-select:none;background:#fff;border:2px solid #444;border-radius:8px;justify-content:center;align-items:center;width:48px;height:48px;font-size:22px;display:flex;box-shadow:0 4px #444}.key-press-animated{animation:5.2s infinite key-press}.key-press-delayed{animation-delay:2.6s}.game-screen{flex-direction:column;flex:1;width:100%;min-height:0;display:flex}.level-indicator{text-align:center;color:var(--color-primary);letter-spacing:.3px;background:linear-gradient(135deg,#667eea1a 0%,#764ba21a 100%);border:2px solid #667eea4d;border-radius:8px;flex-shrink:0;margin:8px 16px;padding:8px 16px;font-size:clamp(14px,3.5vw,16px);font-weight:600;box-shadow:0 2px 8px #667eea1a}.start-screen-content{box-sizing:border-box;flex-direction:column;align-items:center;gap:24px;width:100%;max-width:400px;margin-top:auto;margin-bottom:auto;padding:20px;display:flex}.start-screen-logo-container{box-sizing:border-box;background:#fff;border-radius:24px;justify-content:center;align-items:center;width:200px;height:200px;padding:16px;animation:3s ease-in-out infinite logoFloat;display:flex;overflow:hidden;box-shadow:0 8px 32px #0000004d}@keyframes logoFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.start-screen-logo{object-fit:contain;width:100%;height:100%}.start-screen-title{color:#667eea;text-align:center;text-shadow:0 2px 8px #667eea33;letter-spacing:1px;margin:0;font-size:clamp(32px,8vw,48px);font-weight:700}.start-screen-play-button{color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:50px;outline:none;margin-top:8px;padding:18px 64px;font-size:clamp(20px,5vw,26px);font-weight:700;transition:all .2s;animation:4s ease-in-out 2s infinite buttonShake;position:relative;overflow:hidden;box-shadow:0 6px 24px #667eea66}.start-screen-play-button:before{content:"";background:linear-gradient(90deg,#0000,#ffffff4d,#0000);width:100%;height:100%;animation:4s ease-in-out 2s infinite buttonShine;position:absolute;top:0;left:-100%}@keyframes buttonShake{0%,85%,to{transform:translate(0)rotate(0)}87%{transform:translate(-4px)rotate(-1deg)}89%{transform:translate(4px)rotate(1deg)}91%{transform:translate(-4px)rotate(-1deg)}93%{transform:translate(4px)rotate(1deg)}95%{transform:translate(-2px)rotate(0)}97%{transform:translate(2px)rotate(0)}}@keyframes buttonShine{0%,85%,to{left:-100%}95%{left:100%}}.start-screen-play-button:hover{animation:none;transform:scale(1.05);box-shadow:0 8px 32px #667eea80}.start-screen-play-button:hover:before{animation:none;left:-100%}.start-screen-play-button:active{transform:scale(.95);box-shadow:0 4px 16px #667eea66}.start-screen-controls{gap:24px;display:flex}.start-screen-icon-button{cursor:pointer;width:64px;height:64px;color:var(--color-primary);-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;background:#667eea1a;border:2px solid #667eea4d;border-radius:50%;outline:none;justify-content:center;align-items:center;transition:all .2s;display:flex}.start-screen-icon-button:hover{background:#667eea33;border-color:#667eea80;transform:scale(1.1)}.start-screen-icon-button:active{transform:scale(.95)}.game-completed-block{text-align:center;background:linear-gradient(135deg,#667eea1a 0%,#764ba21a 100%);border:2px solid #667eea4d;border-radius:12px;margin-top:40px;padding:20px}.game-completed-block-icon{margin-bottom:10px;font-size:3rem}.game-completed-block-text{color:#333;font-size:1.2rem;font-weight:600;line-height:1.5}.game-completed-block-text small{opacity:.9;font-size:.9rem;font-weight:400}.world-item{flex-direction:column;align-items:center;gap:12px;display:flex}.world-block{cursor:pointer;background:#fff;border:4px solid #0000;border-radius:12px;justify-content:center;align-items:center;width:86px;height:80px;font-size:2rem;font-weight:700;transition:all .3s;display:flex;position:relative;box-shadow:0 4px 15px #667eea33}.world-block:before{content:"";background:conic-gradient(from 0deg, #000 0deg, #000 calc(var(--completion-percentage,0) * 3.6deg), #667eea calc(var(--completion-percentage,0) * 3.6deg), #667eea 360deg);-webkit-mask-composite:xor;z-index:0;pointer-events:none;border-radius:12px;padding:4px;position:absolute;inset:-4px;-webkit-mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);-webkit-mask-position:0 0,0 0;mask-position:0 0,0 0;-webkit-mask-size:auto,auto;mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.world-block:not(.locked):hover{transform:scale(1.1);box-shadow:0 6px 20px #0000004d}.world-block:not(.locked):active{transform:scale(1.05)}.world-block.locked{cursor:not-allowed;opacity:.6;background:#f5f5f5}.world-block.locked:before{background:#ddd}.world-number{color:#667eea;z-index:2;font-size:2.5rem;position:relative}.world-block.locked .world-number{color:#667eea80}.world-block.mystery{background:#fafafa}.world-block.mystery:before{background:#bbb}.world-block.mystery .world-number{color:#667eea80;font-size:3rem}.lock-icon{z-index:3;background:#fff;border-radius:50%;justify-content:center;align-items:center;width:35px;height:35px;font-size:1.5rem;display:flex;position:absolute;bottom:-5px;right:-5px;box-shadow:0 2px 8px #0003}.world-info{text-align:center;max-width:280px}.world-name{color:#333;margin-bottom:4px;font-size:1.1rem;font-weight:600}.world-level{color:#666;font-size:.9rem;font-weight:500}.world-connector{background:#667eea;width:4px;height:40px;margin:20px 0}@media (width<=600px){.world-block{width:78px;height:70px}.world-number{font-size:2rem}.world-name{font-size:1rem}.world-connector{height:30px;margin:15px 0}}.worlds-screen-content{flex-direction:column;align-items:center;margin-top:0;padding:40px 20px;display:flex}.worlds-screen-title{color:#333;text-align:center;margin:0 0 40px;font-size:1.5rem;font-weight:600}.world-path{flex-direction:column;align-items:center;width:100%;max-width:440px;display:flex;position:relative}@media (width<=600px){.worlds-screen-title{font-size:1.2rem}}:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:#333;--color-primary:#667eea;--color-secondary:#764ba2;--color-text-dark:#333;--color-text-muted:#666;--color-text:#333;--gradient-background:linear-gradient(90deg, #fff9e6, #ffe8cc, #e8d5ff, #f0e6ff, #fff9e6);font-family:system-ui,Avenir,Helvetica,Arial,sans-serif}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}html,body{height:100%;margin:0;overflow:hidden}#root{height:100%;overflow:hidden}.page-container{background:var(--gradient-background);background-size:200% 100%;flex-direction:column;height:100%;animation:15s linear infinite gradientShift;display:flex;overflow:hidden}@keyframes gradientShift{0%{background-position:0%}to{background-position:200%}}.app-main{flex-direction:column;flex:1;align-items:center;min-height:0;display:flex;overflow:hidden auto}button{font-family:inherit}.app-footer{text-align:center;-webkit-backdrop-filter:blur(8px);background:#ffffff59;border-top:1px solid #fff6;flex-shrink:0;padding:16px}.app-footer-community-button{cursor:pointer;color:var(--color-primary);background:0 0;border:none;padding:4px 0;font-size:clamp(13px,3vw,14px);font-weight:500;text-decoration:none;transition:color .2s}.app-footer-community-button:hover{color:var(--color-secondary);text-decoration:underline}.page-header{background:linear-gradient(135deg, var(--color-primary) 0%, var(--color-secondary) 100%);z-index:100;justify-content:center;align-items:center;padding:12px 16px;display:flex;position:relative;box-shadow:0 2px 8px #0000001a}.page-title{text-align:center;color:#fff;letter-spacing:.5px;margin:0;font-size:clamp(18px,4vw,24px);font-weight:600}.page-title-clickable{cursor:pointer;transition:opacity .2s,transform .2s}.page-title-clickable:hover{opacity:.85;transform:scale(1.02)}.page-title-clickable:active{transform:scale(.98)}
