*{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;height:100%;overflow:hidden;font-family:Noto Sans SC,sans-serif;background:#0f0f1a;color:#f0e6d3;touch-action:manipulation}#app{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}#game-container{width:100%;height:100%;max-width:100vw;max-height:100vh}#game-container canvas{display:block;margin:0 auto;image-rendering:pixelated;image-rendering:crisp-edges}#ui-overlay{position:fixed;inset:0;pointer-events:none;z-index:100;display:flex;align-items:center;justify-content:center}#ui-overlay.ui-hidden{display:none}#ui-overlay.ui-panel,#ui-overlay .ui-modal{pointer-events:auto}.ui-panel{flex-direction:column;gap:12px;padding:24px;max-width:420px;width:90%;background:#1a1a2ef2;border:3px solid #c9a227;border-radius:8px;box-shadow:0 8px 32px #00000080}.game-title{font-size:2rem;text-align:center;color:#c9a227;text-shadow:2px 2px 0 #3d2e0a;margin-bottom:8px}.game-btn{min-height:44px;padding:10px 20px;font-size:1rem;font-family:inherit;background:linear-gradient(180deg,#4a3728,#2d2118);color:#f0e6d3;border:2px solid #c9a227;border-radius:6px;cursor:pointer;width:100%;transition:transform .1s,filter .1s}.game-btn:hover:not(:disabled){filter:brightness(1.15);transform:translateY(-1px)}.game-btn:active:not(:disabled){transform:translateY(1px)}.game-btn:disabled{opacity:.45;cursor:not-allowed}.game-btn-small{width:auto;min-width:80px;padding:6px 12px;font-size:.85rem}.game-input{width:100%;min-height:44px;padding:8px 12px;font-size:1rem;font-family:inherit;background:#1a1a2e;color:#f0e6d3;border:2px solid #5a4a32;border-radius:4px}.faction-grid{display:flex;flex-direction:column;gap:10px;width:100%}.faction-card{text-align:left;padding:14px;background:#2d2118;border:2px solid #8b7355;border-radius:6px;color:#f0e6d3;cursor:pointer;font-family:inherit}.faction-card strong{display:block;color:#c9a227;margin-bottom:4px}.faction-card p{font-size:.85rem;opacity:.9}.faction-card.locked{opacity:.5;cursor:not-allowed}.stat-rows{display:flex;flex-direction:column;gap:8px;width:100%}.stat-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.stat-btn{width:36px;height:36px;font-size:1.2rem;background:#4a3728;color:#f0e6d3;border:1px solid #c9a227;border-radius:4px;cursor:pointer}.points-label{font-size:.9rem;color:#c9a227}.ui-map-hud{align-items:flex-start!important;justify-content:flex-start!important;padding:12px;background:transparent!important;border:none!important;box-shadow:none!important;max-width:none!important;width:100%!important}.map-hud-bar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding:8px 12px;background:#1a1a2ed9;border:2px solid #c9a227;border-radius:6px;pointer-events:auto}.hud-player{font-weight:700;color:#c9a227}.hud-location{flex:1;font-size:.9rem}.ui-modal{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;pointer-events:auto;z-index:200}.ui-modal-content{background:#1a1a2e;border:3px solid #c9a227;border-radius:8px;padding:24px;max-width:360px;width:90%;text-align:center}.ui-modal-content h2{color:#c9a227;margin-bottom:12px}.ui-modal-content p{font-size:.9rem;line-height:1.6;margin-bottom:16px}.donate-qr-placeholder{width:180px;height:180px;margin:0 auto 16px;background:#2d2118;border:2px dashed #8b7355;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:#8b7355}.donate-qr-placeholder small{font-size:.75rem}.game-toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);padding:10px 20px;background:#1a1a2ef2;border:2px solid #c9a227;border-radius:6px;font-size:.9rem;pointer-events:none;z-index:300;animation:toast-in .2s ease}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media(max-width:480px){.ui-panel{padding:16px;width:95%}.game-title{font-size:1.6rem}}.story-dialogue{z-index:150}.story-dialogue-content{display:flex;gap:16px;background:#1a1a2e;border:3px solid #c9a227;border-radius:8px;padding:20px;max-width:480px;width:92%;pointer-events:auto}.story-portrait{width:96px;height:96px;border:3px solid #c9a227;border-radius:4px;image-rendering:auto;flex-shrink:0;background:#1a1a2e;box-shadow:0 2px 8px #0006,inset 0 0 0 1px #8b7355}.story-body{flex:1;min-width:0}.story-speaker{color:#c9a227;font-weight:700;margin-bottom:8px}.story-text{line-height:1.7;font-size:.95rem;margin-bottom:12px}.story-buttons{display:flex;flex-direction:column;gap:8px}.battle-panel{z-index:160}.battle-panel-content{background:#1a1a2e;border:3px solid #c9a227;border-radius:8px;padding:16px;max-width:460px;width:95%;max-height:90vh;overflow-y:auto;pointer-events:auto}.battle-panel-content h2{color:#c9a227;text-align:center;margin-bottom:12px}.battle-units{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.battle-unit{padding:8px;border-radius:4px;background:#2d2118}.battle-side-player,.battle-side-ally{border-left:3px solid #2d6a4f}.battle-side-enemy{border-left:3px solid #9d0208}.unit-name{font-weight:700;font-size:.9rem}.hp-bar{height:8px;background:#1a1a2e;border-radius:4px;margin:4px 0;overflow:hidden}.hp-fill{height:100%;background:#40916c;transition:width .2s}.battle-side-enemy .hp-fill{background:#d00000}.hp-text{font-size:.75rem;opacity:.8}.battle-logs{max-height:100px;overflow-y:auto;font-size:.8rem;margin-bottom:12px;padding:8px;background:#0f0f1a;border-radius:4px}.battle-log-damage{color:#e8a598}.battle-log-system{color:#c9a227}.battle-actions{display:flex;flex-direction:column;gap:8px}.battle-wait{text-align:center;color:#8b7355;font-size:.9rem}.battle-result{font-size:1.1rem;font-weight:600;margin-bottom:8px;text-align:center}.battle-result-win{color:#6dbe8a}.battle-result-lose{color:#be6d6d}.battle-lose-hint{color:#a89878;font-size:.9rem;margin-bottom:12px;text-align:center}.map-hud-buttons{display:flex;flex-wrap:wrap;gap:8px;pointer-events:auto;margin-top:8px}.hud-exp,.hud-gold{font-size:.85rem}.save-actions{display:flex;flex-direction:column;gap:8px}.task-panel-content{max-width:420px;max-height:85vh;overflow-y:auto;text-align:left}.task-section-title{color:#c9a227;font-size:.95rem;margin:12px 0 8px}.task-list{margin-bottom:12px}.task-row{display:flex;gap:10px;padding:10px;margin-bottom:8px;background:#2d2118;border-radius:6px;border:1px solid #5a4a32}.task-row.task-clickable{cursor:pointer}.task-row.task-clickable:hover{border-color:#c9a227}.task-row.task-locked{opacity:.55}.task-row.task-completed{border-color:#2d6a4f}.task-portrait{width:64px;height:64px;border-radius:4px;image-rendering:auto;flex-shrink:0;border:2px solid #c9a227;background:#1a1a2e;box-shadow:0 1px 4px #00000059}.task-name{font-weight:700;color:#f0e6d3}.task-brief{font-size:.8rem;opacity:.85;margin-top:2px}.task-lock,.task-done{font-size:.75rem;margin-top:4px}.task-done{color:#40916c}.task-lock{color:#8b7355}.equip-current{text-align:left;margin-bottom:16px;padding:12px;background:#2d2118;border-radius:6px}.equip-name{font-weight:700;color:#c9a227}.equip-stat,.equip-enhance{font-size:.9rem;margin-top:4px}.equip-empty{margin-bottom:16px;color:#8b7355}.city-panel-content{max-width:520px}.city-res-bar{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:12px;font-size:.85rem;color:#c9a227}.city-building-list{display:flex;flex-direction:column;gap:10px;margin-bottom:16px;max-height:360px;overflow-y:auto}.city-building-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px;border:1px solid #8b7355;border-radius:6px;background:#1a1a2e99}.city-building-name{font-weight:700;color:#f0e6d3}.city-building-desc,.city-building-produce{font-size:.78rem;opacity:.85;margin-top:2px}.city-building-produce{color:#40916c}.city-max-label{font-size:.8rem;color:#8b7355;white-space:nowrap}.hud-food{color:#90be6d}.hud-troops{color:#6d9ebe}.hud-minxin{color:#be6d9e}.explore-panel-content{max-width:560px;max-height:85vh;overflow-y:auto}.explore-list{display:flex;flex-direction:column;gap:10px;margin:12px 0 16px}.explore-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:12px;border:1px solid #8b7355;border-radius:6px;background:#1a1a2e99}.explore-row.explore-done{opacity:.55}.explore-row.explore-locked{opacity:.75}.explore-name{font-weight:700;color:#f0e6d3;margin-bottom:4px}.explore-brief{font-size:.85rem;color:#c9a227;margin-bottom:6px}.explore-cost,.explore-reward{font-size:.8rem;color:#90be6d}.explore-lock,.explore-status{font-size:.8rem;color:#8b7355;margin-top:4px}.explore-empty{color:#8b7355;margin:16px 0}
