:root{--navy-abyss:#050912;--navy-deep:#0d1838;--navy-mid:#14245a;--navy-bright:#2849a8;--navy-edge:#3a5cb0;--leather:#3a2415;--leather-deep:#271608;--leather-edge:#160c05;--leather-hi:#5c3c22;--leather-warm:#4a2e18;--gilt-deep:#6b4d12;--gilt:#c8a24e;--gilt-bright:#f0d488;--gilt-pale:#fff3c8;--brass:#8a6a32;--brass-dark:#4a3514;--paper:#ecdfbc;--paper-warm:#ddca9c;--paper-shadow:#b89a64;--paper-deep:#9c7d4a;--oxblood-deep:#4d0a0c;--oxblood:#7a161a;--oxblood-bright:#b8323a;--ink:#3a2410;--ink-soft:#6b4f30;--ink-faint:#8a7048;--ivory:#f3ead2;--ivory-soft:#d8c990;--text-primary:var(--ivory);--text-soft:#c7b78a;--text-muted:#9a8a62;--text-deep:#6d5f40;--accent:var(--gilt-bright);--accent-2:var(--gilt);--danger:var(--oxblood-bright);--line-gold:#6b4d12;--line-navy:#1d2f6a;--font-title:"Cinzel Decorative", "Cinzel", "STKaiti", "KaiTi", serif;--font-engrave:"Cinzel", "Noto Serif SC", "Songti SC", serif;--font-body:"EB Garamond", "Cormorant Garamond", "Noto Serif SC", "Songti SC", serif;--font-italic:"Cormorant Garamond", "Noto Serif SC", serif;--font-cn:"Noto Serif SC", "Songti SC", "STSong", serif;--font-kai:"STKaiti", "KaiTi", "Kaiti SC", "Noto Serif SC", serif;--tex-paper:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='p'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23p)' opacity='0.55'/%3E%3C/svg%3E");--tex-fiber:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='600' height='600'%3E%3Cfilter id='f'%3E%3CfeTurbulence type='turbulence' baseFrequency='0.012 0.16' numOctaves='3' seed='7' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23f)' opacity='0.5'/%3E%3C/svg%3E");--tex-leather:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='l'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.045 0.06' numOctaves='4' seed='3' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23l)' opacity='0.22'/%3E%3C/svg%3E");--tex-grain:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)' opacity='0.4'/%3E%3C/svg%3E");--gilt-foil:linear-gradient(175deg, #fff3c8 0%, #f0d488 24%, #c8a24e 50%, #8a6a32 68%, #e8c878 86%, #c8a24e 100%);--leather-surface:linear-gradient(158deg, #4f3220 0%, #3a2415 46%, #271608 100%);--brass-surface:linear-gradient(180deg, #6a4e22 0%, #4a3514 52%, #2e2008 100%)}*{box-sizing:border-box}html,body{min-height:100vh;touch-action:manipulation;overscroll-behavior:none;min-height:100dvh;color:var(--text-primary);font-family:var(--font-cn), var(--font-body);font-feature-settings:"palt";background-color:#0000;background-image:radial-gradient(at 18% 10%,#1a2e6a44 0%,#0000 40%),radial-gradient(at 84% 82%,#3a1c0c55 0%,#0000 46%),radial-gradient(at 50% 48%,#0a1338 0%,#050b1c 66%,#03060f 100%);background-position:0 0,0 0,0 0;background-repeat:repeat,repeat,repeat;background-size:auto,auto,auto;background-attachment:fixed;background-origin:padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box;margin:0;position:relative}body:before{content:"";pointer-events:none;z-index:0;opacity:.7;background-image:radial-gradient(1px 1px at 12% 18%,#f3ead266 50%,#0000 100%),radial-gradient(1px 1px at 24% 62%,#c8a24e44 50%,#0000 100%),radial-gradient(1px 1px at 42% 28%,#f3ead244 50%,#0000 100%),radial-gradient(1px 1px at 58% 84%,#d8c99044 50%,#0000 100%),radial-gradient(1px 1px at 71% 35%,#f3ead255 50%,#0000 100%),radial-gradient(1px 1px at 88% 14%,#c8a24e55 50%,#0000 100%),radial-gradient(1px 1px at 92% 71%,#f3ead244 50%,#0000 100%),radial-gradient(1px 1px at 36% 91%,#c8a24e33 50%,#0000 100%);background-size:760px 760px;position:fixed;top:0;bottom:0;left:0;right:0}body:after{content:"";pointer-events:none;z-index:0;background:var(--tex-grain), radial-gradient(ellipse at 50% 50%, transparent 52%, #03060ddd 100%);mix-blend-mode:soft-light;opacity:.5;mix-blend-mode:normal;background-size:160px 160px,cover;position:fixed;top:0;bottom:0;left:0;right:0}body,button,select,input,canvas{-webkit-tap-highlight-color:transparent}.app-shell{z-index:1;grid-template-columns:minmax(260px,340px) 1fr;gap:14px;padding:14px;display:grid;position:relative}.panel{background:var(--tex-leather), var(--leather-surface);background-blend-mode:overlay, normal;border:1px solid var(--brass);background-size:220px 220px,cover;border-radius:6px;max-height:calc(100vh - 28px);padding:16px 15px 18px;position:relative;overflow:auto;box-shadow:inset 0 0 0 1px #160c05,inset 0 0 40px #160c0599,inset 0 1px #6c4a2877,0 6px 30px #02060ed0,0 0 0 3px #160c05}.panel>*{z-index:1;position:relative}.panel:before{content:"";z-index:0;pointer-events:none;border:1px solid #6c4a2855;border-radius:3px;position:absolute;top:7px;bottom:7px;left:7px;right:7px;box-shadow:inset 0 0 0 1px #160c0566}.panel:after{content:"";z-index:2;border-bottom:2px solid var(--gilt);border-right:2px solid var(--gilt);filter:drop-shadow(0 0 3px #00000080);pointer-events:none;border-bottom-right-radius:4px;width:22px;height:22px;position:absolute;bottom:4px;right:4px}.panel::-webkit-scrollbar{width:7px}.panel::-webkit-scrollbar-track{background:#160c05}.panel::-webkit-scrollbar-thumb{background:var(--brass);border:1px solid #160c05;border-radius:3px}.panel::-webkit-scrollbar-thumb:hover{background:var(--gilt)}h1{font-family:var(--font-engrave);letter-spacing:.16em;text-align:center;background:var(--gilt-foil);color:#0000;filter:drop-shadow(0 1px #160c05)drop-shadow(0 2px 3px #02060e);-webkit-background-clip:text;background-clip:text;margin:2px 0 8px;padding:4px 0 12px;font-size:1.5rem;font-weight:800;position:relative}h1:after{content:"";background:linear-gradient(90deg, transparent, var(--gilt), var(--gilt-bright), var(--gilt), transparent);width:72%;height:2px;position:absolute;bottom:0;left:50%;transform:translate(-50%);box-shadow:0 1px 2px #160c05}.subtitle{color:var(--text-soft);font-family:var(--font-italic);text-align:center;letter-spacing:.1em;margin:4px 0 12px;font-size:.9rem;font-style:italic}.compact-meta{color:var(--text-muted);font-family:var(--font-italic);margin:0 0 8px;font-size:.84rem;font-style:italic}.status{grid-template-columns:repeat(2,minmax(0,1fr));gap:7px;margin:12px 0;display:grid}.status div{border:1px solid var(--brass-dark);background:linear-gradient(#2a1c0e 0%,#1a1006 100%);border-radius:3px;justify-content:space-between;align-items:center;padding:6px 10px 6px 12px;font-size:.84rem;display:flex;position:relative;box-shadow:inset 0 1px #6c4a2855,inset 0 -2px 4px #0006}.status div:before{content:"";background:linear-gradient(180deg, var(--gilt-bright), var(--gilt-deep));border-radius:2px;width:3px;position:absolute;top:4px;bottom:4px;left:0}.status span{color:var(--text-soft);white-space:nowrap;letter-spacing:.06em;font-size:.78rem}.status strong{color:var(--gilt-bright);font-family:var(--font-engrave);text-align:right;text-overflow:ellipsis;white-space:nowrap;text-shadow:0 1px 1px #160c05;max-width:66%;font-size:.9rem;font-weight:600;overflow:hidden}.controls{border-top:1px solid var(--brass-dark);margin-top:14px;padding-top:12px;position:relative}.controls:before{content:"✦";color:var(--gilt);background:var(--leather-deep);padding:0 8px;font-size:.62rem;position:absolute;top:-9px;left:50%;transform:translate(-50%)}.controls h2{font-family:var(--font-engrave);color:var(--gilt-bright);letter-spacing:.2em;text-transform:uppercase;text-align:center;text-shadow:0 1px #160c05;margin:0 0 10px;font-size:.82rem;font-weight:700}.slim-controls{margin-top:11px;padding-top:11px}.btn-row,.btn-col{gap:7px;display:grid}.btn-row{grid-template-columns:1fr 1fr}button,select,input[type=text]{border:1px solid var(--brass-dark);background:var(--brass-surface);color:var(--ivory);font:inherit;font-family:var(--font-cn);letter-spacing:.04em;border-radius:3px;padding:8px 10px;font-size:.86rem;transition:transform .14s cubic-bezier(.16,1,.3,1),box-shadow .16s,background .16s,color .16s,border-color .16s;position:relative}button{cursor:pointer;color:var(--gilt-pale);text-shadow:0 1px 1px #160c05;box-shadow:inset 0 1px #b8923c66,inset 0 -2px 4px #160c05cc,0 1px 2px #02060e99}select{cursor:pointer;-webkit-appearance:none;appearance:none;background-image:linear-gradient(45deg, transparent 50%, var(--gilt-bright) 50%), linear-gradient(135deg, var(--gilt-bright) 50%, transparent 50%), var(--brass-surface);color:var(--ivory);background-position:calc(100% - 14px) 15px,calc(100% - 9px) 15px,0 0;background-repeat:no-repeat;background-size:5px 5px,5px 5px,100% 100%;padding-right:26px}input[type=text]{color:var(--ivory);background:linear-gradient(#1a1006 0%,#271608 100%)}input[type=text]::placeholder{color:var(--text-muted);font-style:italic}@media (hover:hover){button:hover:not(:disabled),.btn-link:hover{border-color:var(--gilt-bright);color:#fff6dc;background:linear-gradient(#8a6a32 0%,#5a3c16 100%);box-shadow:inset 0 1px #f0d48899,inset 0 -2px 4px #160c05cc,0 0 14px #c8a24e55,0 2px 6px #02060ea0}}button:active:not(:disabled){transform:scale(.97);box-shadow:inset 0 1px 3px #160c05cc}button:disabled{opacity:.4;cursor:not-allowed;filter:grayscale(.5)}.btn-link{border:1px solid var(--brass-dark);background:var(--brass-surface);color:var(--gilt-pale);font:inherit;font-family:var(--font-cn);letter-spacing:.04em;text-shadow:0 1px 1px #160c05;border-radius:3px;justify-content:center;align-items:center;padding:8px 10px;font-size:.86rem;text-decoration:none;transition:all .16s cubic-bezier(.16,1,.3,1);display:inline-flex;box-shadow:inset 0 1px #b8923c66,inset 0 -2px 4px #160c05cc,0 1px 2px #02060e99}.hint{color:var(--text-muted);font-family:var(--font-italic);margin:8px 0 0;font-size:.84rem;font-style:italic;line-height:1.55}#serverTargetValue{color:var(--gilt-bright);font-weight:700}.zone-pick{gap:4px;margin-bottom:6px;display:grid}.zone-pick label{color:var(--text-soft);letter-spacing:.06em;font-size:.78rem}.loadout-grid{gap:8px;display:grid}.loadout-field{gap:4px;display:grid}.loadout-field span{color:var(--text-soft);letter-spacing:.06em;font-size:.78rem;font-weight:600}.loadout-preview{border:1px solid var(--brass-dark);background:var(--tex-paper), linear-gradient(180deg, #e8dcbc 0%, #d6c298 100%);background-blend-mode:multiply, normal;color:var(--ink);font-family:var(--font-cn);background-size:200px 200px,cover;border-radius:3px;gap:4px;margin:8px 0;padding:10px 11px;font-size:.8rem;line-height:1.55;display:grid;position:relative;box-shadow:inset 0 0 0 1px #0002,0 1px 3px #0006}.loadout-preview:before{content:"";pointer-events:none;border:1px solid #8a602044;border-radius:2px;position:absolute;top:3px;bottom:3px;left:3px;right:3px}.loadout-preview strong{color:var(--oxblood)}.slider-wrap{gap:5px;margin:9px 0;display:grid}.slider-wrap label{color:var(--text-soft);letter-spacing:.08em;font-size:.78rem}.slider-wrap strong{color:var(--gilt-bright);font-family:var(--font-engrave);font-size:.95rem;font-weight:600}.zoom-control-row{grid-template-columns:1fr auto 1fr;align-items:center;gap:7px;margin-top:6px;display:grid}.zoom-control-row strong{text-align:center;min-width:50px;color:var(--gilt-bright);font-family:var(--font-engrave);letter-spacing:.05em;font-weight:600}input[type=range]{width:100%;accent-color:var(--gilt);background:#160c05;height:4px}input[type=range]::-webkit-slider-thumb{background:var(--gilt)}.captain-list{color:var(--text-soft);gap:6px;margin:0;padding-left:18px;font-size:.84rem;display:grid}.log{border:1px solid var(--brass-dark);background:var(--tex-grain), linear-gradient(180deg, #1a1006 0%, #0e0803 100%);background-blend-mode:overlay, normal;min-height:96px;max-height:150px;color:var(--ivory-soft);font-size:.82rem;line-height:1.6;font-family:var(--font-italic);background-size:160px 160px,cover;border-radius:3px;padding:10px 11px;overflow:auto;box-shadow:inset 0 2px 6px #0009}.log::-webkit-scrollbar{width:5px}.log::-webkit-scrollbar-thumb{background:var(--brass)}.battle-panel{flex-direction:column;gap:7px;height:calc(100vh - 28px);max-height:calc(100vh - 28px);padding:11px 13px 12px;display:flex;overflow:hidden}.battle-panel>*{margin:0}.battle-panel button,.battle-panel .btn-link{padding-top:5px;padding-bottom:5px}.battle-panel h1{margin:0;padding:2px 0 7px;font-size:1.15rem}.battle-panel .panel-actions{grid-auto-columns:1fr;grid-auto-flow:column;gap:7px;display:grid}.battle-panel .panel-actions .btn-link,.battle-panel .panel-actions button{padding:7px 8px}.battle-panel .controls{margin-top:0;padding-top:8px}.battle-panel .controls h2{margin-bottom:6px}.battle-panel .status{gap:5px;margin:0}.battle-panel .status div{padding:4px 9px 4px 11px}.battle-panel .slider-wrap{gap:4px;margin:4px 0 0}.battle-panel .slider-head{justify-content:space-between;align-items:baseline;display:flex}.battle-panel .zoom-control-row{margin-top:6px}.battle-panel #battleControls{flex-direction:column;gap:7px;display:flex}.battle-panel .btn-grid{grid-template-columns:1fr 1fr;gap:7px;display:grid}.battle-panel .btn-grid .span-2{grid-column:1/-1}.battle-panel .fleet-section{flex-direction:column;flex:auto;min-height:0;display:flex}.battle-panel .fleet-section h2{flex:none}.fleet-roster{flex-direction:column;flex:auto;gap:5px;min-height:0;display:flex}.fleet-row{text-align:left;cursor:pointer;border:1px solid var(--brass-dark);min-height:34px;color:var(--ivory-soft);font:inherit;font-family:var(--font-cn);background:linear-gradient(#2a1c0e 0%,#1a1006 100%);border-radius:3px;flex-direction:column;flex:1 1 0;justify-content:center;gap:3px;padding:4px 9px;transition:border-color .16s,box-shadow .16s,background .16s;display:flex;overflow:hidden;box-shadow:inset 0 1px #6c4a2855,inset 0 -2px 4px #0006}.battle-panel .fleet-row:hover{border-color:var(--gilt);background:linear-gradient(#33230f 0%,#1d1206 100%);box-shadow:inset 0 1px #6c4a2855,inset 0 -2px 4px #0006}.battle-panel .fleet-row.active{border-color:var(--gilt-bright);background:linear-gradient(#3a280f 0%,#201406 100%);box-shadow:inset 0 1px #ffe9a855,inset 0 -2px 4px #160c05,0 0 12px #c8a24e44}.fleet-row.gone{opacity:.5;filter:grayscale(.55);cursor:default}.fleet-row-head{justify-content:space-between;align-items:baseline;gap:8px;display:flex}.fleet-name{color:var(--gilt-pale);letter-spacing:.04em;text-overflow:ellipsis;white-space:nowrap;font-size:.82rem;font-weight:600;overflow:hidden}.fleet-row.active .fleet-name{color:var(--gilt-bright)}.fleet-state{color:var(--text-soft);letter-spacing:.05em;font-size:.72rem;font-family:var(--font-italic);white-space:nowrap;flex:none;font-style:italic}.fleet-state.danger{color:var(--oxblood-bright);font-style:normal}.fleet-gauges{grid-template-columns:1fr 1fr;gap:9px;display:grid}.fleet-gauge{grid-template-columns:auto 1fr auto;align-items:center;gap:6px;display:grid}.fleet-glabel{color:var(--text-muted);letter-spacing:.04em;font-size:.68rem}.fleet-bar{background:#160c05;border-radius:3px;height:6px;overflow:hidden;box-shadow:inset 0 1px 2px #0009}.fleet-fill{border-radius:3px;width:100%;height:100%;transition:width .2s;display:block}.fleet-fill-hull{background:linear-gradient(90deg, var(--gilt-deep), var(--gilt-bright))}.fleet-fill-hull.low{background:linear-gradient(90deg, #7a1c1c, var(--oxblood-bright))}.fleet-fill-energy{background:linear-gradient(90deg,#2f5d52,#6fae97)}.fleet-pct{text-align:right;min-width:26px;color:var(--gilt-pale);font-size:.7rem;font-family:var(--font-engrave);letter-spacing:.02em}.game-wrap{justify-content:center;align-items:flex-start;display:flex;position:relative}#gameCanvas,#onlineCanvas,#debugCanvas{aspect-ratio:1;border:2px solid var(--brass);touch-action:none;background:#03050c;border-radius:6px;width:min(100%,100vh - 28px);height:auto;display:block;box-shadow:inset 0 0 0 1px #160c05,inset 0 0 30px #03050c,0 0 0 4px #160c05,0 0 0 6px #6c4a2855,0 8px 36px #02060ee0}.mobile-battle-hud{z-index:4;border:1px solid var(--brass);background:var(--tex-leather), var(--leather-surface);background-blend-mode:overlay, normal;background-size:220px 220px,cover;border-radius:5px;gap:8px;padding:11px;display:none;position:absolute;bottom:12px;left:12px;right:12px;box-shadow:inset 0 0 0 1px #160c05,inset 0 1px #6c4a2877,0 10px 28px #02060ee0}.mobile-battle-head{grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:7px;display:grid}.mobile-head-actions{gap:6px;display:flex}.mobile-menu-btn{border:1px solid var(--brass-dark);background:var(--brass-surface);color:var(--gilt-pale);white-space:nowrap;font-family:var(--font-cn);letter-spacing:.03em;border-radius:3px;justify-content:center;align-items:center;padding:7px 11px;font-size:.82rem;text-decoration:none;display:inline-flex;box-shadow:inset 0 1px #b8923c66,inset 0 -2px 4px #160c05cc,0 1px 2px #02060e99}.mobile-menu-btn:active{transform:translateY(1px)}.mobile-throttle-wrap{grid-template-columns:auto repeat(5,minmax(0,1fr));align-items:stretch;gap:5px;display:grid}.mobile-throttle-label{color:var(--text-soft);letter-spacing:.1em;align-self:center;padding-right:1px;font-size:.74rem}.mobile-battle-summary{border:1px solid var(--brass-dark);min-width:0;color:var(--gilt-bright);font-family:var(--font-cn);white-space:nowrap;text-overflow:ellipsis;letter-spacing:.03em;background:#1a1006cc;border-radius:3px;padding:7px 11px;font-size:.84rem;overflow:hidden}.mobile-chip-btn{border-radius:3px;min-width:64px;padding:8px 10px}.mobile-zoom-btn{min-width:42px;font-family:var(--font-engrave);color:var(--gilt-bright);padding:8px 0;font-weight:700}.mobile-ship-switch{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;display:grid}.mobile-ship-btn{min-height:42px;padding:8px 4px}.mobile-action-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;display:grid}.mobile-action-grid>button,.mobile-throttle-row{min-height:42px}.mobile-throttle-row{grid-template-columns:repeat(3,minmax(0,1fr));gap:4px;display:grid}.mobile-throttle-btn{min-height:42px;font-family:var(--font-engrave);padding:8px 0;font-weight:600}.ship-switch-btn.active,.mobile-ship-btn.active,.debug-focus-btn.active,button.toggle-active{border-color:var(--gilt-bright);color:#fff6dc;background:linear-gradient(#b8923c 0%,#6b4d12 100%);box-shadow:inset 0 1px #ffe9a8,inset 0 -2px 4px #160c05,0 0 14px #c8a24e88}.debug-speed-btn.active{border-color:var(--gilt-bright);color:#fff6dc;background:linear-gradient(#b8923c 0%,#6b4d12 100%);box-shadow:inset 0 1px #ffe9a8,0 0 12px #c8a24e77}.mobile-throttle-btn.active{border-color:var(--oxblood-bright);color:var(--ivory);background:linear-gradient(#a8242a 0%,#4d0a0c 100%);box-shadow:inset 0 1px #d44a4577,0 0 12px #b8232a66}.mobile-battle-hint{color:var(--text-muted);font-family:var(--font-italic);text-align:center;font-size:.78rem;font-style:italic;line-height:1.5}.battle-nameplate{z-index:2;border:1px solid var(--brass);background:var(--tex-leather), var(--leather-surface);background-blend-mode:overlay, normal;pointer-events:none;background-size:220px 220px,cover;border-radius:4px;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:center;gap:10px;width:min(640px,70%);padding:8px 16px;display:grid;position:absolute;top:14px;left:50%;transform:translate(-50%);box-shadow:inset 0 0 0 1px #160c05,0 6px 18px #02060ec0}.battle-nameplate.hidden-inactive{display:none}.battle-name-side{border:1px solid var(--brass-dark);min-width:0;color:var(--gilt-pale);font-family:var(--font-cn);letter-spacing:.04em;white-space:nowrap;text-overflow:ellipsis;background:#1a1006aa;border-radius:3px;padding:5px 12px;font-size:.84rem;overflow:hidden}.battle-name-side.self{border-color:var(--gilt-bright);color:var(--gilt-bright);box-shadow:inset 0 0 0 1px #c8a24e55,0 0 10px #c8a24e44}.battle-name-a{text-align:right}.battle-name-b{text-align:left}.battle-name-vs{font-family:var(--font-engrave);color:var(--gilt-bright);letter-spacing:.22em;padding:0 4px;font-size:.8rem;font-weight:700}.overlay{background:var(--tex-grain), radial-gradient(ellipse at 50% 45%, #1a1006e8 0%, #03050cf2 72%);background-blend-mode:overlay, normal;border:2px solid var(--brass);background-size:160px 160px,cover;border-radius:6px;place-content:center;gap:18px;display:grid;position:absolute;top:0;bottom:0;left:0;right:0}.overlay.hidden{display:none}.overlay h2{text-align:center;font-family:var(--font-engrave);letter-spacing:.16em;background:var(--gilt-foil);color:#0000;filter:drop-shadow(0 2px 6px #050912)drop-shadow(0 0 16px #c8a24e44);-webkit-background-clip:text;background-clip:text;margin:0;font-size:2rem}.online-shell{grid-template-columns:minmax(280px,360px) 1fr}.compact-status{gap:6px}.compact-status div{padding:5px 9px}.join-code-wrap{grid-template-columns:1fr auto;gap:8px;margin:8px 0;display:grid}.room-list{gap:8px;display:grid}.room-list-compact{max-height:220px;overflow:auto}.room-item{border:1px solid var(--brass-dark);background:linear-gradient(#2a1c0e 0%,#1a1006 100%);border-radius:3px;gap:6px;padding:9px 11px;display:grid;position:relative;box-shadow:inset 0 1px #6c4a2844}.room-item:before{content:"";background:linear-gradient(180deg, var(--gilt-bright), var(--gilt-deep));border-radius:2px;width:3px;position:absolute;top:4px;bottom:4px;left:0}.room-item-title{color:var(--gilt-bright);font-family:var(--font-engrave);letter-spacing:.03em;font-size:.94rem;font-weight:600}.room-item-meta{color:var(--text-soft);font-size:.82rem;line-height:1.5}.room-item-empty{color:var(--text-muted);font-family:var(--font-italic);text-align:center;font-size:.86rem;font-style:italic}.room-summary{border:1px solid var(--brass-dark);background:var(--tex-paper), linear-gradient(180deg, #e8dcbc 0%, #d6c298 100%);background-blend-mode:multiply, normal;color:var(--ink);white-space:pre-line;min-height:70px;font-size:.82rem;line-height:1.55;font-family:var(--font-cn);background-size:200px 200px,cover;border-radius:3px;padding:10px 11px;box-shadow:inset 0 0 0 1px #0002}.room-inline-controls{margin-top:0}.disabled-panel{opacity:.5;filter:grayscale(.45)}.disabled-panel .hint{opacity:.85}.ship-switch{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;margin-bottom:6px;display:grid}.ship-switch-btn{font-family:var(--font-cn);padding:7px 4px;font-size:.84rem}.room-hud{z-index:3;border:1px solid var(--brass);background:var(--tex-leather), var(--leather-surface);background-blend-mode:overlay, normal;background-size:220px 220px,cover;border-radius:5px;gap:9px;width:min(440px,44%);max-height:min(78%,100% - 36px);padding:15px;display:grid;position:absolute;top:18px;right:18px;overflow:auto;box-shadow:inset 0 0 0 1px #160c05,inset 0 1px #6c4a2877,0 14px 34px #02060ed0}.room-hud:before,.room-hud:after{content:"";pointer-events:none;width:16px;height:16px;position:absolute}.room-hud:before{border-top:2px solid var(--gilt);border-left:2px solid var(--gilt);border-top-left-radius:3px;top:5px;left:5px}.room-hud:after{border-bottom:2px solid var(--gilt);border-right:2px solid var(--gilt);border-bottom-right-radius:3px;bottom:5px;right:5px}.room-hud.hidden-in-battle{display:none}.room-hud-head{border-bottom:1px solid var(--brass-dark);justify-content:space-between;align-items:center;gap:10px;padding-bottom:9px;display:flex}.room-hud-head h2{font-family:var(--font-engrave);color:var(--gilt-bright);letter-spacing:.16em;text-shadow:0 1px #160c05;margin:0;font-size:1rem}.room-hud-head strong{color:var(--gilt-bright);font-size:.86rem;font-family:var(--font-engrave)}.room-hud-tags{align-items:center;gap:6px;display:inline-flex}.room-hud-tags strong{border:1px solid var(--brass-dark);background:#1a1006cc;border-radius:3px;padding:3px 9px}.net-debug-hidden{display:none}.debug-shell{grid-template-columns:minmax(310px,400px) 1fr}.debug-team-stack{gap:10px;display:grid}.debug-team-block{border:1px solid var(--brass-dark);background:linear-gradient(#2a1c0e 0%,#1a1006 100%);border-radius:3px;gap:8px;padding:10px;display:grid;position:relative;box-shadow:inset 0 1px #6c4a2844}.debug-team-block:before{content:"";background:linear-gradient(180deg, var(--gilt-bright), var(--gilt-deep));border-radius:2px;width:3px;position:absolute;top:4px;bottom:4px;left:0}.debug-team-head{justify-content:space-between;align-items:center;gap:8px;padding-left:6px;display:flex}.debug-team-head h3{font-family:var(--font-engrave);color:var(--gilt-bright);letter-spacing:.1em;margin:0;font-size:.94rem}.debug-seat-tag{border:1px solid var(--brass);color:var(--gilt-bright);font-size:.74rem;font-family:var(--font-engrave);letter-spacing:.12em;background:#1a1006cc;border-radius:3px;padding:2px 9px}.debug-seat-tag.seat-a{border-color:var(--navy-edge);color:#9ec4ff}.debug-seat-tag.seat-b{border-color:var(--oxblood-bright);color:#ffb3b0}.debug-speed-row{grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;margin-top:8px;display:grid}.debug-focus-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;display:grid}.debug-focus-btn[data-seat=A]{border-color:#284a8a}.debug-focus-btn[data-seat=B]{border-color:#6e2a2c}.debug-selected-card{min-height:82px}.debug-selected-card strong{color:var(--oxblood)}.debug-ai-card{min-height:184px}.debug-ai-headline{justify-content:space-between;align-items:baseline;gap:8px;display:flex}.debug-ai-headline strong{color:var(--oxblood);font-size:.88rem;font-family:var(--font-engrave)}.debug-ai-headline span{color:var(--ink-soft);font-size:.74rem;font-style:italic}.debug-ai-tags{flex-wrap:wrap;gap:5px;display:flex}.debug-ai-tag{color:var(--ink-soft);letter-spacing:.03em;background:#00000010;border:1px solid #8a602066;border-radius:3px;padding:2px 7px;font-size:.72rem}.debug-ai-tag.alert{border-color:var(--oxblood-bright);color:var(--oxblood-deep);background:#b8323a22}.debug-ai-tag.good{border-color:var(--gilt-deep);color:var(--ink);background:#6b4d1222}.debug-ai-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:4px 8px;display:grid}.debug-ai-grid div{background:#00000010;border:1px solid #8a602044;border-radius:3px;padding:5px 7px}.debug-ai-grid strong{color:var(--oxblood);letter-spacing:.06em;font-size:.7rem;font-family:var(--font-engrave);margin-bottom:2px;display:block}.debug-ai-orders{gap:4px;display:grid}.debug-ai-orders div{border-left:2px solid var(--gilt-deep);padding-left:8px}.debug-ai-card .debug-ai-mute{color:var(--ink-faint);font-style:italic}@media (max-width:980px){.app-shell,.online-shell,.debug-shell{grid-template-columns:1fr}.panel{order:2;max-height:none}.battle-panel{height:auto;max-height:none;overflow:visible}.game-wrap{order:1;padding-bottom:198px}.join-code-wrap{grid-template-columns:1fr}.room-hud{width:100%;max-height:none;margin-top:0;position:static}.battle-nameplate{width:min(94%,640px);padding:6px 10px;top:10px}.battle-name-side{padding:4px 8px;font-size:.78rem}.battle-name-vs{letter-spacing:.16em;font-size:.7rem}.mobile-battle-hud{display:grid}h1{letter-spacing:.1em;font-size:1.25rem}.battle-shell{height:100vh;flex-direction:column;gap:8px;height:100dvh;padding:8px;display:flex;overflow:hidden}.battle-shell .battle-panel{display:none}.battle-shell .game-wrap{flex-direction:column;flex:auto;order:0;justify-content:space-between;align-items:center;gap:8px;min-height:0;padding-bottom:0;display:flex}.battle-shell #gameCanvas,.battle-shell #onlineCanvas{flex:none;width:min(100%,100dvh - 352px)}.battle-shell .mobile-battle-hud{flex:none;gap:6px;width:100%;padding:9px 10px;display:grid;position:static;bottom:auto;left:auto;right:auto}.battle-shell .mobile-ship-btn,.battle-shell .mobile-action-grid>button{min-height:40px}.battle-shell .mobile-throttle-btn{min-height:38px}.battle-shell .mobile-battle-hint{white-space:nowrap;text-overflow:ellipsis;font-size:.72rem;line-height:1.35;overflow:hidden}}@media (max-width:980px) and (max-height:560px){.battle-shell .game-wrap{grid-template-rows:100%;grid-template-columns:minmax(0,1fr) minmax(264px,360px);justify-content:center;align-items:center;gap:8px;display:grid}.battle-shell #gameCanvas,.battle-shell #onlineCanvas{justify-self:center;width:auto;max-width:100%;height:auto;max-height:100%}.battle-shell .mobile-battle-hud{align-content:start;height:100%;overflow-y:auto}}.cs-screen{z-index:1000;opacity:1;font-family:var(--font-cn), var(--font-body);color:var(--ink);background:radial-gradient(at 50% 30%,#3a2310 0%,#1a1530 54%,#0b1430 100%),radial-gradient(at 50% 110%,#38240f 0%,#0a1028 80%),#070d1e;transition:opacity .6s,transform .7s cubic-bezier(.4,0,0,1);position:fixed;top:0;bottom:0;left:0;right:0;overflow:hidden}.cs-screen>:not(.cs-bg-canvas){opacity:0;transition:opacity .45s}.cs-screen.visible>:not(.cs-bg-canvas){opacity:1}.cs-screen.leaving{opacity:0;pointer-events:none;transform:scale(1.05)}.cs-bg-canvas{z-index:0;width:100%;height:100%;position:absolute;top:0;bottom:0;left:0;right:0}.cs-screen:before{content:"";z-index:1;pointer-events:none;background:var(--tex-leather), repeating-linear-gradient(94deg, transparent 0, #00000010 2px, transparent 5px, transparent 26px, #00000008 28px, transparent 31px), radial-gradient(ellipse at 50% 100%, transparent 60%, #060a1c44 100%);mix-blend-mode:multiply;opacity:.4;background-size:320px 320px,auto,cover;position:absolute;top:0;bottom:0;left:0;right:0}.cs-screen:after{content:"";z-index:3;pointer-events:none;background:linear-gradient(90deg,#0000 0%,#8a6a32 28%,#f0d488 50%,#8a6a32 72%,#0000 100%);height:2px;position:absolute;top:0;left:0;right:0}.cs-content{z-index:2;grid-template-rows:auto minmax(0,1fr) auto;gap:12px;height:100%;padding:16px 26px 18px;display:grid;position:relative}.cs-header{grid-template-columns:1fr auto 1fr;align-items:center;gap:16px;padding:2px 0;display:grid}.cs-folio{font-family:var(--font-body);color:var(--gilt);letter-spacing:.32em;text-transform:uppercase;text-shadow:0 1px #07040188,0 0 6px #8a6a3244;font-size:.8rem}.cs-folio.left{text-align:left}.cs-folio.right{text-align:right;letter-spacing:.2em;font-style:italic}.cs-header-center{text-align:center;flex-direction:column;align-items:center;gap:5px;display:flex}.cs-sos-badge{filter:drop-shadow(0 2px 6px #02060eaa);background:url(/assets/brand/sos-gold.png) 50%/contain no-repeat;width:46px;height:56px}.cs-title{font-family:var(--font-title);letter-spacing:.14em;background:var(--gilt-foil);color:#0000;filter:drop-shadow(0 1px #2a1808)drop-shadow(0 3px 4px #000a);-webkit-background-clip:text;background-clip:text;margin:2px 0 0;font-size:2rem;font-weight:900;line-height:1}.cs-subtitle{color:var(--gilt);font-family:var(--font-body);letter-spacing:.4em;text-transform:uppercase;margin:0;font-size:.66rem;font-style:italic;font-weight:500}.cs-faction{align-items:center;gap:8px;margin-top:7px;display:inline-flex}.cs-faction-label{font-family:var(--font-kai);letter-spacing:.3em;color:var(--gilt);font-size:.74rem}.cs-faction-btn{font-family:var(--font-engrave);letter-spacing:.18em;border:1px solid var(--brass);color:var(--ink-faint);cursor:pointer;background:linear-gradient(#2a1c0e 0%,#160c05 100%);border-radius:3px;padding:4px 16px;font-size:.72rem;font-weight:700;transition:all .16s;box-shadow:inset 0 1px #6c4a2855}.cs-faction-btn:hover:not(.active){color:var(--gilt-bright);border-color:var(--gilt)}.cs-faction-btn.blue.active{color:#dcebff;text-shadow:0 1px 2px #050912;background:radial-gradient(at 50% 28%,#2849a8 0%,#14245a 68%,#0c1838 100%);border-color:#6fa0ff;box-shadow:inset 0 1px #4a6dc8aa,0 0 14px #2849a888}.cs-faction-btn.red.active{border-color:var(--gilt-bright);color:#ffe6dc;text-shadow:0 1px 2px #2a0607;background:radial-gradient(at 50% 28%,#c8323a 0%,#7a161a 68%,#5a0e10 100%);box-shadow:inset 0 1px #ff8a6e88,0 0 14px #b8232a88}.cs-setup-row{flex-wrap:wrap;justify-content:center;align-items:center;gap:22px;margin-top:7px;display:flex}.cs-setup-row .cs-faction,.cs-setup-row .cs-difficulty{margin-top:0}.csm-setup-row{flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;padding:0 10px 6px;display:flex}.csm-setup-row .csm-difficulty{margin-top:0}.csm-setup-row .csm-faction-btn{padding:4px 9px;font-size:.72rem}.csm-setup-row .csm-diff-btn{padding:4px 8px;font-size:.66rem}.csm-setup-row .csm-faction-label{letter-spacing:.08em}.cs-difficulty{flex-wrap:wrap;justify-content:center;align-items:center;gap:6px;margin-top:7px;display:inline-flex}.cs-diff-btn{font-family:var(--font-engrave);letter-spacing:.12em;border:1px solid var(--brass);color:var(--ink-faint);cursor:pointer;background:linear-gradient(#2a1c0e 0%,#160c05 100%);border-radius:3px;padding:4px 12px;font-size:.7rem;font-weight:700;transition:all .16s}.cs-diff-btn:hover:not(.active){color:var(--gilt-bright);border-color:var(--gilt)}.cs-diff-btn.active{border-color:var(--gilt-bright);color:#fff6dc;background:linear-gradient(#b8923c 0%,#6b4d12 100%);box-shadow:inset 0 1px #ffe9a8,0 0 12px #c8a24e88}.csm-difficulty{flex-wrap:wrap;align-items:center;gap:5px;margin-top:6px;display:flex}.csm-faction-label{font-family:var(--font-kai);letter-spacing:.16em;color:var(--gilt);font-size:.7rem}.csm-diff-btn{border:1px solid var(--brass);color:var(--ink-faint);cursor:pointer;background:#160c05;border-radius:4px;padding:5px 11px;font-size:.72rem}.csm-diff-btn.active{border-color:var(--gilt-bright);color:#fff6dc;background:linear-gradient(#b8923c 0%,#6b4d12 100%)}.cs-book-stage{perspective:2600px;perspective-origin:50% 38%;width:min(92vw,1040px);min-height:0;margin:0 auto;position:relative}.cs-book{background:var(--tex-leather), linear-gradient(180deg, #4a2c14 0%, #38200e 100%);background-blend-mode:overlay, normal;width:100%;height:100%;transform-style:preserve-3d;background-size:220px 220px,cover;border:1px solid #160c05;border-radius:6px 10px 10px 6px;grid-template-columns:1fr 1fr;padding:10px;display:grid;position:relative;box-shadow:inset 0 0 0 2px #6c4a2855,inset 0 0 40px #160c0577,0 22px 60px #000000c0,0 0 0 1px #07040188}.cs-book:before,.cs-book:after{content:"";z-index:0;background:repeating-linear-gradient(90deg,#d8c79c 0 1px,#b89a64 1px 2px,#e8dcbc 2px 3px);width:12px;position:absolute;top:14px;bottom:14px;box-shadow:0 4px 10px #0006}.cs-book:before{border-radius:4px 0 0 4px;left:-8px;transform:skewY(.6deg)}.cs-book:after{border-radius:0 4px 4px 0;right:-8px;transform:skewY(-.6deg)}.cs-page-half{color:var(--ink);background:radial-gradient(circle at 12% 88%,#8a602033 0%,#0000 24%),radial-gradient(circle at 90% 10%,#8a602026 0%,#0000 20%),radial-gradient(at 38% 26%,#f0e4c2 0%,#e3d09c 46%,#cdb277 80%,#b0915a 100%);padding:22px 30px 16px;position:relative;overflow:hidden}.cs-page-left{border-radius:3px 0 0 3px;flex-direction:column;display:flex}.cs-page-right{border-radius:0 3px 3px 0;flex-direction:column;display:flex}.cs-page-half:before{content:"";pointer-events:none;background:var(--tex-fiber), radial-gradient(circle at 22% 38%, #6b452022 0%, transparent 1.4%), radial-gradient(circle at 68% 72%, #8a602026 0%, transparent 1.1%), radial-gradient(circle at 86% 32%, #6b452020 0%, transparent 1.6%), radial-gradient(circle at 14% 64%, #8a602022 0%, transparent 1%);mix-blend-mode:multiply;opacity:.7;background-size:cover,auto,auto,auto,auto;position:absolute;top:0;bottom:0;left:0;right:0}.cs-page-half:after{content:"";pointer-events:none;mix-blend-mode:multiply;background:radial-gradient(at 0 0,#4a280f99 0%,#0000 15%),radial-gradient(at 100% 0,#4a280f99 0%,#0000 15%),radial-gradient(at 0 100%,#4a280f99 0%,#0000 17%),radial-gradient(at 100% 100%,#4a280f99 0%,#0000 17%),radial-gradient(#0000 62%,#3a1d0a3a 100%);position:absolute;top:0;bottom:0;left:0;right:0}.cs-page-left{box-shadow:inset -26px 0 36px -16px #160c05b0}.cs-page-right{box-shadow:inset 26px 0 36px -16px #160c05b0}.cs-page-half>*{z-index:1;position:relative}.cs-page-right>*{flex-shrink:0}.cs-gutter{z-index:11;pointer-events:none;background:linear-gradient(90deg,#0000 0%,#160c0544 16%,#160c05cc 46%,#160c05ee 50%,#160c05cc 54%,#160c0544 84%,#0000 100%);width:30px;position:absolute;top:10px;bottom:10px;left:50%;transform:translate(-50%)}.cs-gutter:before{content:"";background:linear-gradient(90deg,#0000 44%,#6c4a2866 49%,#1a0e04 50%,#6c4a2866 51%,#0000 56%);position:absolute;top:0;bottom:0;left:0;right:0}.cs-gutter-deco{background:linear-gradient(#f0d488 0%,#8a6a32 100%);border-radius:2px;width:12px;height:9px;position:absolute;left:50%;transform:translate(-50%);box-shadow:0 1px 2px #160c05,inset 0 1px #fff3c8aa}.cs-gutter-deco.top{top:11%}.cs-gutter-deco.bot{bottom:11%}.cs-page-num{font-family:var(--font-body);color:var(--ink-soft);letter-spacing:.18em;border-bottom:1px solid #8a602055;justify-content:space-between;align-items:baseline;margin-bottom:10px;padding-bottom:6px;font-size:.74rem;display:flex}.cs-page-num-folio{letter-spacing:.1em;color:var(--ink-faint);font-style:italic}.cs-portrait-frame{background:radial-gradient(at 50% 34%,#1c2f58 0%,#0e1838 58%,#060a1c 100%);border-radius:3px;flex:auto;width:92%;height:auto;min-height:0;margin:0 auto;position:relative;overflow:hidden;box-shadow:inset 0 0 0 1px #160c05,inset 0 0 40px #03050caa,0 4px 14px #0008}.cs-portrait-frame:before{content:"";z-index:3;pointer-events:none;border:1px solid #c8a24e88;border-radius:2px;position:absolute;top:7px;bottom:7px;left:7px;right:7px;box-shadow:inset 0 0 0 3px #0003,inset 0 0 0 4px #6b4d1255}.cs-portrait{filter:drop-shadow(0 8px 18px #0009);z-index:2;background-position:50% 6%;background-repeat:no-repeat;background-size:contain;position:absolute;top:0;bottom:0;left:0;right:0}.cs-portrait-frame .cs-portrait-glow{z-index:1;background:radial-gradient(at 50% 30%,#ffffff14 0%,#0000 46%),radial-gradient(at 50% 96%,#03050cdd 0%,#0000 40%);position:absolute;top:0;bottom:0;left:0;right:0}.cs-photo-corner{z-index:4;pointer-events:none;background:linear-gradient(135deg,#3a2a10 0%,#1a1006 100%);width:22px;height:22px;position:absolute;box-shadow:inset 0 0 0 1px #c8a24e66}.cs-photo-corner.tl{clip-path:polygon(0 0,100% 0,0 100%);top:6px;left:6px}.cs-photo-corner.tr{clip-path:polygon(0 0,100% 0,100% 100%);top:6px;right:6px}.cs-photo-corner.bl{clip-path:polygon(0 0,0 100%,100% 100%);bottom:6px;left:6px}.cs-photo-corner.br{clip-path:polygon(100% 0,100% 100%,0 100%);bottom:6px;right:6px}.cs-page-name-block{text-align:center;margin-top:12px;position:relative}.cs-page-name-block:before,.cs-page-name-block:after{content:"";background:linear-gradient(90deg,#0000,#8a6020);width:16%;height:1px;position:absolute;top:14px}.cs-page-name-block:before{left:6%}.cs-page-name-block:after{background:linear-gradient(270deg,#0000,#8a6020);right:6%}.cs-page-fullname{font-family:var(--font-kai);color:var(--ink);letter-spacing:.1em;text-shadow:0 1px #f0e4c2;font-size:1.5rem;font-weight:700}.cs-page-roman{font-family:var(--font-italic);color:var(--ink-soft);letter-spacing:.06em;margin-top:2px;font-size:.9rem;font-style:italic}.cs-page-seal{z-index:5;text-align:center;color:#ffe6c0;width:76px;height:76px;font-family:var(--font-engrave);letter-spacing:.06em;opacity:0;pointer-events:none;background:radial-gradient(circle at 38% 32%,#c8323a 0%,#8a161a 52%,#5a0e10 100%);border-radius:50%;place-content:center;font-size:.62rem;font-weight:700;line-height:1.3;transition:transform .4s cubic-bezier(.34,1.56,.64,1),opacity .3s;display:grid;position:absolute;bottom:92px;right:22px;transform:rotate(-9deg)scale(.4);box-shadow:inset 0 2px 4px #ff8a6e55,inset 0 -3px 6px #2a060788,0 3px 8px #0009}.cs-page-seal:before{content:"";border:1px dashed #ffd0b088;border-radius:50%;position:absolute;top:7px;bottom:7px;left:7px;right:7px}.cs-page-seal.shown{opacity:.96;transform:rotate(-9deg)scale(1)}.cs-page-seal small{letter-spacing:.18em;opacity:.8;margin-top:2px;font-size:.5rem;display:block}.cs-page-chapter{font-family:var(--font-engrave);color:var(--ink-soft);letter-spacing:.18em;text-transform:uppercase;border-bottom:1px solid #8a602055;justify-content:space-between;align-items:baseline;margin-bottom:10px;padding-bottom:6px;font-size:.78rem;display:flex}.cs-page-chapter-zh{font-family:var(--font-kai);letter-spacing:.1em;color:var(--oxblood)}.cs-page-flavor{font-family:var(--font-cn);color:var(--oxblood);letter-spacing:.04em;text-align:center;margin:2px 0 10px;padding:6px 26px 8px;font-size:1.02rem;font-weight:500;line-height:1.6;position:relative}.cs-page-flavor:before,.cs-page-flavor:after{color:#b8923c;font-family:Cormorant Garamond,serif;font-size:1.9rem;line-height:0;position:absolute}.cs-page-flavor:before{content:"“";top:16px;left:6px}.cs-page-flavor:after{content:"”";bottom:2px;right:6px}.cs-page-section-title{font-family:var(--font-engrave);letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);align-items:center;gap:10px;margin:10px 0 7px;font-size:.72rem;display:flex}.cs-page-section-title:before,.cs-page-section-title:after{content:"";background:linear-gradient(90deg,#0000,#8a6020aa,#0000);flex:1;height:1px}.cs-page-section-title-zh{font-family:var(--font-kai);letter-spacing:.14em;color:var(--oxblood);font-size:.92rem}.cs-page-stats{background:#00000008;border:1px solid #8a602066;border-radius:2px;grid-template-columns:repeat(4,1fr);display:grid;overflow:hidden}.cs-page-stat{border-bottom:1px solid #8a602033;border-right:1px solid #8a602033;flex-direction:column;align-items:center;gap:1px;padding:6px 4px;display:flex}.cs-page-stat:nth-child(4n){border-right:none}.cs-page-stat:nth-last-child(-n+4){border-bottom:none}.cs-page-stat-label{font-family:var(--font-engrave);letter-spacing:.12em;color:var(--ink-faint);font-size:.6rem}.cs-page-stat-val{font-family:var(--font-body);color:var(--ink);font-size:1.05rem;font-weight:600}.cs-page-skills{gap:7px;display:grid}.cs-page-skill{background:#00000008;border:1px solid #8a602044;border-radius:2px;padding:6px 10px 6px 14px;position:relative}.cs-page-skill:before{content:"";background:linear-gradient(180deg, var(--gilt), var(--gilt-deep));width:3px;position:absolute;top:6px;bottom:6px;left:0}.cs-page-skill-header{align-items:baseline;gap:8px;margin-bottom:3px;display:flex}.cs-page-skill-type{font-family:var(--font-engrave);letter-spacing:.1em;color:#fff3e0;white-space:nowrap;background:linear-gradient(#8a161a,#5a0e10);border-radius:2px;padding:1px 6px;font-size:.62rem}.cs-page-skill-name{font-family:var(--font-kai);color:var(--ink);font-size:.98rem;font-weight:700}.cs-page-skill-desc{font-family:var(--font-cn);color:var(--ink-soft);margin:0;font-size:.8rem;line-height:1.5}.cs-page-enlist{margin-top:10px}.cs-enlist-prompt{text-align:center;font-family:var(--font-kai);letter-spacing:.12em;color:var(--ink-soft);margin-bottom:9px;font-size:.92rem}.cs-enlist-prompt strong{color:var(--oxblood);font-weight:700}.cs-enlist-actions{grid-template-columns:auto 1fr;align-items:stretch;gap:10px;display:grid}.cs-enlist-back{font-family:var(--font-cn);letter-spacing:.04em;border:1px solid var(--brass-dark);color:var(--ivory-soft);cursor:pointer;white-space:nowrap;background:linear-gradient(#2a1c0e 0%,#160c05 100%);border-radius:3px;padding:10px 14px;font-size:.82rem;transition:all .16s;box-shadow:inset 0 1px #6c4a2855}.cs-enlist-back:hover:not(:disabled){border-color:var(--gilt);color:var(--gilt-bright);box-shadow:inset 0 1px #6c4a2855,0 0 10px #c8a24e44}.cs-enlist-back:disabled{opacity:.32;cursor:default}.cs-enlist-cta{font-family:var(--font-engrave);letter-spacing:.16em;border:1px solid var(--gilt);cursor:pointer;border-radius:3px;padding:10px 16px;font-size:1.02rem;font-weight:700;transition:all .18s}.cs-enlist-cta:disabled{opacity:1;filter:none;cursor:default}.cs-enlist-select{color:#fff3e0;border-color:var(--gilt-bright);text-shadow:0 1px 2px #2a0607;background:radial-gradient(at 50% 25%,#c8323a 0%,#7a161a 68%,#5a0e10 100%);box-shadow:inset 0 1px #ff8a6e55,0 0 14px #b8232a55,0 2px 6px #0006}.cs-enlist-select:hover{transform:translateY(-1px);box-shadow:inset 0 1px #ff8a6e88,0 0 22px #d44a4577,0 3px 8px #0008}.cs-enlist-chosen{color:var(--gilt-bright);border-color:var(--gilt-deep);background:linear-gradient(#6b4d12 0%,#3a2a08 100%);box-shadow:inset 0 1px #c8a24e55}.cs-enlist-ready{color:var(--ink-faint);border-color:var(--brass-dark);background:linear-gradient(#2a1c0e 0%,#160c05 100%)}.cs-fleet-slot.targeting{border-color:var(--gilt-bright);animation:1.9s ease-in-out infinite cs-target-pulse}.cs-fleet-slot.targeting .cs-fleet-slot-label{color:var(--gilt-bright)}.cs-fleet-slot.targeting .cs-fleet-slot-name{color:var(--gilt-bright);font-style:italic}@keyframes cs-target-pulse{0%,to{box-shadow:inset 0 1px #6c4a2855,0 0 0 1px #f0d48844,0 0 10px #c8a24e44}50%{box-shadow:inset 0 1px #6c4a2855,0 0 0 1px #f0d488aa,0 0 18px #c8a24e88}}.cs-page-foot{text-align:center;font-family:var(--font-engrave);letter-spacing:.34em;text-transform:uppercase;color:var(--ink-faint);margin-top:auto;padding-top:10px;font-size:.62rem;position:relative}.cs-page-foot:before{content:"";background:linear-gradient(90deg,#0000,#8a6020aa,#0000);width:46%;height:1px;margin:0 auto 8px;display:block}.cs-page-foot span{color:var(--oxblood);letter-spacing:.2em}.cs-page-flipper{z-index:10;width:calc(50% - 10px);transform-style:preserve-3d;will-change:transform;pointer-events:none;transition:transform .82s cubic-bezier(.46,.03,.28,1);position:absolute;top:10px;bottom:10px}.cs-page-flipper.next{transform-origin:0;right:10px;transform:rotateY(0)}.cs-page-flipper.next.flipping{transform:rotateY(-180deg)}.cs-page-flipper.prev{transform-origin:100%;left:10px;transform:rotateY(0)}.cs-page-flipper.prev.flipping{transform:rotateY(180deg)}.cs-flip-side{-webkit-backface-visibility:hidden;backface-visibility:hidden;position:absolute;top:0;bottom:0;left:0;right:0;overflow:hidden}.cs-flip-back{transform:rotateY(180deg)}.cs-flip-shade{z-index:9;pointer-events:none;opacity:0;position:absolute;top:0;bottom:0;left:0;right:0}.cs-page-flipper.next.flipping .cs-flip-front .cs-flip-shade{background:linear-gradient(90deg,#160c0500 0%,#160c0555 64%,#160c05cc 100%);animation:.82s cubic-bezier(.46,.03,.28,1) forwards cs-shade-away}.cs-page-flipper.prev.flipping .cs-flip-front .cs-flip-shade{background:linear-gradient(270deg,#160c0500 0%,#160c0555 64%,#160c05cc 100%);animation:.82s cubic-bezier(.46,.03,.28,1) forwards cs-shade-away}.cs-page-flipper.next.flipping .cs-flip-back .cs-flip-shade{background:linear-gradient(270deg,#160c0500 0%,#160c0588 100%);animation:.82s cubic-bezier(.46,.03,.28,1) forwards cs-shade-rest}.cs-page-flipper.prev.flipping .cs-flip-back .cs-flip-shade{background:linear-gradient(90deg,#160c0500 0%,#160c0588 100%);animation:.82s cubic-bezier(.46,.03,.28,1) forwards cs-shade-rest}@keyframes cs-shade-away{0%{opacity:0}to{opacity:1}}@keyframes cs-shade-rest{0%{opacity:1}50%{opacity:.92}to{opacity:0}}.cs-flip-side{will-change:transform}.cs-nav-btn{z-index:12;border:1px solid var(--gilt);background:var(--brass-surface);width:46px;height:120px;color:var(--gilt-bright);cursor:pointer;border-radius:6px;justify-content:center;align-items:center;font-size:1.6rem;line-height:1;transition:background .18s,box-shadow .18s,color .18s;display:flex;position:absolute;top:50%;transform:translateY(-50%);box-shadow:inset 0 1px #f0d48866,0 4px 12px #0009}.cs-nav-btn:active:not(:disabled){transform:translateY(-50%)scale(.96)}.cs-nav-btn:hover{color:#fff6dc;background:linear-gradient(#b8923c,#6b4d12);box-shadow:0 0 16px #c8a24e88,0 4px 12px #0009}.cs-nav-btn:disabled{opacity:.3;cursor:default}.cs-nav-prev{left:-26px}.cs-nav-next{right:-26px}.cs-footer{grid-template-columns:1fr auto;align-items:end;gap:14px;display:grid}.cs-tabs{flex-wrap:wrap;align-items:flex-end;gap:5px;display:flex}.cs-tab{background:var(--tex-paper), linear-gradient(180deg, #cdb277 0%, #a8895180 100%);background-blend-mode:multiply, normal;color:var(--ink-soft);cursor:pointer;background-size:200px 200px,cover;border:1px solid #160c05;border-bottom:none;border-radius:5px 5px 0 0;gap:1px;padding:6px 11px 8px;transition:all .18s;display:grid;position:relative;top:6px;box-shadow:inset 0 1px #f0e4c266}.cs-tab:hover{color:var(--ink);top:2px}.cs-tab.current{background:var(--tex-paper), linear-gradient(180deg, #f0e4c2 0%, #ddca9c 100%);background-blend-mode:multiply, normal;border-color:var(--gilt);background-size:200px 200px,cover;top:0;box-shadow:inset 0 1px #fff6e0,0 -2px 8px #0004}.cs-tab.current .cs-tab-name{color:var(--oxblood)}.cs-tab.assigned{box-shadow:inset 0 2px 0 var(--oxblood-bright), inset 0 1px 0 #f0e4c266}.cs-tab-no{font-family:var(--font-body);letter-spacing:.08em;font-size:.6rem;font-style:italic}.cs-tab-name{font-family:var(--font-kai);color:var(--ink);font-size:.88rem;font-weight:700}.cs-fleet-bar{grid-template-columns:repeat(3,auto) auto;grid-auto-flow:column;align-items:center;gap:10px;display:grid}.cs-fleet-slot{border:1px solid var(--brass-dark);background:linear-gradient(#2a1c0e 0%,#160c05 100%);border-radius:40px 4px 4px 40px;align-items:center;gap:7px;padding:5px 10px 5px 6px;display:flex;position:relative;box-shadow:inset 0 1px #6c4a2855}.cs-fleet-slot.filled{border-color:var(--gilt);box-shadow:inset 0 1px #6c4a2855,0 0 12px #c8a24e33}.cs-fleet-slot-icon{border:1px solid var(--brass-dark);background:#07040188 50%/cover no-repeat;border-radius:50%;flex:none;width:36px;height:36px;box-shadow:inset 0 0 0 1px #160c05}.cs-fleet-slot.filled .cs-fleet-slot-icon{border-color:var(--gilt-bright)}.cs-fleet-slot-meta{flex-direction:column;line-height:1.15;display:flex}.cs-fleet-slot-label{font-family:var(--font-engrave);letter-spacing:.08em;color:var(--gilt);font-size:.64rem;display:block}.cs-fleet-slot-name{font-family:var(--font-kai);color:var(--ivory-soft);font-size:.94rem;font-weight:700}.cs-fleet-slot.filled .cs-fleet-slot-name{color:var(--gilt-bright)}.cs-launch{border:1px solid var(--gilt);min-width:130px;color:var(--ink-faint);font-family:var(--font-engrave);letter-spacing:.34em;cursor:not-allowed;background:linear-gradient(#3a2410 0%,#1a1006 100%);border-radius:4px;padding:12px 26px;font-size:1.15rem;font-weight:800;transition:all .22s;position:relative;overflow:hidden;box-shadow:inset 0 1px #6c4a2855,0 4px 12px #0009}.cs-launch:disabled{cursor:not-allowed}.cs-launch-text{z-index:2;position:relative}.cs-launch.ready{cursor:pointer;color:#fff6dc;border-color:var(--gilt-bright);text-shadow:0 1px 2px #2a0607;background:radial-gradient(at 50% 30%,#c8323a 0%,#8a161a 60%,#5a0e10 100%);animation:2.4s ease-in-out infinite cs-launch-pulse;box-shadow:inset 0 1px #ff8a6e66,0 0 20px #b8232a77,0 4px 14px #0009}.cs-launch.ready:hover{transform:translateY(-1px);box-shadow:inset 0 1px #ff8a6e88,0 0 28px #d44a4599,0 6px 18px #000a}.cs-launch-glow{z-index:1;opacity:0;background:linear-gradient(90deg,#0000,#fff3c855,#0000);position:absolute;top:0;bottom:0;left:0;right:0;transform:translate(-120%)}.cs-launch.ready .cs-launch-glow{opacity:1;animation:2.8s ease-in-out infinite cs-launch-sweep}@keyframes cs-launch-pulse{0%,to{box-shadow:inset 0 1px #ff8a6e66,0 0 18px #b8232a66,0 4px 14px #0009}50%{box-shadow:inset 0 1px #ff8a6e88,0 0 30px #d44a45aa,0 4px 14px #0009}}@keyframes cs-launch-sweep{0%{transform:translate(-120%)}60%,to{transform:translate(120%)}}.cs-mode-links{z-index:4;justify-content:center;gap:18px;margin-top:2px;display:flex}.cs-mode-link{font-family:var(--font-body);letter-spacing:.18em;color:var(--gilt);border-bottom:1px solid #0000;font-size:.74rem;text-decoration:none;transition:all .16s}.cs-mode-link:hover{color:var(--gilt-bright);border-bottom-color:var(--gilt)}button.cs-mode-link{-webkit-appearance:none;appearance:none;cursor:pointer;background:0 0;border:0;border-bottom:1px solid #0000;padding:0}.csm{height:100vh;flex-direction:column;height:100dvh;display:flex;bottom:auto;overflow:hidden}.csm-top{padding:calc(env(safe-area-inset-top,0px) + 8px) 12px 8px;z-index:3;flex:none;justify-content:space-between;align-items:center;gap:10px;display:flex}.csm-back{font-family:var(--font-cn);color:var(--gilt-pale);border:1px solid var(--brass-dark);background:#160c05aa;border-radius:999px;padding:7px 16px;font-size:.9rem;text-decoration:none}.csm-random{-webkit-appearance:none;appearance:none;font-family:var(--font-cn);color:var(--gilt-pale);border:1px solid var(--brass);cursor:pointer;background:#160c05aa;border-radius:999px;padding:7px 14px;font-size:.84rem}.csm-faction{gap:6px;display:flex}.csm-faction-btn{border:1px solid var(--brass-dark);color:var(--text-soft);font-family:var(--font-cn);background:#160c05aa;border-radius:999px;padding:7px 15px;font-size:.84rem}.csm-faction-btn.blue.active{color:#fff;background:var(--navy-mid);border-color:var(--navy-edge)}.csm-faction-btn.red.active{color:#fff;background:var(--oxblood);border-color:var(--oxblood-bright)}.csm-stage{touch-action:pan-y;flex:auto;min-height:0;position:relative;overflow:hidden}.csm-track{will-change:transform;transition:transform .34s cubic-bezier(.22,.61,.36,1);display:flex;position:absolute;top:0;bottom:0;left:0;right:0}.csm-track.csm-dragging{transition:none}.csm-slide{flex:0 0 100%;height:100%;position:relative}.csm-portrait{filter:drop-shadow(0 10px 26px #0009);background-position:50% 6%;background-repeat:no-repeat;background-size:contain;position:absolute;top:0;bottom:0;left:0;right:0}.csm-arrow{z-index:2;border:1px solid var(--brass-dark);width:40px;height:66px;color:var(--gilt-bright);background:#160c0599;border-radius:8px;font-size:1.8rem;line-height:1;position:absolute;top:46%;transform:translateY(-50%)}.csm-arrow:active:not(:disabled){border-color:var(--gilt-bright);color:#fff6dc;box-shadow:none;background:linear-gradient(#8a6a32,#5a3c16);transform:translateY(-50%)scale(.93)}.csm-prev{left:6px}.csm-next{right:6px}.csm-caption{z-index:2;text-align:center;pointer-events:none;background:linear-gradient(#0000,#05091af2 78%);padding:30px 16px 10px;position:absolute;bottom:0;left:0;right:0}.csm-idx{font-family:var(--font-body);letter-spacing:.24em;color:var(--gilt);font-size:.72rem}.csm-name{font-family:var(--font-kai);color:var(--ivory);text-shadow:0 2px 6px #000;white-space:nowrap;text-overflow:ellipsis;font-size:1.5rem;font-weight:800;overflow:hidden}.csm-title{font-family:var(--font-cn);color:var(--gilt-pale);letter-spacing:.06em;white-space:nowrap;text-overflow:ellipsis;font-size:.84rem;overflow:hidden}.csm-slide.is-assigned:after{content:"已编入";z-index:2;background:var(--gilt-bright);color:#160c05;font-family:var(--font-cn);letter-spacing:.12em;border-radius:999px;padding:3px 14px;font-size:.68rem;position:absolute;top:8px;left:50%;transform:translate(-50%)}.csm-info{flex:none;padding:8px 12px 0}.csm-dots{justify-content:center;gap:7px;margin-bottom:8px;display:flex}.csm-dot{background:#6c4a2877;border:none;border-radius:50%;width:8px;height:8px;padding:0}.csm-dot.active{background:var(--gilt-bright);box-shadow:0 0 8px var(--gilt)}.csm-stats{grid-template-columns:repeat(4,1fr);gap:6px;display:grid}.csm-chip{border:1px solid var(--brass-dark);background:linear-gradient(#2a1c0e,#160c05);border-radius:6px;flex-direction:column;align-items:center;gap:1px;padding:5px 3px;display:flex}.csm-chip span{color:var(--text-soft);letter-spacing:.02em;font-size:.6rem}.csm-chip strong{font-family:var(--font-engrave);color:var(--gilt-bright);font-size:.92rem}.csm-skills{grid-template-columns:1fr 1fr;gap:6px;margin-top:8px;display:grid}.csm-skill{text-align:left;border:1px solid var(--brass-dark);color:var(--gilt-pale);background:#160c0566;border-radius:6px;padding:6px 9px}.csm-skill-head{white-space:nowrap;align-items:baseline;gap:6px;display:flex;overflow:hidden}.csm-skill-tag{color:var(--oxblood-bright);letter-spacing:.06em;flex:none;font-size:.6rem}.csm-skill-name{text-overflow:ellipsis;min-width:0;font-family:var(--font-kai);color:var(--gilt-pale);flex:1;font-size:.84rem;overflow:hidden}.csm-skill-desc{-webkit-line-clamp:4;min-height:5.8em;color:var(--text-soft);-webkit-box-orient:vertical;margin:5px 0 0;font-size:.72rem;line-height:1.45;display:-webkit-box;overflow:hidden}.csm-bar{padding:10px 12px calc(env(safe-area-inset-bottom,0px) + 12px);border-top:1px solid var(--brass-dark);background:var(--leather-surface);flex:none;align-items:center;gap:10px;margin-top:8px;display:flex}.csm-fleet{flex:none;gap:8px;display:flex}.csm-slot{border:1px solid var(--brass-dark);background:#160c05;border-radius:10px;width:46px;height:46px;padding:0;position:relative;overflow:hidden}.csm-slot-icon{background:50% 16%/cover no-repeat;position:absolute;top:0;bottom:0;left:0;right:0}.csm-slot-label{z-index:1;text-align:center;color:var(--gilt-pale);background:#160c05cc;padding:1px 0;font-size:.56rem;position:absolute;bottom:0;left:0;right:0}.csm-slot.filled{border-color:var(--gilt)}.csm-slot.targeting{border-color:var(--gilt-bright);box-shadow:0 0 0 2px var(--gilt-bright), 0 0 12px #c8a24e88}.csm-cta{border:1px solid var(--gilt);min-height:50px;font-family:var(--font-engrave);letter-spacing:.2em;color:var(--gilt-pale);background:linear-gradient(#3a2410,#1a1006);border-radius:10px;flex:auto;font-size:1.05rem;font-weight:800}.csm-cta.select{color:#fff6dc;background:linear-gradient(#8a6a32,#5a3c16)}.csm-cta.ready{color:#fff6dc;border-color:var(--gilt-bright);background:radial-gradient(at 50% 30%,#c8323a,#8a161a 60%,#5a0e10);box-shadow:0 0 18px #c8323a88}@media (max-height:560px){.csm{grid-template:"top top""stage info"minmax(0,1fr)"stage bar"/1.05fr 1fr;display:grid}.csm-top{grid-area:top}.csm-stage{grid-area:stage}.csm-info{grid-area:info;min-height:0;padding-bottom:8px;overflow-y:auto}.csm-bar{grid-area:bar;margin-top:0}.csm-caption{padding-bottom:8px}.csm-name{font-size:1.2rem}.csm-skills{grid-template-columns:1fr 1fr}}.mpage{height:100vh;z-index:1;background:radial-gradient(120% 90% at 50% 0,#122050 0%,#0a1430 44%,#05091a 100%);flex-direction:column;height:100dvh;display:flex;position:fixed;top:0;bottom:auto;left:0;right:0;overflow:hidden}.mpage-top{padding:calc(env(safe-area-inset-top,0px) + 12px) 14px 8px;flex:none;align-items:center;gap:12px;display:flex}.mpage-back{border:1px solid var(--brass);width:40px;height:40px;color:var(--gilt-pale);background:#160c0588;border-radius:50%;flex:none;justify-content:center;align-items:center;font-size:1.4rem;text-decoration:none;display:inline-flex}.mpage-title{font-family:var(--font-title);letter-spacing:.08em;background:var(--gilt-foil);color:#0000;filter:drop-shadow(0 1px #160c05);-webkit-background-clip:text;background-clip:text;margin:0;font-size:1.5rem;font-weight:900}.mpage-body{min-height:0;padding:6px 16px calc(env(safe-area-inset-bottom,0px) + 18px);flex-direction:column;flex:auto;gap:14px;display:flex;overflow-y:auto}.mfield{flex-direction:column;gap:8px;display:flex}.mfield-label{font-family:var(--font-cn);letter-spacing:.06em;color:var(--gilt-pale);font-size:.84rem}.mfield input{border-radius:10px;width:100%;padding:13px 14px;font-size:1rem}.m-faction{grid-template-columns:1fr 1fr;gap:10px;display:grid}.m-faction .pv-faction-btn{border-radius:10px;padding:14px 0;font-size:1rem}.m-guide-item{border:1px solid var(--brass-dark);background:#160c0566;border-radius:8px;padding:12px 14px}.m-guide-item h3{font-family:var(--font-engrave);letter-spacing:.06em;color:var(--gilt-bright);margin:0 0 5px;font-size:1rem}.m-guide-item p{font-family:var(--font-cn);color:var(--text-soft);margin:0;font-size:.82rem;line-height:1.55}.m-guide-sub{font-family:var(--font-engrave);letter-spacing:.1em;color:var(--gilt-bright);margin:6px 0 0;font-size:1.05rem}.m-guide-key{border:1px solid var(--brass-dark);background:#160c0544;border-radius:8px;align-items:center;gap:12px;padding:9px 12px;display:flex}.m-guide-key kbd{font-family:var(--font-body);color:var(--gilt-pale);border:1px solid var(--brass-dark);white-space:nowrap;background:#0c1430;border-radius:5px;padding:3px 9px;font-size:.76rem}.m-guide-key span{font-family:var(--font-cn);color:var(--text-soft);font-size:.84rem}.ts-stage.mmenu{min-height:100vh;height:100vh;min-height:100dvh;flex-direction:column;height:100dvh;display:flex}.mmenu .mmenu-hero{opacity:1;flex:auto;width:100%;min-height:150px;position:relative;top:auto;bottom:auto;left:auto;right:auto}.mmenu .ts-hero-img{opacity:1;-webkit-mask-image:linear-gradient(#000 64%,#0000 100%);mask-image:linear-gradient(#000 64%,#0000 100%)}.mmenu-shell{z-index:2;min-height:0;padding:calc(env(safe-area-inset-top,0px) + 16px) 18px calc(env(safe-area-inset-bottom,0px) + 14px);flex-direction:column;flex:auto;gap:10px;display:flex;position:relative}.mmenu-head{text-align:center;flex-direction:column;align-items:center;gap:4px;display:flex}.mmenu-list{gap:9px}.mmenu-foot{text-align:center;font-family:var(--font-cn);letter-spacing:.12em;color:var(--text-muted);font-size:.7rem}.mmenu .ts-item{border:1px solid var(--brass-dark);background:#160c05aa;border-radius:12px;padding:11px 18px}.mmenu .ts-item-no{color:var(--gilt)}.mmenu .ts-item-label{font-size:1.3rem}.mmenu .ts-item-sub{display:none}.mmenu .ts-item-cue{opacity:1;transform:none}@media (max-height:560px){.mmenu-head .ts-subtitle,.mmenu .mmenu-hero{display:none}.mmenu .mmenu-list{grid-template-columns:1fr 1fr;gap:8px;margin-top:12px;display:grid}.mmenu .ts-item{padding:10px 14px}.mmenu .ts-item-label{font-size:1.1rem}.mmenu .ts-item-sub{display:none}}.app-root{min-height:100vh;min-height:100dvh}.boot-splash{min-height:100vh;font-family:var(--font-engrave);letter-spacing:.34em;color:var(--text-muted);place-content:center;display:grid}.ts-stage{background:radial-gradient(120% 90% at 78% 16%,#1a2c64 0%,#0c1738 38%,#05091a 78%,#03060f 100%);min-height:100vh;position:relative;overflow:hidden}.ts-faction-red{background:radial-gradient(120% 90% at 78% 16%,#4a1726 0%,#2a0c1c 40%,#14060f 80%,#0a040a 100%)}.ts-bg{z-index:0;width:100%;height:100%;position:absolute;top:0;bottom:0;left:0;right:0}.ts-vignette{z-index:1;pointer-events:none;background:var(--tex-grain), radial-gradient(ellipse at 32% 50%, transparent 40%, #03060ccc 100%);mix-blend-mode:soft-light;opacity:.6;background-size:180px 180px,cover;position:absolute;top:0;bottom:0;left:0;right:0}.ts-hero{z-index:1;pointer-events:none;width:min(62%,880px);position:absolute;top:0;bottom:0;right:0}.ts-hero-img{opacity:.96;width:100%;height:100%;position:absolute;top:0;bottom:0;left:0;right:0;-webkit-mask-image:linear-gradient(90deg,#0000 0%,#000 16%);mask-image:linear-gradient(90deg,#0000 0%,#000 16%)}.ts-content{z-index:2;flex-direction:column;justify-content:center;gap:34px;width:min(560px,94%);min-height:100vh;padding:48px clamp(24px,6vw,82px);display:flex;position:relative}.ts-seal{filter:drop-shadow(0 2px #160c05)drop-shadow(0 6px 14px #02060eb0);background:url(/assets/brand/sos-gold.png) 50%/contain no-repeat;width:62px;height:75px;margin-bottom:8px}.ts-title{font-family:var(--font-title);letter-spacing:.06em;background:var(--gilt-foil);color:#0000;filter:drop-shadow(0 2px #160c05)drop-shadow(0 6px 16px #02060e);-webkit-background-clip:text;background-clip:text;margin:0;font-size:clamp(2.8rem,7vw,4.6rem);font-weight:900;line-height:1.02}.ts-subtitle{font-family:var(--font-italic);letter-spacing:.22em;color:var(--text-soft);margin:10px 0 0;font-size:1.05rem;font-style:italic}.ts-rule{background:linear-gradient(90deg, var(--gilt-bright), var(--gilt) 42%, transparent);width:210px;height:2px;margin-top:16px;box-shadow:0 1px 3px #02060e}.ts-menu{flex-direction:column;gap:4px;display:flex}.ts-item{cursor:pointer;border-left:2px solid #0000;border-radius:8px;align-items:center;gap:16px;padding:13px 18px 13px 14px;text-decoration:none;transition:background .18s,border-color .18s,transform .18s;display:flex;position:relative}.ts-item:focus{outline:none}.ts-item:hover{border-left-color:var(--gilt);background:linear-gradient(90deg,#f0d4881f,#0000 82%);transform:translate(6px)}.ts-item:focus-visible{border-left-color:var(--gilt);background:linear-gradient(90deg,#f0d4881f,#0000 82%);transform:translate(6px)}.ts-item-no{font-family:var(--font-title);letter-spacing:.04em;text-align:center;min-width:2.2em;color:var(--brass);font-size:1rem;font-weight:700;transition:color .18s}.ts-item:hover .ts-item-no{color:var(--gilt-bright)}.ts-item:focus-visible .ts-item-no{color:var(--gilt-bright)}.ts-item-body{flex-direction:column;flex:1;gap:1px;display:flex}.ts-item-label{font-family:var(--font-engrave);letter-spacing:.12em;color:var(--text-primary);font-size:1.5rem;font-weight:700;transition:color .18s,text-shadow .18s}.ts-item:hover .ts-item-label{color:var(--gilt-bright);text-shadow:0 0 16px #c8a24e44}.ts-item:focus-visible .ts-item-label{color:var(--gilt-bright);text-shadow:0 0 16px #c8a24e44}.ts-item-sub{font-family:var(--font-cn);letter-spacing:.04em;color:var(--text-muted);font-size:.78rem}.ts-item-cue{color:var(--gilt);opacity:0;font-size:1.2rem;transition:opacity .18s,transform .18s;transform:translate(-6px)}.ts-item:hover .ts-item-cue{opacity:1;transform:none}.ts-item:focus-visible .ts-item-cue{opacity:1;transform:none}.ts-foot{font-family:var(--font-cn);letter-spacing:.08em;color:var(--text-muted);justify-content:space-between;align-items:center;gap:16px;font-size:.76rem;display:flex}.ts-ver{font-family:var(--font-italic);font-style:italic}.page-stage{background:radial-gradient(120% 90% at 50% 0,#122050 0%,#0a1430 44%,#05091a 100%);justify-content:center;min-height:100vh;display:flex;position:relative;overflow:auto}.page-bg{z-index:0;pointer-events:none;background:var(--tex-grain), radial-gradient(ellipse at 50% 40%, transparent 55%, #03060ccc 100%);opacity:.5;mix-blend-mode:soft-light;background-size:180px 180px,cover;position:fixed;top:0;bottom:0;left:0;right:0}.page-frame{z-index:1;flex-direction:column;gap:20px;width:min(560px,92%);margin:0 auto;padding:48px 0 56px;display:flex;position:relative}.page-frame-wide{width:min(860px,92%)}.page-scroll{flex-direction:column;gap:20px;display:flex}.page-back{font-family:var(--font-cn);letter-spacing:.08em;color:var(--text-soft);border:1px solid var(--brass);border-radius:999px;align-self:flex-start;padding:6px 18px;font-size:.9rem;text-decoration:none;transition:all .16s}.page-back:hover{color:var(--gilt-bright);border-color:var(--gilt)}.page-title{font-family:var(--font-title);letter-spacing:.1em;background:var(--gilt-foil);color:#0000;filter:drop-shadow(0 2px #160c05)drop-shadow(0 4px 10px #02060e);-webkit-background-clip:text;background-clip:text;margin:0;font-size:clamp(2rem,5vw,2.8rem);font-weight:900}.page-card{border:1px solid var(--brass);background:var(--tex-leather), var(--leather-surface);background-blend-mode:overlay, normal;background-size:220px 220px,cover;border-radius:8px;flex-direction:column;gap:20px;padding:24px;display:flex;box-shadow:inset 0 0 0 1px #160c05,inset 0 0 36px #160c0588,0 8px 28px #02060ec0,0 0 0 2px #160c05}.pv-field{flex-direction:column;gap:8px;display:flex}.pv-label{font-family:var(--font-cn);letter-spacing:.1em;color:var(--text-soft);font-size:.82rem}#pvNickname{font-family:var(--font-cn);color:var(--text-primary);border:1px solid var(--brass);background:#0c1430;border-radius:6px;padding:10px 14px;font-size:1.05rem;box-shadow:inset 0 1px 4px #02060e}#pvNickname:focus{border-color:var(--gilt);outline:none;box-shadow:inset 0 1px 4px #02060e,0 0 0 2px #c8a24e44}.pv-faction{gap:10px;display:flex}.pv-faction-btn{font-family:var(--font-cn);letter-spacing:.06em;cursor:pointer;color:var(--text-soft);border:1px solid var(--brass);background:#0c1430;border-radius:6px;flex:1;padding:10px;font-size:.95rem;transition:all .16s}.pv-faction-btn.blue.active{color:#fff;background:var(--navy-mid);border-color:var(--navy-edge);box-shadow:0 0 0 1px var(--navy-edge), 0 3px 12px #14245a88}.pv-faction-btn.red.active{color:#fff;background:var(--oxblood);border-color:var(--oxblood-bright);box-shadow:0 0 0 1px var(--oxblood-bright), 0 3px 12px #7a161a88}.pv-note{font-family:var(--font-cn);color:var(--text-muted);margin:4px 0 0;font-size:.76rem;line-height:1.6}.pv-tip{font-family:var(--font-italic);color:var(--text-muted);text-align:center;font-size:.9rem;font-style:italic}.guide-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;display:grid}.guide-item{background:var(--tex-paper), linear-gradient(160deg, var(--paper) 0%, var(--paper-warm) 100%);background-blend-mode:multiply, normal;border:1px solid var(--brass);color:var(--ink);background-size:200px 200px,cover;border-radius:8px;padding:16px 18px;box-shadow:0 4px 16px #02060e80}.guide-item h3{font-family:var(--font-engrave);letter-spacing:.1em;color:var(--ink);margin:0 0 6px;font-size:1.1rem}.guide-item p{font-family:var(--font-cn);color:var(--ink-soft);margin:0;font-size:.86rem;line-height:1.65}.credits-list{flex-direction:column;align-items:center;gap:28px;padding:36px 8px 16px;display:flex}.credit-row{flex-direction:column;align-items:center;gap:9px;display:flex}.credit-role{font-family:var(--font-engrave);letter-spacing:.34em;color:var(--gilt-bright);font-size:.82rem}.credit-name{font-family:var(--font-cn);letter-spacing:.1em;color:var(--gilt-pale);text-shadow:0 1px 10px #02060e80;font-size:1.5rem}.guide-subtitle{font-family:var(--font-engrave);letter-spacing:.14em;color:var(--gilt-bright);margin:8px 0 0;font-size:1.2rem}.guide-keys{grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:8px;display:grid}.guide-key{align-items:center;gap:10px;display:flex}.guide-key kbd{font-family:var(--font-cn);color:var(--gilt-bright);border:1px solid var(--brass);text-align:center;background:#0c1430;border-radius:5px;min-width:6em;padding:4px 9px;font-size:.76rem;box-shadow:inset 0 -2px #02060e}.guide-key span{font-family:var(--font-cn);color:var(--text-soft);font-size:.84rem}.guide-quickstart{border:1px solid var(--gilt);background:linear-gradient(#2a1c0c66 0%,#160c0588 100%);border-radius:10px;padding:14px 18px 16px}.qs-head{font-family:var(--font-engrave);letter-spacing:.18em;color:var(--gilt-bright);margin-bottom:11px;font-size:1.05rem}.qs-steps{flex-direction:column;gap:9px;margin:0;padding:0;list-style:none;display:flex}.qs-steps li{align-items:flex-start;gap:11px;display:flex}.qs-no{color:#fff6dc;width:22px;height:22px;font-family:var(--font-engrave);background:linear-gradient(#b8923c 0%,#6b4d12 100%);border-radius:50%;flex:none;justify-content:center;align-items:center;margin-top:1px;font-size:.82rem;font-weight:700;display:inline-flex;box-shadow:inset 0 1px #ffe9a8}.qs-steps li>span:last-child{font-family:var(--font-cn);color:var(--text-soft);font-size:.88rem;line-height:1.55}.qs-goal{border-top:1px solid var(--brass-dark);font-family:var(--font-cn);color:var(--text-soft);margin-top:12px;padding-top:11px;font-size:.86rem}.qs-steps b,.qs-goal b,.m-guide-item b{color:var(--gilt-bright);font-weight:700}.guide-item b{color:var(--gilt-deep);font-weight:700}@media (max-width:980px){.page-stage{height:100vh;min-height:0;align-items:stretch;height:100dvh;overflow:hidden}.page-frame,.page-frame-wide{gap:12px;width:100%;height:100%;margin:0;padding:14px 14px 16px;overflow:hidden}.page-title{font-size:1.7rem}.page-back{padding:5px 14px;font-size:.84rem}.page-scroll{flex:auto;gap:12px;min-height:0;padding-right:2px;overflow-y:auto}.page-card{padding:16px}.guide-grid{grid-template-columns:1fr 1fr;gap:8px}.guide-item{padding:9px 11px}.guide-item h3{letter-spacing:.06em;margin-bottom:3px;font-size:.92rem}.guide-item p{font-size:.7rem;line-height:1.45}.guide-subtitle{margin:2px 0 0;font-size:.98rem}.guide-keys{grid-template-columns:1fr 1fr;gap:6px}.guide-key span{font-size:.74rem}.lobby-view{overflow:hidden}.lobby-frame{width:100%;height:100vh;gap:12px;height:100dvh;margin:0;padding:12px 14px 14px}.lobby-title{font-size:clamp(1.4rem,6vw,1.9rem)}.lobby-grid{flex:auto;gap:12px;min-height:0;padding-right:2px;overflow-y:auto}.lobby-card{gap:8px;padding:14px 16px}.debug-shell{height:100vh;flex-direction:column;gap:8px;height:100dvh;padding:8px;display:flex;overflow:hidden}.debug-shell .game-wrap{flex:none;order:0;justify-content:center;padding-bottom:0;display:flex}.debug-shell #debugCanvas{width:min(100%,46dvh)}.debug-shell .debug-panel{flex:auto;order:1;height:auto;min-height:0;max-height:none;overflow-y:auto}}@media (max-width:980px) and (max-height:560px){.debug-shell{flex-direction:row;align-items:stretch}.debug-shell .game-wrap{flex:auto;align-items:center;min-width:0}.debug-shell #debugCanvas{width:auto;max-width:100%;height:100%;max-height:100%}.debug-shell .debug-panel{flex:none;width:min(52%,400px);height:100%}.ts-content{height:100vh;min-height:0;justify-content:center;gap:8px;width:min(620px,94%);height:100dvh;padding:10px clamp(16px,5vw,60px)}.ts-seal,.ts-subtitle,.ts-rule{display:none}.ts-title{font-size:1.5rem}.ts-menu{gap:3px}.ts-item{gap:12px;padding:8px 14px}.ts-item-label{font-size:1.15rem}.ts-item-sub,.ts-foot{font-size:.66rem}}.overlay-actions{flex-wrap:wrap;justify-content:center;align-items:center;gap:14px;display:flex}.overlay-home-link{font-family:var(--font-cn);letter-spacing:.08em;text-decoration:none}.btn-link-home{font-weight:600}@media (max-width:720px){.menu-stage{gap:22px;padding:28px 0 18px}.menu-item-label{font-size:1.32rem}.menu-item-mode{width:100%}.home-profile-row{grid-template-columns:1fr;gap:12px}.home-fleet{grid-template-columns:1fr}}.online-hidden{display:none!important}#openFleetSelectBtn{width:100%;font-family:var(--font-cn);letter-spacing:.08em;color:var(--gilt-bright);border-color:var(--gilt-deep)}#openFleetSelectBtn:hover{color:var(--gilt-pale);border-color:var(--gilt)}#lobbyView[hidden],#battleView[hidden]{display:none!important}.online-root{min-height:100vh}.lobby-view{background:radial-gradient(120% 90% at 50% 0,#122050 0%,#0a1430 44%,#05091a 100%);min-height:100vh;position:relative;overflow:auto}.lobby-frame{z-index:1;flex-direction:column;gap:22px;width:min(920px,92%);margin:0 auto;padding:40px 0 48px;display:flex;position:relative}.lobby-head{grid-template-columns:auto 1fr auto;align-items:center;gap:16px;display:grid}.lobby-title{text-align:center;font-family:var(--font-title);letter-spacing:.12em;background:var(--gilt-foil);color:#0000;filter:drop-shadow(0 2px #160c05)drop-shadow(0 4px 10px #02060e);-webkit-background-clip:text;background-clip:text;margin:0;font-size:clamp(1.6rem,4vw,2.4rem);font-weight:900}.lobby-conn{justify-self:end;gap:8px;display:inline-flex}.lobby-conn strong{font-family:var(--font-cn);letter-spacing:.06em;color:var(--gilt-bright);border:1px solid var(--brass);background:#0c1430;border-radius:999px;padding:4px 12px;font-size:.78rem}.lobby-grid{grid-template-columns:repeat(2,1fr);align-items:start;gap:18px;display:grid}.lobby-card{border:1px solid var(--brass);background:var(--tex-leather), var(--leather-surface);background-blend-mode:overlay, normal;background-size:220px 220px,cover;border-radius:8px;flex-direction:column;gap:10px;padding:20px 22px;display:flex;box-shadow:inset 0 0 0 1px #160c05,inset 0 0 36px #160c0588,0 8px 28px #02060ec0,0 0 0 2px #160c05}.lobby-card-title{font-family:var(--font-engrave);letter-spacing:.12em;color:var(--gilt-bright);border-bottom:1px solid #6c4a2855;margin:6px 0 2px;padding-bottom:6px;font-size:1.02rem}.lobby-card-title:first-child{margin-top:0}@media (max-width:720px){.lobby-grid{grid-template-columns:1fr}.lobby-head{grid-template-columns:1fr;justify-items:center;gap:8px}.lobby-conn{justify-self:center}}.page-stars{z-index:0;pointer-events:none;width:100%;height:100%;position:fixed;top:0;bottom:0;left:0;right:0}#app>*{animation:.3s both routeFade}@keyframes routeFade{0%{opacity:0}to{opacity:1}}.ts-content,.page-frame,.lobby-frame{animation:.44s cubic-bezier(.22,.61,.36,1) both routeRise}@keyframes routeRise{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}@media (prefers-reduced-motion:reduce){#app>*,.ts-content,.page-frame,.lobby-frame{animation:none}}.debug-legacy-toggle{font-family:var(--font-cn);color:var(--gilt-pale);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;margin-top:4px;font-size:.82rem;display:flex}.debug-legacy-toggle input{accent-color:var(--gilt);cursor:pointer;width:15px;height:15px}.debug-seat-tag{transition:color .2s}.tut-overlay{z-index:150;pointer-events:none;justify-content:center;align-items:flex-end;padding:0 16px 22px;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.tut-overlay.tut-mobile{padding:0 8px calc(var(--tut-hud-clear,200px) + 8px);justify-content:center;align-items:flex-end}.tut-overlay.tut-mobile.tut-bias-left{justify-content:flex-start}.tut-overlay.tut-mobile.tut-bias-right{justify-content:flex-end}.tut-card{pointer-events:auto;box-sizing:border-box;border:1px solid var(--brass);background:var(--tex-leather), var(--leather-surface);background-blend-mode:overlay, normal;width:min(440px,92vw);color:var(--text-soft);border-radius:7px;padding:14px 16px 13px;animation:.34s cubic-bezier(.2,.7,.3,1) tut-rise;box-shadow:inset 0 0 0 1px #160c05,inset 0 1px #6c4a2877,0 10px 34px #02060ed8,0 0 0 3px #160c05}.tut-overlay.tut-mobile .tut-card{border-radius:6px;width:min(82%,360px);padding:8px 11px 9px;animation:.3s cubic-bezier(.2,.7,.3,1) tut-rise}.tut-overlay.tut-mobile .tut-step{margin-bottom:1px;font-size:.64rem}.tut-overlay.tut-mobile .tut-title{margin-bottom:3px;font-size:.94rem}.tut-overlay.tut-mobile .tut-body{font-size:.79rem;line-height:1.46}.tut-overlay.tut-mobile .tut-wait{margin-top:5px;font-size:.72rem}.tut-overlay.tut-mobile .tut-actions{gap:10px;margin-top:8px}.tut-overlay.tut-mobile .tut-next{padding:5px 16px;font-size:.82rem}.tut-overlay.tut-mobile .tut-skip{font-size:.7rem}@keyframes tut-rise{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}@keyframes tut-drop{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:none}}.tut-step{font-family:var(--font-italic);letter-spacing:.1em;color:var(--text-muted);margin:0 0 3px;font-size:.74rem;font-style:italic}.tut-title{font-family:var(--font-engrave);letter-spacing:.06em;background:var(--gilt-foil);color:#0000;filter:drop-shadow(0 1px 2px #050912);-webkit-background-clip:text;background-clip:text;margin:0 0 6px;font-size:1.12rem}.tut-body{color:var(--ivory);margin:0;font-size:.9rem;line-height:1.62}.tut-body b{color:var(--gilt-bright);font-weight:600}.tut-wait{color:var(--gilt);margin:8px 0 0;font-size:.8rem;font-style:italic}.tut-actions{align-items:center;gap:14px;margin-top:12px;display:flex}.tut-next{border:1px solid var(--gilt);color:#fff6dc;font-family:var(--font-engrave);letter-spacing:.16em;cursor:pointer;text-shadow:0 1px 2px #2a0607;background:radial-gradient(at 50% 28%,#c8323a 0%,#8a161a 62%,#5a0e10 100%);border-radius:4px;flex:none;padding:8px 26px;font-size:.98rem;font-weight:700;transition:transform .18s,box-shadow .18s,border-color .18s;box-shadow:inset 0 1px #ff8a6e55,0 0 16px #b8232a55,0 4px 12px #0008}.tut-next:hover{border-color:var(--gilt-bright);transform:translateY(-1px);box-shadow:inset 0 1px #ff8a6e88,0 0 24px #d44a4588,0 5px 14px #000a}.tut-skip{color:var(--text-muted);cursor:pointer;text-underline-offset:2px;background:0 0;border:none;margin-left:auto;padding:4px 2px;font-size:.78rem;text-decoration:underline}.tut-skip:hover{color:var(--text-soft)}.tut-highlight{border-radius:7px;animation:1.5s ease-in-out infinite tut-pulse;position:relative}@keyframes tut-pulse{0%,to{box-shadow:0 0 0 2px #f0d48866,0 0 10px 2px #c8a24e55}50%{box-shadow:0 0 0 2px #f0d488cc,0 0 18px 5px #c8a24eaa}}.guide-replay{border:1px solid var(--brass);color:var(--gilt-bright);letter-spacing:.04em;cursor:pointer;background:linear-gradient(175deg,#4f3220,#271608);border-radius:5px;margin-top:10px;padding:6px 16px;font-size:.86rem;text-decoration:none;display:inline-block;box-shadow:inset 0 1px #6c4a2877,0 2px 8px #0005}.guide-replay:hover{filter:brightness(1.12)}
