@import"https://fonts.googleapis.com/css2?family=Pirata+One&family=IM+Fell+English:ital@0;1&display=swap";:root{color:#f5f7fb;background:#06131f;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html,body,#root{width:100%;height:100%;margin:0;overflow:hidden}button{font:inherit}input{min-width:0;font:inherit}.appShell{position:fixed;inset:0;background:#071923}.pirate-hud{position:fixed;left:16px;top:16px;display:grid;gap:5px;min-width:210px;padding:12px 14px;color:var(--parchment);background:linear-gradient(180deg,#fff0c80d,#00000029),linear-gradient(180deg,var(--wood-light),var(--wood-dark));border:2px solid var(--gold);border-radius:10px;box-shadow:0 0 0 4px var(--wood-darkest),0 10px 26px #00000073}.hud-title{font-family:var(--pirate-display);font-size:22px;letter-spacing:1px;color:var(--gold-bright);text-shadow:0 2px 0 #241505}.hud-line{font-family:var(--pirate-body);font-size:13px;color:var(--parchment)}.hud-line.dim{color:#ecdbb299;font-size:12px}.hud-line.ok{color:#a7d29a}.hud-line.warn{color:#e6b45a}.hudLogout{justify-self:start;margin-top:4px;padding:3px 8px;font-family:var(--pirate-body);font-size:12px;color:var(--parchment);cursor:pointer;background:#1c110994;border:1px solid rgba(192,145,78,.7);border-radius:6px}.authShell{position:fixed;inset:0;display:grid;place-items:center;background:radial-gradient(circle at 50% 38%,rgba(20,84,98,.42),transparent 34%),linear-gradient(180deg,#071923,#03080d)}.authPanel{width:min(92vw,420px)}.authSwitch{margin-bottom:14px}.authPanel input{width:100%;padding:10px 11px;color:var(--parchment);background:#120b06b8;border:2px solid rgba(192,145,78,.72);border-radius:8px;outline:none}.authPanel input:focus{border-color:var(--gold-bright)}.authError{margin:8px 0;font-family:var(--pirate-body);color:#f0a05d;text-align:center}.shipStatus{display:grid;gap:5px;margin:5px 0 2px}.hudBar{display:grid;grid-template-columns:52px 1fr 46px;gap:7px;align-items:center;font-family:var(--pirate-body);font-size:12px}.hudBarTrack{height:9px;overflow:hidden;background:#0f0804b8;border:1px solid rgba(192,145,78,.58);border-radius:999px;box-shadow:inset 0 1px 4px #000000b3}.hudBarTrack i{display:block;height:100%;border-radius:inherit;transition:width .18s ease}.hudBarTrack .hull{background:linear-gradient(90deg,#9c3325,#f0a05d)}.hudBarTrack .sails{background:linear-gradient(90deg,#d7d0bc,#f6f1df)}.hudBarTrack .crew{background:linear-gradient(90deg,#477c5d,#9bd29d)}.hudBar em{color:var(--parchment-dim);font-style:normal;text-align:right}.minimap-frame{position:fixed;right:18px;bottom:18px;width:190px;height:190px;border-radius:50%;padding:0;background:radial-gradient(circle at 50% 50%,transparent 62%,var(--wood) 66%,var(--wood-dark) 100%);border:3px solid var(--gold);box-shadow:0 0 0 5px var(--wood-darkest),0 10px 26px #00000080}.minimap-canvas{position:absolute;inset:0;border-radius:50%;clip-path:circle(49% at 50% 50%)}.compass{position:absolute;font-family:var(--pirate-display);font-size:14px;color:var(--gold-bright);text-shadow:0 1px 2px #000}.compass.n{top:2px;left:50%;transform:translate(-50%)}.compass.s{bottom:2px;left:50%;transform:translate(-50%)}.compass.e{right:4px;top:50%;transform:translateY(-50%)}.compass.w{left:4px;top:50%;transform:translateY(-50%)}.map-panel{width:min(88vmin,880px);max-height:96vh;overflow:auto;padding:18px 22px}.map-canvas-wrap{display:grid;place-items:center;padding:6px;background:var(--wood-darkest);border:2px solid var(--rope);border-radius:10px;box-shadow:inset 0 2px 14px #0009}.map-canvas{width:min(62vmin,680px);height:min(62vmin,680px);border-radius:4px}.map-legend{display:flex;flex-wrap:wrap;gap:8px 16px;align-items:center;justify-content:center;margin:14px 0;font-family:var(--pirate-body);font-size:13px;color:var(--parchment-dim)}.map-legend .dot{display:inline-block;width:11px;height:11px;margin-right:5px;border-radius:50%;vertical-align:-1px}.map-legend .dot.self{background:#ffd66b}.map-legend .dot.other{background:#e4614b}.map-legend .dot.land{background:#d8c08a}.map-legend .dot.wreck{background:#3a2a1c;border:1px solid #6b5238}.map-legend .map-scale{font-style:italic;color:#ecdbb28c}.debugPanel{position:fixed;right:16px;top:16px;display:grid;gap:4px;min-width:180px;padding:10px 12px;border:1px solid rgba(126,215,193,.35);border-radius:8px;background:#050e18d1;font-variant-numeric:tabular-nums}.debugPanel strong{font-size:12px;color:#7ed7c1}.debugPanel span{color:#f5f7fbd1;font-size:12px}:root{--sea-abyss: #06131f;--wood-darkest: #1c1109;--wood-dark: #2b1a0f;--wood: #3d2717;--wood-light: #5c3c23;--parchment: #ecdbb2;--parchment-dim: #cdb890;--gold: #d9a441;--gold-bright: #f3ca6d;--rope: #c0914e;--ink: #2a1c0f;--danger: #9c3325;--blood: #7c1a12;--blood-bright: #b52a1c;--steel: #9fb0bb;--pirate-display: "Pirata One", "IM Fell English", Georgia, "Times New Roman", serif;--pirate-body: "IM Fell English", Georgia, serif}.pirate-scrim{position:fixed;inset:0;display:grid;place-items:center;background:radial-gradient(circle at 50% 40%,#0a1622b8,#03080ee0);z-index:20}.pirate-panel{position:relative;color:var(--parchment);background:linear-gradient(180deg,#fff0c80f,#0000002e),linear-gradient(180deg,var(--wood-light),var(--wood) 42%,var(--wood-dark));border:3px solid var(--gold);border-radius:14px;box-shadow:0 0 0 6px var(--wood-darkest),0 18px 44px #0000008c,inset 0 2px #ffecbe2e,inset 0 -14px 30px #0006;padding:26px 30px}.pirate-panel:before,.pirate-panel:after{content:"";position:absolute;width:12px;height:12px;border-radius:50%;background:radial-gradient(circle at 35% 30%,var(--gold-bright),#7a5320 70%);box-shadow:0 1px 2px #0009;top:10px}.pirate-panel:before{left:10px}.pirate-panel:after{right:10px}.pirate-title{margin:0 0 4px;font-family:var(--pirate-display);font-weight:400;letter-spacing:1.5px;color:var(--gold-bright);text-shadow:0 2px 0 #2a1a0a,0 0 18px rgba(240,200,110,.35);text-align:center}.pirate-title.xl{font-size:40px}.pirate-title.lg{font-size:28px}.pirate-subtitle{margin:0 0 18px;text-align:center;font-family:var(--pirate-body);font-style:italic;color:var(--parchment-dim);font-size:14px}.pirate-rule{height:3px;margin:12px 0;border:0;background:linear-gradient(90deg,transparent,var(--rope),transparent)}.pirate-btn{display:block;width:100%;margin:8px 0;padding:12px 16px;font-family:var(--pirate-body);font-size:17px;letter-spacing:.5px;color:var(--parchment);text-align:center;cursor:pointer;background:linear-gradient(180deg,var(--wood-light),var(--wood-dark));border:2px solid var(--rope);border-radius:9px;box-shadow:inset 0 1px #ffecbe24,0 3px 8px #00000059;transition:transform .08s ease,filter .12s ease,border-color .12s ease}.pirate-btn:hover{transform:translateY(-1px);filter:brightness(1.12);border-color:var(--gold)}.pirate-btn:active{transform:translateY(1px)}.pirate-btn.primary{color:var(--ink);font-weight:700;background:linear-gradient(180deg,var(--gold-bright),var(--gold));border-color:#8a5f22}.pirate-btn.danger{color:#f4e3d0;background:linear-gradient(180deg,#b5442f,var(--danger));border-color:#61201a}.pirate-segment{display:grid;grid-auto-flow:column;gap:6px}.pirate-segment button{padding:8px 10px;font-family:var(--pirate-body);font-size:14px;color:var(--parchment);cursor:pointer;background:linear-gradient(180deg,var(--wood-light),var(--wood-dark));border:2px solid var(--rope);border-radius:8px;text-transform:capitalize}.pirate-segment button.active{color:var(--ink);font-weight:700;background:linear-gradient(180deg,var(--gold-bright),var(--gold));border-color:#8a5f22}.pirate-field{display:grid;gap:6px;margin:14px 0}.pirate-field>span{font-family:var(--pirate-body);font-size:14px;color:var(--parchment-dim);letter-spacing:.4px}.pirate-hint{margin-top:14px;text-align:center;font-family:var(--pirate-body);font-style:italic;font-size:12px;color:#ecdbb299}.inventory-panel{width:min(92vmin,720px);max-height:94vh;overflow:auto}.inv-goldbar{display:flex;align-items:center;justify-content:space-between;margin-top:2px;font-family:var(--pirate-body)}.inv-gold{font-size:18px;color:var(--gold-bright);text-shadow:0 1px 2px #000}.inv-weight{font-size:13px;color:var(--parchment-dim)}.inv-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px}.inv-stat{display:grid;gap:1px;min-width:0;padding:8px 10px;text-align:center;background:#120b067a;border:1px solid rgba(192,145,78,.55);border-radius:8px}.inv-stat b{font-family:var(--pirate-display);font-size:20px;font-weight:400;color:var(--gold-bright)}.inv-stat small{overflow:hidden;font-family:var(--pirate-body);font-size:11px;color:var(--parchment-dim);text-overflow:ellipsis;white-space:nowrap}.inv-body{display:grid;grid-template-columns:1fr 210px;gap:16px}.inv-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}.inv-slot{position:relative;aspect-ratio:1;padding:0;border:2px solid rgba(120,92,52,.7);border-radius:8px;background:linear-gradient(180deg,#00000047,#0000006b);box-shadow:inset 0 2px 8px #00000080;cursor:default}.inv-slot.filled{cursor:pointer;background:linear-gradient(180deg,var(--wood-light),var(--wood-dark))}.inv-slot.filled:hover{filter:brightness(1.12)}.inv-slot.active{outline:2px solid var(--gold-bright);outline-offset:1px}.inv-slot.common{border-color:#7a6a52}.inv-slot.fine{border-color:#4f9d76}.inv-slot.rare{border-color:#4f7fd0}.inv-slot.legendary{border-color:var(--gold-bright);box-shadow:inset 0 2px 8px #00000080,0 0 12px #f3ca6d59}.inv-mark{display:inline-grid;place-items:center;width:38px;height:38px;font-family:var(--pirate-display);font-size:19px;line-height:1;color:#1c1109;background:linear-gradient(180deg,var(--parchment),var(--rope));border:2px solid rgba(28,17,9,.5);border-radius:50%;box-shadow:inset 0 1px #fff3,0 2px 6px #00000059}.inv-mark.ammo,.inv-detail-icon.ammo{background:linear-gradient(180deg,#d0d3cf,#5f6766)}.inv-mark.supply,.inv-detail-icon.supply{background:linear-gradient(180deg,#d8a160,#79431f)}.inv-mark.treasure,.inv-detail-icon.treasure{background:linear-gradient(180deg,#ffb1b1,#9c3325)}.inv-mark.chart,.inv-detail-icon.chart{background:linear-gradient(180deg,#f0dfb8,#b9914d)}.inv-mark.key,.inv-detail-icon.key{background:linear-gradient(180deg,#ffe28a,#a16e21)}.inv-qty{position:absolute;right:3px;bottom:2px;padding:0 4px;font-family:var(--pirate-body);font-size:12px;color:#fff;background:#0009;border-radius:5px}.inv-detail{display:grid;align-content:start;gap:6px;padding:14px;text-align:center;background:var(--wood-darkest);border:2px solid var(--rope);border-radius:10px}.inv-detail-icon{display:inline-grid;place-items:center;justify-self:center;width:64px;height:64px;margin-bottom:4px;font-family:var(--pirate-display);font-size:28px;line-height:1;color:#1c1109;border:3px solid rgba(28,17,9,.5);border-radius:50%;box-shadow:inset 0 1px #ffffff2e,0 5px 14px #00000061}.inv-detail-name{margin:0;font-family:var(--pirate-display);font-size:22px;color:var(--parchment)}.inv-rarity{justify-self:center;padding:2px 10px;border-radius:999px;font-family:var(--pirate-body);font-size:12px;color:#0d0a06}.inv-rarity.common{background:#b6a789}.inv-rarity.fine{background:#6fc79a}.inv-rarity.rare{background:#7aa6e6}.inv-rarity.legendary{background:var(--gold-bright)}.inv-detail-qty{margin:4px 0 0;font-family:var(--pirate-body);color:var(--parchment-dim)}.inv-detail-note{margin:6px 0 0;font-family:var(--pirate-body);font-style:italic;font-size:13px;color:#ecdbb2b8}.inv-detail-empty{font-family:var(--pirate-body);font-style:italic;color:var(--parchment-dim)}@media(max-width:760px){.inventory-panel{width:min(94vw,520px);padding:22px 18px}.inv-body{grid-template-columns:1fr}.inv-grid{grid-template-columns:repeat(4,1fr)}.inv-summary{grid-template-columns:1fr}.inv-detail{min-height:156px}}.captain-card{position:fixed;left:16px;top:16px;display:flex;align-items:center;gap:10px;padding:8px 12px 8px 8px;color:var(--parchment);background:linear-gradient(180deg,#3c2717f5,#1c1109f5);border:2px solid var(--gold);border-radius:10px;box-shadow:0 0 0 3px var(--wood-darkest),0 8px 22px #00000080}.captain-crest{display:grid;place-items:center;width:40px;height:40px;font-size:22px;color:#f4e6c8;background:radial-gradient(circle at 40% 35%,var(--blood-bright),var(--blood) 70%);border:2px solid var(--gold);border-radius:8px;box-shadow:inset 0 -4px 8px #00000080}.captain-info{display:grid;gap:1px}.captain-name{font-family:var(--pirate-display);font-size:19px;letter-spacing:.6px;color:var(--gold-bright);text-shadow:0 1px 2px #000}.captain-sub{font-family:var(--pirate-body);font-size:12px;color:var(--parchment)}.captain-sub.dim{color:#ecdbb299}.captain-leave{margin-left:4px;width:32px;height:32px;font-size:16px;color:var(--parchment);cursor:pointer;background:linear-gradient(180deg,var(--wood-light),var(--wood-dark));border:2px solid var(--rope);border-radius:8px}.captain-leave:hover{border-color:var(--gold);filter:brightness(1.1)}.hud-status{position:fixed;left:18px;bottom:20px;display:grid;gap:7px;width:232px;padding:12px 14px;background:linear-gradient(180deg,#2b1a0ff0,#140c06f0);border:2px solid var(--gold);border-radius:10px;box-shadow:0 0 0 3px var(--wood-darkest),0 8px 22px #00000080}.stat-bar{display:grid;grid-template-columns:46px 1fr;align-items:center;gap:8px}.stat-label{font-family:var(--pirate-body);font-size:13px;color:var(--parchment-dim);text-transform:uppercase;letter-spacing:.5px}.stat-track{position:relative;height:16px;border:1px solid rgba(0,0,0,.55);border-radius:4px;background:#0000006b;box-shadow:inset 0 1px 3px #0009;overflow:hidden}.stat-fill{position:absolute;inset:0 auto 0 0;height:100%;border-radius:3px;transition:width .18s ease}.stat-fill.hull{background:linear-gradient(180deg,#d8483a,var(--blood))}.stat-fill.sails{background:linear-gradient(180deg,#e7d6ad,#b79458)}.stat-fill.crew{background:linear-gradient(180deg,#5aa2c8,#2f6f92)}.stat-text{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--pirate-body);font-size:11px;font-style:normal;color:#fff;text-shadow:0 1px 2px #000}.hud-onfire{margin-top:2px;text-align:center;font-family:var(--pirate-display);font-size:14px;letter-spacing:1px;color:#ffce7a;text-shadow:0 0 10px rgba(255,90,30,.8);animation:firePulse .9s ease-in-out infinite}@keyframes firePulse{0%,to{opacity:.65}50%{opacity:1}}.hud-dock{position:fixed;left:50%;bottom:16px;transform:translate(-50%);display:flex;align-items:flex-end;gap:16px}.reload-wheel{position:relative;width:132px;height:132px;display:grid;place-items:center;filter:drop-shadow(0 6px 14px rgba(0,0,0,.55))}.reload-svg{position:absolute;inset:0;width:100%;height:100%}.reload-track{fill:#0c0703d1;stroke:#241505;stroke-width:10}.reload-fill{fill:none;stroke:var(--gold-bright);stroke-width:9;stroke-linecap:round;transform:rotate(-90deg);transform-origin:65px 65px;transition:stroke .2s ease}.reload-wheel.reloading .reload-fill{stroke:var(--blood-bright)}.reload-wheel.secured .reload-fill{stroke:#6b5238}.cannon-pip{fill:#4a3418;stroke:var(--rope);stroke-width:1}.reload-wheel.ready .cannon-pip{fill:var(--gold-bright)}.reload-center{display:grid;justify-items:center;gap:0;z-index:1}.reload-glyph{font-size:34px;line-height:1;filter:drop-shadow(0 1px 2px #000)}.reload-count{font-family:var(--pirate-body);font-size:13px;color:var(--parchment)}.broadside-tag{position:absolute;top:6px;left:50%;transform:translate(-50%);font-family:var(--pirate-display);font-size:11px;letter-spacing:1px;color:var(--gold-bright);text-shadow:0 1px 2px #000;white-space:nowrap;z-index:1}.reload-state{position:absolute;bottom:4px;left:50%;transform:translate(-50%);font-family:var(--pirate-display);font-size:12px;letter-spacing:1px;z-index:1;text-shadow:0 1px 2px #000}.reload-wheel.ready .reload-state{color:#9fe08a}.reload-wheel.reloading .reload-state{color:#f0a25a}.reload-wheel.secured .reload-state{color:#ecdbb28c}.weapon-slots{display:flex;gap:6px}.weapon-slot{position:relative;display:grid;justify-items:center;gap:1px;width:58px;padding:7px 4px 5px;cursor:pointer;color:var(--parchment);background:linear-gradient(180deg,#3c2717eb,#180e07eb);border:2px solid var(--rope);border-radius:9px;box-shadow:0 4px 10px #0006}.weapon-slot:hover{filter:brightness(1.12)}.weapon-slot.active{border-color:var(--gold-bright);box-shadow:0 0 0 1px var(--gold-bright),0 0 14px #f3ca6d66}.slot-key{position:absolute;top:2px;left:5px;font-family:var(--pirate-body);font-size:11px;color:#ecdbb2a6}.slot-glyph{font-size:22px;line-height:1}.slot-name{font-family:var(--pirate-body);font-size:11px;letter-spacing:.3px}.map-canvas-wrap{position:relative}.map-canvas{cursor:grab;touch-action:none}.map-canvas:active{cursor:grabbing}.map-controls{position:absolute;right:12px;bottom:12px;display:grid;gap:6px}.map-controls button{width:34px;height:34px;font-size:17px;line-height:1;color:var(--parchment);cursor:pointer;background:linear-gradient(180deg,var(--wood-light),var(--wood-dark));border:2px solid var(--rope);border-radius:7px;box-shadow:0 3px 8px #0006}.map-controls button:hover{border-color:var(--gold);filter:brightness(1.12)}.dock-prompt{position:fixed;left:50%;bottom:172px;transform:translate(-50%);display:flex;align-items:center;gap:10px;padding:9px 18px;font-family:var(--pirate-body);font-size:15px;color:var(--parchment);background:linear-gradient(180deg,#3c2717f2,#180e07f2);border:2px solid var(--gold);border-radius:999px;box-shadow:0 0 0 3px var(--wood-darkest),0 6px 18px #00000080;animation:dockPulse 1.6s ease-in-out infinite}.dock-prompt.far{border-color:var(--rope);animation:none;color:var(--parchment-dim)}.dock-prompt b{color:var(--gold-bright)}.dock-anchor{font-size:18px}@keyframes dockPulse{0%,to{box-shadow:0 0 0 3px var(--wood-darkest),0 6px 18px #00000080}50%{box-shadow:0 0 0 3px var(--wood-darkest),0 6px 24px #f3ca6d80}}.port-scene{position:fixed;inset:0;z-index:30;overflow:auto;display:grid}.port-sky{position:absolute;inset:0;background:linear-gradient(180deg,#2a3d63,#6b5a7a 42%,#d98a5a 78%,#e8a45f)}.port-silhouette{position:absolute;left:0;right:0;bottom:0;height:46%;background:radial-gradient(120% 80% at 20% 100%,#1c2a22 0 40%,transparent 42%),radial-gradient(90% 90% at 62% 100%,#24160f 0 44%,transparent 46%),linear-gradient(180deg,transparent,#0c1a24 60%,#08131b 100%)}.port-harbor{position:relative;min-height:188px;overflow:hidden;display:grid;grid-template-columns:1.1fr 1.2fr .9fr;gap:20px;align-items:center;padding:18px 22px;color:var(--parchment);background:linear-gradient(180deg,#162737db,#26170eeb),radial-gradient(circle at 74% 18%,rgba(255,211,128,.2),transparent 38%);border:3px solid var(--rope);border-radius:12px;box-shadow:0 12px 24px #00000061}.port-harbor-art{position:relative;height:148px;border:1px solid rgba(243,202,109,.25);border-radius:8px;background:linear-gradient(180deg,#1c3b55,#c47a58 57%,#102535 58%,#07131c)}.port-harbor-art:before{content:"";position:absolute;left:0;right:0;bottom:24px;height:18px;background:repeating-linear-gradient(90deg,rgba(236,219,178,.18) 0 24px,transparent 24px 48px),linear-gradient(180deg,#1e667ee6,#051a26f2)}.port-moon{position:absolute;width:34px;height:34px;right:30px;top:20px;border-radius:50%;background:#ffe1a0;box-shadow:0 0 28px #ffd6808c}.port-lighthouse{position:absolute;left:34px;bottom:38px;width:34px;height:74px;background:linear-gradient(90deg,#c6c1b3,#596178);clip-path:polygon(28% 0,72% 0,86% 100%,14% 100%)}.port-lighthouse:after{content:"";position:absolute;left:24px;top:9px;width:96px;height:18px;background:linear-gradient(90deg,rgba(255,228,150,.7),transparent);transform:skewY(-8deg)}.port-ship{position:absolute;left:118px;bottom:38px;width:96px;height:30px;border-radius:0 0 42px 42px;background:#4b2315}.port-ship:before{content:"";position:absolute;left:42px;bottom:24px;width:5px;height:66px;background:#2d170e}.port-ship:after{content:"";position:absolute;left:48px;bottom:42px;width:46px;height:38px;background:#1b1d27;clip-path:polygon(0 0,100% 20%,82% 100%,8% 88%)}.port-dock{position:absolute;left:0;right:0;bottom:16px;height:10px;background:repeating-linear-gradient(90deg,#6b3e24 0 22px,#42200f 22px 26px)}.port-harbor-copy{display:grid;gap:7px}.port-kicker{font-family:var(--pirate-body);font-size:12px;color:var(--gold-bright);text-transform:uppercase;letter-spacing:.08em}.port-harbor-copy strong{font-family:var(--pirate-display);font-size:clamp(28px,4vw,46px);color:var(--gold-bright);line-height:1}.port-harbor-copy p{margin:0;font-family:var(--pirate-body);font-size:14px;color:var(--parchment-dim)}.port-harbor-stats{display:grid;gap:10px}.port-meter{display:grid;grid-template-columns:64px 1fr 56px;gap:8px;align-items:center;font-family:var(--pirate-body);font-size:12px}.port-meter i{height:10px;overflow:hidden;border:1px solid rgba(0,0,0,.55);border-radius:6px;background:#0000006b}.port-meter b{display:block;height:100%}.port-meter b.hull{background:linear-gradient(90deg,var(--blood),#ff9d62)}.port-meter b.sails{background:linear-gradient(90deg,#b79458,#fff0c8)}.port-meter b.integrity{background:linear-gradient(90deg,#6fd6a8,var(--gold-bright))}.port-meter b.locked{background:linear-gradient(90deg,#72524d,#b18371)}.port-meter em{font-style:normal;text-align:right;color:var(--parchment)}.port-content{position:relative;width:min(1000px,94vw);margin:0 auto;padding:28px 0 40px;display:grid;gap:16px;align-content:start}.port-head{display:flex;align-items:center;justify-content:space-between;gap:16px}.port-head .pirate-title{text-align:left}.port-head .pirate-subtitle{text-align:left;margin:0}.port-sail{width:auto;padding:12px 22px}.port-tabs{display:flex;gap:10px}.port-tab{display:flex;align-items:center;gap:8px;padding:10px 18px;font-family:var(--pirate-body);font-size:16px;color:var(--parchment);cursor:pointer;background:linear-gradient(180deg,#3c2717eb,#180e07eb);border:2px solid var(--rope);border-radius:10px 10px 0 0}.port-tab.active{color:var(--ink);font-weight:700;background:linear-gradient(180deg,var(--gold-bright),var(--gold));border-color:#8a5f22}.port-tab-glyph{font-size:20px}.port-panel{padding:22px 26px}.port-panel .pirate-title{text-align:left}.port-panel .pirate-subtitle{text-align:left;margin-bottom:6px}.port-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.port-card{display:grid;justify-items:center;gap:3px;padding:16px 12px;text-align:center;cursor:pointer;color:var(--parchment);background:linear-gradient(180deg,#0000003d,#0006);border:2px solid var(--rope);border-radius:10px}.port-card:hover:not(:disabled){filter:brightness(1.12);border-color:var(--gold)}.port-card.owned{border-color:#4f9d76}.port-card.locked{opacity:.55;cursor:not-allowed}.port-card-glyph{font-size:30px}.port-card-title{font-family:var(--pirate-display);font-size:17px;color:var(--gold-bright)}.port-card-note{font-family:var(--pirate-body);font-size:12px;color:var(--parchment-dim)}.port-card-cost{font-family:var(--pirate-body);font-size:13px;color:var(--parchment);margin-top:2px}.captain-card,.hud-status,.hud-dock,.debugPanel,.minimap-frame,.dock-prompt{pointer-events:none}.captain-card button,.hud-dock button,.hud-dock .weapon-slot{pointer-events:auto}.shipyard-layout{display:grid;grid-template-columns:1fr 260px;gap:16px;align-items:start}.shipyard-grid{grid-template-columns:repeat(3,1fr)}.ship-card{cursor:pointer}.ship-card.active{border-color:var(--gold-bright);box-shadow:0 0 0 1px var(--gold-bright),0 0 14px #f3ca6d66}.ship-sheet{display:grid;gap:10px;padding:14px;background:var(--wood-darkest);border:2px solid var(--rope);border-radius:10px}.ship-sheet-head{display:flex;align-items:center;gap:10px}.ship-sheet-glyph{font-size:34px;line-height:1}.ship-sheet-name{display:block;font-family:var(--pirate-display);font-size:18px;color:var(--gold-bright)}.ship-sheet-archetype{display:block;font-family:var(--pirate-body);font-size:12px;color:var(--parchment-dim);text-transform:uppercase;letter-spacing:.5px}.ship-sheet-tagline{margin:0;font-family:var(--pirate-body);font-style:italic;font-size:12px;color:#ecdbb2bf}.ship-stat-bars{display:grid;gap:6px}.ship-stat-row{display:grid;grid-template-columns:56px 1fr 44px;align-items:center;gap:6px}.ship-stat-label{font-family:var(--pirate-body);font-size:11px;color:var(--parchment-dim)}.ship-stat-track{height:8px;border:1px solid rgba(0,0,0,.55);border-radius:4px;background:#0000006b;overflow:hidden}.ship-stat-fill{display:block;height:100%}.ship-stat-fill.hull{background:linear-gradient(90deg,var(--blood),#d8483a)}.ship-stat-fill.sails{background:linear-gradient(90deg,#b79458,#e7d6ad)}.ship-stat-fill.crew{background:linear-gradient(90deg,#2f6f92,#5aa2c8)}.ship-stat-fill.speed{background:linear-gradient(90deg,#2f9268,#6fd6a8)}.ship-stat-fill.turn{background:linear-gradient(90deg,#8a5f22,var(--gold-bright))}.ship-stat-fill.guns{background:linear-gradient(90deg,#4a3418,#a9765a)}.ship-stat-value{font-family:var(--pirate-body);font-style:normal;font-size:11px;color:var(--parchment);text-align:right}.ship-preview{width:100%;height:140px;border:1px solid rgba(192,145,78,.4);border-radius:8px;overflow:hidden;background:radial-gradient(circle at 50% 30%,rgba(255,230,180,.08),transparent 70%)}.respawn-scrim{z-index:40}.respawn-panel{width:min(560px,92vw)}.respawn-integrity-warning{margin:4px 0 10px;padding:8px 12px;text-align:center;font-family:var(--pirate-body);font-size:13px;color:#ffce7a;background:#7c1a1259;border:1px solid var(--blood-bright);border-radius:8px}.respawn-options{display:grid;gap:10px;margin:6px 0 4px}.respawn-option{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:4px 10px;padding:12px 16px;text-align:left;cursor:pointer;color:var(--parchment);background:linear-gradient(180deg,var(--wood-light),var(--wood-dark));border:2px solid var(--rope);border-radius:9px}.respawn-option:hover{border-color:var(--gold);filter:brightness(1.1)}.respawn-option-kind{grid-row:1;font-family:var(--pirate-body);font-size:12px;color:var(--parchment-dim)}.respawn-option-name{grid-row:2;grid-column:1 / 2;font-family:var(--pirate-display);font-size:17px;color:var(--gold-bright)}.respawn-option-dist{grid-row:1 / 3;grid-column:3;align-self:center;font-family:var(--pirate-body);font-size:12px;color:var(--parchment-dim)}.respawn-option-note{grid-row:2;grid-column:2;justify-self:start;font-family:var(--pirate-body);font-style:italic;font-size:11px;color:#e6a15a}.repair-card:disabled{opacity:.6;cursor:default}.integrity-row{display:grid;grid-template-columns:56px 1fr;align-items:center;gap:8px;margin-top:2px}.integrity-pips{display:flex;gap:2px}.integrity-pip{font-size:11px;opacity:.25;filter:grayscale(1)}.integrity-pip.filled{opacity:1;filter:none}.integrity-row.low .integrity-pip.filled{filter:hue-rotate(-30deg)}.integrity-row.unsailable .integrity-pip.filled{filter:hue-rotate(-60deg) saturate(1.6)}.integrity-warning{grid-column:1 / -1;margin-top:2px;font-family:var(--pirate-body);font-size:11px;color:var(--blood-bright);text-align:center}@media(max-width:900px){.port-harbor{grid-template-columns:1fr}.port-harbor-art{height:120px}}
