@import "https://fonts.googleapis.com/css2?family=Press+Start+2P&display=swap";*{box-sizing:border-box;image-rendering:pixelated;margin:0;padding:0}html,body{color:#f8f8f2;cursor:crosshair;touch-action:none;background:#2d2b55;width:100%;height:100dvh;font-family:"Press Start 2P",cursive;overflow:hidden}body:before{content:"";pointer-events:none;z-index:999;background:repeating-linear-gradient(0deg,#0000,#0000 3px,#00000014 3px 6px);width:100%;height:100%;position:fixed;top:0;left:0}body:after{content:"";pointer-events:none;z-index:998;background:radial-gradient(circle,#0000 70%,#00000040 100%);width:100%;height:100%;position:fixed;top:0;left:0}#main{image-rendering:pixelated;display:block}.hud-top{pointer-events:none;z-index:100;justify-content:space-between;align-items:flex-start;display:flex;position:absolute;top:16px;left:20px;right:20px}.brand-header{align-items:flex-start;gap:12px;margin-bottom:10px;display:flex}.brand-titles{flex-direction:column;gap:2px;display:flex}.brand h1{color:#ff79c6;text-shadow:3px 3px #000,-1px -1px #000,1px -1px #000,-1px 1px #000,0 0 10px #ff79c680;letter-spacing:1px;margin:0;font-size:16px;line-height:1.4}.brand .cn-name{color:#50fa7b;text-shadow:2px 2px #000;letter-spacing:1px;font-size:11px}.brand .cn-name #mode-name{color:#ff79c6}.brand .sub{color:#bd93f9;text-shadow:2px 2px #000;letter-spacing:1px;font-size:10px}.score-board{text-align:right;cursor:grab;pointer-events:auto;background:#00000080;border:3px solid #6272a4;min-width:170px;padding:10px 14px;box-shadow:4px 4px #0006}.score-board .row{color:#6272a4;text-shadow:2px 2px #000;justify-content:space-between;align-items:center;margin:5px 0;font-size:10px;display:flex}.score-board .row .label{color:#f8f8f2;margin-right:12px}.score-board .row span:not(.label){color:#50fa7b;text-shadow:2px 2px #000;white-space:nowrap}.legend-panel{pointer-events:auto;z-index:100;background:#282a36eb;border:3px solid #6272a4;width:210px;padding:0;position:absolute;top:50%;right:16px;transform:translateY(-50%);box-shadow:4px 4px #0006}.legend-header{color:#ff79c6;text-shadow:2px 2px #000;cursor:grab;-webkit-user-select:none;user-select:none;border-bottom:2px solid #6272a4;justify-content:space-between;align-items:center;padding:10px 12px;font-size:10px;display:flex}.legend-toggle{color:#50fa7b;cursor:pointer;text-align:center;background:#44475a;border:2px solid #6272a4;width:24px;height:24px;font-family:"Press Start 2P",cursive;font-size:10px;line-height:20px;box-shadow:2px 2px #0006}.legend-toggle:hover{color:#ff79c6;background:#6272a4}.legend-content{padding:10px 14px}.probe-date{color:#50fa7b;text-align:center;text-shadow:2px 2px #000;border-bottom:1px dashed #6272a466;margin-bottom:8px;padding-bottom:8px;font-size:10px}.legend-panel.collapsed .legend-content{display:none}.legend-panel.collapsed{width:auto;min-width:110px}.legend-panel.collapsed .legend-header{border-bottom:none}.legend-item{text-shadow:2px 2px #000;cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;margin:10px 0;font-size:10px;display:flex}.legend-item.hidden-layer{opacity:.4}.legend-name{flex:1}.legend-unit{color:#8be9fd;margin-right:6px;font-size:7px}.legend-value{color:#f8f8f2;margin-left:8px;font-size:9px}.pixel-icon{border:2px solid #000;flex-shrink:0;width:14px;height:14px;margin-right:10px;box-shadow:2px 2px #00000080}.legend-item.gold{color:gold}.legend-item.gold .pixel-icon{background:gold;border-color:#b8860b}.legend-item.spx{color:#8be9fd}.legend-item.spx .pixel-icon{background:#8be9fd;border-color:#6272a4}.legend-item.bond{color:#bd93f9}.legend-item.bond .pixel-icon{background:#bd93f9;border-color:indigo}.legend-item.china{color:#ff6b9d}.legend-item.china .pixel-icon{background:repeating-linear-gradient(90deg,#ff6b9d,#ff6b9d 3px,#0000 3px 6px);border-color:#ff6b9d}.event-legend{border-top:2px solid #6272a4;margin-top:14px;padding-top:10px}.event-legend:before{content:"事件类型";color:#ff79c6;text-align:center;text-shadow:2px 2px #000;margin-bottom:10px;font-size:10px;display:block}.ev-item{text-shadow:2px 2px #000;color:#f8f8f2;align-items:center;margin:8px 0;font-size:9px;display:flex}.ev-pixel{border:2px solid #000;flex-shrink:0;width:10px;height:10px;margin-right:8px;box-shadow:1px 1px #00000080}#world-replay-panel .mode-select{margin-top:24px}#world-replay-panel .replay-stats{color:#8be9fd;text-shadow:2px 2px #000;margin-bottom:16px;font-size:12px;line-height:2}#back-to-menu-btn{margin-top:24px;font-size:12px}.fullscreen-btn{color:gold;border-color:gold}.fullscreen-btn:hover{color:#2d2b55;background:gold}.hud-bottom{pointer-events:none;z-index:100;justify-content:space-between;align-items:flex-end;display:flex;position:absolute;bottom:16px;left:20px;right:20px}.controls-hint{color:#50fa7b;text-shadow:2px 2px #000;cursor:grab;pointer-events:auto;-webkit-user-select:none;user-select:none;background:#0009;border:2px solid #50fa7b;padding:10px 14px;font-size:10px;line-height:2.2}.zoom-controls{pointer-events:auto;gap:10px;display:flex}.pixel-btn{color:#f8f8f2;cursor:pointer;text-shadow:2px 2px #000;background:#44475a;border:3px solid #6272a4;padding:10px 14px;font-family:"Press Start 2P",cursive;font-size:10px;transition:transform .1s;box-shadow:4px 4px #00000080}.pixel-btn:hover{color:#ff79c6;background:#6272a4;border-color:#ff79c6}.pixel-btn:active{transform:translate(3px,3px);box-shadow:1px 1px #00000080}#info-card{z-index:200;pointer-events:none;width:420px;max-width:90vw;display:none;position:absolute}.card-inner{background:#282a36f5;border:4px solid #ff79c6;padding:18px;box-shadow:6px 6px #0009,0 0 20px #ff79c633}.card-header{border-bottom:3px solid #6272a4;margin-bottom:14px;padding-bottom:10px}.card-tag{color:#bd93f9;text-shadow:2px 2px #000;letter-spacing:1px;margin-bottom:8px;font-size:9px}.card-title{color:#ff79c6;text-shadow:3px 3px #000;font-size:14px;line-height:1.6}.card-body{font-size:10px;line-height:2.2}.data-row{border-bottom:1px dashed #6272a4;justify-content:space-between;padding:6px 0;display:flex}.data-row:last-child{border-bottom:none}.data-label{color:#6272a4;text-shadow:2px 2px #000}.data-value{color:#50fa7b;text-shadow:2px 2px #000}.data-value.up{color:gold}.data-value.down{color:#f55}.data-value.neu{color:#8be9fd}.card-desc{color:#f8f8f2;text-shadow:2px 2px #000;border-top:3px solid #6272a4;margin-top:14px;padding-top:12px;font-size:10px;line-height:2}.card-connections{color:#ff6b9d;text-shadow:2px 2px #000;border-top:1px solid #6272a4;margin-top:10px;padding-top:10px;font-size:9px;line-height:1.8}.card-footer{color:#6272a4;text-shadow:2px 2px #000;border-top:1px solid #6272a4;margin-top:10px;padding-top:10px;font-size:9px}.arrow-box{border-top:10px solid #ff79c6;border-left:10px solid #0000;border-right:10px solid #0000;width:0;height:0;position:absolute;bottom:-10px;left:24px}.minimap-box{pointer-events:auto;cursor:grab;z-index:100;background:#282a36eb;border:3px solid #6272a4;width:220px;height:70px;position:absolute;bottom:80px;right:16px;box-shadow:4px 4px #0006}.minimap-label{color:#bd93f9;z-index:100;pointer-events:none;text-shadow:2px 2px #000;background:#0006;border:2px solid #6272a4;padding:4px 8px;font-size:9px;position:absolute;top:-24px;left:0}#start-screen{z-index:1000;background:#2d2b55;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;transition:opacity .5s;display:flex;position:fixed;top:0;left:0}#start-screen.hidden{opacity:0;pointer-events:none}.start-title{color:#ff79c6;text-shadow:4px 4px #000,0 0 30px #ff79c666;text-align:center;margin-top:40px;margin-bottom:24px;font-size:28px;line-height:2}.start-sub{color:#bd93f9;text-align:center;text-shadow:2px 2px #000;margin-bottom:40px;font-size:12px;line-height:2.2}.start-sub .cn-title{color:#ff79c6;text-shadow:4px 4px #000,0 0 20px #ff79c666;margin-bottom:8px;font-size:22px;display:block}.blink{animation:.8s step-end infinite blink}@keyframes blink{50%{opacity:0}}.pixel-box.start-btn{cursor:pointer;pointer-events:all;color:#50fa7b;text-shadow:2px 2px #000;background:#44475a;border:4px solid #50fa7b;padding:18px 36px;font-size:14px;transition:all .2s;box-shadow:6px 6px #00000080}.pixel-box.start-btn:hover{color:#2d2b55;text-shadow:none;background:#50fa7b;transform:translate(-2px,-2px)}.avatar-selector{flex-direction:column;align-items:center;gap:12px;margin-top:30px;display:flex}.avatar-title{color:#bd93f9;text-shadow:2px 2px #000;font-size:10px}.avatar-options{justify-content:center;gap:12px;display:flex}.avatar-option{cursor:pointer;background:#44475a;border:3px solid #6272a4;flex-direction:column;align-items:center;gap:6px;padding:10px 12px;transition:transform .1s,border-color .1s;display:flex;box-shadow:4px 4px #00000080}.avatar-option:hover{border-color:#ff79c6;transform:translate(-2px,-2px)}.avatar-option.selected{background:#3a3c4a;border-color:#50fa7b}.avatar-pixel{border:2px solid #000;width:20px;height:20px;box-shadow:2px 2px #00000080}.avatar-label{color:#f8f8f2;text-shadow:2px 2px #000;text-align:center;font-size:8px;line-height:1.6}.menu-btn{pointer-events:auto;background:#00000080;padding:8px 12px;font-size:9px;position:static}#rotate-hint{z-index:2000;text-align:center;background:#2d2b55;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:20px;display:none;position:fixed;top:0;left:0}#rotate-hint .phone-icon{color:#ff79c6;text-shadow:4px 4px #000;margin-bottom:20px;font-size:60px;animation:2s ease-in-out infinite rotatePhone}@keyframes rotatePhone{0%,to{transform:rotate(0)}50%{transform:rotate(90deg)}}#rotate-hint h2{color:#ff79c6;text-shadow:3px 3px #000;margin-bottom:16px;font-size:16px;line-height:1.8}#rotate-hint p{color:#bd93f9;text-shadow:2px 2px #000;max-width:280px;font-size:10px;line-height:2}@media screen and (aspect-ratio<=1){.hud-top{top:8px;left:10px;right:10px}.brand-header{gap:8px;margin-bottom:4px}.brand h1{letter-spacing:1px;font-size:12px}.brand .sub{font-size:7px}.menu-btn{padding:6px 8px;font-size:7px}.score-board{border-width:2px;padding:6px 10px;box-shadow:2px 2px #0006}.score-board .row{margin:3px 0;font-size:8px}.legend-panel{border-width:2px;width:auto;min-width:120px;top:80px;bottom:auto;right:8px;transform:none}.legend-panel:not(.collapsed){width:170px}.legend-header{padding:6px 8px;font-size:8px}.legend-toggle{border-width:1px;width:18px;height:18px;font-size:8px;line-height:16px}.legend-content{padding:6px 8px}.legend-item{margin:4px 0;font-size:7px}.pixel-icon{border-width:1px;width:9px;height:9px;margin-right:5px;box-shadow:1px 1px #00000080}.event-legend{margin-top:6px;padding-top:4px}.event-legend:before{margin-bottom:4px;font-size:8px}.ev-item{margin:2px 0;font-size:6px}.ev-pixel{width:6px;height:6px;box-shadow:none;border-width:1px;margin-right:4px}.hud-bottom{bottom:8px;left:10px;right:10px}.pixel-btn{border-width:2px;padding:6px 10px;font-size:8px;box-shadow:2px 2px #00000080}.minimap-box{border-width:2px;width:140px;height:40px;bottom:50px;right:8px;box-shadow:2px 2px #0006}.minimap-label{border-width:1px;padding:2px 6px;font-size:7px}.probe-date{margin-bottom:6px;padding-bottom:6px;font-size:8px}.legend-value{margin-left:4px;font-size:7px}#info-card{width:100%;max-width:100%;padding:8px;bottom:48px;right:0;top:auto!important;left:0!important}.card-inner{border-width:3px;max-height:42vh;padding:12px;overflow-y:auto;box-shadow:4px 4px #0009,0 0 12px #ff79c633}.card-title{font-size:11px}.card-body,.card-desc{font-size:8px}.card-footer{font-size:7px}.arrow-box{display:none}.hud-bottom{justify-content:flex-start;bottom:8px;left:10px;right:10px}.controls-hint{display:none}.zoom-controls{gap:6px}.start-title{margin-bottom:16px;font-size:18px}.start-sub{margin-bottom:24px;font-size:9px}.pixel-box.start-btn{border-width:3px;padding:12px 24px;font-size:10px}#rotate-hint{z-index:300;cursor:pointer;-webkit-user-select:none;user-select:none;background:#282a36eb;border:2px solid #ff79c6;flex-direction:row;align-items:center;gap:8px;width:auto;height:auto;padding:6px 10px;transition:transform .1s,box-shadow .1s;display:flex;position:fixed;top:auto;bottom:46px;left:50%;transform:translate(-50%);box-shadow:4px 4px #0006}#rotate-hint:active{transform:translate(-50%)translate(2px,2px);box-shadow:1px 1px #0006}#rotate-hint .phone-icon{margin:0;font-size:20px;animation:2s ease-in-out infinite rotatePhone}#rotate-hint h2{text-align:left;margin:0;font-size:9px;line-height:1.4}#rotate-hint p{color:#bd93f9;text-align:left;margin:0;font-size:7px;line-height:1.4;display:block}}@media screen and (aspect-ratio>=1) and (height<=500px){.hud-top{top:8px;left:10px;right:10px}.brand-header{gap:8px;margin-bottom:4px}.brand h1{letter-spacing:1px;font-size:12px}.brand .sub{font-size:7px}.menu-btn{padding:6px 8px;font-size:7px}.score-board{border-width:2px;padding:6px 10px;box-shadow:2px 2px #0006}.score-board .row{margin:3px 0;font-size:8px}.legend-panel{border-width:2px;width:auto;min-width:100px;top:80px;bottom:auto;right:8px;transform:none}.legend-panel:not(.collapsed){width:170px}.legend-header{padding:6px 8px;font-size:8px}.legend-toggle{border-width:1px;width:18px;height:18px;font-size:8px;line-height:16px}.legend-content{padding:6px 8px}.legend-item{margin:5px 0;font-size:7px}.pixel-icon{border-width:1px;width:10px;height:10px;margin-right:6px}.event-legend{margin-top:8px;padding-top:6px}.event-legend:before{margin-bottom:6px;font-size:8px}.ev-item{margin:3px 0;font-size:6px}.ev-pixel{border-width:1px;width:7px;height:7px;margin-right:5px}.hud-bottom{justify-content:flex-start;bottom:8px;left:10px;right:10px}.controls-hint{display:none}.zoom-controls{gap:6px}.pixel-btn{border-width:2px;padding:6px 10px;font-size:8px;box-shadow:2px 2px #00000080}.minimap-box{border-width:2px;width:150px;height:44px;bottom:50px;right:8px}.minimap-label{border-width:1px;padding:2px 6px;font-size:7px}.probe-date{margin-bottom:6px;padding-bottom:6px;font-size:8px}.legend-value{margin-left:4px;font-size:7px}#info-card{width:320px;max-width:85vw}.card-inner{border-width:3px;padding:12px}.card-title{font-size:11px}.card-body,.card-desc{font-size:8px}.card-footer{font-size:7px}.start-title{margin-bottom:16px;font-size:18px}.start-sub{margin-bottom:24px;font-size:9px}.pixel-box.start-btn{border-width:3px;padding:12px 24px;font-size:10px}#rotate-hint{display:none!important}}.screen-overlay{z-index:1500;text-align:center;background:#2d2b55f5;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:20px;display:flex;position:fixed;top:0;left:0}.screen-overlay.hidden{display:none}.screen-title{color:#ff79c6;text-shadow:4px 4px #000,0 0 20px #ff79c666;margin-bottom:30px;font-size:24px;line-height:1.8}.world-grid{grid-template-columns:repeat(4,1fr);gap:20px;width:100%;max-width:900px;display:grid}.world-card{cursor:pointer;background:#44475a;border:4px solid #6272a4;padding:16px;transition:transform .1s;position:relative;box-shadow:6px 6px #00000080}.world-card:hover{border-color:#ff79c6;transform:translate(-3px,-3px)}.world-card.locked{opacity:.5;cursor:not-allowed;border-color:#44475a}.world-card.completed:after{content:"✓";color:#50fa7b;text-shadow:2px 2px #000;font-size:14px;position:absolute;top:6px;right:8px}.world-card .world-id{color:#50fa7b;text-shadow:2px 2px #000;margin-bottom:8px;font-size:10px}.world-card .world-name{color:#f8f8f2;text-shadow:2px 2px #000;margin-bottom:12px;font-size:12px;line-height:1.6}.world-card .world-year{color:#bd93f9;text-shadow:2px 2px #000;font-size:8px}.quiz-overlay{z-index:1600;background:#000000b3;justify-content:center;align-items:center;width:100%;height:100%;padding:20px;display:flex;position:fixed;top:0;left:0}.quiz-overlay.hidden{display:none}.quiz-inner{background:#282a36fa;border:4px solid #ff79c6;width:560px;max-width:90vw;padding:24px;box-shadow:8px 8px #0009,0 0 30px #ff79c64d}.quiz-header{border-bottom:3px solid #6272a4;justify-content:space-between;align-items:center;margin-bottom:18px;padding-bottom:12px;display:flex}.quiz-boss-tag{color:#f55;text-shadow:2px 2px #000;font-size:12px}.quiz-hearts{color:#f55;text-shadow:2px 2px #000;letter-spacing:4px;font-size:16px}.quiz-question{color:#f8f8f2;text-shadow:2px 2px #000;margin-bottom:20px;font-size:14px;line-height:2}.quiz-options{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px;display:grid}.quiz-option{color:#f8f8f2;cursor:pointer;text-shadow:2px 2px #000;background:#44475a;border:3px solid #6272a4;padding:14px;font-family:"Press Start 2P",cursive;font-size:10px;line-height:1.6;transition:transform .1s;box-shadow:4px 4px #00000080}.quiz-option:hover{background:#6272a4;border-color:#ff79c6}.quiz-option:active{transform:translate(3px,3px);box-shadow:1px 1px #00000080}.quiz-option.correct{color:#2d2b55;text-shadow:none;background:#50fa7b;border-color:#50fa7b}.quiz-option.wrong{background:#f55;border-color:#f55}.quiz-option.disabled{opacity:.5;cursor:not-allowed}.mode-select{flex-direction:column;align-items:center;gap:20px;display:flex}.quiz-beat-btn{color:#2d2b55;cursor:pointer;width:100%;text-shadow:none;background:#50fa7b;border:4px solid #50fa7b;margin-top:16px;padding:16px;font-family:"Press Start 2P",cursive;font-size:16px;transition:transform .1s;animation:.6s step-end infinite beatPulse;display:block;box-shadow:6px 6px #00000080}.quiz-beat-btn:hover{color:#2d2b55;background:#ff79c6;border-color:#ff79c6}.quiz-beat-btn:active{transform:translate(3px,3px);box-shadow:1px 1px #00000080}.quiz-beat-btn.hidden{display:none}@keyframes beatPulse{0%,to{transform:scale(1)}50%{transform:scale(1.03)}}#mobile-controls{pointer-events:none;z-index:250;width:100%;height:100%;display:none;position:fixed;bottom:0;left:0}.dpad-left{pointer-events:auto;grid-template-rows:56px 56px;grid-template-columns:56px 56px;gap:8px;display:grid;position:absolute;bottom:16px;left:16px}.dpad-btn{color:#f8f8f2;cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:none;background:#44475ad9;border:3px solid #6272a4;border-radius:8px;justify-content:center;align-items:center;width:56px;height:56px;font-family:"Press Start 2P",cursive;font-size:16px;display:flex;box-shadow:3px 3px #00000080}.dpad-btn:active{background:#ff79c6;border-color:#ff79c6;transform:translate(2px,2px);box-shadow:1px 1px #00000080}#btn-left{grid-area:2/1}#btn-right{grid-area:2/2}#btn-jump{background:#50fa7b33;border-color:#50fa7b;grid-area:1/2}#btn-jump:active{color:#2d2b55;background:#50fa7b}.action-right{pointer-events:auto;position:absolute;bottom:16px;right:16px}#btn-beat{color:#2d2b55;cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:none;text-align:center;background:#50fa7b;border:4px solid #50fa7b;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;font-family:"Press Start 2P",cursive;font-size:12px;line-height:1.4;display:flex;box-shadow:4px 4px #00000080}#btn-beat:disabled{opacity:.3;cursor:not-allowed}#btn-beat:active:not(:disabled){background:#ff79c6;border-color:#ff79c6;transform:translate(2px,2px);box-shadow:1px 1px #00000080}@media (pointer:coarse),screen and (width<=1024px){#mobile-controls{display:block}}@media screen and (aspect-ratio<=1){.dpad-left{grid-template-rows:48px 48px;grid-template-columns:48px 48px;gap:6px;bottom:12px;left:12px}.dpad-btn{border-width:2px;width:48px;height:48px;font-size:14px}.action-right{bottom:12px;right:12px}#btn-beat{border-width:3px;width:64px;height:64px;font-size:10px}}@media screen and (aspect-ratio>=1) and (height<=500px){#mobile-controls{display:block}.dpad-left{grid-template-rows:44px 44px;grid-template-columns:44px 44px;gap:5px;bottom:8px;left:8px}.dpad-btn{width:44px;height:44px;font-size:12px}#btn-beat{width:56px;height:56px;font-size:9px}}.clear-stats{color:#8be9fd;text-shadow:2px 2px #000;margin-bottom:16px;font-size:12px;line-height:2}.clear-loot{color:gold;text-shadow:2px 2px #000;margin-bottom:30px;font-size:10px;line-height:1.8}@media screen and (aspect-ratio<=1),screen and (width<=640px){.world-grid{grid-template-columns:repeat(2,1fr);gap:12px}.screen-title{margin-bottom:16px;font-size:16px}.world-card{border-width:3px;padding:10px}.world-card .world-name{font-size:9px}.world-card .world-id,.world-card .world-year{font-size:7px}.quiz-inner{border-width:3px;padding:16px}.quiz-header{margin-bottom:12px;padding-bottom:8px}.quiz-boss-tag{font-size:9px}.quiz-hearts{font-size:12px}.quiz-question{margin-bottom:14px;font-size:10px}.quiz-options{grid-template-columns:1fr;gap:8px}.quiz-option{border-width:2px;padding:10px;font-size:8px}}
