.character-select{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;padding:2rem;position:relative}.reset-button{position:absolute;top:1rem;right:1rem;background:#ef4444;color:#fff;border:none;padding:.5rem 1rem;border-radius:.5rem;cursor:pointer;font-size:.9rem;transition:background .3s}.reset-button:hover{background:#dc2626}.character-select h1{margin-bottom:3rem;font-size:3rem;text-align:center}.character-options{display:flex;gap:3rem;flex-wrap:wrap;justify-content:center}.character-card{background:#1a1a1a;border:2px solid #646cff;border-radius:1rem;padding:2rem;width:250px;cursor:pointer;transition:all .3s ease;text-align:center}.character-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #646cff4d;border-color:#747bff}.character-image{font-size:5rem;margin-bottom:1rem}.character-card h2{margin-bottom:.5rem;font-size:1.8rem}.character-card p{color:#888;font-size:1rem}.character-card.wizard:hover{border-color:#9d4edd;box-shadow:0 10px 30px #9d4edd4d}.character-card.gymnast:hover{border-color:#f72585;box-shadow:0 10px 30px #f725854d}.world-map{width:100%;height:100vh;display:flex;flex-direction:column;background:#1a1a1a}.world-map-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:#242424;border-bottom:2px solid #333}.world-map-header h1{font-size:2rem;margin:0}.header-buttons{display:flex;gap:1rem;align-items:center}.character-info{display:flex;gap:1rem;align-items:center;padding:.5rem 1rem;background:#1a1a1a;border-radius:.5rem}.character-info .health{color:#ef4444;font-weight:700}.world-map canvas{flex:1;cursor:pointer}.instructions{text-align:center;padding:1rem;background:#242424;color:#888;border-top:2px solid #333}button{padding:.5rem 1rem;background:#646cff;color:#fff;border:none;border-radius:.5rem;cursor:pointer;font-size:1rem;transition:background .3s}button:hover{background:#747bff}.ability-unlock-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s}.ability-unlock-popup{background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:1.5rem;padding:2.5rem;max-width:500px;width:90%;border:3px solid;position:relative;animation:slideUp .5s ease-out;text-align:center}.unlock-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.unlock-header h2{margin:0;font-size:1.8rem;color:#fbbf24;text-transform:uppercase;letter-spacing:1px}.close-button{background:none;border:none;color:#aaa;font-size:2rem;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .3s}.close-button:hover{background:#ffffff1a;color:#fff}.ability-icon{width:120px;height:120px;margin:0 auto 1.5rem;border-radius:50%;border:4px solid;display:flex;align-items:center;justify-content:center;font-size:4rem;background:#ffffff0d;animation:pulse 2s infinite}.ability-details{margin-bottom:1.5rem}.ability-name{font-size:2rem;margin:0 0 .5rem;color:#fff}.ability-rarity{display:inline-block;padding:.35rem 1rem;border:2px solid;border-radius:2rem;font-size:.9rem;font-weight:700;letter-spacing:1px}.ability-description{color:#ccc;line-height:1.6;margin:1.5rem 0;font-size:1.05rem}.ability-stats{display:flex;gap:2rem;justify-content:center;margin:2rem 0}.stat-item{display:flex;flex-direction:column;align-items:center;gap:.25rem}.stat-icon{font-size:1.8rem}.stat-value{font-size:1.8rem;font-weight:700;color:#fff}.stat-label{font-size:.9rem;color:#888;text-transform:uppercase;letter-spacing:.5px}.unlock-footer{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.1)}.unlock-footer p{color:#888;margin:0;font-size:.9rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.region-3d{width:100%;height:100vh;display:flex;flex-direction:column;background:#0a0a0a;position:relative}.region-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:#242424;border-bottom:2px solid #333;gap:2rem}.region-header h2{margin:0;font-size:1.5rem;flex-shrink:0}.region-stats{display:flex;gap:1.5rem;flex:1}.region-stats .health{color:#ef4444;font-weight:700}.region-3d canvas{flex:1;width:100%;outline:none}.interaction-prompt{position:absolute;bottom:30%;left:50%;transform:translate(-50%);background:#000000e6;padding:1.5rem 2rem;border-radius:1rem;border:2px solid #fbbf24;text-align:center;animation:pulse 1.5s infinite}.interaction-prompt p{margin:0 0 1rem;font-size:1.2rem;color:#fbbf24}.interaction-prompt button{background:#fbbf24;color:#000;border:none;padding:.75rem 1.5rem;border-radius:.5rem;font-size:1rem;font-weight:700;cursor:pointer;transition:all .3s}.interaction-prompt button:hover{background:#f59e0b;transform:scale(1.05)}.boss-prompt{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000f2;padding:2rem 3rem;border-radius:1rem;border:3px solid #ef4444;text-align:center;box-shadow:0 0 30px #ef444480;animation:bossPulse 2s infinite}.boss-prompt h3{margin:0 0 .5rem;font-size:2rem;color:#ef4444}.boss-prompt p{margin:0 0 1.5rem;font-size:1.2rem;color:#aaa}.boss-button{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;padding:1rem 2rem;border-radius:.5rem;font-size:1.2rem;font-weight:700;cursor:pointer;transition:all .3s;text-transform:uppercase}.boss-button:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:scale(1.1);box-shadow:0 0 20px #ef4444b3}.controls-overlay{position:absolute;bottom:1rem;left:1rem;background:#000000b3;padding:1rem;border-radius:.5rem;font-size:.9rem;color:#aaa}.controls-overlay p{margin:.25rem 0}.controls-overlay strong{color:#fff}@keyframes pulse{0%,to{transform:translate(-50%) scale(1)}50%{transform:translate(-50%) scale(1.05)}}@keyframes bossPulse{0%,to{box-shadow:0 0 30px #ef444480}50%{box-shadow:0 0 50px #ef4444cc}}.profile{width:100%;min-height:100vh;background:#1a1a1a}.profile-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:#242424;border-bottom:2px solid #333}.profile-header h1{margin:0;font-size:2rem}.profile-content{padding:2rem;max-width:1200px;margin:0 auto}.character-details{text-align:center;margin-bottom:3rem}.character-icon{font-size:5rem;margin-bottom:1rem}.character-details h2{margin-bottom:1rem}.health-bar{max-width:400px;margin:0 auto}.health-label{margin-bottom:.5rem;font-weight:700}.health-bar-container{width:100%;height:30px;background:#333;border-radius:15px;overflow:hidden;margin-bottom:.5rem}.health-bar-fill{height:100%;background:linear-gradient(90deg,#ef4444,#f87171);transition:width .3s ease}.health-text{color:#888}.skill-tree-section{margin-bottom:3rem}.skill-tree-section h3{margin-bottom:1.5rem;font-size:1.5rem}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;margin-bottom:2rem}.skill-card{background:#242424;border:2px solid #333;border-radius:.75rem;padding:1.5rem;transition:all .3s}.skill-card:hover{transform:translateY(-2px);border-color:#444}.skill-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.skill-header h4{margin:0;font-size:1.3rem;color:#fff}.mastery-badge{font-size:.75rem;text-transform:uppercase;font-weight:700;padding:.35rem .75rem;border:2px solid;border-radius:1rem;letter-spacing:.5px}.skill-progress-bar{width:100%;height:25px;background:#1a1a1a;border-radius:12px;overflow:hidden;margin-bottom:.75rem;border:1px solid #333}.skill-progress-fill{height:100%;transition:width .5s ease;border-radius:12px}.skill-stats{display:flex;justify-content:space-between;align-items:center;font-size:.9rem}.skill-percentage{font-weight:700;color:#fff}.skill-questions{color:#888}.abilities-section{margin-top:3rem}.abilities-section h3{margin-bottom:1.5rem;font-size:1.5rem}.no-abilities{text-align:center;color:#888;font-size:1.1rem;padding:2rem}.abilities-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.ability-card{background:#242424;border:2px solid;border-radius:.5rem;padding:1.5rem;transition:transform .2s}.ability-card:hover{transform:translateY(-2px)}.ability-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.ability-header h4{margin:0;font-size:1.2rem}.rarity-badge{font-size:.8rem;text-transform:uppercase;font-weight:700;padding:.25rem .5rem;background:#ffffff1a;border-radius:.25rem}.ability-description{color:#aaa;margin-bottom:1rem;line-height:1.5}.ability-stats{display:flex;gap:1rem;font-size:.9rem;color:#888}.question-challenge{width:100%;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e);padding:2rem;position:relative}.challenge-header{text-align:center;margin-bottom:2rem}.challenge-header h2{font-size:2.5rem;margin-bottom:.5rem}.progress{font-size:1.2rem;color:#aaa}.question-card{background:#242424;border-radius:1rem;padding:3rem;max-width:700px;width:100%;box-shadow:0 10px 40px #00000080}.question-text{font-size:2rem;margin-bottom:3rem;text-align:center;line-height:1.5}.answers{display:flex;flex-direction:column;gap:1rem}.answer-button{background:#1a1a1a;border:2px solid #646cff;color:#fff;padding:1.5rem;border-radius:.75rem;font-size:1.3rem;cursor:pointer;transition:all .3s;text-align:center}.answer-button:hover:not(:disabled){background:#2a2a2a;transform:translate(10px);border-color:#747bff}.answer-button:disabled{cursor:not-allowed;opacity:.7}.answer-button.selected{background:#2a2a3a;border-color:#747bff}.answer-button.correct{background:#22c55e;border-color:#16a34a;animation:correctPulse .5s}.answer-button.incorrect{background:#ef4444;border-color:#dc2626;animation:shake .5s}.feedback{margin-top:2rem;padding:1rem;border-radius:.5rem;text-align:center;font-size:1.5rem;font-weight:700}.feedback.correct{background:#22c55e33;color:#22c55e}.feedback.incorrect{background:#ef444433;color:#ef4444}.challenge-stats{margin-top:2rem;display:flex;gap:2rem;justify-content:center}.stat{display:flex;align-items:center;gap:.5rem;font-size:1.2rem}.stat-label{color:#aaa}.stat-value{font-weight:700;color:#22c55e;font-size:1.5rem}.exit-button{position:absolute;top:1rem;right:1rem;background:#333;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:.5rem;cursor:pointer;font-size:1rem;transition:background .3s}.exit-button:hover{background:#444}.question-challenge.complete{background:linear-gradient(135deg,#1a1a2e,#16213e,#1a1a2e)}.completion-card{background:#242424;border-radius:1.5rem;padding:4rem;max-width:600px;width:100%;text-align:center;box-shadow:0 20px 60px #000000b3;animation:slideIn .5s}.completion-card h1{font-size:3rem;margin-bottom:2rem;color:#fbbf24}.score{margin-bottom:2rem}.score-circle{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;width:200px;height:200px;border-radius:50%;background:linear-gradient(135deg,#646cff,#747bff);margin-bottom:1rem;box-shadow:0 10px 30px #646cff80}.score-number{font-size:4rem;font-weight:700;color:#fff}.score-total{font-size:1.5rem;color:#fffc}.score-percentage{font-size:1.8rem;color:#aaa}.perfect-message{font-size:1.5rem;color:#22c55e;margin-bottom:2rem;font-weight:700}.great-message{font-size:1.3rem;color:#fbbf24;margin-bottom:2rem;font-weight:700}.continue-button{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#000;border:none;padding:1.5rem 3rem;border-radius:.75rem;font-size:1.5rem;font-weight:700;cursor:pointer;transition:all .3s;text-transform:uppercase;box-shadow:0 5px 20px #fbbf2466}.continue-button:hover{transform:scale(1.05);box-shadow:0 10px 30px #fbbf2499}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}@keyframes slideIn{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}.battle{width:100%;min-height:100vh;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f0f1e);display:flex;flex-direction:column;padding:2rem}.battle-header{display:flex;align-items:center;justify-content:space-between;gap:2rem;margin-bottom:2rem;background:#0006;padding:1.5rem;border-radius:1rem;border:2px solid #333}.combatant{flex:1}.combatant h3{margin:0 0 .75rem;font-size:1.5rem}.player-info h3{color:#22c55e}.boss-info{text-align:right}.boss-info h3{color:#ef4444}.health-bar-wrapper{display:flex;flex-direction:column;gap:.5rem}.health-bar{width:100%;height:30px;background:#1a1a1a;border-radius:15px;overflow:hidden;border:2px solid #333}.health-fill{height:100%;transition:width .5s ease;border-radius:15px}.player-health{background:linear-gradient(90deg,#22c55e,#16a34a)}.boss-health{background:linear-gradient(90deg,#ef4444,#dc2626)}.health-text{font-size:.9rem;color:#aaa;font-weight:700}.vs-indicator{font-size:2.5rem;font-weight:700;color:#fbbf24;text-shadow:0 0 20px rgba(251,191,36,.5);flex-shrink:0}.battle-main{display:flex;gap:2rem;flex:1}.question-section{flex:2;display:flex;flex-direction:column;gap:1.5rem}.round-progress{background:#0006;padding:1rem;border-radius:.75rem;text-align:center;border:2px solid #333}.round-progress p{margin:0 0 .75rem;color:#fbbf24;font-weight:700}.progress-dots{display:flex;gap:.75rem;justify-content:center}.progress-dot{width:20px;height:20px;border-radius:50%;background:#333;border:2px solid #555;transition:all .3s}.progress-dot.completed{background:#22c55e;border-color:#16a34a;box-shadow:0 0 10px #22c55e80}.battle-question-card{background:#0009;border-radius:1rem;padding:2.5rem;border:2px solid #444;flex:1;display:flex;flex-direction:column;justify-content:center}.question-text{font-size:1.8rem;margin-bottom:2rem;text-align:center;color:#fff}.battle-answers{display:flex;flex-direction:column;gap:1rem}.battle-answer-button{background:#1a1a2a;border:2px solid #646cff;color:#fff;padding:1.25rem;border-radius:.75rem;font-size:1.2rem;cursor:pointer;transition:all .3s}.battle-answer-button:hover:not(:disabled){background:#2a2a3a;border-color:#747bff;transform:translate(8px)}.battle-answer-button:disabled{cursor:not-allowed;opacity:.7}.battle-answer-button.correct{background:#22c55e;border-color:#16a34a;animation:correctPulse .5s}.battle-answer-button.incorrect{background:#ef4444;border-color:#dc2626;animation:shake .5s}.battle-feedback{margin-top:1.5rem;padding:.75rem;border-radius:.5rem;text-align:center;font-size:1.3rem;font-weight:700}.battle-feedback.correct{background:#22c55e33;color:#22c55e}.battle-feedback.incorrect{background:#ef444433;color:#ef4444}.battle-log{flex:1;background:#0006;border-radius:1rem;padding:1.5rem;border:2px solid #333;max-width:350px}.battle-log h4{margin:0 0 1rem;font-size:1.2rem;color:#fbbf24;text-align:center}.log-messages{display:flex;flex-direction:column;gap:.75rem}.log-message{background:#00000080;padding:.75rem;border-radius:.5rem;color:#ccc;font-size:.95rem;border-left:3px solid #646cff;animation:slideIn .3s}.battle-ui{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;text-align:center}.battle-ui h2{font-size:2.5rem;color:#fbbf24;margin-bottom:1rem}.ability-prompt{font-size:1.2rem;color:#aaa;margin-bottom:2rem}.ability-selection{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;max-width:900px;width:100%}.selectable-ability{background:#0009;border:2px solid #646cff;border-radius:1rem;padding:1.5rem;cursor:pointer;transition:all .3s}.selectable-ability:hover{transform:scale(1.05);border-color:#fbbf24;box-shadow:0 10px 30px #fbbf244d}.selectable-ability h4{margin:0 0 .5rem;font-size:1.3rem;color:#fff}.ability-rarity{margin:0 0 .75rem;font-size:.85rem;text-transform:uppercase;font-weight:700;color:#888}.ability-effect{margin:0;font-size:1.1rem;color:#22c55e;font-weight:700}@keyframes correctPulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-8px)}75%{transform:translate(8px)}}@keyframes slideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.App{width:100%;height:100vh;overflow:hidden}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}#root{width:100%;height:100vh}
