.welcome-screen{display:flex;align-items:center;justify-content:center;width:100vw;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);opacity:0;transition:opacity .5s ease-in}.welcome-screen.visible{opacity:1}.welcome-content{text-align:center;padding:2rem;max-width:500px}.welcome-title{font-size:3rem;color:#fff;margin-bottom:2rem;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.welcome-question{font-size:1.5rem;color:#fff;margin-bottom:2rem;line-height:1.6}.welcome-buttons{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.welcome-button{padding:1rem 2rem;font-size:1.1rem;border:none;border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s;font-weight:600}.welcome-button.primary{background:#fff;color:#667eea}.welcome-button.primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.welcome-button.secondary{background:#fff3;color:#fff;border:2px solid white}.welcome-button.secondary:hover{background:#ffffff4d;transform:translateY(-2px)}.skip-tutorial-link{background:none;border:none;color:#ffffffb3;font-size:.9rem;cursor:pointer;text-decoration:underline;transition:color .2s}.skip-tutorial-link:hover{color:#fff}@media (max-width: 600px){.welcome-title{font-size:2rem}.welcome-question{font-size:1.2rem}.welcome-button{font-size:1rem}}.tutorial-progress{position:fixed;top:20px;left:50%;transform:translate(-50%);z-index:999;pointer-events:none}.tutorial-progress-dots{display:flex;gap:12px;align-items:center}.progress-dot{width:10px;height:10px;border-radius:50%;background:#ffffff4d;transition:all .3s ease;border:2px solid rgba(255,255,255,.5)}.progress-dot.active{background:#667eea;border-color:#667eea;width:14px;height:14px;box-shadow:0 0 12px #667eea99}.progress-dot.complete{background:#fffc;border-color:#fffc}.tutorial-overlay{position:fixed;bottom:0;left:0;width:100%;display:flex;justify-content:center;z-index:1000;pointer-events:none;animation:slideUp .4s ease-out}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.tutorial-content{background:#fffffffa;backdrop-filter:blur(10px);padding:1.5rem;border-radius:16px 16px 0 0;max-width:600px;width:100%;text-align:center;box-shadow:0 -4px 24px #0003;pointer-events:auto;margin:0 auto}.tutorial-title{font-size:1.4rem;color:#333;margin-bottom:.75rem;font-weight:600}.tutorial-message{font-size:1rem;color:#555;margin-bottom:1rem;line-height:1.5}.tutorial-summary{text-align:left;margin:1rem 0;padding:.75rem;background:#f0f0f099;border-radius:8px}.tutorial-summary ol{margin:0;padding-left:1.5rem}.tutorial-summary li{margin-bottom:.4rem;font-size:.95rem;color:#333}.audio-toggle{margin:1rem 0}.audio-toggle label{display:flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;font-size:.9rem;color:#555}.audio-toggle input[type=checkbox]{width:20px;height:20px;cursor:pointer}.tutorial-feedback{font-size:2rem;margin:.5rem 0;animation:pop .3s ease-out}.tutorial-feedback.correct{color:#4caf50}.tutorial-feedback.incorrect{color:#f44336}@keyframes pop{0%{transform:scale(.5);opacity:0}50%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.tutorial-celebration{font-size:1.5rem;color:#4caf50;margin:.75rem 0;animation:bounce .6s ease-out}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.tutorial-error{font-size:1rem;color:#f44336;margin:.75rem 0;font-weight:600}.tutorial-buttons{display:flex;flex-direction:row;gap:.75rem;margin-top:1rem;justify-content:center;flex-wrap:wrap}.tutorial-button{padding:.75rem 1.5rem;font-size:1rem;border:none;border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s;font-weight:600}.tutorial-button.primary{background:#667eea;color:#fff}.tutorial-button.primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.tutorial-button.secondary{background:transparent;color:#667eea;border:2px solid #667eea}.tutorial-button.secondary:hover{background:#667eea1a;transform:translateY(-2px)}@media (max-width: 600px){.tutorial-content{padding:1rem;max-width:100%;border-radius:12px 12px 0 0}.tutorial-title{font-size:1.2rem}.tutorial-message{font-size:.9rem}.tutorial-button{font-size:.9rem;padding:.6rem 1.2rem}.tutorial-buttons{flex-direction:column}}.tutorial-game{width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e3c72,#2a5298);position:relative}.tutorial-canvas{border-radius:12px;box-shadow:0 8px 32px #0000004d;background:#ffffff0d;cursor:pointer;max-width:90vw;max-height:80vh}.skip-button{position:absolute;top:20px;right:20px;padding:.75rem 1.5rem;background:#fff3;border:2px solid white;color:#fff;border-radius:8px;font-size:1rem;cursor:pointer;transition:background .2s;z-index:999}.skip-button:hover{background:#ffffff4d}@media (max-width: 600px){.tutorial-canvas{transform:scale(.8)}.skip-button{top:10px;right:10px;padding:.5rem 1rem;font-size:.9rem}}:root{--bg: #0a0a0f;--surface: #111118;--surface2: #18181f;--border: rgba(255, 255, 255, .07);--accent-r: #ff3b5c;--accent-g: #00e59b;--accent-b: #3b8bff;--accent-y: #ffe03b;--text: #e8e8f0;--muted: #6b6b80}*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;min-height:100%;overflow-x:hidden}body{font-family:Space Mono,monospace;background:var(--bg);color:var(--text);line-height:1.6;font-size:14px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;touch-action:manipulation;user-select:none;-webkit-user-select:none}#root{width:100%;min-height:100vh;overflow-x:hidden}@media (max-width: 480px){body{font-size:13px}}button{cursor:pointer;border:none;background:none;font:inherit;color:inherit}button:disabled{opacity:.5;cursor:not-allowed}canvas{display:block}
