:root{color-scheme:dark;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}html,body,#root{margin:0;height:100%;width:100%;overflow:hidden;background:#0a1a2f}canvas{display:block}.join-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:radial-gradient(circle at 50% 30%,#16385e,#0a1a2f 70%)}.join-card{width:min(90vw,380px);padding:32px;border-radius:16px;background:#081628d9;border:1px solid rgba(120,180,255,.25);box-shadow:0 24px 60px #00000080;text-align:center}.join-card h1{margin:0 0 4px;font-size:34px;letter-spacing:1px;color:#ffd166}.join-card p{margin:0 0 24px;color:#9fc0e0;font-size:14px}.join-card input{width:100%;padding:12px 14px;font-size:16px;border-radius:10px;border:1px solid rgba(120,180,255,.35);background:#0c2138;color:#eaf3ff;outline:none}.join-card input:focus{border-color:#ffd166}.join-card button{margin-top:16px;width:100%;padding:12px;font-size:16px;font-weight:600;border:none;border-radius:10px;background:#ffd166;color:#0a1a2f;cursor:pointer;transition:transform .05s ease,filter .15s ease}.join-card button:hover{filter:brightness(1.05)}.join-card button:active{transform:translateY(1px)}.join-card .status{margin-top:14px;font-size:13px;min-height:16px}.status.error{color:#ff8a80}.status.connecting{color:#9fc0e0}.hud{position:fixed;top:12px;left:12px;width:256px;padding:11px 13px 12px;border-radius:14px;background:linear-gradient(180deg,#0c1b2ce6,#060f1bed);border:1px solid rgba(96,140,190,.3);box-shadow:0 3px 16px #00000080,inset 0 1px #96bef012;color:#cfe2f7;pointer-events:none}.hud-head{display:flex;align-items:center;gap:11px;margin-bottom:9px}.hud-emblem{flex:none;width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:radial-gradient(circle at 50% 38%,#1a3046f2,#08121efa);border:2px solid #c9a14e;box-shadow:0 0 0 2px #08101cf2,0 0 10px #c9a14e59,inset 0 0 7px #0009;font-size:23px;line-height:1}.hud-headcol{flex:1;min-width:0}.hud-top{display:flex;align-items:baseline;gap:7px}.hud-cap{flex:1;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hud-cap b{color:#ffe08a}.hud-faction{font-size:10.5px;font-weight:800;letter-spacing:.05em;text-transform:uppercase}.hud-stats{display:flex;gap:14px;margin-top:4px;font-size:12px;color:#9fc0e0}.hud-stat b{color:#e8b964;font-variant-numeric:tabular-nums}.hud-keys{display:grid;grid-template-columns:1fr 1fr;gap:5px 12px;padding-top:10px;border-top:1px solid rgba(96,140,190,.18)}.hud-key{display:flex;align-items:center;gap:6px;font-size:11.5px;color:#a9c4de}.hud kbd{min-width:14px;padding:1px 5px;border-radius:4px;background:#78b4ff24;border:1px solid rgba(120,180,255,.32);box-shadow:0 1px #00000073;color:#e6f0fb;font:600 10.5px/1.45 ui-monospace,SFMono-Regular,Menlo,monospace;text-align:center}.topright{position:fixed;top:56px;right:12px;z-index:20;display:flex;flex-direction:column;align-items:flex-end;gap:8px;pointer-events:none}.faction-war{width:198px;padding:9px 11px 10px;border-radius:12px;background:linear-gradient(180deg,#0c1b2ce6,#060f1bed);border:1px solid rgba(96,140,190,.3);box-shadow:0 3px 16px #00000080,inset 0 1px #96bef012;pointer-events:none}.fw-title{color:#dce9f8;font-size:12px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;text-align:center;padding-bottom:7px;margin-bottom:8px;border-bottom:1px solid rgba(120,180,255,.14)}.fw-row{margin-top:9px;padding:4px 5px;border-radius:7px}.fw-row:first-of-type{margin-top:0}.fw-row.self{background:#78b4ff14;box-shadow:inset 0 0 0 1px #78b4ff29}.fw-head{display:flex;justify-content:space-between;align-items:center}.fw-name{display:flex;align-items:center;gap:5px;font-size:13px;font-weight:800}.fw-dot{width:8px;height:8px;border-radius:50%;box-shadow:0 0 6px currentColor}.fw-crown{font-size:11px;filter:drop-shadow(0 0 2px rgba(255,210,74,.7))}.fw-you{margin-left:1px;padding:0 5px;border-radius:8px;background:#78b4ff2e;color:#cfe2f7;font-size:9px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.fw-score{color:#f3f7fc;font-size:14px;font-weight:800;font-variant-numeric:tabular-nums;text-shadow:0 1px 2px #000}.fw-bar{height:7px;margin:5px 0 4px;border-radius:4px;background:#0006;overflow:hidden}.fw-fill{height:100%;border-radius:4px;box-shadow:0 0 8px currentColor;transition:width .4s ease}.fw-sub{display:flex;justify-content:space-between;color:#8fb0cf;font-size:10.5px;font-variant-numeric:tabular-nums}.topbars{position:fixed;top:10px;left:50%;transform:translate(-50%);display:flex;align-items:flex-start;gap:10px;pointer-events:none}.vitals{display:grid;grid-template-columns:26px 222px auto;align-items:center;gap:7px 10px;padding:10px 13px;border-radius:14px;background:linear-gradient(180deg,#0c1b2ce6,#060f1bed);border:1px solid rgba(96,140,190,.3);box-shadow:0 3px 16px #00000080,inset 0 1px #96bef012}.vital{display:contents}.vital-ico{width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#ffffff0d;box-shadow:inset 0 0 0 1px #78b4ff38;font-size:14px;line-height:1}.vital-ico.hp{color:#ff6b6b;box-shadow:inset 0 0 0 1px #ff6b6b73}.lvl-badge{width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:linear-gradient(180deg,#6fb6ff,#b388ff);color:#0a1c30;font-size:12px;font-weight:800;box-shadow:0 0 7px #968cff80}.vital-bar{height:12px;border-radius:6px;background:#0006;border:1px solid rgba(120,180,255,.22);overflow:hidden}.vital-val{min-width:72px;text-align:right;white-space:nowrap;color:#eaf3ff;font-size:12px;font-weight:800;font-variant-numeric:tabular-nums;text-shadow:0 1px 2px rgba(0,0,0,.6)}.vital-max{color:#87a6c4;font-weight:600}.health-fill{height:100%;border-radius:5px;transition:width .15s ease,background .2s ease}.xp-fill{height:100%;border-radius:5px;background:linear-gradient(90deg,#6fb6ff,#b388ff);transition:width .2s ease}.sail-fill{height:100%;border-radius:5px;background:linear-gradient(90deg,#9fd0ff,#eaf3ff);transition:width .1s linear}.repairing{position:fixed;bottom:74px;left:50%;transform:translate(-50%);padding:6px 14px;border-radius:8px;background:#081628cc;border:1px solid rgba(120,220,160,.5);color:#9be6b4;font-size:13px;font-weight:600;pointer-events:none}.cargo{position:fixed;left:12px;bottom:196px;display:flex;flex-direction:column;align-items:flex-start;gap:9px;padding:10px 11px;border-radius:14px;background:linear-gradient(180deg,#0c1b2ce6,#060f1bed);border:1px solid rgba(96,140,190,.3);box-shadow:0 3px 16px #00000080,inset 0 1px #96bef012;pointer-events:none}.wallet{display:flex;align-items:center;gap:8px;padding:0 2px;pointer-events:auto}.wallet-amount{color:#e8b964;font-weight:800;font-size:16px;line-height:1;font-variant-numeric:tabular-nums;text-shadow:0 0 3px #000,0 1px 2px #000}.wallet-label{color:#b9883a;font-size:11px;font-weight:600;letter-spacing:.02em}.inventory{display:grid;grid-template-columns:repeat(4,40px);gap:4px;pointer-events:none}.inv-empty{grid-column:1 / -1;max-width:172px;color:#7fa3c4;font-size:12px}.inv-item{position:relative;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:#00000047;box-shadow:inset 0 0 0 1px #78b4ff29}.inv-count{position:absolute;right:3px;bottom:1px;color:#ffd166;font-size:11px;font-weight:700;line-height:1;text-shadow:0 0 3px #000,0 1px 2px #000}.talent-btn{position:fixed;top:12px;right:58px;z-index:20;display:flex;align-items:center;gap:8px;padding:8px 14px;border-radius:10px;background:#0a1626e6;border:1px solid rgba(96,140,190,.32);color:#eaf3ff;font-size:14px;font-weight:600;cursor:pointer}.talent-btn.has{border-color:#ffd166;box-shadow:0 0 0 2px #ffd1664d;animation:pulse 1.6s ease-in-out infinite}@keyframes pulse{50%{box-shadow:0 0 14px 2px #ffd16680}}.tb-key{width:18px;height:18px;border-radius:4px;background:#ffd16633;color:#ffd166;font-size:11px;font-weight:700;display:grid;place-items:center}.tb-badge{background:#ffd166;color:#0a1a2f;border-radius:10px;padding:1px 8px;font-size:12px;font-weight:700}.debug-tools{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:4px;max-width:230px;pointer-events:auto}.debug-xp,.debug-res{display:flex;align-items:center;gap:5px;padding:6px 10px;border-radius:8px;background:#280c28cc;border:1px dashed rgba(255,140,200,.5);color:#ff9ad0;font-size:12px;font-weight:600;cursor:pointer}.debug-xp:hover,.debug-res:hover{filter:brightness(1.2)}.chatbox{position:fixed;left:12px;bottom:12px;z-index:19;width:min(42vw,360px);display:flex;flex-direction:column;gap:6px;font-size:13px;pointer-events:none}.chatbox.open{pointer-events:auto}.chat-log{max-height:150px;overflow-y:auto;display:flex;flex-direction:column;gap:2px;padding:6px 8px;border-radius:8px;background:#06101c52;opacity:.72;transition:opacity .15s ease,background .15s ease;scrollbar-width:thin}.chatbox.open .chat-log{opacity:1;background:#06101c9e;pointer-events:auto}.chat-log:empty{display:none}.chat-line{line-height:1.35;color:#dfeaf6;text-shadow:0 1px 2px rgba(0,0,0,.85);word-break:break-word}.chat-tag{font-weight:800;font-size:11px}.chat-from{font-weight:700}.chat-text{color:#cfe0f0}.chat-line.self .chat-text{color:#fff}.chat-input-row{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:8px;background:#06101cd9;border:1px solid rgba(120,180,255,.4);pointer-events:auto;transition:opacity .15s ease,background .15s ease,border-color .15s ease}.chatbox:not(.open) .chat-input-row{background:#06101c66;opacity:.5;pointer-events:none}.chat-channel{font-weight:800;font-size:11px;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.chat-input{flex:1;min-width:0;background:transparent;border:none;outline:none;color:#eaf3ff;font-size:13px;font-family:inherit}.chat-input::placeholder{color:#6a86a4}.action-bar{position:fixed;bottom:12px;right:12px;display:flex;gap:10px;z-index:20}.action-btn{display:flex;align-items:center;gap:8px;padding:8px 14px;border-radius:12px;background:#0a1626e6;border:1px solid rgba(96,140,190,.32);color:#eaf3ff;font-size:14px;font-weight:600;cursor:pointer}.action-btn:hover{filter:brightness(1.12)}.action-btn.trade{border-color:#ffd166;box-shadow:0 0 12px #ffd1664d}.action-btn.ship{border-color:#8fd0ff;box-shadow:0 0 12px #8fd0ff4d}.event-banner{position:fixed;top:150px;left:50%;transform:translate(-50%);z-index:18;padding:10px 20px;border-radius:12px;background:linear-gradient(180deg,#3c2c0cf2,#281c08f2);border:1px solid #ffd24a;box-shadow:0 0 22px #ffd24a59;color:#ffe9a8;font-size:15px;font-weight:700;white-space:nowrap;pointer-events:none;animation:event-pop .3s ease-out}@keyframes event-pop{0%{opacity:0;transform:translate(-50%,-8px)}to{opacity:1;transform:translate(-50%)}}.ammo-bar{position:fixed;bottom:14px;left:50%;transform:translate(-50%);z-index:14;display:flex;gap:12px}.ammo-slot{position:relative;width:88px;height:88px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;padding-top:9px;border-radius:50%;background:radial-gradient(circle at 50% 34%,#222e3af5,#080d13fa);border:1px solid rgba(130,150,170,.35);box-shadow:0 4px 14px #0000008c,inset 0 2px 6px #ffffff0f,inset 0 -8px 16px #00000080;color:#d7dde3;cursor:pointer}.ammo-slot.sel{border-color:#e8b964;box-shadow:0 0 0 2px #e8b9648c,0 4px 18px #e8b9644d,inset 0 2px 6px #ffffff14,inset 0 -8px 16px #00000080}.ammo-slot.empty{opacity:.5}.ammo-key{position:absolute;top:-3px;left:50%;transform:translate(-50%);width:19px;height:19px;display:grid;place-items:center;border-radius:50%;background:radial-gradient(circle at 50% 35%,#f4f7fa,#c2cbd2);color:#1a2128;font-size:11px;font-weight:800;border:1px solid rgba(0,0,0,.35);box-shadow:0 1px 3px #0009}.ammo-icon{width:42px;height:36px;object-fit:contain;filter:drop-shadow(0 2px 3px rgba(0,0,0,.55))}.ammo-name{font-size:11px;font-weight:700;line-height:1.1;color:#e7eef4;text-shadow:0 1px 2px rgba(0,0,0,.8)}.ammo-count{font-size:11px;font-weight:700;line-height:1;color:#aebcc9}.ammo-slot.sel .ammo-count{color:#f0d49a}.debug-window{position:fixed;top:100px;left:12px;z-index:30;min-width:188px;padding:10px 12px;border-radius:10px;background:#060e18e0;border:1px solid rgba(120,180,255,.3);color:#cfe3f7;font-family:ui-monospace,Cascadia Code,Menlo,monospace;font-size:12px;pointer-events:none}.dbg-title{font-weight:700;color:#8fd0ff;margin-bottom:6px}.dbg-row{display:flex;justify-content:space-between;gap:16px;line-height:1.55}.dbg-k{color:#7fa3c4}.dbg-v{font-weight:700}.dbg-row.sub{line-height:1.35;font-size:11px}.dbg-row.sub .dbg-k{color:#5f7d9a;padding-left:8px}.dbg-row.sub .dbg-v{font-weight:600;color:#9fc0e0}.dbg-v.hot{color:#e05a4a}.dbg-sep{height:1px;background:#78b4ff33;margin:6px 0}.dbg-foot{margin-top:6px;color:#5a7a98;font-size:11px}.wind{display:flex;flex-direction:column;align-items:center;gap:2px;margin-top:2px;pointer-events:none;-webkit-user-select:none;user-select:none}.wind-dial{position:relative;width:48px;height:48px;border-radius:50%;background:radial-gradient(circle at 50% 38%,#14283ceb,#060f1bf2);border:2px solid #c9a14e;box-shadow:0 0 0 2px #08101cf2,0 0 10px #c9a14e4d,inset 0 0 6px #0000008c}.wind-sail{position:absolute;left:50%;top:7px;bottom:7px;width:3px;transform:translate(-50%);border-radius:2px;background:#eae0c8d9}.wind-hull{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:12px;color:#8fd0ff8c;transform-origin:50% 50%}.wind-arrow{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:900;transform-origin:50% 50%}.wind-label{font-size:11px;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.6)}.shop-panel{width:min(94vw,460px);background:linear-gradient(180deg,#0e2a47,#0a1c30);border:1px solid rgba(120,180,255,.3);border-radius:16px;padding:20px;box-shadow:0 30px 80px #0009}.shop-gold{display:flex;align-items:center;gap:6px;color:#ffd166;font-weight:700}.shop-list{display:flex;flex-direction:column;gap:8px;margin:6px 0}.shop-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:10px;background:#0c2138b3;border:1px solid rgba(120,180,255,.15)}.shop-name{display:flex;align-items:center;gap:7px;color:#eaf3ff;font-size:13px;flex:1}.shop-have{color:#7fa3c4;font-size:12px}.shop-empty{color:#7fa3c4;font-size:13px;text-align:center;padding:14px 8px}.shop-dot{width:12px;height:12px;border-radius:3px;box-shadow:inset 0 0 0 1px #0000004d}.shop-buy{padding:6px 12px;border-radius:8px;border:none;background:#ffd166;color:#0a1a2f;font-weight:700;font-size:12px;cursor:pointer}.shop-buy:disabled{background:#78b4ff2e;color:#7fa3c4;cursor:default}.shop-row.current{border-color:#8fd0ff80;background:#14304ecc}.ship-tag{color:#8fd0ff;font-size:11px;font-weight:600}.ship-owned{color:#8fd0ff;font-size:12px;font-weight:700;padding:6px 12px}.ship-locked{color:#6a86a4;font-size:12px;padding:6px 12px}.shop-row.craft{flex-direction:row;justify-content:space-between}.craft-io{display:flex;align-items:center;gap:8px;font-size:12px;flex-wrap:wrap}.craft-inputs{display:flex;gap:8px}.craft-ing{display:flex;align-items:center;gap:4px;color:#cfe2f7}.craft-ing.short{color:#ff8a80}.craft-arrow{color:#9fc0e0}.craft-out{display:flex;align-items:center;gap:4px;color:#ffd166;font-weight:600}.craft-panel{width:min(96vw,1000px);height:min(88vh,720px);display:flex;flex-direction:column;background:linear-gradient(180deg,#0e2a47,#0a1c30);border:1px solid rgba(120,180,255,.3);border-radius:16px;padding:20px;box-shadow:0 30px 80px #0009}.craft-layout{display:flex;gap:16px;flex:1;min-height:0}.craft-scroll{flex:1;min-width:0;overflow-y:auto;padding-right:4px;display:flex;flex-direction:column;gap:18px}.craft-cargo{width:300px;flex:0 0 auto;display:flex;flex-direction:column;gap:8px;padding-left:16px;border-left:1px solid rgba(120,180,255,.15);min-height:0}.craft-cargo-scroll{flex:0 0 auto;max-height:200px;overflow-y:auto}@media(max-width:640px){.craft-layout{flex-direction:column}.craft-cargo{width:auto;border-left:none;border-top:1px solid rgba(120,180,255,.15);padding-left:0;padding-top:12px}}.craft-tabs{display:flex;flex-wrap:wrap;gap:6px;margin:2px 0 12px}.craft-tab{padding:6px 14px;border-radius:9px;border:1px solid rgba(120,180,255,.2);background:#0c213899;color:#cfe2f7;font-size:13px;font-weight:600;cursor:pointer;transition:border-color .1s ease,background .1s ease}.craft-tab:hover{border-color:#8fd0ff80}.craft-tab.active{background:#ffd166;color:#0a1a2f;border-color:#ffd166}.craft-make-label{font-size:11px;color:#8fb6dd}.craft-card.locked .craft-make-label{color:#e0857c}.craft-make{display:flex;gap:4px}.craft-make-btn{flex:1;padding:6px 0;border-radius:7px;border:1px solid rgba(255,209,102,.5);background:#ffd16624;color:#ffd166;font-size:12px;font-weight:800;cursor:pointer}.craft-make-btn:hover:not(:disabled){background:#ffd16647}.craft-make-btn:disabled{border-color:#78b4ff26;background:#78b4ff0f;color:#5a7a98;cursor:default}.craft-queue{flex:1;min-height:90px;display:flex;flex-direction:column;gap:7px;overflow-y:auto}.craft-queue-sum{font-size:11px;color:#9fd0ff;font-weight:600}.craft-queue-empty{color:#6a86a4;font-size:12px;padding:6px 2px;line-height:1.4}.craft-job{display:flex;align-items:center;gap:9px;padding:8px;border-radius:10px;background:#0c2138b3;border:1px solid rgba(120,180,255,.16)}.craft-job.active{border-color:#8fd0ff73;background:#14304eb3}.craft-job-icon{position:relative;flex:0 0 auto;width:34px;height:34px;display:grid;place-items:center}.craft-job-count{position:absolute;right:-5px;bottom:-5px;min-width:16px;padding:0 3px;border-radius:8px;background:#ffd166;color:#0a1a2f;font-size:10px;font-weight:800;text-align:center}.craft-job-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.craft-job-top{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.craft-job-name{font-size:13px;font-weight:600;color:#eaf3ff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.craft-job-time{flex:0 0 auto;font-size:11px;font-weight:700;color:#9fd0ff;font-variant-numeric:tabular-nums}.craft-job-bar{height:6px;border-radius:3px;background:#081628d9;overflow:hidden}.craft-job-fill{height:100%;background:linear-gradient(90deg,#6fb6ff,#9be6b4);transition:width .1s linear}.craft-job-sub{font-size:10.5px;color:#7fa3c4}.craft-cancel{flex:0 0 auto;width:22px;height:22px;border-radius:6px;border:1px solid rgba(224,90,74,.4);background:#e05a4a1f;color:#f3b4ac;font-size:12px;line-height:1;cursor:pointer}.craft-cancel:hover{background:#e05a4a40}.craft-cat-title{margin:4px 0 0;font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:#8fb6dd;display:flex;align-items:center;gap:10px}.craft-cat-title:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,rgba(120,180,255,.3),transparent)}.craft-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:12px;margin-top:10px}.craft-card{display:flex;flex-direction:column;gap:10px;padding:12px;border-radius:12px;background:linear-gradient(180deg,#122c48b3,#0a1a2cb3);border:1px solid rgba(120,180,255,.18);transition:transform .12s ease,border-color .12s ease,box-shadow .12s ease}.craft-card:hover{transform:translateY(-2px);border-color:#8fd0ff73;box-shadow:0 10px 24px #00000059}.craft-card.locked{opacity:.62;filter:saturate(.7)}.craft-card.locked:hover{transform:none;box-shadow:none}.craft-card-head{display:flex;gap:12px;align-items:center}.craft-out-icon{position:relative;width:64px;height:64px;flex:0 0 auto;border-radius:12px;display:grid;place-items:center;background:radial-gradient(circle at 35% 30%,#78b4ff2e,#06122099);border:1px solid rgba(120,180,255,.2);box-shadow:inset 0 2px 6px #00000059}.craft-out-badge{position:absolute;right:-6px;bottom:-6px;min-width:20px;height:20px;padding:0 5px;border-radius:10px;background:#ffd166;color:#0a1a2f;font-size:12px;font-weight:800;display:grid;place-items:center;box-shadow:0 2px 6px #0006}.craft-card-meta{display:flex;flex-direction:column;gap:3px;min-width:0}.craft-card-name{color:#eaf3ff;font-weight:700;font-size:15px}.craft-card-desc{color:#9fc0e0;font-size:12px;line-height:1.3}.craft-card-stats{display:inline-flex;align-items:center;gap:4px;color:#ffd166;font-size:11px;font-weight:600}.craft-ingredients{display:flex;flex-wrap:wrap;gap:6px}.craft-chip{display:inline-flex;align-items:center;gap:5px;padding:4px 8px 4px 5px;border-radius:8px;background:#5fd35f1f;border:1px solid rgba(95,211,95,.35);color:#cdeccd;font-size:12px;font-weight:600}.craft-chip.short{background:#e05a4a1f;border-color:#e05a4a66;color:#f3b4ac}.craft-chip-count .sep{opacity:.5;margin:0 1px}.craft-card-foot{display:flex;flex-direction:column;gap:6px;margin-top:auto}.craft-max{padding:6px 10px;border-radius:8px;border:1px solid rgba(120,180,255,.35);background:#78b4ff1f;color:#cfe2f7;font-weight:700;font-size:12px;cursor:pointer}.craft-max:hover{background:#78b4ff38}.inv-grid{display:grid;grid-template-columns:repeat(auto-fill,var(--slot, 46px));gap:6px;justify-content:start;align-content:start}.inv-slot{position:relative;width:var(--slot, 46px);height:var(--slot, 46px);border-radius:8px;background:linear-gradient(180deg,#0a1a2ce6,#061220e6);border:1px solid rgba(120,180,255,.14);box-shadow:inset 0 2px 5px #0006;display:grid;place-items:center}.inv-slot.filled{border-color:#78b4ff52;background:radial-gradient(circle at 38% 30%,#78b4ff24,#081424f2);cursor:default;transition:border-color .1s ease,box-shadow .1s ease}.inv-slot.filled:hover{border-color:#8fd0ff99;box-shadow:inset 0 2px 5px #0006,0 0 0 1px #8fd0ff4d}.inv-slot-count{position:absolute;right:3px;bottom:1px;font-size:11px;font-weight:800;color:#fff;text-shadow:0 1px 2px #000,0 0 3px #000;pointer-events:none}.settings-btn{position:fixed;top:12px;right:12px;z-index:20;width:38px;height:36px;border-radius:10px;background:#0a1626e6;border:1px solid rgba(96,140,190,.32);color:#cfe2f7;font-size:18px;cursor:pointer}.settings-btn:hover{filter:brightness(1.2)}.settings-panel{width:min(92vw,460px);background:linear-gradient(180deg,#0e2a47,#0a1c30);border:1px solid rgba(120,180,255,.3);border-radius:16px;padding:20px;box-shadow:0 30px 80px #0009}.set-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 0}.set-label{color:#cfe2f7;font-weight:600}.seg{display:flex;border-radius:9px;overflow:hidden;border:1px solid rgba(120,180,255,.3)}.seg button{padding:8px 14px;background:#0c2138cc;color:#cfe2f7;border:none;cursor:pointer;font-size:13px}.seg button.on{background:#ffd166;color:#0a1a2f;font-weight:700}.tt-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#040c16c7;display:grid;place-items:center;z-index:50}.tt-panel{width:min(97vw,1000px);max-height:90vh;overflow:auto;background:linear-gradient(180deg,#0e2a47,#0a1c30);border:1px solid rgba(120,180,255,.3);border-radius:16px;padding:20px;box-shadow:0 30px 80px #0009}.tt-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.tt-header h2{margin:0;color:#ffd166;letter-spacing:1px}.tt-meta{display:flex;align-items:center;gap:12px;color:#cfe2f7;font-size:14px}.tt-points{padding:3px 10px;border-radius:10px;background:#78b4ff26}.tt-points.has{background:#ffd166;color:#0a1a2f;font-weight:700}.tt-close{width:30px;height:30px;border-radius:8px;border:1px solid rgba(120,180,255,.3);background:transparent;color:#cfe2f7;cursor:pointer;font-size:14px}.tt-trees{display:flex;gap:18px;justify-content:center}.tt-tree{background:#07122080;border:1px solid rgba(120,180,255,.15);border-radius:12px;padding:10px}.tt-tree-head{display:flex;justify-content:space-between;align-items:center;color:#9fc0e0;font-weight:700;font-size:14px;padding:2px 6px 8px}.tt-tree-pts{color:#ffd166;background:#ffd1661f;border-radius:8px;padding:1px 8px}.tt-grid{position:relative}.tt-arrows{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.tt-node{position:absolute;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;text-align:center;padding:4px;border-radius:10px;border:2px solid rgba(120,180,255,.25);background:#0c2138eb;color:#eaf3ff;cursor:default}.tt-node.can{cursor:pointer;border-color:#ffd166;box-shadow:0 0 10px #ffd16659}.tt-node.can:hover{filter:brightness(1.15)}.tt-node.partial{border-color:#6fb6ff}.tt-node.locked{opacity:.45}.tt-node.maxed{border-color:#5fd35f;box-shadow:0 0 8px #5fd35f59}.tt-node-name{font-weight:700;font-size:11px;line-height:1.15}.tt-node-rank{font-size:11px;font-weight:700;color:#ffd166}.tt-node.maxed .tt-node-rank{color:#5fd35f}.tt-node-lock{position:absolute;top:3px;right:5px;font-size:10px}.tt-tip{position:fixed;width:250px;z-index:60;pointer-events:none;background:#06121f;border:1px solid rgba(120,180,255,.45);border-radius:10px;padding:10px 12px;box-shadow:0 16px 40px #0009}.tt-tip-name{color:#ffd166;font-weight:700;font-size:14px}.tt-tip-rank{color:#cfe2f7;font-size:12px;margin-top:2px}.tt-tip-max{color:#5fd35f}.tt-tip-desc{color:#eaf3ff;font-size:12px;margin:8px 0;line-height:1.35}.tt-tip-req{font-size:11px;margin-top:3px}.tt-tip-req.met{color:#8fd39a}.tt-tip-req.unmet{color:#ff8a80}.tt-tip-foot{margin-top:8px;padding-top:6px;border-top:1px solid rgba(120,180,255,.15);color:#9fc0e0;font-size:11px}.tt-foot{margin-top:16px;color:#7fa3c4;font-size:12px;text-align:center}.ship-panel{width:min(94vw,680px)}.ship-panel .tt-header h2{text-shadow:0 0 14px rgba(255,209,102,.35)}.ship-body{display:flex;gap:22px;padding:16px 4px 4px;align-items:stretch}.ship-preview-wrap{position:relative;flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:12px;padding:16px 16px 14px;border-radius:16px;background:radial-gradient(120% 90% at 50% 30%,#1c42688c,#09182900 62%),linear-gradient(180deg,#123150,#0a1d33 58%,#08182c);border:1px solid rgba(120,180,255,.28);box-shadow:0 18px 40px #0000008c,inset 0 1px #96bef01a,inset 0 0 0 1px #08122099}.ship-preview-wrap:before{content:"";position:absolute;top:8px;right:8px;bottom:8px;left:8px;border-radius:12px;pointer-events:none;border:1px solid rgba(143,208,255,.16);box-shadow:inset 0 2px 10px #00000080,inset 0 0 0 1px #0000004d;z-index:2}.ship-preview{position:relative;width:328px;height:328px;display:flex;align-items:center;justify-content:center;line-height:0;border-radius:10px;overflow:hidden;background:radial-gradient(95% 75% at 50% 36%,#3c6ea54d,#07132200 60%),radial-gradient(140% 120% at 50% 100%,#040b14e6,#040b1400 55%),linear-gradient(180deg,#133453,#0c2138 52%,#081626);box-shadow:inset 0 0 60px #0000008c,inset 0 0 0 1px #78b4ff1f}.ship-preview:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(180deg,#b4d7ff1a,#b4d7ff00 38%)}.ship-preview:after{content:"";position:absolute;left:6%;right:6%;bottom:9%;height:38%;pointer-events:none;background:radial-gradient(60% 100% at 50% 100%,#78b4ff29,#78b4ff00 70%)}.ship-preview canvas{position:relative;z-index:1;max-width:100%;max-height:100%;width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 10px 18px rgba(0,0,0,.55))}.ship-preview-name{position:relative;z-index:1;padding:4px 14px;border-radius:999px;font-size:12px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:#eaf3ff;background:#0c2138b3;border:1px solid rgba(120,180,255,.22);box-shadow:inset 0 1px #96bef01a;text-shadow:0 1px 2px rgba(0,0,0,.6)}.ship-cosmetics{flex:1;min-width:0;display:flex;flex-direction:column;gap:14px}.ship-cosmetics h3{margin:0 0 10px;padding-bottom:7px;color:#8fd0ff;font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;border-bottom:1px solid rgba(120,180,255,.14)}.skin-group{margin:0;padding:12px 13px 13px;border-radius:12px;background:#0c213899;border:1px solid rgba(120,180,255,.15);box-shadow:inset 0 1px #96bef00f}.skin-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(70px,1fr));gap:9px}.skin-swatch{position:relative;display:flex;flex-direction:column;align-items:center;gap:8px;padding:11px 4px 9px;border-radius:12px;background:linear-gradient(180deg,#122c48b3,#091829b3);border:1px solid rgba(120,180,255,.18);color:#c7d7e8;cursor:pointer;box-shadow:inset 0 1px #96bef012;transition:transform .12s ease,border-color .12s ease,background .12s ease,box-shadow .12s ease,color .12s ease}.skin-swatch:hover:not(:disabled){transform:translateY(-2px);border-color:#ffd1668c;color:#eaf3ff;box-shadow:0 10px 22px #0006,inset 0 1px #96bef01a}.skin-swatch.selected{border-color:#ffd166;background:linear-gradient(180deg,#362e168c,#1e293ce0);color:#fff3d6;box-shadow:0 0 0 1px #ffd1668c,0 0 16px #ffd16642,inset 0 1px #ffe1a02e}.skin-swatch.selected .skin-label{color:#ffd166}.skin-swatch.selected:after{content:"✓";position:absolute;top:-6px;right:-6px;width:18px;height:18px;border-radius:50%;display:grid;place-items:center;font-size:11px;font-weight:900;line-height:1;color:#0a1a2f;background:#ffd166;box-shadow:0 2px 6px #00000073,0 0 8px #ffd16699}.skin-swatch.soon{opacity:.4;cursor:default}.skin-swatch.soon:hover{transform:none;border-color:#78b4ff2e;color:#c7d7e8;box-shadow:inset 0 1px #96bef012}.skin-dot{width:30px;height:30px;border-radius:50%;border:1px solid rgba(0,0,0,.45);box-shadow:inset 0 2px 4px #ffffff59,inset 0 -4px 7px #00000073,0 0 7px currentColor;transition:box-shadow .12s ease,transform .12s ease}.skin-swatch:hover:not(:disabled) .skin-dot{transform:scale(1.06)}.skin-swatch.selected .skin-dot{transform:scale(1.06);box-shadow:inset 0 2px 4px #fff6,inset 0 -4px 7px #00000073,0 0 10px currentColor,0 0 0 2px #ffd1668c}.skin-label{font-size:11px;font-weight:700;letter-spacing:.02em;font-variant-numeric:tabular-nums}.ship-hint{margin:2px 0 0;color:#9bb0c4;font-size:12px;line-height:1.5}.ship-hint.dim{margin-top:auto;padding-top:12px;border-top:1px solid rgba(120,180,255,.12);color:#6a86a4;font-style:italic}.item-icon{display:inline-flex;line-height:0;flex:0 0 auto}.item-tip{position:fixed;z-index:100;padding:10px 12px;border-radius:10px;background:#081220f5;border:1px solid rgba(120,180,255,.35);box-shadow:0 12px 30px #0000008c;pointer-events:none}.item-tip-name{font-size:14px;font-weight:800;line-height:1.15}.item-tip-kind{font-size:10px;text-transform:uppercase;letter-spacing:.7px;color:#7fa3c4;margin:2px 0 6px}.item-tip-desc{font-size:12px;color:#cfe0f0;line-height:1.4}.item-tip-sell{margin-top:6px;font-size:12px;color:#ffd166;font-weight:600}.map-toolbar{position:fixed;top:16px;right:16px;z-index:70;display:flex;gap:10px}.map-btn{display:flex;align-items:center;gap:8px;padding:8px 14px;border-radius:12px;background:#0a1626e6;border:1px solid rgba(96,140,190,.32);color:#eaf3ff;font-size:14px;font-weight:600;cursor:pointer}.map-btn:hover{filter:brightness(1.12)}.game-root.touch .hud-keys,.game-root.touch .tb-key,.game-root.touch .ammo-key,.game-root.touch .debug-tools,.game-root.touch .action-bar,.game-root.touch .talent-btn,.game-root.touch .settings-btn,.game-root.touch .hud,.game-root.touch .faction-war{display:none}.game-root.touch{-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}.game-root.touch .touch-joystick{position:fixed;left:14px;bottom:18px;width:116px;height:116px;z-index:30;touch-action:none;opacity:.4;transition:opacity .25s ease}.game-root.touch .touch-joystick.active{opacity:1}.game-root.touch .tj-base{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:radial-gradient(circle,#78b4ff24,#08122073);border:2px solid rgba(150,200,255,.4);box-shadow:inset 0 0 18px #00000073}.game-root.touch .tj-ring{position:absolute;top:-7px;right:-7px;bottom:-7px;left:-7px;border-radius:50%;-webkit-mask:radial-gradient(farthest-side,transparent calc(100% - 5px),#000 calc(100% - 5px));mask:radial-gradient(farthest-side,transparent calc(100% - 5px),#000 calc(100% - 5px));pointer-events:none}.game-root.touch .tj-power{position:absolute;top:-2px;left:50%;transform:translate(-50%);font-size:11px;font-weight:700;color:#cfe2f7;text-shadow:0 1px 2px #000;pointer-events:none}.game-root.touch .tj-knob{position:absolute;left:50%;top:50%;width:50px;height:50px;margin:-25px 0 0 -25px;border-radius:50%;background:radial-gradient(circle at 40% 35%,#bed7fff2,#5078b4e6);border:1px solid rgba(255,255,255,.55);box-shadow:0 2px 8px #00000080;pointer-events:none}.game-root.touch .tj-knob.active{background:radial-gradient(circle at 40% 35%,#eaf3ff,#6aa0d8)}.game-root.touch .touch-aimstick{position:fixed;right:14px;bottom:18px;width:116px;height:116px;z-index:30;touch-action:none;opacity:.4;transition:opacity .25s ease}.game-root.touch .touch-aimstick.active{opacity:1}.game-root.touch .as-base{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:radial-gradient(circle,#ffbe7824,#200e0873);border:2px solid rgba(255,200,120,.4);box-shadow:inset 0 0 18px #00000073}.game-root.touch .as-knob{position:absolute;left:50%;top:50%;width:50px;height:50px;margin:-25px 0 0 -25px;border-radius:50%;background:radial-gradient(circle at 40% 35%,#ffdcaaf2,#c87846e6);border:1px solid rgba(255,255,255,.55);box-shadow:0 2px 8px #00000080;pointer-events:none}.game-root.touch .as-knob.active{background:radial-gradient(circle at 40% 35%,#fff0dd,#e0935a)}.game-root.touch .touch-actions{position:fixed;top:8px;right:8px;z-index:40;display:flex;gap:8px}.game-root.touch .touch-btn{width:46px;height:46px;border-radius:12px;background:#0a1626eb;border:1px solid rgba(96,140,190,.4);color:#eaf3ff;font-size:20px;line-height:1;display:grid;place-items:center;pointer-events:auto;cursor:pointer}.game-root.touch .touch-btn.on{border-color:#ffd166;box-shadow:0 0 0 2px #ffd1664d}.game-root.touch .touch-menu{position:fixed;top:60px;right:8px;z-index:41;display:flex;flex-direction:column;gap:6px;padding:8px;border-radius:12px;background:#081220f5;border:1px solid rgba(120,180,255,.3);box-shadow:0 16px 40px #0000008c;pointer-events:auto}.game-root.touch .touch-menu-item{padding:12px 16px;border-radius:10px;background:#0c2138cc;border:1px solid rgba(120,180,255,.2);color:#eaf3ff;font-size:15px;font-weight:600;text-align:left;white-space:nowrap;cursor:pointer}.game-root.touch .touch-sail-cluster{position:fixed;left:16px;bottom:144px;z-index:40;display:flex;flex-direction:row;align-items:center;gap:8px}.game-root.touch .touch-sail,.game-root.touch .touch-repair{width:32px;height:32px;border-radius:50%;background:#0a1626e6;border:1px solid rgba(96,140,190,.4);color:#eaf3ff;font-size:15px;line-height:1;pointer-events:auto;cursor:pointer;touch-action:none}.game-root.touch .touch-repair{color:#9be6b4;border-color:#78dca080}.game-root.touch .touch-interact{position:fixed;right:12px;top:50%;transform:translateY(-50%);z-index:42;display:flex;flex-direction:column;gap:10px}.game-root.touch .touch-interact-btn{padding:12px 16px;border-radius:12px;background:#0a1626f2;border:1px solid rgba(96,140,190,.4);color:#eaf3ff;font-size:15px;font-weight:700;white-space:nowrap;pointer-events:auto;cursor:pointer}.game-root.touch .touch-interact-btn.trade{border-color:#ffd166;box-shadow:0 0 12px #ffd1664d}.game-root.touch .touch-interact-btn.ship{border-color:#8fd0ff;box-shadow:0 0 12px #8fd0ff4d}.game-root.touch .touch-place-surface{position:fixed;top:0;right:0;bottom:0;left:0;z-index:45;touch-action:none}.game-root.touch .touch-place-hint{position:fixed;top:14px;left:50%;transform:translate(-50%);z-index:46;padding:8px 16px;border-radius:10px;background:#081628d9;border:1px solid rgba(120,180,255,.4);color:#9fd0ff;font-size:14px;font-weight:600;white-space:nowrap;pointer-events:none}.game-root.touch .touch-place-actions{position:fixed;bottom:18px;left:50%;transform:translate(-50%);z-index:46;display:flex;gap:14px}.game-root.touch .touch-place-btn{padding:14px 28px;border-radius:12px;font-size:16px;font-weight:700;border:1px solid rgba(120,180,255,.4);background:#0a1626f2;color:#eaf3ff;pointer-events:auto;cursor:pointer}.game-root.touch .touch-place-btn.confirm{background:#ffd166;color:#0a1a2f;border-color:#ffd166}.game-root.touch .touch-place-btn.cancel{border-color:#e05a4a80;color:#f3b4ac}.game-root.touch .topbars{top:6px;left:6px;flex-direction:column;align-items:flex-start;gap:4px;transform:scale(.72);transform-origin:top left}.game-root.touch .vitals{grid-template-columns:24px 128px auto}.game-root.touch .vitals .vital:last-child{display:none}.game-root.touch .ammo-bar{display:none}.game-root.touch .touch-ammo{position:fixed;left:50%;bottom:14px;transform:translate(-50%);z-index:36;width:56px;height:56px;pointer-events:none}.game-root.touch .touch-ammo-btn{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:radial-gradient(circle at 50% 34%,#222e3af5,#080d13fa);border:1px solid rgba(232,185,100,.7);box-shadow:0 4px 14px #0000008c;display:grid;place-items:center;pointer-events:auto;cursor:pointer;touch-action:none}.game-root.touch .touch-ammo-btn.open{box-shadow:0 0 0 2px #e8b96499,0 4px 18px #e8b9644d}.game-root.touch .touch-ammo-btn img{width:34px;height:28px;object-fit:contain;filter:drop-shadow(0 2px 3px rgba(0,0,0,.55))}.game-root.touch .touch-ammo-opt{position:absolute;left:50%;top:50%;width:50px;height:50px;margin:-25px 0 0 -25px;border-radius:50%;background:radial-gradient(circle at 50% 34%,#222e3af5,#080d13fa);border:1px solid rgba(130,150,170,.45);box-shadow:0 4px 14px #0000008c;display:grid;place-items:center;pointer-events:none}.game-root.touch .touch-ammo-opt img{width:30px;height:24px;object-fit:contain}.game-root.touch .touch-ammo-opt.sel{border-color:#e8b964b3}.game-root.touch .touch-ammo-opt.empty{opacity:.45}.game-root.touch .touch-ammo-opt.hi{border-color:#e8b964;background:radial-gradient(circle at 50% 34%,#50421efa,#140e06fa);box-shadow:0 0 0 3px #e8b964b3,0 4px 18px #e8b96480}.game-root.touch .touch-ammo-count{position:absolute;right:2px;bottom:0;font-size:10px;font-weight:800;color:#ffd166;text-shadow:0 0 3px #000,0 1px 2px #000}.game-root.touch .cargo{top:126px;bottom:auto;left:6px;padding:6px 8px;gap:6px;transform:scale(.8);transform-origin:top left}.game-root.touch .inventory{grid-template-columns:repeat(4,30px)}.game-root.touch .inv-item{width:30px;height:30px}.game-root.touch .chatbox{display:none}.game-root.touch.portrait .topbars{transform:scale(.7)}.game-root.touch .tt-overlay{place-items:start center;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:max(10px,env(safe-area-inset-top)) max(10px,env(safe-area-inset-right)) max(10px,env(safe-area-inset-bottom)) max(10px,env(safe-area-inset-left))}.game-root.touch .shop-panel,.game-root.touch .ship-panel,.game-root.touch .craft-panel,.game-root.touch .settings-panel,.game-root.touch .tt-panel{width:min(96vw,460px);max-width:96vw;max-height:calc(100dvh - 20px);overflow-y:auto;-webkit-overflow-scrolling:touch;padding:16px;border-radius:14px;box-sizing:border-box}.game-root.touch .ship-panel{width:min(96vw,680px)}.game-root.touch .craft-panel{width:min(96vw,1000px);height:auto;max-height:calc(100dvh - 24px)}.game-root.touch .tt-panel{width:min(96vw,1000px)}.game-root.touch .tt-close{width:44px;height:44px;border-radius:10px;font-size:18px;flex:0 0 auto}.game-root.touch .tt-header{margin-bottom:12px;gap:8px}.game-root.touch .tt-header h2{font-size:19px;letter-spacing:.5px}.game-root.touch .tt-meta{gap:8px;font-size:13px}.game-root.touch .tt-foot{margin-top:12px;font-size:11px;line-height:1.45}.game-root.touch .shop-row{gap:10px;padding:10px 12px;border-radius:12px}.game-root.touch .shop-name{font-size:14px;gap:8px;min-width:0}.game-root.touch .shop-have{font-size:13px;flex:0 0 auto}.game-root.touch .shop-buy{min-height:44px;padding:8px 16px;font-size:14px;border-radius:10px;flex:0 0 auto}.game-root.touch .ship-owned,.game-root.touch .ship-locked{min-height:44px;display:flex;align-items:center;font-size:13px}.game-root.touch .craft-inputs{flex-wrap:wrap;gap:6px 10px}.game-root.touch .craft-ing{font-size:12px}.game-root.touch.portrait .shop-row{flex-wrap:wrap}.game-root.touch.portrait .shop-name{flex:1 1 60%}.game-root.touch.portrait .shop-buy{flex:1 1 100%;justify-content:center}.game-root.touch .craft-scroll,.game-root.touch .craft-queue,.game-root.touch .craft-cargo-scroll{-webkit-overflow-scrolling:touch}.game-root.touch .craft-tabs{gap:8px;margin-bottom:10px}.game-root.touch .craft-tab{min-height:44px;padding:8px 16px;font-size:14px}.game-root.touch .craft-grid{grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:10px}.game-root.touch .craft-card:hover{transform:none;box-shadow:none}.game-root.touch .craft-chip{padding:5px 9px 5px 6px;font-size:13px}.game-root.touch .craft-make{gap:6px}.game-root.touch .craft-make-btn{min-height:44px;font-size:14px}.game-root.touch .craft-job{padding:9px;gap:10px}.game-root.touch .craft-cancel{width:44px;height:44px;font-size:16px}.game-root.touch.portrait .craft-layout{flex-direction:column}.game-root.touch.portrait .craft-scroll{flex:1 1 auto}.game-root.touch.portrait .craft-cargo{width:auto;flex:0 0 auto;border-left:none;border-top:1px solid rgba(120,180,255,.15);padding-left:0;padding-top:12px}.game-root.touch.portrait .craft-cargo-scroll{max-height:160px}.game-root.touch.landscape .craft-cargo{width:240px}.game-root.touch .ship-preview{width:min(74vw,328px);height:auto;aspect-ratio:1 / 1}.game-root.touch .ship-preview-wrap{flex:0 1 auto;max-width:100%;align-self:center;padding:12px}.game-root.touch .skin-row{gap:10px}.game-root.touch .skin-swatch{min-height:56px;padding:12px 6px 11px}.game-root.touch.portrait .ship-body{flex-direction:column;gap:16px;padding:12px 2px 2px;align-items:stretch}.game-root.touch.portrait .ship-cosmetics{flex:0 0 auto}.game-root.touch.landscape .ship-body{gap:16px;padding:12px 2px 2px}.game-root.touch.landscape .ship-preview{width:min(40vw,328px)}.game-root.touch .tt-tree-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}.game-root.touch .tt-tree-tab{flex:1 1 auto;min-height:44px;padding:8px 14px;border-radius:9px;border:1px solid rgba(120,180,255,.25);background:#0c2138b3;color:#cfe2f7;font-size:14px;font-weight:700;cursor:pointer}.game-root.touch .tt-tree-tab.active{background:#ffd166;color:#0a1a2f;border-color:#ffd166}.game-root.touch .tt-trees{justify-content:center}.game-root.touch .tt-node{-webkit-tap-highlight-color:transparent}.game-root.touch .tt-node.can:active{filter:brightness(1.2)}.game-root.touch .tt-tip{width:auto;max-width:min(78vw,250px)}.game-root.touch .tt-tip-desc,.game-root.touch .tt-tip-req,.game-root.touch .tt-tip-foot{font-size:12px}.game-root.touch .set-row{padding:12px 0;gap:10px}.game-root.touch .set-label{font-size:15px}.game-root.touch .seg{flex-wrap:wrap}.game-root.touch .seg button{min-height:44px;padding:10px 16px;font-size:14px;flex:1 1 auto}.game-root.touch.portrait .set-row{flex-direction:column;align-items:stretch}.game-root.touch.portrait .seg{width:100%}.game-root.touch.portrait .seg button{flex:1 1 33%}
