: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;max-width:360px;padding:8px 12px;border-radius:10px;background:#08162899;border:1px solid rgba(120,180,255,.2);color:#cfe2f7;font-size:13px;line-height:1.5;pointer-events:none}.hud b{color:#ffd166}.topbars{position:fixed;top:10px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:5px;pointer-events:none}.health,.xp{display:flex;align-items:center;gap:8px}.xp-bar{width:220px;height:8px;border-radius:5px;background:#081628b3;border:1px solid rgba(120,180,255,.25);overflow:hidden}.xp-fill{height:100%;background:linear-gradient(90deg,#6fb6ff,#b388ff);transition:width .2s ease}.xp-text{color:#cfe2f7;font-size:12px;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.6)}.sails{display:flex;align-items:center;gap:8px}.sail-label{color:#cfe2f7;font-size:12px;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.6)}.sail-bar{width:160px;height:8px;border-radius:5px;background:#081628b3;border:1px solid rgba(120,180,255,.25);overflow:hidden}.sail-fill{height:100%;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}.health-bar{width:220px;height:14px;border-radius:7px;background:#081628b3;border:1px solid rgba(120,180,255,.3);overflow:hidden}.health-fill{height:100%;transition:width .15s ease,background .2s ease}.health-text{color:#cfe2f7;font-size:12px;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.6)}.inventory{position:fixed;left:12px;bottom:196px;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:6px;background:#081628b3;border:1px solid rgba(120,180,255,.2)}.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:#081628cc;border:1px solid rgba(120,180,255,.3);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{position:fixed;top:54px;right:12px;z-index:20;display:flex;flex-wrap:wrap;justify-content:flex-end;gap:4px;max-width:230px}.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:10px;background:#081628d9;border:1px solid rgba(120,180,255,.3);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:12px;left:50%;transform:translate(-50%);z-index:14;display:flex;gap:6px}.ammo-slot{display:flex;flex-direction:column;align-items:center;gap:2px;width:64px;padding:6px 4px 5px;border-radius:9px;background:#081628d1;border:1px solid rgba(120,180,255,.22);color:#cfe0f2;cursor:pointer;position:relative}.ammo-slot.sel{border-color:#ffd166;box-shadow:0 0 12px #ffd16659;background:#182840e6}.ammo-slot.empty{opacity:.45}.ammo-key{position:absolute;top:2px;left:5px;font-size:9px;color:#6a86a4}.ammo-dot{width:14px;height:14px;border-radius:50%;box-shadow:inset 0 0 0 1px #00000059}.ammo-name{font-size:11px;font-weight:600}.ammo-count{font-size:11px;font-weight:700;color:#ffd166}.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:44px;height:44px;border-radius:50%;background:#081628c7;border:1px solid rgba(120,180,255,.3)}.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:#081628cc;border:1px solid rgba(120,180,255,.3);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(96vw,720px)}.ship-body{display:flex;gap:18px;padding:14px 16px 18px}.ship-diagram{position:relative;width:150px;flex:0 0 150px;min-height:340px}.ship-hull{position:absolute;left:28px;right:28px;top:6%;bottom:6%;background:linear-gradient(180deg,#b48b5a,#8a6740 60%,#6f5230);border:2px solid #4a3620;clip-path:polygon(50% 0%,82% 9%,100% 34%,100% 90%,84% 100%,16% 100%,0% 90%,0% 34%,18% 9%);box-shadow:inset 0 0 18px #00000059}.ship-end{position:absolute;left:0;right:0;text-align:center;color:#9bb3cc;font-size:11px;font-weight:700}.ship-bow{top:-16px}.ship-stern{bottom:-16px}.cannon-slot{position:absolute;width:50px;margin-top:-22px;display:flex;flex-direction:column;align-items:center;gap:1px;padding:3px 0;border-radius:8px;background:#081628d9;border:1px dashed rgba(120,180,255,.4);color:#9fb6cc;cursor:pointer;-webkit-user-select:none;user-select:none}.cannon-slot.filled{border-style:solid;background:#182840eb;color:#eaf3ff}.cannon-slot:hover{border-color:#ffd166}.cannon-basic{font-size:20px;line-height:18px;color:#5a7a98;opacity:.7}.cannon-slot-tag{font-size:10px;font-weight:700}.ship-arsenal{flex:1;min-width:0}.ship-arsenal h3{margin:6px 0;color:#8fd0ff;font-size:14px}.ship-hint{margin:0 0 10px;color:#9bb0c4;font-size:12px;line-height:1.45}.ship-hint.dim{color:#6a86a4;font-style:italic}.cannon-tray{display:flex;flex-wrap:wrap;gap:8px}.cannon-chip{display:flex;flex-direction:column;align-items:center;gap:1px;width:92px;padding:8px 6px 6px;border-radius:10px;background:#081628d9;border:1px solid rgba(120,180,255,.3);color:#eaf3ff;cursor:grab}.cannon-chip:active{cursor:grabbing}.cannon-chip.empty{opacity:.4;cursor:default}.cannon-chip-label{font-size:12px;font-weight:700}.cannon-chip-mult{font-size:11px;color:#ffd166}.cannon-chip-count{font-size:11px;color:#9bb0c4}.ship-inventory{display:flex;flex-wrap:wrap;gap:6px 14px}.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}
