:root{--font-option-a-display:"Cinzel", "Times New Roman", serif;--font-option-a-ui:"Noto Sans SC", "PingFang SC", "Microsoft YaHei", sans-serif;--font-option-b-display:"Uncial Antiqua", "Times New Roman", serif;--font-option-b-ui:"Noto Sans SC", "PingFang SC", "Microsoft YaHei", sans-serif;--font-option-c-display:"Marcellus SC", "Times New Roman", serif;--font-option-c-ui:"Noto Sans SC", "PingFang SC", "Microsoft YaHei", sans-serif;--font-display:var(--font-option-a-display);--font-ui:var(--font-option-a-ui);font-family:var(--font-ui);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:#ffffffde;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#242424;margin:0;font-weight:400;line-height:1.5}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}body{font-family:var(--font-ui);touch-action:none;-webkit-user-select:none;user-select:none;background:#000;margin:0;padding:0;overflow:hidden}h1,h2,h3,.menu-title,#unit-name{font-family:var(--font-display)}html{touch-action:none;overflow:hidden}#renderCanvas{touch-action:none;top:env(safe-area-inset-top,0px);left:env(safe-area-inset-left,0px);right:env(safe-area-inset-right,0px);bottom:env(safe-area-inset-bottom,0px);z-index:0;width:auto;height:auto;position:fixed}#app{display:none}canvas{display:block}#game-ui{pointer-events:none;z-index:10;width:100%;height:100%;position:fixed;top:0;left:0}#game-ui>*{pointer-events:auto}#main-menu,#faction-menu,#pause-menu,#victory-screen,#defeat-screen,#game-ui{will-change:opacity, transform}.overlay-enter{animation:.22s ease-out overlay-enter}@keyframes overlay-enter{0%{opacity:0;transform:translateY(8px)scale(.99)}to{opacity:1;transform:translateY(0)scale(1)}}@media (prefers-reduced-motion:reduce){.overlay-enter{animation:none}}#keyboard-hint{top:calc(10px + env(safe-area-inset-top,0px));left:calc(10px + env(safe-area-inset-left,0px));box-sizing:border-box;z-index:1000;pointer-events:none;background:linear-gradient(135deg,#120e06e6 0%,#0a0803f5 100%);border:2px solid #c9a22766;border-radius:8px;flex-direction:column;gap:6px;padding:24px 12px 8px;transition:all .3s;display:flex;position:fixed;box-shadow:inset 0 0 20px #c9a2270d,0 0 15px #c9a2271f}#game-ui.keyboard-hint-dismissed #keyboard-hint{display:none}.keyboard-hint__dismiss{color:#e8c87a;cursor:pointer;pointer-events:auto;background:#080603b3;border:1px solid #c9a22773;border-radius:4px;justify-content:center;align-items:center;width:20px;height:20px;padding:0;font-size:14px;line-height:1;display:inline-flex;position:absolute;top:4px;right:4px}.keyboard-hint__dismiss:hover,.keyboard-hint-restore:hover{color:#ffd45a;background:#2e240ee0;border-color:#ddb83ad9}.keyboard-hint-restore{top:calc(10px + env(safe-area-inset-top,0px));left:calc(10px + env(safe-area-inset-left,0px));color:#e8c87a;cursor:pointer;z-index:1000;background:linear-gradient(135deg,#120e06e6 0%,#0a0803f5 100%);border:2px solid #c9a22773;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;padding:0;font-size:16px;display:none;position:fixed;box-shadow:inset 0 0 14px #c9a22712,0 0 15px #c9a2271f}#game-ui.keyboard-hint-dismissed .keyboard-hint-restore{display:inline-flex}#keyboard-hint .arrow-key{pointer-events:auto}.hint-row{align-items:center;gap:10px;display:flex}.hint-row:first-child{justify-content:flex-start}.hint-row:last-child{justify-content:space-between}.hint-group{align-items:center;gap:6px;min-width:70px;display:flex}.hint-key{color:#c9a227;text-shadow:0 1px 2px #000000b3;background:linear-gradient(135deg,#1e180aeb 0%,#0e0a04f5 100%);border:2px solid #c9a22780;border-radius:5px;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;font-weight:700;transition:all .2s;display:flex;box-shadow:inset 0 0 10px #c9a22714}.hint-key.active{background:linear-gradient(135deg,#5a461cf2 0%,#32260e 100%);border-color:#c9a227;transform:scale(1.1);box-shadow:inset 0 0 20px #c9a22733,0 0 20px #c9a22766}.hint-text{color:#c9a227;text-shadow:0 1px 1px #0009;white-space:nowrap;font-size:11px}.hint-arrows-vertical{flex-direction:column;justify-content:flex-start;align-items:center;gap:2px;min-height:48px;display:flex}.hint-row:last-child .hint-arrows-vertical{flex:1;justify-content:center;align-items:center;min-height:48px}.hint-arrows-horizontal{gap:2px;display:flex}.arrow-key{color:#c9a227;text-shadow:0 1px 1px #0009;cursor:pointer;-webkit-user-select:none;user-select:none;background:linear-gradient(135deg,#1a1408b8 0%,#0c0903d1 100%);border:1.5px solid #c9a22766;border-radius:4px;justify-content:center;align-items:center;width:22px;height:22px;font-size:12px;transition:all .2s;display:flex}.arrow-key.active{color:#ddb83a;background:linear-gradient(135deg,#503e18eb 0%,#2c220cf5 100%);border-color:#c9a227;transform:scale(1.15);box-shadow:0 0 15px #c9a22759}.arrow-key:hover{color:#ddb83a;background:linear-gradient(135deg,#2e240ed1 0%,#1a1408e0 100%);border-color:#c9a22799}#top-bar{top:env(safe-area-inset-top,0px);z-index:100;background:linear-gradient(#0e0b06ed 0%,#080603f7 100%);border:2px solid #c9a22773;border-top:none;border-bottom-right-radius:8px;border-bottom-left-radius:8px;gap:12px;height:38px;padding:6px 20px;display:flex;position:fixed;left:50%;transform:translate(-50%);box-shadow:0 4px 15px #c9a2271f}#top-controls{top:calc(6px + env(safe-area-inset-top,0px));right:calc(124px + env(safe-area-inset-right,0px));z-index:1000;align-items:center;gap:8px;height:38px;display:flex;position:fixed}.resource{color:#e8c87a;text-shadow:0 1px 2px #000000b3;background:linear-gradient(135deg,#1e180ab3 0%,#100c04d9 100%);border:1.5px solid #c9a22766;border-radius:6px;align-items:center;gap:6px;padding:4px 12px;font-size:13px;font-weight:700;display:flex}.resource-label{color:#f1dca0;text-transform:uppercase;font-size:11px;font-weight:800}.res-icon{justify-content:center;align-items:center;width:18px;height:18px;display:inline-flex}.res-icon svg{fill:none;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round;width:18px;height:18px}.res-icon--gold svg{stroke:#ffd45a;filter:drop-shadow(0 0 4px #ffd45a80)}.res-icon--lumber svg{stroke:#7fd18b;filter:drop-shadow(0 0 4px #7fd18b73)}.res-icon--food svg{stroke:#ff9f66;filter:drop-shadow(0 0 4px #ff9f6673)}.tech-badge{text-transform:none;justify-content:center;min-width:120px}.mute-btn{color:gold;cursor:pointer;background:linear-gradient(135deg,#231c0cd9 0%,#100c04eb 100%);border:1px solid #c9a22780;border-radius:6px;align-self:center;width:34px;height:26px;font-weight:800;transition:all .15s;box-shadow:inset 0 0 6px #c9a2271a}.mute-btn:hover{border-color:#c9a227;box-shadow:inset 0 0 10px #c9a22726,0 0 8px #c9a22733}.top-toast{color:#e8c87a;text-shadow:0 1px 2px #000000b3;opacity:1;background:linear-gradient(135deg,#241c0cf2 0%,#100c04f5 100%);border:1.5px solid #c9a22799;border-radius:6px;margin-top:6px;padding:6px 14px;font-size:13px;font-weight:700;transition:opacity .3s,transform .3s;transform:translateY(0);box-shadow:0 6px 18px #00000080,0 0 10px #c9a22726}.top-toast.fade-out{opacity:0;transform:translateY(-6px)}#top-toast-container{top:calc(40px + env(safe-area-inset-top,0px));z-index:150;pointer-events:none;flex-direction:column;align-items:center;gap:4px;display:flex;position:fixed;left:50%;transform:translate(-50%)}#bottom-panel{bottom:env(safe-area-inset-bottom,0px);box-sizing:border-box;background:linear-gradient(#0e0a05ed 0%,#080603f7 100%);border-top:2px solid #c9a22773;justify-content:space-between;width:100%;height:130px;padding:8px;display:flex;position:fixed;left:0;box-shadow:0 -4px 20px #c9a2271a}#minimap-container{box-sizing:border-box;background:linear-gradient(135deg,#0e0a05e6 0%,#080603f2 100%);border:2px solid #c9a22773;border-radius:6px;width:130px;height:130px;padding:5px;box-shadow:inset 0 0 15px #c9a2270f}#minimap{background:radial-gradient(circle,#001a1a 0%,#000 100%);border-radius:3px;width:100%;height:100%;position:relative;overflow:hidden}#minimap-canvas{cursor:pointer;width:100%;height:100%;display:block}.minimap-click-flash{left:var(--minimap-flash-x,50%);top:var(--minimap-flash-y,50%);pointer-events:none;border:2px solid #ffe88cf2;border-radius:50%;width:20px;height:20px;animation:.52s ease-out forwards minimap-click-flash;position:absolute;transform:translate(-50%,-50%)scale(.55);box-shadow:0 0 12px #ffd65abf,inset 0 0 8px #ffd65a73}.minimap-sidebar-hint{box-sizing:border-box;min-height:120px;padding:8px}.minimap-hint-text{color:#c8d7e6eb;margin:0;font-size:11px;line-height:1.35}#command-card-container{flex:1;justify-content:center;align-items:center;padding:0 10px;display:flex}#command-card{background:linear-gradient(135deg,#120e068c 0%,#0a0803b8 100%);border:2px solid #c9a2274d;border-radius:6px;grid-template-columns:repeat(4,50px);grid-auto-rows:50px;gap:5px;padding:6px;display:grid}.cmd-btn{color:#c9a227;cursor:pointer;text-shadow:0 1px 2px #000000b3;background:linear-gradient(135deg,#1e180ae0 0%,#0e0a04eb 100%);border:2px solid #c9a22773;border-radius:5px;width:50px;height:50px;font-size:9px;font-weight:700;transition:all .2s;box-shadow:inset 0 0 10px #c9a2270f}.cmd-btn:hover{background:linear-gradient(135deg,#3c3014eb 0%,#1c1608f5 100%);border-color:#c9a227;transform:translateY(-2px)scale(1.03);box-shadow:inset 0 0 15px #c9a2271a,0 0 12px #c9a22740}.cmd-btn:active{transform:translateY(0)scale(.98)}.cmd-btn:empty{opacity:.2;cursor:default;background:linear-gradient(135deg,#0a080466 0%,#06040280 100%);border-color:#c9a22726}.cmd-btn:empty:hover{transform:none;box-shadow:inset 0 0 10px #00ffff0d}#info-panel-container{box-sizing:border-box;background:linear-gradient(135deg,#120e06e0 0%,#0a0803ed 100%);border:2px solid #c9a22773;border-radius:6px;flex-direction:column;width:180px;height:100%;padding:6px;display:flex;box-shadow:inset 0 0 15px #c9a2270d}#unit-portrait{background:radial-gradient(circle,#28200ebf 0%,#0e0a04eb 100%);border:2px solid #c9a22780;border-radius:4px;width:100%;height:40px;margin-bottom:4px;box-shadow:inset 0 0 15px #c9a22714}#unit-info{color:#c9a227;flex-direction:column;flex:1;gap:2px;display:flex}#unit-info h3{color:#ddb83a;text-shadow:0 1px 2px #000000b3;text-align:center;letter-spacing:.5px;border-bottom:1.5px solid #c9a22766;margin:0 0 2px;padding-bottom:2px;font-size:11px}.info-bar{margin-bottom:2px}.bar-label{color:#c9a227d9;text-shadow:0 1px 1px #00000080;margin-bottom:2px;font-size:10px}.hp-bar{background:linear-gradient(90deg,#000000bf 0%,#140e06e0 100%);border:1.5px solid #c9a22766;border-radius:2px;width:100%;height:8px;margin-bottom:2px;overflow:hidden;box-shadow:inset 0 1px 4px #000000b3}.hp-fill{background:linear-gradient(90deg,#0f0 0%,#0d0 50%,#0f0 100%);height:100%;transition:width .3s;box-shadow:0 0 8px #00ff00b3}.stat-row{color:#c9a227d9;text-shadow:0 1px 1px #00000080;background:#1e160859;border-left:2px solid #c9a22780;border-radius:2px;justify-content:space-between;align-items:center;gap:6px;margin:1px 0;padding:2px 6px;font-size:10px;display:flex}.stat-row .stat-label{color:#c9a227e6;text-overflow:ellipsis;white-space:nowrap;min-width:0;font-weight:700;overflow:hidden}.stat-row .stat-value{color:#fff;text-shadow:0 0 5px #ffffffb3;text-align:right;white-space:pre-line;margin-left:auto;font-weight:700}.move-order-marker{left:var(--move-order-x,50vw);top:var(--move-order-y,50vh);pointer-events:none;z-index:900;border:2px solid #ffe88cf2;border-radius:50%;width:34px;height:34px;animation:.68s ease-out forwards move-order-ping;position:fixed;transform:translate(-50%,-50%)scale(.55);box-shadow:0 0 18px #ffd65aa6,inset 0 0 14px #ffd65a59}.move-order-marker:after{content:"";border:2px solid #7fd18bd9;border-radius:50%;position:absolute;inset:7px}@keyframes move-order-ping{0%{opacity:0;transform:translate(-50%,-50%)scale(.55)}18%{opacity:1}to{opacity:0;transform:translate(-50%,-50%)scale(1.45)}}@keyframes minimap-click-flash{0%{opacity:0;transform:translate(-50%,-50%)scale(.55)}20%{opacity:1}to{opacity:0;transform:translate(-50%,-50%)scale(1.75)}}#selection-box{pointer-events:none;z-index:1000;background-color:#00ff001a;border:2px solid #0f0;position:fixed}#main-menu,#faction-menu,#pause-menu,#victory-screen,#defeat-screen{box-sizing:border-box;width:100%;height:100%;padding:env(safe-area-inset-top,0px) env(safe-area-inset-right,0px) env(safe-area-inset-bottom,0px) env(safe-area-inset-left,0px);z-index:10000;background:#000000e6;justify-content:center;align-items:center;display:flex;position:fixed;top:0;left:0}#main-menu{background:linear-gradient(#10080333 0%,#1008038c 100%);overflow:hidden}#main-menu:before{content:"";background-image:linear-gradient(#0a06032e 0%,#0a06038f 100%),radial-gradient(circle,#f8c0621f 0%,#0000 42%),url(/og-image.png);background-position:50%;background-size:cover;position:absolute;inset:0;transform:scale(1.02)}#main-menu>*{z-index:1;position:relative}.menu-container{text-align:center;background:linear-gradient(135deg,#0e0c09 0%,#0b0f14 100%);border:2px solid #c9a2278c;border-radius:10px;width:min(520px,100vw - 32px);min-width:0;padding:40px 60px;box-shadow:0 0 30px #c9a22733}#main-menu .menu-container{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:linear-gradient(#1c120ac7 0%,#100b06d6 100%);border-color:#cd9849e6;box-shadow:0 18px 50px #00000073,inset 0 0 0 1px #ffd6942e}#faction-menu{background:linear-gradient(#0e090340 0%,#0a060299 100%);overflow:hidden}#faction-menu:before{content:"";background-image:linear-gradient(#0a060338 0%,#0a060399 100%),radial-gradient(circle,#c9a22714 0%,#0000 45%),url(/og-image.png);background-position:50%;background-size:cover;position:absolute;inset:0;transform:scale(1.02)}#faction-menu>*{z-index:1;position:relative}#victory-screen{background:radial-gradient(circle at 50% 40%,#3c2c0c8c 0%,#060402e6 70%)}#defeat-screen{background:radial-gradient(circle at 50% 40%,#2806068c 0%,#060202e6 70%)}.menu-title{color:#c9a227;text-shadow:0 0 10px #c9a22780;flex-direction:column;align-items:center;gap:4px;margin-bottom:30px;font-size:48px;font-weight:700;display:flex}.menu-title-zh{font-family:var(--font-ui);letter-spacing:.2em;opacity:.75;text-shadow:none;font-size:18px;font-weight:400}.menu-hero-subtitle{font-family:var(--font-ui);letter-spacing:.3em;text-transform:uppercase;color:#00dcdc8c;text-shadow:0 0 10px #00dcdc33;text-align:center;margin:-16px 0 0;font-size:clamp(.5rem,1.2vw,.7rem);font-weight:700}.menu-version-line{font-family:var(--font-ui);color:#ffffff4d;text-align:center;letter-spacing:.08em;margin:8px 0 0;font-size:.65rem}.menu-notice{font-family:var(--font-ui);color:#c9a227cc;text-align:center;letter-spacing:.04em;margin:8px 0 0;font-size:.78rem}#settings-overlay{z-index:20000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);pointer-events:auto;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.sov-panel{background:linear-gradient(160deg,#44260e 0%,#221207 100%);border:1px solid #d9b446b3;border-radius:4px;flex-direction:column;width:min(900px,95vw);max-height:min(680px,95vh);display:flex;overflow:hidden;box-shadow:inset 0 0 0 1px #d9b4463d,0 18px 52px #00000073}.sov-header{border-bottom:1px solid #c9a22733;justify-content:space-between;align-items:center;padding:14px 20px 12px;display:flex}.sov-header-meta{font-family:var(--font-ui);letter-spacing:.2em;color:#c83c3cd9;text-transform:uppercase;font-size:.55rem;font-weight:700}.sov-title{font-family:var(--font-ui);letter-spacing:.35em;text-transform:uppercase;color:#c9a227;text-shadow:0 0 30px #c9a22766;margin:0;font-size:clamp(1.5rem,3vw,2.1rem);font-weight:700}.sov-close{color:#c9a227b3;cursor:pointer;background:0 0;border:1px solid #c9a22759;border-radius:2px;justify-content:center;align-items:center;width:32px;height:32px;font-size:1rem;transition:background .15s,color .15s;display:flex}.sov-close:hover{color:#c9a227;background:#c9a2271f}.sov-subtitle{font-family:var(--font-ui);letter-spacing:.1em;text-transform:uppercase;color:#e8cd84e0;text-align:center;margin:8px 20px 0;font-size:.72rem;font-weight:700;line-height:1.45}.sov-body{flex:1;min-height:0;display:flex;overflow:hidden}.sov-sidebar{border-right:1px solid #c9a2272e;flex-direction:column;flex-shrink:0;width:190px;padding:14px 0 10px;display:flex}.sov-profile{border-bottom:1px solid #c9a22726;align-items:center;gap:10px;margin-bottom:6px;padding:0 14px 14px;display:flex}.sov-profile-icon{background:linear-gradient(135deg,#5a1e1e 0%,#3a1010 100%);border:1px solid #c9a22766;border-radius:4px;flex-shrink:0;width:36px;height:36px}.sov-profile-name{font-family:var(--font-ui);letter-spacing:.08em;text-transform:uppercase;color:#e9cd84f2;font-size:.8rem;font-weight:700}.sov-profile-sub{font-family:var(--font-ui);letter-spacing:.04em;text-transform:uppercase;color:#ddc076ad;margin-top:2px;font-size:.64rem;line-height:1.35}.sov-nav{flex-direction:column;flex:1;gap:1px;padding:4px 0;display:flex}.sov-nav-btn{cursor:pointer;font-family:var(--font-ui);letter-spacing:.08em;text-transform:uppercase;color:#e9cd84b8;text-align:left;background:0 0;border:none;border-left:3px solid #0000;align-items:center;gap:8px;padding:9px 14px;font-size:.76rem;font-weight:700;line-height:1.35;transition:background .12s,color .12s,border-color .12s;display:flex}.sov-nav-btn:hover{color:#f5dfa1f2;background:#c9a2271a}.sov-nav-btn.sov-active{color:#c9a227;background:#c9a2271a;border-left-color:#c9a227}.sov-nav-icon{object-fit:contain;color:#e9cd84bf;flex-shrink:0;width:20px;height:20px;display:block}.sov-nav-label{flex:1}.sov-nav-num{color:inherit;opacity:.82;font-size:.62rem}.sov-status{border:1px solid #c9a2272e;border-radius:3px;margin:6px 12px 0;padding:10px}.sov-status-title{font-family:var(--font-ui);letter-spacing:.08em;text-transform:uppercase;color:#e9cd84db;margin-bottom:6px;font-size:.7rem;font-weight:700}.sov-status-text{font-family:var(--font-ui);color:#e6cb84b8;font-size:.74rem;line-height:1.6}.sov-content{scrollbar-width:thin;scrollbar-color:#c9a2274d transparent;flex:1;padding:16px 20px;overflow-y:auto}.sov-content::-webkit-scrollbar{width:4px}.sov-content::-webkit-scrollbar-track{background:0 0}.sov-content::-webkit-scrollbar-thumb{background:#c9a2274d;border-radius:2px}.sov-tab{display:none}.sov-tab.sov-active{display:block}.sov-section-header{margin-bottom:14px}.sov-section-title{font-family:var(--font-ui);letter-spacing:.12em;text-transform:uppercase;color:#ecd390f5;margin:0 0 4px;font-size:1.34rem;font-weight:700}.sov-section-desc{font-family:var(--font-ui);color:#e6cb84b8;margin:0;font-size:.82rem;line-height:1.55}.sov-group-label{font-family:var(--font-ui);letter-spacing:.1em;text-transform:uppercase;color:#eacf8ad1;border-bottom:1px solid #c9a2272e;margin:16px 0 12px;padding-bottom:5px;font-size:.7rem;font-weight:700}.sov-group-label:first-child{margin-top:0}.sov-row-2col{grid-template-columns:1fr 1fr;gap:12px;display:grid}.sov-field-col{flex-direction:column;gap:12px;display:flex}.sov-field{background:#e1c1621f;border:1px solid #e1c16257;border-radius:3px;padding:10px 12px}.sov-field-label{font-family:var(--font-ui);letter-spacing:.1em;text-transform:uppercase;color:#ecd28ee0;margin-bottom:8px;font-size:.7rem;font-weight:700}.sov-field-label-row{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.sov-field-label-row .sov-field-label{margin-bottom:0}.sov-range-val{font-family:var(--font-ui);color:#f6df9df2;background:#c9a2272e;border:1px solid #c9a22766;border-radius:2px;padding:1px 6px;font-size:.74rem;font-weight:700}.sov-select{color:#eed588f5;width:100%;font-family:var(--font-ui);cursor:pointer;appearance:none;background:#241408e0 url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='rgba(201,162,39,0.6)'/%3E%3C/svg%3E") right 10px center no-repeat;border:1px solid #e1c1627a;border-radius:2px;padding:8px 28px 8px 10px;font-size:.86rem}.sov-select:focus{border-color:#c9a22799;outline:none}.sov-range{appearance:none;cursor:pointer;background:#c9a22726;border-radius:2px;width:100%;height:4px}.sov-range::-webkit-slider-thumb{appearance:none;cursor:pointer;background:radial-gradient(circle,#e8c84a 0%,#c8a020 100%);border:2px solid #c9a22780;border-radius:50%;width:14px;height:14px;box-shadow:0 0 6px #c9a22780}.sov-range::-moz-range-thumb{cursor:pointer;background:radial-gradient(circle,#e8c84a 0%,#c8a020 100%);border:2px solid #c9a22780;border-radius:50%;width:14px;height:14px;box-shadow:0 0 6px #c9a22780}.sov-hint{font-family:var(--font-ui);color:#e5ca84b3;margin:6px 0 0;font-size:.72rem;line-height:1.55}.sov-checkbox-row{cursor:pointer;background:#c9a2270a;border:1px solid #c9a2271f;border-radius:3px;align-items:center;gap:10px;padding:6px 12px;display:flex}.sov-checkbox-row:hover{background:#c9a22714}.sov-checkbox{appearance:none;cursor:pointer;background:#0c0804cc;border:1px solid #c9a22766;border-radius:2px;flex-shrink:0;width:14px;height:14px;position:relative}.sov-checkbox:checked{background:#c9a22740;border-color:#c9a227}.sov-checkbox:checked:after{content:"";background:#c9a227;border-radius:1px;position:absolute;inset:2px}.sov-checkbox-label{font-family:var(--font-ui);letter-spacing:.08em;text-transform:uppercase;color:#eacf8ae0;font-size:.74rem;font-weight:700;line-height:1.4}.sov-keybinds{flex-direction:column;gap:4px;margin-bottom:4px;display:flex}.sov-keybind-row{background:#c9a22714;border:1px solid #c9a22733;border-radius:2px;align-items:center;gap:14px;padding:6px 12px;display:flex}.sov-key{font-family:var(--font-ui);color:#f6df9dfa;text-align:center;background:#c9a22733;border:1px solid #c9a2274d;border-radius:2px;flex-shrink:0;min-width:110px;padding:2px 7px;font-size:.74rem;font-weight:700}.sov-keybind-action{font-family:var(--font-ui);color:#e6cb84c7;font-size:.76rem;line-height:1.45}.sov-links-list{flex-direction:column;gap:10px;display:flex}.sov-legal-link{font-family:var(--font-ui);color:#e9cd84d9;background:#c9a2271f;border:1px solid #e9cd844d;border-radius:3px;padding:12px 14px;font-size:.9rem;font-weight:500;text-decoration:none;transition:all .2s;display:inline-block}.sov-legal-link:hover{color:#e9cd84;background:#c9a22740;border-color:#e9cd8499;text-decoration:none}.victory-title{color:#ddb83a;text-shadow:0 0 15px #ddb83a99}.defeat-title{color:#f44;text-shadow:0 0 15px #f44c}.menu-buttons{flex-direction:column;gap:15px;margin-top:30px;display:flex}.menu-btn{color:#c9a227;cursor:pointer;text-transform:uppercase;background:linear-gradient(#282010f2 0%,#100c06fa 100%);border:1px solid #c9a22799;border-radius:5px;padding:15px 30px;font-size:18px;font-weight:700;transition:all .3s;box-shadow:0 4px 10px #00000080}.menu-btn:hover{color:#ddb83a;background:linear-gradient(#46361af2 0%,#20180afa 100%);border-color:#ddb83ad9;transform:translateY(-2px);box-shadow:0 6px 15px #00000080,0 0 12px #c9a22726}.menu-btn:active{transform:translateY(0);box-shadow:0 2px 5px #0006}.menu-btn:disabled,.menu-btn.menu-btn-disabled{cursor:not-allowed;opacity:.6;box-shadow:none;background:linear-gradient(135deg,#5e6470 0%,#4a505d 100%);border-color:#7b8596;transform:none}.menu-btn:disabled:hover,.menu-btn.menu-btn-disabled:hover{box-shadow:none;background:linear-gradient(135deg,#5e6470 0%,#4a505d 100%);transform:none}#pause-menu{background:radial-gradient(circle,#14100b85 0%,#060504db 65%),url(/og-image.png) 50%/cover no-repeat}body.help-overlay-open #pause-menu{pointer-events:none}.pause-panel.menu-container{background:linear-gradient(#17181af5 0%,#0c0d10fa 100%);border:2px solid #7e6e58f2;border-radius:12px;width:min(620px,100vw - 36px);padding:26px 30px 24px;box-shadow:0 30px 60px #000000a8,inset 0 0 0 2px #00000080,0 0 0 1px #ad8d5c3d}.pause-panel .menu-title{color:#d7c49b;font-family:var(--font-display);letter-spacing:.08em;text-shadow:0 1px #000000b3,0 0 20px #a0784233;margin-bottom:16px;font-size:clamp(30px,4vw,42px)}.pause-buttons{gap:10px;margin-top:0}.pause-action-btn.menu-btn{text-transform:uppercase;letter-spacing:.06em;width:100%;font-family:var(--font-display);color:#ceb88f;background:linear-gradient(#2d353cf5 0%,#12181ef5 100%);border:1px solid #6c767ee6;border-radius:0;padding:11px 34px;font-size:clamp(17px,2.1vw,27px);font-weight:600;position:relative;box-shadow:inset 0 0 0 1px #0000008c,0 0 18px #0003}.pause-action-btn.menu-btn:before,.pause-action-btn.menu-btn:after{content:"";background:#16120ef2;border:1px solid #b2986ab3;width:10px;height:10px;position:absolute;top:50%;transform:translateY(-50%)rotate(45deg)}.pause-action-btn.menu-btn:before{left:14px}.pause-action-btn.menu-btn:after{right:14px}.pause-action-btn.menu-btn:hover{color:#f4d59f;background:linear-gradient(#46361df0 0%,#241a10f0 100%);border-color:#b2986af2;transform:none;box-shadow:inset 0 0 0 1px #0009,0 0 16px #aa743833}.pause-language-wrap{border-top:1px solid #88785e80;margin-top:14px;padding-top:12px}.pause-language-title{text-align:center;color:#d3c097;letter-spacing:.08em;text-transform:uppercase;font-size:13px;font-family:var(--font-display);margin:0 0 10px}.pause-lang-bar{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.pause-lang-btn{color:#98a3af;letter-spacing:.04em;text-transform:uppercase;cursor:pointer;background:linear-gradient(#252c34fa 0%,#11161dfa 100%);border:1px solid #626b74f2;border-radius:0;min-width:66px;padding:9px 12px;font-size:13px}.pause-lang-btn:hover{color:#f4d59f;border-color:#b2986ae6}.pause-lang-btn.is-active{color:#1d1710;background:linear-gradient(#e6c384fa 0%,#b18644fa 100%);border-color:#dcba80f2}.pause-status{text-align:center;color:#c7ad7e;letter-spacing:.04em;min-height:18px;margin:12px 0 0;font-size:13px}.game-stats{text-align:left;background:#0000004d;border-radius:5px;margin:20px 0;padding:20px}.stat-item{color:#fff;border-bottom:1px solid #ffffff1a;margin:10px 0;padding:8px;font-size:16px}.stat-item span{color:#c9a227;float:right;font-weight:700}.vision-mask{background:linear-gradient(to center, #000000b3 0%, #00000080 50%, #0000 100%);pointer-events:none;z-index:500;height:100%;transition:opacity .3s;position:fixed;top:0;bottom:0}#vision-mask-left{background:linear-gradient(90deg,#000000b3 0%,#00000080 50%,#0000 100%);left:0}#vision-mask-right{background:linear-gradient(270deg,#000000b3 0%,#00000080 50%,#0000 100%);right:0}#compass{top:calc(10px + env(safe-area-inset-top,0px));right:calc(10px + env(safe-area-inset-right,0px));z-index:1000;pointer-events:none;background:linear-gradient(135deg,#120e06eb 0%,#0a0803f5 100%);border:2px solid #c9a22766;border-radius:50%;justify-content:center;align-items:center;width:100px;height:100px;display:flex;position:fixed;box-shadow:inset 0 0 20px #c9a2270f,0 0 15px #c9a22726}.compass-label{color:#c9a227;text-shadow:0 1px 2px #000000b3;pointer-events:none;font-size:16px;font-weight:700;position:absolute}.compass-north{top:5px;left:50%;transform:translate(-50%)}.compass-east{top:50%;right:5px;transform:translateY(-50%)}.compass-south{bottom:5px;left:50%;transform:translate(-50%)}.compass-west{top:50%;left:5px;transform:translateY(-50%)}.compass-center{z-index:2;background:#c9a227;border-radius:50%;width:8px;height:8px;box-shadow:0 0 10px #c9a22799}.compass-pointer{transform-origin:bottom;z-index:3;background:linear-gradient(red 0%,#f44 50%,#0000 100%);border-radius:2px 2px 0 0;width:3px;height:35px;position:absolute;top:50%;left:50%;transform:translate(-50%,-100%)rotate(0);box-shadow:0 0 8px #f00c}#help-overlay.help-overlay{z-index:30000;padding:calc(16px + env(safe-area-inset-top,0px)) calc(16px + env(safe-area-inset-right,0px)) calc(16px + env(safe-area-inset-bottom,0px)) calc(16px + env(safe-area-inset-left,0px));box-sizing:border-box;pointer-events:auto;touch-action:pan-y;-webkit-overflow-scrolling:touch;background:radial-gradient(85% 65% at 50% 40%,#3c26128c 0%,#0000 55%),#060402e0;justify-content:center;align-items:center;display:none;position:fixed;inset:0;overflow:hidden auto}.help-panel.menu-container{width:min(560px,100vw - 24px);max-width:min(560px,100%);max-height:min(calc(100dvh - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px) - 32px), 92dvh);text-align:left;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);-webkit-overflow-scrolling:touch;background:linear-gradient(#241a10eb 0%,#120c08f5 100%);border:1px solid #d4a85873;border-radius:14px;flex-direction:column;padding:0;display:flex;overflow:hidden;box-shadow:0 24px 60px #0000008c,inset 0 0 0 1px #ffe0b41f,0 0 40px #78481c26}.help-topbar{background:linear-gradient(#30221480 0%,#0000 100%);border-bottom:1px solid #d4a85833;flex-direction:column;flex-shrink:0;align-items:center;gap:10px;padding:18px 22px 16px;display:flex}.help-lang-bar{flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;width:100%;display:flex}.help-lang-btn{min-height:40px;font-family:var(--font-ui);letter-spacing:.04em;text-transform:none;color:#fff5e6e0;cursor:pointer;box-shadow:none;background:#00000040;border:1px solid #d4a85859;border-radius:999px;flex:none;margin:0;padding:8px 14px;font-size:13px;font-weight:600;line-height:1.2;transition:background .18s,border-color .18s,color .18s,box-shadow .18s}.help-lang-btn:hover{background:#50381c59;border-color:#ffd68c8c;transform:none;box-shadow:0 0 12px #d4a8581f}.help-lang-btn.is-active{color:#1a1208;background:linear-gradient(135deg,#e8c47a 0%,#c9a227 100%);border-color:#ffe8bcd9;box-shadow:0 0 20px #e8b45040}.help-lang-btn.is-active:hover{color:#1a1208;background:linear-gradient(135deg,#f0d090 0%,#d4ae38 100%);transform:none}.help-version{letter-spacing:.06em;text-transform:uppercase;color:#e6d2b48c;text-align:center;font-size:12px;font-weight:500;font-family:var(--font-ui);margin:0}.help-title.menu-title{text-align:center;color:#f0dcc0;text-shadow:0 1px #00000073,0 0 28px #d4a8582e;border-bottom:none;flex-shrink:0;margin:0;padding:20px 24px 12px;font-size:clamp(22px,4.2vw,32px);font-weight:700}.help-body{color:#fff8eee6;flex:auto;min-height:0;padding:8px 24px 20px;font-size:14px;line-height:1.6;overflow-y:auto}.help-section{margin-bottom:20px}.help-section:last-child{margin-bottom:0}.help-section h3{font-family:var(--font-display);color:#e8c896;letter-spacing:.08em;text-transform:uppercase;text-shadow:0 1px 2px #00000059;margin:0 0 10px;font-size:15px;font-weight:700}.help-list{margin:0;padding-left:1.15rem}.help-list li{margin-bottom:8px}.help-list li::marker{color:#d4a858bf}.help-list.help-compact li{margin-bottom:6px}.help-p{margin:0 0 10px}.help-p.help-en{opacity:.88;font-size:13px}.help-p code{color:#ffe8c8;background:#00000059;border:1px solid #d4a85840;border-radius:4px;padding:2px 6px;font-size:12px}.help-actions.menu-buttons{background:linear-gradient(#0000 0%,#18100a8c 100%);border-top:1px solid #d4a85833;flex-shrink:0;margin:0;padding:16px 22px 22px}.help-dismiss-btn.menu-btn{letter-spacing:.12em;text-transform:uppercase;color:#1e1408;background:linear-gradient(135deg,#f0d18a 0%,#c9a227 45%,#a67c20 100%);border:1px solid #ffecc8a6;border-radius:8px;width:100%;margin:0;padding:14px 24px;font-size:16px;box-shadow:0 6px 20px #00000059,inset 0 0 0 1px #ffffff1f}.help-dismiss-btn.menu-btn:hover{background:linear-gradient(135deg,#f8dfa0 0%,#d4ae38 45%,#b88a28 100%);transform:translateY(-1px);box-shadow:0 8px 26px #0006,0 0 24px #d4a85833}.help-dismiss-btn.menu-btn:active{transform:translateY(0)}#help-overlay .menu-buttons{margin-top:0}.help-mobile-notice{background:#281c10a6;border:1px solid #d4a8584d;border-radius:10px;padding:14px 16px;box-shadow:inset 0 0 0 1px #0003}button,.arrow-key,.cmd-btn,.mute-btn,.menu-btn,.help-lang-btn{-webkit-tap-highlight-color:transparent;touch-action:manipulation}.menu-btn,.help-lang-btn{min-height:44px}.mobile-play-hint{left:env(safe-area-inset-left,0px);right:env(safe-area-inset-right,0px);top:calc(56px + env(safe-area-inset-top,0px));z-index:130;box-sizing:border-box;pointer-events:none;text-align:center;font-family:var(--font-ui);background:linear-gradient(135deg,#0a1626f0 0%,#060e1ceb 100%);border:1px solid #00c8ff73;border-radius:8px;flex-direction:column;gap:4px;margin:0 8px;padding:8px 12px;display:none;position:fixed;box-shadow:0 8px 22px #00000059}.mobile-play-hint__title{color:#ffd76a;text-shadow:0 0 10px #0000008c;font-size:clamp(13px,3.5vw,15px);font-weight:700}.mobile-play-hint__detail{color:#e6f0ffe6;font-size:clamp(11px,3vw,13px);line-height:1.35}.help-mobile-notice{background:#281c10a6;border:1px solid #d4a8584d;border-radius:8px;padding:12px 14px}.help-mobile-callout-en{margin-bottom:0}@media (width<=767px) and (orientation:portrait) and (pointer:coarse){.mobile-play-hint{display:flex}#keyboard-hint,.keyboard-hint-restore{top:calc(152px + env(safe-area-inset-top,0px))}#keyboard-hint{max-width:calc(100vw - env(safe-area-inset-left,0px) - env(safe-area-inset-right,0px) - 24px)}}@media (width<=767px){.menu-title{font-size:clamp(28px,9vw,48px)}.menu-container{width:min(520px,100vw - 24px);padding:28px 20px}#top-bar{left:env(safe-area-inset-left,0px);right:env(safe-area-inset-right,0px);flex-wrap:wrap;justify-content:center;row-gap:6px;width:auto;max-width:none;height:auto;min-height:38px;padding:6px 10px;transform:none}#top-controls{top:calc(88px + env(safe-area-inset-top,0px));left:env(safe-area-inset-left,0px);right:env(safe-area-inset-right,0px);flex-wrap:wrap;justify-content:center;height:auto;min-height:44px;padding:0 10px}.mute-btn{width:auto;min-width:44px;min-height:44px;padding:0 10px;font-size:14px}.tech-badge{flex:140px;justify-content:center;min-width:0}#compass{width:72px;height:72px;top:calc(140px + env(safe-area-inset-top,0px))}.compass-label{font-size:13px}#bottom-panel{-webkit-overflow-scrolling:touch;flex-direction:column;align-items:stretch;gap:8px;height:auto;max-height:min(52dvh,420px);padding:8px;overflow:hidden auto}#bottom-panel>*{flex-shrink:0}#minimap-container{aspect-ratio:1;align-self:center;width:100%;max-width:160px;height:auto}#info-panel-container{flex-direction:row;align-items:stretch;gap:8px;width:100%;height:auto;max-height:none}#unit-portrait{width:56px;min-width:56px;height:56px;margin-bottom:0}#unit-info{flex:1;min-width:0}#command-card-container{-webkit-overflow-scrolling:touch;justify-content:stretch;width:100%;padding:0;overflow:auto hidden}#command-card{grid-template-columns:repeat(4,minmax(48px,1fr));grid-auto-rows:minmax(48px,auto);gap:8px;width:max-content;min-width:100%;padding:8px}.cmd-btn{box-sizing:border-box;width:100%;min-width:48px;min-height:48px;padding:2px 4px;font-size:clamp(9px,2.6vw,11px)}.arrow-key{border-width:2px;width:44px;min-width:44px;height:44px;min-height:44px;font-size:16px}.hint-key{width:36px;height:36px;font-size:16px}.hint-text{font-size:12px}#keyboard-hint{gap:8px;padding:10px 14px}}@media (width<=767px) and (orientation:landscape){#bottom-panel{max-height:min(42dvh,280px)}}@media (pointer:coarse) and (width<=767px){#command-card{gap:10px}.arrow-key+.arrow-key{margin-left:2px}}@media (prefers-reduced-motion:reduce){.hint-key,.arrow-key,.cmd-btn,.mute-btn,.menu-btn,.help-lang-btn,.top-toast,.hp-fill,#keyboard-hint,.keyboard-hint-restore,.move-order-marker,.minimap-click-flash{transition:none!important;animation:none!important}.hint-key.active,.arrow-key.active,.cmd-btn:hover,.menu-btn:hover,.help-lang-btn:hover,.help-dismiss-btn.menu-btn:hover{transform:none}}
