*{box-sizing:border-box;margin:0;padding:0}body{color:#e2eaf4;background:#0e1a2b;height:100vh;font-family:system-ui,Segoe UI,Roboto,sans-serif;overflow:hidden}#root{flex-direction:column;width:100vw;height:100vh;display:flex}.game-wrapper{flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:24px;display:flex;overflow-y:auto}.game-wrapper--playing{justify-content:flex-start;padding:12px;overflow:hidden}.map-container{flex:1;width:100%;min-height:0;position:relative}.hud{background:#162032;border:1px solid #2a3f5c;border-radius:10px;flex-direction:column;gap:8px;width:100%;margin-bottom:12px;padding:10px 16px;transition:border-color .2s;display:flex}.hud--correct{border-color:#27ae60;animation:.5s correct-flash}.hud--wrong{border-color:#e74c3c;animation:.4s wrong-shake}@keyframes correct-flash{0%{box-shadow:0 0 #27ae6000}40%{box-shadow:0 0 0 8px #27ae6059}to{box-shadow:0 0 #27ae6000}}@keyframes wrong-shake{0%,to{transform:translate(0)}20%{transform:translate(-5px)}40%{transform:translate(5px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}@keyframes streak-combo{0%{transform:scale(1)}50%{transform:scale(1.4)}to{transform:scale(1)}}.hud-top-row{justify-content:space-between;align-items:center;gap:8px;display:flex}.hud-score{color:#7fa8cc;min-width:60px;font-size:15px;font-weight:700}.hud-streak-area{flex:1;justify-content:center;align-items:center;gap:8px;display:flex}.hud-streak{color:#f5a623;font-size:18px;font-weight:700;animation:.4s streak-combo}.hud-multiplier{color:#1a2a3a;background:#f5a623;border-radius:12px;padding:2px 8px;font-size:14px;font-weight:800}.hud-timer-wrap{align-items:center;display:flex}.hud-timer-ring{width:44px;height:44px;position:relative}.hud-timer-num{justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex;position:absolute;inset:0}.hud-prompt{align-items:center;gap:12px;min-height:44px;display:flex}.hud-question-num{color:#579;white-space:nowrap;font-size:13px}.hud-prompt-text{color:#e8f0f8;flex:1;font-size:20px;font-weight:600}.hud-flag{object-fit:cover;border:1px solid #2a3f5c;border-radius:4px;width:54px;height:36px}.hud-progress-bar{background:#1e2f44;border-radius:2px;width:100%;height:4px;overflow:hidden}.hud-progress-fill{background:#4a90d9;border-radius:2px;height:100%;transition:width .3s}.map-reset-btn{color:#7fa8cc;cursor:pointer;background:#162032e0;border:1px solid #2a3f5c;border-radius:6px;padding:4px 10px;font-size:13px;position:absolute;top:8px;right:8px}.map-reset-btn:hover{background:#1e3048}.country-tooltip{pointer-events:none;z-index:100;white-space:nowrap;background:#0e1a2bf2;border:1px solid #2a3f5c;border-radius:8px;align-items:center;gap:8px;padding:6px 10px;display:flex;box-shadow:0 4px 16px #0006}.tooltip-flag{object-fit:cover;border-radius:2px;width:27px;height:18px}.tooltip-name{color:#e8f0f8;font-size:14px;font-weight:700}.tooltip-capital{color:#7fa8cc;font-size:12px}.mode-menu{text-align:center;width:100%;padding:24px 16px}.mode-menu-hero{margin-bottom:24px}.mode-menu-title{color:#e8f4ff;letter-spacing:-1px;margin-bottom:4px;font-size:48px;font-weight:800}.mode-menu-subtitle{color:#7fa8cc;margin-bottom:0;font-size:16px}.char-badge-btn{cursor:pointer;color:#e2eaf4;background:#162032;border:1px solid #2a3f5c;border-radius:20px;align-items:center;gap:6px;margin-bottom:12px;padding:6px 14px;font-size:14px;transition:background .15s;display:inline-flex}.char-badge-btn:hover{background:#1e3048;border-color:#4a90d9}.char-badge-emoji{font-size:18px}.char-badge-name{font-weight:600}.char-badge-edit{color:#579;font-size:12px}.diff-toggle{justify-content:center;gap:10px;margin-bottom:24px;display:flex}.diff-btn{color:#7fa8cc;cursor:pointer;background:#162032;border:1.5px solid #2a3f5c;border-radius:20px;padding:6px 20px;font-size:14px;font-weight:600;transition:all .15s}.diff-btn:hover{background:#1e3048}.diff-btn--active{background:#1a2e46;font-weight:700}.mode-cards{grid-template-columns:repeat(2,1fr);gap:16px;max-width:640px;margin:0 auto;display:grid}.mode-card{cursor:pointer;color:#e2eaf4;background:#162032;border:1px solid #2a3f5c;border-radius:12px;flex-direction:column;align-items:center;gap:8px;padding:24px 16px;transition:background .15s,border-color .15s,transform .1s;display:flex}.mode-card:hover{background:#1e3048;border-color:#4a90d9;transform:translateY(-2px)}.mode-card-emoji{font-size:36px}.mode-card-label{color:#e8f0f8;font-size:18px;font-weight:700}.mode-card-desc{color:#7fa8cc;text-align:center;font-size:13px}.char-select{text-align:center;width:100%;max-width:700px;padding:24px 16px}.char-select-header{margin-bottom:20px}.char-select-title{color:#e8f4ff;margin-bottom:8px;font-size:40px;font-weight:800}.char-select-subtitle{color:#7fa8cc;font-size:15px}.char-profile-badge{text-align:left;background:#162032;border:1px solid #2a3f5c;border-radius:12px;align-items:center;gap:12px;margin-bottom:20px;padding:12px 16px;display:flex}.char-profile-emoji{font-size:36px}.char-profile-name{color:#e8f0f8;margin-bottom:4px;font-size:15px;font-weight:700}.char-profile-xp{color:#579;margin-top:4px;font-size:12px}.xp-bar-wrap{background:#1e2f44;border-radius:3px;width:160px;height:6px;overflow:hidden}.xp-bar-fill{background:linear-gradient(90deg,#4a90d9,#27ae60);border-radius:3px;height:100%;transition:width .5s}.char-grid{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px;display:grid}.char-card{cursor:pointer;color:#e2eaf4;background:#162032;border:2px solid #2a3f5c;border-radius:12px;flex-direction:column;align-items:center;gap:6px;padding:16px 8px;transition:all .15s;display:flex}.char-card:hover{background:#1e3048;border-color:#4a90d9}.char-card--selected{background:#1a2e46;border-color:#f5a623}.char-card-emoji{font-size:32px}.char-card-name{font-size:15px;font-weight:700}.char-card-title{color:#7fa8cc;font-size:11px}.char-detail{text-align:left;background:#162032;border:1px solid #2a3f5c;border-radius:12px;align-items:flex-start;gap:16px;margin-bottom:24px;padding:14px 18px;display:flex}.char-detail-emoji{font-size:48px}.char-detail-name{color:#e8f0f8;margin-bottom:4px;font-size:16px;font-weight:700}.char-detail-desc{color:#7fa8cc;margin-bottom:6px;font-size:13px}.char-detail-bonus{color:#f5a623;font-size:13px;font-weight:600}.story-intro{text-align:center;max-width:540px;margin:0 auto;padding:40px 24px;animation:.5s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}.story-char{margin-bottom:8px;font-size:80px}.story-char-name{color:#e8f0f8;margin-bottom:12px;font-size:20px;font-weight:700}.story-diff-badge{color:#7fa8cc;background:#162032;border:1px solid #2a3f5c;border-radius:16px;margin-bottom:20px;padding:4px 16px;font-size:13px;display:inline-block}.story-text{color:#c8d8e8;margin-bottom:32px;font-size:17px;line-height:1.7}.story-countdown{color:#7fa8cc;margin-left:6px;font-size:14px}.results-screen{text-align:center;width:100%;max-width:540px;margin:0 auto;padding:28px 16px}.results-pb-badge{color:#1a2a3a;background:#f5a623;border-radius:20px;margin-bottom:16px;padding:6px 20px;font-size:15px;font-weight:800;display:inline-block}.results-char-row{text-align:left;background:#162032;border:1px solid #2a3f5c;border-radius:12px;align-items:center;gap:16px;margin-bottom:20px;padding:14px 20px;display:flex}.results-char-emoji{font-size:52px}.results-grade{color:#e8f4ff;margin-bottom:4px;font-size:24px;font-weight:800}.results-char-msg{color:#7fa8cc;font-size:14px}.results-stats-row{grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:20px;display:grid}.results-stat{background:#162032;border:1px solid #2a3f5c;border-radius:10px;flex-direction:column;align-items:center;gap:4px;padding:12px 6px;display:flex}.results-stat-val{color:#e8f0f8;font-size:18px;font-weight:700}.results-stat-lbl{color:#579;font-size:11px}.results-xp-section{margin-bottom:20px}.results-levelup{color:#f5a623;margin-bottom:8px;font-size:18px;font-weight:800;animation:.6s streak-combo}.results-level-label{color:#7fa8cc;margin-bottom:4px;font-size:13px}.results-xp-bar{width:100%}.results-xp-text{color:#579;margin-top:4px;font-size:12px}.results-leaderboard{text-align:left;background:#162032;border:1px solid #2a3f5c;border-radius:12px;margin-bottom:20px;padding:14px}.results-lb-title{color:#7fa8cc;margin-bottom:10px;font-size:14px;font-weight:700}.results-lb-row{border-bottom:1px solid #1e2f44;align-items:center;gap:10px;padding:5px 0;font-size:14px;display:flex}.results-lb-row:last-child{border-bottom:none}.results-lb-rank{color:#f5a623;width:24px;font-weight:700}.results-lb-char{font-size:18px}.results-lb-pct{color:#e8f0f8;min-width:42px;font-weight:700}.results-lb-score{color:#7fa8cc;flex:1}.results-lb-date{color:#456;font-size:11px}.results-actions{justify-content:center;gap:12px;display:flex}.btn-primary{color:#fff;cursor:pointer;background:#4a90d9;border:none;border-radius:8px;padding:12px 32px;font-size:16px;font-weight:600;transition:background .15s}.btn-primary:hover{background:#3576b8}.btn-primary.btn-large{padding:14px 40px;font-size:18px}.btn-secondary{color:#7fa8cc;cursor:pointer;background:#162032;border:1px solid #2a3f5c;border-radius:8px;padding:12px 28px;font-size:16px;font-weight:600;transition:background .15s}.btn-secondary:hover{background:#1e3048}.campaign-map{flex-direction:column;gap:20px;width:100%;max-width:860px;padding:0 4px;display:flex}.campaign-header{flex-direction:column;gap:10px;display:flex}.campaign-header-top{justify-content:center;align-items:center;gap:16px;display:flex}.campaign-title{color:#e8f4ff;font-size:36px;font-weight:800}.campaign-player-hp{align-items:center;gap:10px;display:flex}.campaign-hp-label{white-space:nowrap;min-width:110px;font-size:14px;font-weight:700}.campaign-hp-track{background:#1e2f44;border-radius:5px;flex:1;height:10px;overflow:hidden}.campaign-hp-fill{border-radius:5px;height:100%;transition:width .5s,background .3s}.villain-path{scrollbar-width:thin;scrollbar-color:#2a3f5c #0e1a2b;gap:8px;padding:8px 4px 12px;display:flex;overflow-x:auto}.villain-node{background:#162032;border:2px solid #2a3f5c;border-radius:12px;flex-direction:column;flex-shrink:0;align-items:center;gap:4px;min-width:88px;padding:10px 8px;transition:border-color .2s;display:flex}.villain-node--current{border-color:#f5a623;animation:1.8s ease-in-out infinite villain-pulse}.villain-node--defeated{opacity:.55;border-color:#1e2f44}.villain-node--locked{opacity:.3;border-color:#1a2535}.villain-node--boss{border-radius:14px}.villain-node-stage{letter-spacing:.5px;font-size:10px;font-weight:800}.villain-node-emoji{font-size:30px;line-height:1}.villain-node-name{color:#a0b8cc;text-align:center;font-size:11px;font-weight:600}.villain-node-hp-bar{background:#1e2f44;border-radius:3px;width:64px;height:5px;overflow:hidden}.villain-node-hp-fill{background:#e74c3c;border-radius:3px;height:100%;transition:width .5s}@keyframes villain-pulse{0%,to{box-shadow:0 0 #f5a62380}50%{box-shadow:0 0 0 10px #f5a62300}}.campaign-challenge{background:#162032;border:1px solid #2a3f5c;border-radius:14px;align-items:flex-start;gap:14px;padding:16px 20px;display:flex}.challenge-villain-emoji{font-size:52px;line-height:1}.challenge-villain-details{flex-direction:column;gap:6px;display:flex}.challenge-villain-name{color:#e8f0f8;font-size:17px;font-weight:700}.challenge-villain-title{font-size:14px;font-weight:600}.challenge-villain-desc{color:#7fa8cc;font-size:13px;line-height:1.5}.challenge-stats{flex-wrap:wrap;gap:16px;display:flex}.challenge-stat{color:#a0b8cc;font-size:13px;font-weight:600}.challenge-damaged{color:#f5a623;font-style:italic}.campaign-complete{text-align:center;padding:20px}.campaign-complete-emoji{margin-bottom:12px;font-size:64px}.campaign-complete-title{color:#f5a623;margin-bottom:8px;font-size:28px;font-weight:800}.campaign-complete-desc{color:#7fa8cc;font-size:15px;line-height:1.6}.campaign-actions{justify-content:center;gap:12px;display:flex}.battle-screen{flex-direction:column;gap:16px;width:100%;max-width:760px;animation:.3s fadeIn;display:flex}.battle-header{text-align:center}.battle-stage-badge{color:#fff;letter-spacing:1px;border-radius:12px;margin-bottom:6px;padding:3px 12px;font-size:11px;font-weight:800;display:inline-block}.battle-title{color:#e8f0f8;font-size:20px;font-weight:700}.battle-subtitle{color:#7fa8cc;margin-top:4px;font-size:13px}.battle-arena{background:#0d1a2a;border:1px solid #2a3f5c;border-radius:16px;justify-content:space-between;align-items:flex-start;gap:12px;min-height:220px;padding:20px 16px;display:flex}.battle-side{flex-direction:column;flex:1;align-items:flex-start;gap:6px;display:flex}.battle-side--right{align-items:flex-end}.battle-combatant-name{color:#a0b8cc;font-size:14px;font-weight:700}.battle-hp-track{background:#1e2f44;border-radius:5px;width:100%;height:10px;overflow:hidden}.battle-hp-fill{border-radius:5px;height:100%;transition:width .7s,background .3s}.battle-hp-fill--villain{background:#e74c3c}.battle-hp-text{color:#579;font-size:12px}.battle-sprite-wrap{margin-top:8px;position:relative}.battle-sprite{transform-origin:bottom;font-size:72px;line-height:1;transition:transform .3s;display:block}.battle-sprite--villain{transform:scaleX(-1)}@keyframes player-charge{0%{transform:translate(0)scale(1)}40%{transform:translate(100px)scale(1.25)}70%{transform:translate(80px)scale(1.15)}to{transform:translate(0)scale(1)}}@keyframes villain-hit{0%,to{transform:scaleX(-1)translate(0)rotate(0)}25%{transform:scaleX(-1)translate(-18px)rotate(-12deg)}50%{transform:scaleX(-1)translate(10px)rotate(8deg)}75%{transform:scaleX(-1)translate(-8px)rotate(-4deg)}}@keyframes villain-counter-charge{0%{transform:scaleX(-1)translate(0)scale(1)}40%{transform:scaleX(-1)translate(-100px)scale(1.25)}70%{transform:scaleX(-1)translate(-80px)scale(1.15)}to{transform:scaleX(-1)translate(0)scale(1)}}@keyframes player-recoil{0%,to{transform:translate(0)rotate(0)}25%{transform:translate(-18px)rotate(-12deg)}50%{transform:translate(10px)rotate(8deg)}75%{transform:translate(-8px)rotate(-4deg)}}@keyframes dmg-float{0%{opacity:1;font-size:28px;transform:translateY(0)}to{opacity:0;font-size:20px;transform:translateY(-60px)}}.battle-anim-charge{animation:.7s forwards player-charge}.battle-anim-hit{animation:.6s forwards villain-hit}.battle-anim-counter-charge{animation:.7s forwards villain-counter-charge}.battle-anim-recoil{animation:.6s forwards player-recoil}.battle-dmg{pointer-events:none;white-space:nowrap;font-size:28px;font-weight:900;animation:1s forwards dmg-float;position:absolute}.battle-dmg--villain{color:#e74c3c;top:10px;left:-10px}.battle-dmg--player{color:#e74c3c;top:10px;right:-10px}.battle-center{flex-direction:column;align-items:center;gap:8px;min-width:56px;padding-top:60px;display:flex}.battle-vs-icon{font-size:28px}.battle-power-badge{color:#1a2a3a;background:#f5a623;border-radius:12px;padding:4px 10px;font-size:13px;font-weight:800;animation:.5s streak-combo}.battle-log{color:#c8d8e8;text-align:center;background:#0d1a2a;border:1px solid #1e2f44;border-radius:10px;justify-content:center;align-items:center;min-height:48px;padding:12px 16px;font-size:15px;display:flex}.battle-outcome{text-align:center;border:2px solid #0000;border-radius:16px;flex-direction:column;align-items:center;gap:12px;padding:20px 24px;animation:.4s fadeIn;display:flex}.battle-outcome--victory{background:#27ae601f;border-color:#27ae60}.battle-outcome--defeat{background:#e74c3c1f;border-color:#e74c3c}.battle-outcome--ongoing{background:#f5a6231a;border-color:#f5a623}.battle-outcome-title{color:#e8f4ff;font-size:32px;font-weight:900;animation:.6s streak-combo}.battle-outcome-xp{color:#f5a623;font-size:20px;font-weight:700}.battle-outcome-levelup{color:#f5a623;font-size:18px;font-weight:800;animation:.6s .2s both streak-combo}.battle-outcome-xprow{align-items:center;gap:10px;display:flex}.battle-xp-bar{width:180px!important}.battle-outcome-xplabel{color:#579;font-size:12px}.battle-outcome-hint{color:#7fa8cc;background:#162032;border-radius:8px;max-width:380px;padding:8px 14px;font-size:13px}
