@import"https://fonts.googleapis.com/css2?family=Cinzel:wght@500;700;900&family=Noto+Serif+KR:wght@500;700;900&family=Noto+Sans+KR:wght@500;700;900&family=Noto+Serif+JP:wght@500;700;900&family=Noto+Serif+SC:wght@500;700;900&display=swap";:root{color-scheme:dark;--font-display: "Cinzel", "Noto Serif KR", Georgia, serif;--font-roman: "Noto Serif KR", Georgia, serif;--font-body: "Noto Serif KR", Georgia, serif;--font-ko: "Noto Serif KR", system-ui, sans-serif;--font-num: "Cinzel", "Noto Serif KR", Georgia, serif;--gold: #d6ad55;--gold-bright: #f4d97c;--gold-deep: #8a6320;--deep-gold: #946315;--bronze: #7d5520;--brass: #c99338;--copper-verdigris: #4a8a78;--wax-red: #8e2a25;--wax-red-deep: #5d1816;--leather: #221710;--leather-light: #3a281a;--leather-edge: #5b3a1c;--ink: #f4e4ba;--ink-deep: #14110d;--cream: #fff1c2;--parchment: #f0d9a4;--parchment-edge: #c9a566;--panel: rgba(18, 14, 10, .9);--line: rgba(214, 173, 85, .5);--wood: #5b3218;--wood-dark: #1f1209;--grain-overlay: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence baseFrequency='.95' numOctaves='2' seed='4' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.9 0 0 0 0 0.78 0 0 0 0 0.46 0 0 0 .12 0'/></filter><rect width='180' height='180' filter='url(%23n)'/></svg>")}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;overflow:hidden;background:#020b0f;color:var(--ink);font-family:var(--font-roman)}button{min-height:44px;border:1px solid rgba(255,226,146,.78);border-radius:4px;background:linear-gradient(180deg,rgba(255,248,204,.52),transparent 28%),linear-gradient(180deg,#d8a44b 0,#9a5b22 58%,#533018);color:#241404;font:inherit;font-weight:900;cursor:pointer;text-shadow:0 1px 0 rgba(255,231,158,.28);box-shadow:inset 0 1px #ffffff59,inset 0 -8px 14px #2f16065c,0 4px #2f1a09d1,0 12px 24px #00000047}button:hover:not(:disabled){filter:brightness(1.08) saturate(1.06)}button:active:not(:disabled){transform:translateY(2px);box-shadow:inset 0 1px #ffffff40,0 2px #503009b8}button:disabled{opacity:.45;cursor:not-allowed;filter:saturate(.4)}button.secondary{color:var(--cream);background:linear-gradient(180deg,rgba(255,236,171,.14),transparent 34%),linear-gradient(180deg,#1d3d42,#102629 68%,#091517);border-color:#d4aa5094;text-shadow:0 2px 6px rgba(0,0,0,.62)}.v3,.world,.title,.captains,.register,.town-view{position:fixed;inset:0;overflow:hidden}.world canvas{width:100%;height:100%;display:block}.world-hidden{opacity:0;pointer-events:none}.boot-splash{position:fixed;inset:0;z-index:50;display:grid;place-items:center;align-content:center;gap:18px;min-height:100svh;border:0;border-radius:0;background:linear-gradient(180deg,#02080b2e,#02080bdb),radial-gradient(circle at 50% 43%,rgba(255,205,92,.22),transparent 32%),var(--boot-bg) center / cover no-repeat;color:var(--cream);box-shadow:none;overflow:hidden}.boot-splash:hover:not(:disabled){filter:none}.boot-splash:active:not(:disabled){transform:none;box-shadow:none}.boot-splash:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0 49%,rgba(255,232,158,.14) 50%,transparent 51%),radial-gradient(circle at 50% 50%,transparent 0 28%,rgba(0,0,0,.44) 64%,rgba(0,0,0,.82) 100%);animation:bootScan 2.8s ease-in-out infinite}.boot-mark{position:relative;z-index:2;display:grid;place-items:center;width:clamp(142px,18vw,250px);aspect-ratio:1;border:2px solid rgba(255,232,158,.72);border-radius:24px;background:#03090cb8;box-shadow:0 0 0 1px #ffffff14 inset,0 0 48px #f1ca6452,0 28px 90px #000000b8;animation:bootLogo .8s cubic-bezier(.2,.9,.2,1) both}.boot-mark img{width:72%;height:72%;object-fit:contain;image-rendering:auto;filter:drop-shadow(0 12px 22px rgba(0,0,0,.62))}.boot-splash strong{position:relative;z-index:2;font-family:Cinzel,serif;font-size:clamp(2rem,4.2vw,4.8rem);letter-spacing:.12em;text-shadow:0 10px 36px rgba(0,0,0,.82),0 0 28px rgba(241,202,100,.26)}.boot-splash small{position:relative;z-index:2;color:var(--gold);font-size:clamp(.95rem,1.5vw,1.25rem);letter-spacing:.26em;animation:clickBlink 1.05s steps(2,end) infinite}.boot-splash i{position:absolute;right:18px;bottom:16px;opacity:.001;pointer-events:none}.title{position:fixed;display:grid;align-items:center;padding:0 8vw;background:#020709;isolation:isolate}.title:before{content:"";position:absolute;inset:0;z-index:-3;background-image:var(--title-bg);background-size:cover;background-position:center;transform:scale(1.025);animation:titleDrift 16s ease-in-out infinite alternate}.title:after{content:"";position:absolute;inset:0;z-index:-2;background:linear-gradient(90deg,#000000c7 0 36%,#00000057 53%,#0000001f),radial-gradient(circle at 23% 58%,rgba(255,204,93,.12),transparent 27%),radial-gradient(circle at 70% 18%,rgba(72,190,210,.18),transparent 28%),linear-gradient(180deg,#0000001f,#00000094);pointer-events:none}.title>div{position:relative;z-index:2;width:min(760px,92vw);padding-top:7vh;animation:titleEnter .72s cubic-bezier(.2,.9,.2,1) both}.title>div:before{content:"";display:block;width:172px;height:7px;margin-bottom:24px;border-radius:999px;background:linear-gradient(90deg,transparent,var(--gold),transparent);box-shadow:0 0 26px #f1ca6480}.title>div:after{content:"";position:absolute;left:-34px;top:calc(7vh + 52px);width:1px;height:350px;background:linear-gradient(180deg,transparent,rgba(241,202,100,.72),transparent);box-shadow:0 0 18px #f1ca6461}.title h1,.captains h1,.port-ui h1{margin:0 0 24px;font-family:var(--font-display);font-size:clamp(4rem,10vw,9rem);line-height:.86;text-shadow:0 10px 30px #000}.title h1{max-width:100%;display:inline-flex;flex-wrap:nowrap;gap:.16em;font-family:var(--font-display);font-size:clamp(3rem,6.4vw,7rem);font-weight:900;letter-spacing:.02em;color:#f4d97c;white-space:nowrap;text-shadow:0 3px 0 rgba(60,30,8,.8),0 16px 30px rgba(0,0,0,.75)}.title p{margin:0 0 14px;color:var(--gold);font-family:var(--font-display);font-weight:700;letter-spacing:.14em;text-shadow:0 5px 20px rgba(0,0,0,.86)}.title button{position:relative;width:250px;min-height:72px;margin-top:24px;overflow:hidden;border-radius:10px;border-color:#fff4beeb;background:linear-gradient(180deg,rgba(255,255,255,.42),transparent 34%),linear-gradient(180deg,#ffeeb3 0,#efc556 45%,#b56c18);color:#1f1300;font-size:1.5rem;box-shadow:inset 0 1px #ffffffb3,inset 0 -8px 16px #5c310961,0 6px #4d2b0ae6,0 18px 42px #0000007a,0 0 38px #f1ca6438}.title button:before{content:"";position:absolute;inset:-40% auto -40% -52%;width:48%;transform:skew(-18deg);background:linear-gradient(90deg,transparent,rgba(255,255,255,.62),transparent);animation:buttonSheen 2.6s ease-in-out infinite}.title button:after{content:"";position:absolute;inset:7px;border:1px solid rgba(80,48,8,.42);border-radius:7px;pointer-events:none}.title-menu{display:flex;flex-direction:column;gap:14px;align-items:flex-start;margin-top:8px}.title-menu .title button,.title-menu button{margin-top:0}.title button.secondary{background:linear-gradient(180deg,#1c120ad1,#080e12d1);border-color:#d6ad558c;color:#f4e4baeb;box-shadow:inset 0 1px #ffffff14,0 4px 14px #0000006b;text-shadow:0 1px 0 rgba(0,0,0,.6)}.title button.secondary:before{display:none}.title button.secondary:after{border-color:#d6ad5538}.title button.secondary:hover{border-color:var(--gold);color:var(--gold-bright)}.captains{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-template-rows:auto minmax(0,1fr) auto;gap:16px;padding:4.5vh 5vw 4vh;background:linear-gradient(180deg,#0805036b,#04080a94 72%),var(--captain-map-bg) center / cover no-repeat,linear-gradient(180deg,#14100b,#04080a 72%)}.captains:before{content:"";position:absolute;inset:0;pointer-events:none;background:repeating-linear-gradient(90deg,rgba(255,228,155,.035) 0 1px,transparent 1px 9px),radial-gradient(circle at 50% 100%,rgba(18,83,96,.22),transparent 50%)}.captain-head{position:relative;z-index:2;grid-column:1 / -1;display:flex;align-items:end;justify-content:space-between;gap:18px;border-bottom:1px solid rgba(212,170,80,.34);padding-bottom:10px}.captain-head span{order:2;color:var(--gold);font-family:Cinzel,serif;font-weight:900;letter-spacing:.16em;text-transform:uppercase;text-shadow:0 4px 18px #000}.captains h1{margin:0;font-size:clamp(2.8rem,6vw,6.4rem)}.captain-card{position:relative;display:grid;grid-template-rows:1fr auto auto auto;align-items:end;min-height:58vh;padding:22px;overflow:hidden;text-align:left;color:var(--ink);background:linear-gradient(180deg,rgba(255,229,156,.05),transparent 40%),radial-gradient(circle at 50% 24%,rgba(212,170,80,.14),transparent 35%),linear-gradient(135deg,#4729138c,#0a12128c);border-radius:6px;box-shadow:inset 0 0 0 1px #d6ad5552,inset 0 -16px 30px #00000040,0 18px 40px #00000059;transform:translateY(0);transition:transform .18s ease,filter .18s ease,box-shadow .18s ease,border-color .18s ease}.captain-card:hover,.captain-card:focus-visible{transform:translateY(-6px) scale(1.01);filter:brightness(1.12);box-shadow:inset 0 0 0 2px #ffeba5d1,0 34px 90px #0000009e}.captain-card.selected{border-color:#ffeeb1f5;box-shadow:inset 0 0 0 2px #ffeeb1db,inset 0 -18px 38px #00000047,0 0 36px #d99c3b47,0 34px 90px #0000009e}.captain-card.selected:before{content:"SELECTED";position:absolute;left:18px;top:16px;z-index:3;color:#241404;padding:5px 10px;border:1px solid rgba(255,245,199,.72);background:linear-gradient(180deg,#f4ddb0,#c99338);font-family:Cinzel,serif;font-size:.72rem;font-weight:900;letter-spacing:.14em;box-shadow:0 8px 18px #0000005c}.captain-card img{position:absolute;left:50%;bottom:18%;width:min(82%,430px);height:68%;object-fit:contain;transform:translate(-50%);filter:drop-shadow(0 28px 30px rgba(0,0,0,.72))}.captain-card strong,.captain-card span,.captain-card small{position:relative;z-index:2}.captain-card strong{font-size:clamp(1.35rem,2vw,2.3rem);text-shadow:0 4px 14px #000}.captain-card span{color:var(--gold);font-weight:900}.captain-card small{max-width:30ch;color:#fff3c9d1;font-weight:800;line-height:1.45}.captain-confirm{position:relative;z-index:2;grid-column:1 / -1;display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,540px);gap:6px 18px;align-items:center;padding:14px 16px;border:1px solid var(--leather-edge);border-radius:4px;background:linear-gradient(180deg,rgba(214,173,85,.06),transparent 42%),#140e0894;box-shadow:inset 0 0 0 1px #d6ad5524,0 14px 28px #0000004d}.captain-confirm span{color:var(--gold);font-weight:900}.captain-confirm strong{font-size:clamp(1.25rem,2.2vw,2rem);text-shadow:0 4px 14px #000}.captain-confirm small{color:#fff3c9c2;font-weight:900}.captain-confirm-actions{grid-column:2;grid-row:2 / span 2;display:flex;gap:10px;justify-self:end}.captain-confirm button{min-width:118px}.captain-name-field{grid-column:2;grid-row:1;justify-self:end;width:min(100%,540px);display:grid;grid-template-columns:auto minmax(260px,420px);gap:10px;align-items:center;color:var(--gold);font-family:var(--font-display);font-weight:900}.captain-name-field input{min-width:0;min-height:42px;padding:0 12px;border:1px solid rgba(244,217,124,.42);border-radius:4px;background:#00000047;color:#ffe8a3;font:inherit;font-family:var(--font-roman);font-weight:800}.captain-name-field input:focus{outline:2px solid rgba(244,217,124,.48);outline-offset:2px}.captain-name-error{grid-column:2;justify-self:end;color:#ffb0a3}.register{display:grid;grid-template-columns:minmax(260px,42vw) 1fr;align-items:center;gap:4vw;padding:8vh 8vw;background:radial-gradient(circle at 32% 50%,rgba(219,178,93,.22),transparent 35%),linear-gradient(120deg,#031014,#071b20)}.register img{width:100%;height:78vh;object-fit:contain;filter:drop-shadow(0 28px 40px #000);animation:selectPop .9s ease both}.register span{color:var(--gold);font-weight:900;letter-spacing:.16em}.register h1{margin:10px 0;font-size:clamp(3rem,7vw,7rem);font-family:Cinzel,serif;line-height:.86}.register p{font-size:clamp(1.15rem,2vw,1.7rem);font-weight:900}.register strong{display:inline-block;margin-top:20px;padding:14px 20px;border:1px solid var(--line);background:var(--panel);border-radius:8px}.hud{position:fixed;top:15px;right:18px;z-index:10;display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}.hud span{display:inline-flex;align-items:center;gap:7px;min-height:42px;padding:8px 11px;border:1px solid rgba(243,199,97,.48);border-radius:7px;background:linear-gradient(180deg,rgba(255,226,140,.1),transparent 44%),#041114d6;font-weight:900;box-shadow:inset 0 0 0 1px #fff4bd0f,0 12px 28px #0000004d}.hud svg{width:17px;color:var(--gold)}.hud .hull-ok{color:#a4f1bf}.hud .hull-mid{color:#f5d066}.hud .hull-low{color:#ff8a7a}.companion-roster{position:fixed;top:72px;right:18px;z-index:11;display:flex;gap:8px;padding:8px;border:1px solid rgba(243,199,97,.48);border-radius:7px;background:linear-gradient(180deg,rgba(255,226,140,.1),transparent 44%),#041114db;box-shadow:inset 0 0 0 1px #fff4bd0f,0 14px 30px #00000057}.companion-slot{position:relative;width:54px;height:62px;margin:0;overflow:hidden;border:1px solid rgba(243,199,97,.4);border-radius:6px;background:radial-gradient(circle at 50% 28%,#ffe0872e,#00000061 70%)}.companion-slot img{width:100%;height:100%;object-fit:cover;object-position:50% 16%}.companion-slot.is-locked img{filter:brightness(0) saturate(0);opacity:.72}.companion-slot.is-locked:after{content:"?";position:absolute;inset:0;display:grid;place-items:center;color:var(--gold-bright);font-family:var(--font-display);font-size:1.7rem;font-weight:900;text-shadow:0 3px 12px #000}.companion-slot figcaption{position:absolute;left:0;right:0;bottom:0;padding:2px 3px 3px;overflow:hidden;background:linear-gradient(180deg,transparent,rgba(0,0,0,.76));color:var(--cream);font-size:.58rem;font-weight:900;line-height:1.05;text-align:center;text-overflow:ellipsis;white-space:nowrap}.toast{position:fixed;top:72px;left:50%;transform:translate(-50%);z-index:40;padding:10px 16px;border:1px solid rgba(243,199,97,.65);border-radius:999px;background:#051114d6;font-weight:900;box-shadow:0 14px 40px #0000006b}.town-view{z-index:1;background:#071315;isolation:isolate}.town-view:before{content:"";position:absolute;inset:0;background-image:var(--town-bg);background-size:cover;background-position:center;transform:scale(1.015);animation:townBreath 12s ease-in-out infinite alternate}.town-view:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,#0000000a 0 42%,#00000085),radial-gradient(circle at 52% 56%,transparent 0 40%,rgba(0,0,0,.34) 100%);pointer-events:none}.town-caption{position:absolute;left:32px;top:86px;z-index:2;display:grid;gap:3px;padding:14px 18px;border-left:3px solid var(--gold);color:var(--cream);text-shadow:0 5px 18px rgba(0,0,0,.78)}.town-caption span,.town-caption small{color:var(--gold);font-weight:900}.town-caption strong{font-size:clamp(2.4rem,5vw,5.2rem);line-height:.9}.port-ui,.town-ui,.route-ui,.combat,.danger-hud{position:fixed;z-index:18;border:1px solid rgba(212,170,80,.64);border-radius:6px;background:linear-gradient(180deg,rgba(255,226,146,.08),transparent 30%),repeating-linear-gradient(135deg,rgba(255,236,174,.02) 0 1px,transparent 1px 7px),linear-gradient(135deg,#24170c94,#06111294);box-shadow:inset 0 0 0 1px #fff4bd0f,inset 0 -18px 28px #00000038,0 22px 60px #0000006b}.port-ui{left:26px;bottom:26px;width:min(1200px,calc(100vw - 52px));display:grid;grid-template-columns:1fr;gap:12px;padding:18px 22px 16px;background:var(--grain-overlay),radial-gradient(120% 90% at 50% 0%,rgba(214,173,85,.08),transparent 55%),linear-gradient(170deg,#1a1410b8,#0a0805b8);border:1px solid var(--leather-edge);border-radius:4px;box-shadow:inset 0 0 0 1px #d6ad5524,inset 0 -60px 80px #00000047,0 24px 48px #00000073;font-family:var(--font-roman);color:var(--ink)}.port-ui:before,.port-ui:after{content:"";position:absolute;width:26px;height:26px;border:1px solid var(--gold);opacity:.55;pointer-events:none}.port-ui:before{top:8px;left:8px;border-right:none;border-bottom:none}.port-ui:after{top:8px;right:8px;border-left:none;border-bottom:none}.port-ui h1{margin:0 0 2px;font-family:var(--font-display);font-weight:900;font-size:clamp(2.4rem,4.8vw,4rem);letter-spacing:.02em;color:#f4d97c;text-shadow:0 2px 0 rgba(0,0,0,.65);position:relative}.port-row{display:grid;gap:12px}.port-row.services{grid-template-columns:repeat(2,minmax(0,1fr))}.port-row.services .port-building.market{grid-column:1 / -1}.port-row.actions{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.port-building{position:relative;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;min-height:110px;align-content:start;padding:12px 14px 10px;border:1px solid var(--leather-edge);border-radius:3px;background:linear-gradient(180deg,rgba(214,173,85,.06),transparent 40%),linear-gradient(160deg,#3a281a8c,#2217108c);box-shadow:inset 0 0 0 1px #d6ad551a,inset 0 -10px 20px #00000040}.port-building>span:first-child{grid-column:1 / -1;display:inline-flex;align-items:center;gap:8px;font-family:var(--font-display);font-weight:700;font-size:1.05rem;letter-spacing:.02em;color:var(--gold-bright);text-shadow:0 1px 0 rgba(0,0,0,.65);border-bottom:1px solid rgba(214,173,85,.22);padding-bottom:6px;margin-bottom:2px}.port-building>span:first-child svg{color:var(--gold)}.port-building.tavern,.port-building.guild{grid-template-columns:1fr}.port-building.hire{grid-column:1 / -1;grid-template-columns:minmax(150px,.56fr) minmax(220px,1fr) minmax(210px,auto);align-items:center;min-height:0}.port-building.hire>span:first-child{grid-column:1;grid-row:1 / span 2;margin:0;padding:0;border-bottom:0}.port-building.hire .card-pitch{grid-column:2;grid-row:1 / span 2}.port-building.hire>button{grid-column:3;grid-row:1;width:100%;min-height:48px}.port-building.hire .wage-note{grid-column:3;grid-row:2;justify-self:stretch;font-family:var(--font-roman);color:#e8d2a0c7;font-size:.8rem;letter-spacing:0;text-align:right;background:none;padding:0}.port-building .card-pitch{margin:0;display:grid;gap:4px;padding:0;font-family:var(--font-roman)}.port-building .card-pitch em{font-family:var(--font-display);font-style:normal;font-weight:700;font-size:1rem;color:var(--gold-bright);letter-spacing:0}.port-building .card-pitch span{font-size:.82rem;line-height:1.45;color:#e8d2a0d1}.port-building .guild-status{display:grid;place-items:center;min-height:56px;border:1px dashed rgba(214,173,85,.35);border-radius:4px;color:#f4d97cb3;font-family:var(--font-body);font-style:italic;font-weight:500;letter-spacing:.04em;background:#0000002e}.port-building.market{grid-template-columns:1fr;gap:8px;padding:12px 14px}.port-building.market>.market-head{grid-column:1 / -1;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;border-bottom:1px solid rgba(214,173,85,.22);padding-bottom:6px;margin-bottom:2px}.port-building.market>.market-head>span:first-child{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-display);font-weight:700;font-size:1.05rem;letter-spacing:.02em;color:var(--gold-bright);text-shadow:0 1px 0 rgba(0,0,0,.65)}.port-building.market>.market-head>span:first-child svg{color:var(--gold)}.port-building.market>.market-head>small{font-family:var(--font-roman);color:#e8d2a0b8;font-size:.78rem;letter-spacing:.04em}.port-building.market .market-sell{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border:1px solid var(--gold-deep);border-radius:3px;background:linear-gradient(170deg,#5e401c8c,#281a0ea6);color:var(--gold-bright);font-family:var(--font-display);cursor:pointer;transition:border-color .2s,box-shadow .2s}.port-building.market .market-sell:hover:not(:disabled){border-color:var(--gold);box-shadow:0 0 0 1px #d6ad5559,0 0 14px #d6ad5540}.port-building.market .market-sell:disabled{opacity:.4;cursor:not-allowed}.port-building.market .market-sell strong{font-size:.8rem;letter-spacing:.04em}.port-building.market .market-sell em{font-style:normal;font-weight:700;color:#f4d97c}.market-body{display:grid;grid-template-columns:minmax(170px,1fr) 2.6fr;gap:10px}.market-cargo,.market-stalls{display:flex;flex-direction:column;gap:6px;min-width:0}.market-cargo{border-right:1px solid rgba(214,173,85,.15);padding-right:10px}.market-cargo h4,.market-stalls h4{margin:0;font-family:var(--font-display);font-size:.76rem;letter-spacing:.14em;color:var(--gold);text-transform:uppercase}.market-cargo h4 em{font-style:normal;color:#e8d2a0bf;font-size:.72rem;letter-spacing:.04em;margin-left:4px}.market-cargo>ul{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:5px}.market-cargo .cargo-empty{margin:6px 0 0;font-family:var(--font-roman);font-size:.78rem;font-style:italic;color:#e8d2a06b}.cargo-chip{position:relative;width:100%;display:grid;grid-template-rows:auto auto auto;justify-items:center;gap:1px;padding:4px 4px 5px;border:1px solid rgba(214,173,85,.3);border-radius:3px;background:radial-gradient(110% 70% at 50% -10%,rgba(214,173,85,.14),transparent 60%),linear-gradient(170deg,#4a321673,#22160c8c);color:#e8d2a0e6;cursor:pointer;transition:border-color .2s,box-shadow .2s}.cargo-chip:hover{border-color:var(--gold);box-shadow:0 0 0 1px #d6ad5566}.cargo-chip .chip-art{display:grid;place-items:center;width:56px;height:56px}.cargo-chip .chip-art img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.65))}.cargo-chip .chip-qty{position:absolute;top:3px;right:4px;font-family:var(--font-display);font-size:.68rem;font-weight:700;padding:0 5px;border-radius:999px;background:#d6ad55e6;color:#1a1208}.cargo-chip .chip-name{font-family:var(--font-display);font-size:.74rem;font-weight:600;color:var(--gold-bright);white-space:nowrap}.cargo-chip .chip-sub{font-size:.7rem;color:#f4d97c;font-weight:700}.market-grid{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:5px}.market-good{display:contents}.market-good>button{position:relative;width:100%;display:grid;grid-template-rows:auto auto auto;justify-items:center;gap:1px;padding:4px 3px 5px;border:1px solid rgba(214,173,85,.22);border-radius:3px;background:radial-gradient(110% 70% at 50% -10%,rgba(214,173,85,.1),transparent 60%),linear-gradient(170deg,#22181380,#0c08058c);cursor:pointer;color:#e8d2a0e6;font-family:var(--font-roman);transition:border-color .2s,box-shadow .2s,transform .2s}.market-good>button:hover:not(:disabled){border-color:var(--gold);box-shadow:0 0 0 1px #d6ad5559,0 0 14px #d6ad5538;transform:translateY(-1px)}.market-good>button:disabled{opacity:.42;cursor:not-allowed}.market-good .good-art{display:grid;place-items:center;width:56px;height:56px}.market-good .good-art img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.6))}.market-good .good-name{font-family:var(--font-display);font-size:.74rem;font-weight:600;color:var(--gold-bright);letter-spacing:.02em;white-space:nowrap}.market-good .good-price{font-size:.74rem;font-weight:700;color:#f4d97c}.market-good .good-badge{position:absolute;top:3px;left:3px;font-family:var(--font-display);font-size:.58rem;letter-spacing:.08em;padding:0 4px;border-radius:2px;border:1px solid rgba(214,173,85,.35);background:#0009;color:#e8d2a0e6}.market-good.is-specialty .good-badge{color:#ffd07a;border-color:#d6ad55b3;background:#4e3212d9}.market-good.is-demand .good-badge{color:#b3e3ff;border-color:#78b4dc8c;background:#142846d9}.market-good.is-neutral .good-badge{color:#e8d2a0b3}.market-good .good-owned{position:absolute;top:3px;right:3px;font-family:var(--font-display);font-size:.66rem;font-weight:700;padding:0 4px;border-radius:999px;background:#d6ad55e6;color:#1a1208;text-shadow:none}.market-good.is-owned>button{border-color:#d6ad558c}.action-button{position:relative;isolation:isolate;overflow:hidden;display:grid;grid-template-columns:auto 1fr;align-items:center;gap:12px;min-height:78px;padding:10px 14px;border:1px solid var(--gold-deep);border-radius:3px;cursor:pointer;text-align:left;background:var(--grain-overlay),radial-gradient(120% 100% at 50% -10%,rgba(214,173,85,.12),transparent 55%),linear-gradient(170deg,#221813a6,#0c0805a6);box-shadow:inset 0 0 0 1px #d6ad5524,inset 0 0 30px #00000059,0 8px 18px #00000059;transition:transform .25s cubic-bezier(.2,.8,.2,1),box-shadow .25s,border-color .25s}.action-button:before,.action-button:after{content:"";position:absolute;width:16px;height:16px;border:1px solid var(--gold);opacity:.5;pointer-events:none;transition:opacity .35s}.action-button:before{top:4px;left:4px;border-right:none;border-bottom:none;width:10px;height:10px}.action-button:after{top:4px;right:4px;border-left:none;border-bottom:none;width:10px;height:10px}.action-button .icon-bg{position:relative;display:grid;place-items:center;width:56px;height:56px;z-index:0}.action-button .icon-bg svg{width:100%;height:100%;color:var(--gold);opacity:.82;filter:drop-shadow(0 4px 8px rgba(0,0,0,.55));transition:transform .3s cubic-bezier(.2,.8,.2,1),opacity .3s}.action-button .label{position:relative;z-index:1;display:grid;gap:2px;align-content:center;background:none;border:none;padding:0;margin:0}.action-button strong{font-family:var(--font-display);font-weight:700;font-size:1.05rem;letter-spacing:.02em;color:#f4d97c;text-shadow:0 1px 0 rgba(0,0,0,.65);line-height:1.1}.action-button small{display:block;padding:0;background:none;font-family:var(--font-roman);font-weight:500;font-size:.76rem;letter-spacing:0;color:#e8d2a0cc;line-height:1.2}.action-button:hover:not(:disabled){transform:translateY(-2px);border-color:var(--gold);box-shadow:inset 0 0 0 1px #f4d97c4d,inset 0 0 30px #0000004d,0 12px 24px #00000073}.action-button:hover:not(:disabled) .icon-bg svg{transform:scale(1.05);opacity:1}.action-button:hover:not(:disabled):before,.action-button:hover:not(:disabled):after{opacity:1}.action-button.depart{border-color:var(--gold);background:var(--grain-overlay),radial-gradient(120% 100% at 50% -10%,rgba(244,217,124,.22),transparent 55%),linear-gradient(170deg,#2a1d10b8,#110a04b8);box-shadow:inset 0 0 0 1px #f4d97c4d,inset 0 0 30px #00000059,0 10px 20px #0006,0 0 18px #d6ad552e}.action-button.depart .icon-bg svg{opacity:.88}.action-button.depart strong{color:#ffe8a3}.action-button:disabled{opacity:.42;filter:grayscale(.6) brightness(.85);cursor:not-allowed}.town-section{position:relative;isolation:isolate;overflow:hidden;display:grid;gap:10px;align-content:start;padding:16px 18px 14px;border:1px solid var(--leather-edge);border-radius:3px;background:linear-gradient(180deg,rgba(214,173,85,.06),transparent 40%),linear-gradient(160deg,#3a281a8c,#2217108c);box-shadow:inset 0 0 0 1px #d6ad551a,inset 0 -12px 24px #00000047}.town-section:before,.town-section:after{content:"";position:absolute;width:14px;height:14px;border:1px solid var(--gold);opacity:.45;pointer-events:none}.town-section:before{top:5px;left:5px;border-right:none;border-bottom:none}.town-section:after{bottom:5px;right:5px;border-left:none;border-top:none}.town-section .icon-bg{position:absolute;inset:0;display:grid;place-items:center;pointer-events:none;z-index:0;opacity:.1}.town-section .icon-bg svg{width:70%;height:70%;max-width:180px;max-height:180px;color:var(--gold)}.town-section header{position:relative;z-index:1;display:flex;align-items:baseline;gap:12px;border-bottom:1px solid rgba(214,173,85,.28);padding-bottom:8px;margin-bottom:4px}.town-section header svg{color:var(--gold);align-self:center}.town-section header h2{margin:0;font-family:var(--font-display);font-weight:700;font-size:1.3rem;letter-spacing:.02em;color:var(--gold-bright);text-shadow:0 1px 0 rgba(0,0,0,.65)}.town-section header small{margin-left:auto;font-family:var(--font-body);font-style:italic;font-size:.85rem;color:#f4d97c8c}.town-section button{position:relative;z-index:1;min-height:60px;display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:normal}.town-return{grid-column:1 / -1;position:relative;isolation:isolate;overflow:hidden;display:grid;gap:3px;place-items:center;min-height:88px;padding:14px;border-radius:3px;border:1px solid var(--gold);background:var(--grain-overlay),radial-gradient(80% 200% at 50% 50%,rgba(214,173,85,.22),transparent 70%),linear-gradient(170deg,#2a1d10,#110a04);box-shadow:inset 0 0 0 1px #f4d97c4d,inset 0 -10px 30px #00000073,0 10px 22px #00000073;transition:transform .3s,box-shadow .3s}.town-return:hover{transform:translateY(-2px);box-shadow:inset 0 0 0 1px #f4d97c80,0 18px 32px #00000080,0 0 24px #d6ad5540}.town-return svg{color:var(--gold)}.town-return strong{font-family:var(--font-display);font-weight:700;font-size:1.3rem;letter-spacing:.04em;color:#f4d97c;text-shadow:0 1px 0 rgba(0,0,0,.65)}.town-return small{display:block;padding:0;background:none;font-family:var(--font-roman);color:#e8d2a0cc;font-size:.82em}.town-ui{left:30px;bottom:30px;width:min(860px,calc(100vw - 60px));display:grid;grid-template-columns:1fr 1fr;gap:14px;padding:20px 22px 18px;background:var(--grain-overlay),radial-gradient(120% 90% at 50% 0%,rgba(214,173,85,.08),transparent 55%),linear-gradient(170deg,#1a1410b8,#0a0805b8);border:1px solid var(--leather-edge);border-radius:4px;box-shadow:inset 0 0 0 1px #d6ad5524,inset 0 -60px 80px #00000047,0 24px 48px #00000073;font-family:var(--font-roman);color:var(--ink)}.town-ui:before,.town-ui:after{content:"";position:absolute;width:22px;height:22px;border:1px solid var(--gold);opacity:.55;pointer-events:none}.town-ui:before{top:8px;left:8px;border-right:none;border-bottom:none}.town-ui:after{top:8px;right:8px;border-left:none;border-bottom:none}.town-ui h1{grid-column:1 / -1;margin:0 0 4px;font-family:var(--font-display);font-weight:900;font-size:clamp(2rem,4.2vw,3.4rem);letter-spacing:.02em;color:#f4d97c;text-shadow:0 2px 0 rgba(0,0,0,.65)}.town-ui button{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:56px}.town-ui small{color:#251600bd;font-size:.74rem}.town-section small,.town-section header small{color:#fff0c4d1;background:none;padding:0}.town-section button small{color:#251600d1;font-size:.72em;padding:1px 6px;background:#00000024;border-radius:999px}.port-ui button,.route-ui button,.combat button{background:linear-gradient(180deg,rgba(255,244,203,.42),transparent 28%),linear-gradient(180deg,#d8a44b,#9a5b22 68%,#533018)}.port-ui button{display:inline-flex;align-items:center;justify-content:center;gap:7px;white-space:nowrap}.port-ui small{display:inline-block;padding:2px 5px;border-radius:999px;background:#2314002e;font-size:.72em}.port-ui .loot-status{grid-column:1 / -1;color:var(--gold);font-weight:900}.route-ui{right:28px;top:86px;width:380px;padding:16px;display:grid;gap:10px}.route-ui h2,.combat h2{margin:0;font-size:2rem}.route-summary{display:flex;align-items:center;gap:10px;margin:0 0 4px;color:var(--cream);font-weight:900}.route-summary span{color:var(--gold)}.route-ui button{text-align:left;padding:12px}.route-ui small{display:block;margin-top:4px;font-weight:800}.route-ui .selected{outline:3px solid #fff1aa}.route-actions{display:grid;grid-template-columns:auto 1fr;gap:10px;margin-top:4px}.route-actions button{text-align:center;padding:12px 16px}.danger-select{background:linear-gradient(180deg,#ffd273,#c85c34 70%,#81301c)}.helm{position:fixed;left:26px;bottom:26px;z-index:13;display:grid;grid-template-columns:56px 80px 56px;gap:8px;padding:12px;border:1px solid var(--leather-edge);border-radius:4px;background:var(--grain-overlay),linear-gradient(170deg,#221710eb,#0a0805e6);box-shadow:inset 0 0 0 1px #d6ad5524,inset 0 -12px 24px #0006,0 14px 28px #00000080;font-family:var(--font-display)}.helm button{min-height:42px;padding:0;border:1px solid var(--leather-edge);border-radius:3px;background:linear-gradient(180deg,rgba(214,173,85,.08),transparent 40%),linear-gradient(170deg,var(--leather-light),var(--leather));color:#f4d97c;font-family:var(--font-display);font-weight:700;letter-spacing:.04em;text-shadow:0 1px 0 rgba(0,0,0,.65);box-shadow:inset 0 0 0 1px #d6ad551f,inset 0 -6px 12px #00000059;transition:border-color .2s,box-shadow .2s,transform .1s}.helm button:hover{border-color:var(--gold);box-shadow:inset 0 0 0 1px #f4d97c59,inset 0 -6px 12px #00000059}.helm button:active{transform:translateY(1px)}.helm strong{grid-column:1 / -1;min-height:38px;display:grid;place-items:center;border:1px solid rgba(214,173,85,.35);border-radius:3px;background:linear-gradient(170deg,#3a281ad9,#140e08d9);color:#f4d97c;font-family:var(--font-display);font-weight:700;letter-spacing:.06em;text-shadow:0 1px 0 rgba(0,0,0,.65)}.helm .course-button{font-family:var(--font-display);letter-spacing:.12em}.danger-hud{left:26px;top:86px;display:inline-flex;align-items:center;gap:8px;padding:11px 14px;color:#ffe090;font-weight:900}.danger-hud svg{color:#ff715f}.wind-dial{position:fixed;right:24px;bottom:24px;z-index:12;display:grid;justify-items:center;gap:8px;padding:12px 14px 11px;border:1px solid var(--leather-edge);border-radius:4px;background:var(--grain-overlay),linear-gradient(170deg,#221710eb,#0a0805e6);box-shadow:inset 0 0 0 1px #d6ad5524,inset 0 -10px 22px #0006,0 14px 28px #00000080;color:var(--ink);font-family:var(--font-display)}.wind-dial small{font-family:var(--font-display);font-weight:700;font-size:.82rem;letter-spacing:.02em;color:#f4d97ce6;white-space:nowrap}.wind-ring{border:2px solid rgba(214,173,85,.55)}.wind-ring strong{font-family:var(--font-display);font-weight:700;color:#f4d97c}.wind-arrow{color:var(--gold-bright);filter:drop-shadow(0 0 4px rgba(214,173,85,.6))}.target-arrow{background:var(--gold-bright);box-shadow:0 0 6px #f4d97c8c}.target-arrow:before{background:var(--gold-bright)}.wind-ring{position:relative;width:116px;aspect-ratio:1;border:none;background:none;filter:drop-shadow(0 6px 14px rgba(0,0,0,.6))}.wind-ring .compass-rose{position:absolute;inset:0;width:100%;height:100%}.wind-ring strong{position:absolute;left:50%;top:74%;z-index:5;transform:translate(-50%);padding:1px 9px 2px;font-family:var(--font-display);font-weight:700;font-size:.68rem;letter-spacing:.14em;color:var(--gold-bright);background:#0a0805d1;border:1px solid rgba(214,173,85,.45);border-radius:999px;text-shadow:0 1px 0 rgba(0,0,0,.8)}.wind-arrow,.target-arrow,.no-sail-zone{position:absolute;left:50%;top:50%;z-index:4}.wind-arrow{width:76px;height:24px;color:#f9df70;font-size:1.35rem;line-height:24px;transform-origin:50% 50%;text-align:right;filter:drop-shadow(0 0 10px rgba(255,225,111,.72))}.target-arrow{width:6px;height:38px;border-radius:6px;background:#7ce7ff;transform-origin:50% 50%;box-shadow:0 0 16px #7ce7ffbf}.target-arrow:before{content:"";position:absolute;left:50%;top:-6px;width:14px;height:14px;border-radius:50%;background:#7ce7ff;transform:translate(-50%)}.no-sail-zone{width:46px;height:78px;transform:translate(-50%,-50%);border-radius:50% 50% 10px 10px;background:linear-gradient(180deg,#ff5d4a57,#ff5d4a05 70%);clip-path:polygon(50% 50%,8% 0,92% 0);filter:drop-shadow(0 0 9px rgba(255,93,74,.5))}.no-sail-zone:before,.no-sail-zone:after{content:"";position:absolute;top:-1px;width:3px;height:44px;border-radius:999px;background:#ff705ce6;transform-origin:50% 100%}.no-sail-zone:before{left:9px;transform:rotate(-18deg)}.no-sail-zone:after{right:9px;transform:rotate(18deg)}.combat{right:22px;bottom:24px;width:360px;padding:14px;display:grid;gap:10px}.combat p{margin:0;font-weight:900}.combat-meter{position:relative;display:grid;grid-template-columns:46px 1fr;align-items:center;gap:8px;min-height:20px;font-weight:900}.combat-meter b{font-size:.82rem;color:#ffe090}.combat-meter i{position:relative;height:10px;overflow:hidden;border-radius:999px;background:#fff3c924;box-shadow:inset 0 0 0 1px #ffe89a3d}.combat-meter i:before{content:"";position:absolute;inset:0 auto 0 0;width:var(--value);border-radius:inherit;background:linear-gradient(90deg,#7ce7ff,#ffe090 60%,#ff715f);box-shadow:0 0 14px #ffe09073}.boarding{position:fixed;inset:8vh 8vw;z-index:24;overflow:hidden;border:1px solid rgba(243,199,97,.68);border-radius:8px;background:linear-gradient(180deg,#050e100f,#050e10c7),var(--boarding-bg) center / cover no-repeat,repeating-linear-gradient(90deg,#795225 0 56px,#5c391b 56px 62px);box-shadow:0 40px 120px #000000ad}.boarding:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 34%,rgba(255,229,150,.16),transparent 30%),linear-gradient(90deg,rgba(14,31,37,.46),transparent 38%,rgba(73,16,19,.44))}.boarding h2{position:absolute;left:28px;top:20px;z-index:4;margin:0;font-size:clamp(2rem,4vw,3.8rem);text-shadow:0 8px 18px #000}.boarding p{position:absolute;right:30px;top:30px;z-index:4;margin:0;font-weight:900}.fighter{position:absolute;z-index:2;bottom:0;width:min(34vw,420px);height:70vh;object-fit:contain;filter:drop-shadow(0 28px 30px rgba(0,0,0,.75));transition:transform .42s cubic-bezier(.25,1.2,.35,1.05),filter .25s}.fighter.ally{left:14%}.fighter.enemy{right:13%;transform:scaleX(-1)}.boarding.generated-fighters .fighter{width:min(39vw,520px);height:82vh}.boarding.generated-fighters .fighter.ally{left:6%}.boarding.generated-fighters .fighter.enemy{right:4%}.boarding.stage-idle .fighter.ally{transform:translate(0)}.boarding.stage-idle .fighter.enemy{transform:scaleX(-1) translate(0)}.boarding.stage-advance .fighter.ally{transform:translate(11vw)}.boarding.stage-advance .fighter.enemy{transform:scaleX(-1) translate(11vw)}.boarding.stage-clash .fighter.ally{transform:translate(16vw) translateY(-1.4vh) scale(1.04);filter:drop-shadow(0 28px 30px rgba(0,0,0,.75)) brightness(1.18)}.boarding.stage-clash .fighter.enemy{transform:scaleX(-1) translate(16vw) translateY(-1.4vh) scale(1.04);filter:drop-shadow(0 28px 30px rgba(0,0,0,.75)) brightness(1.05)}.boarding.stage-clash{animation:boardingShake .32s ease-out}.boarding.stage-recoil .fighter.ally{transform:translate(-2.4vw)}.boarding.stage-recoil .fighter.enemy{transform:scaleX(-1) translate(-5vw);filter:drop-shadow(0 28px 30px rgba(0,0,0,.75)) brightness(.7) saturate(.6)}.boarding.stage-win .fighter.ally{transform:translate(8vw)}.boarding.stage-win .fighter.enemy{transform:scaleX(-1) translate(-12vw) translateY(2vh) rotate(8deg);filter:drop-shadow(0 28px 30px rgba(0,0,0,.75)) brightness(.55) saturate(.4);opacity:.6}.slash{position:absolute;z-index:3;left:42%;top:30%;width:280px;height:280px;object-fit:contain;animation:slashPop .42s ease-out forwards;filter:drop-shadow(0 0 22px #fff1a1);pointer-events:none}.clash-flash{position:absolute;inset:0;z-index:2;background:radial-gradient(circle at 50% 46%,rgba(255,240,180,.55),rgba(255,200,100,.18) 22%,transparent 50%);animation:clashFlash .42s ease-out forwards;pointer-events:none}.boarding .enemy-count{position:absolute;right:30px;top:24px;z-index:4;margin:0;font-family:var(--font-roman);font-weight:700;font-size:1rem;letter-spacing:.02em;color:var(--ink);background:#0a0805a6;border:1px solid var(--leather-edge);border-radius:3px;padding:6px 12px;box-shadow:inset 0 0 0 1px #d6ad5538}.boarding .enemy-count b{margin-left:4px;font-family:var(--font-display);color:var(--gold-bright);font-size:1.15rem}@keyframes boardingShake{0%,to{transform:translate(0)}20%{transform:translate(-6px,3px)}45%{transform:translate(7px,-2px)}70%{transform:translate(-3px,1px)}}@keyframes clashFlash{0%{opacity:1;transform:scale(.65)}to{opacity:0;transform:scale(1.25)}}@keyframes slashPop{0%{opacity:0;transform:scale(.4) rotate(-12deg)}35%{opacity:1;transform:scale(1.1) rotate(4deg)}to{opacity:0;transform:scale(1.3) rotate(8deg)}}.audio-state{position:fixed;right:18px;bottom:16px;z-index:8;padding:4px 10px;border-radius:4px;background:#0009;color:#f4e4bad9;font-size:.72rem;letter-spacing:.08em;pointer-events:none}.topleft-controls{position:fixed;top:14px;left:14px;z-index:50;display:inline-flex;align-items:center;gap:6px}.topleft-btn{display:inline-grid;place-items:center;width:30px;height:30px;min-height:0;padding:0;border:1px solid rgba(214,173,85,.28);border-radius:50%;background:linear-gradient(180deg,#24170c8c,#0611128c);color:#f4e4ba8c;cursor:pointer;text-shadow:none;transition:color .16s ease,border-color .16s ease,background .16s ease}.topleft-btn:hover{color:var(--gold-bright);border-color:#d6ad55a6;transform:none}.topleft-btn.is-on{color:var(--gold-bright);border-color:var(--gold);background:linear-gradient(180deg,#3c2610d1,#140c06d1)}.topleft-popover{position:absolute;top:38px;left:0;min-width:180px;padding:8px;border:1px solid rgba(214,173,85,.35);border-radius:6px;background:linear-gradient(180deg,#1c120af5,#080e12f5);box-shadow:0 12px 28px -8px #000000b3;display:flex;flex-direction:column;gap:4px}.topleft-popover-row{display:grid;grid-template-columns:14px 1fr auto;align-items:center;gap:10px;padding:8px 10px;min-height:0;height:auto;border:1px solid transparent;border-radius:4px;background:transparent;color:var(--ink);font-family:var(--font-roman);font-size:.82rem;letter-spacing:.04em;cursor:pointer;text-align:left;text-shadow:none;text-transform:none;font-weight:500;transition:background .14s ease}.topleft-popover-row:hover{background:#d6ad551a;transform:none}.topleft-popover-row svg{color:var(--gold-bright)}.topleft-popover-row span{color:var(--ink);font-weight:600}.topleft-popover-row small{color:var(--gold);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase}.topleft-popover-row.is-muted svg,.topleft-popover-row.is-muted small{color:#d8a274}.topleft-popover-link{grid-template-columns:14px minmax(0,1fr);grid-template-rows:auto auto;align-items:center;gap:1px 10px}.topleft-popover-link svg{grid-row:1 / span 2}.topleft-popover-link span,.topleft-popover-link small{grid-column:2;justify-self:start}.topleft-popover-link small{color:var(--gold);font-size:.68rem;letter-spacing:.04em;line-height:1.1;text-transform:none;white-space:nowrap}.topleft-popover-language{padding:8px 10px 6px;border-top:1px solid rgba(214,173,85,.18)}.topleft-popover-language .lang-switcher{width:100%;display:grid;gap:7px;font-family:var(--font-roman);letter-spacing:.04em;text-transform:none}.topleft-popover-language .lang-switcher-label{font-family:var(--font-display);color:var(--gold);font-size:.82rem;letter-spacing:.08em}.topleft-popover-language .lang-switcher-list{display:flex;flex-wrap:wrap;gap:8px}.topleft-popover-language .lang-switcher-sep{display:none}.topleft-popover-language .lang-switcher-item{font-size:.78rem}@keyframes selectPop{0%{opacity:0;transform:translateY(24px) scale(.94)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes bootLogo{0%{opacity:0;transform:translateY(18px) scale(.72)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes bootScan{0%,to{opacity:.46;transform:translate(-1.5%)}50%{opacity:.86;transform:translate(1.5%)}}@keyframes clickBlink{0%,46%{opacity:1}47%,to{opacity:.18}}@keyframes titleEnter{0%{opacity:0;transform:translate(-28px) scale(.98)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes titleDrift{0%{transform:scale(1.025) translateZ(0)}to{transform:scale(1.055) translate3d(-1.2%,.8%,0)}}@keyframes townBreath{0%{transform:scale(1.015) translateZ(0)}to{transform:scale(1.04) translate3d(-.8%,.5%,0)}}@keyframes buttonSheen{0%,42%{left:-58%}70%,to{left:112%}}@keyframes pulseDanger{50%{transform:scale(1.08);box-shadow:0 0 30px #ff4d3b99}}@media(max-width:760px){.title{align-items:start;padding:14svh 7vw 7vh}.title:after{background:linear-gradient(180deg,#0000001a 0 36%,#000000b8),linear-gradient(90deg,#00000085,#00000024)}.title>div{width:100%;padding-top:0}.title>div:before{width:128px;height:5px;margin-bottom:14px}.title>div:after{display:none}.title h1{display:grid;gap:.06em;margin-bottom:18px;font-size:clamp(3.35rem,18vw,5.55rem);line-height:.94;white-space:normal}.title p{margin-bottom:10px;font-size:.68rem;letter-spacing:.11em}.title-menu{gap:12px;margin-top:4px}.title button{width:min(250px,80vw);min-height:64px}.captains{grid-template-columns:1fr;grid-template-rows:auto;padding:18px 12px 20px;overflow:auto}.captain-head{align-items:start;flex-direction:column;gap:4px}.captain-head span{order:0;font-size:.72rem}.captains h1{font-size:2.85rem}.captain-card{min-height:42vh}.captain-card img{height:76%;bottom:7%;left:74%;opacity:.82}.topleft-controls{top:20px}.captain-confirm{grid-template-columns:1fr;position:sticky;bottom:0}.captain-confirm-actions{grid-column:1;grid-row:auto}.captain-confirm button{flex:1;min-width:0}.captain-name-field{grid-column:1;grid-row:auto;justify-self:stretch;width:100%;grid-template-columns:1fr;gap:6px}.captain-name-error{grid-column:1;justify-self:stretch}.register{grid-template-columns:1fr;padding:4vh 7vw}.register img{height:48vh}.hud{left:10px;right:10px;top:10px}.hud span{min-height:36px;padding:6px 8px;font-size:.84rem}.companion-roster{top:112px;right:10px;gap:6px;padding:6px}.companion-slot{width:46px;height:52px}.toast{top:148px;max-width:calc(100vw - 24px);text-align:center}.town-caption{left:14px;top:82px;padding:10px 12px}.town-caption strong{font-size:2.65rem}.port-ui{grid-template-columns:1fr;left:10px;right:10px;bottom:10px;width:auto;gap:10px;padding:14px 14px 12px;max-height:60svh;overflow:auto}.port-ui h1{font-size:2.4rem;margin-bottom:0}.port-row.services{grid-template-columns:1fr 1fr}.port-row.actions{grid-template-columns:repeat(2,1fr);gap:10px}.port-building{min-height:92px;padding:11px;gap:6px}.port-building.market{grid-template-columns:1fr;grid-column:1 / -1}.port-building.hire{grid-template-columns:1fr;align-items:stretch}.port-building.hire>span:first-child,.port-building.hire .card-pitch,.port-building.hire>button,.port-building.hire .wage-note{grid-column:1;grid-row:auto}.port-building.hire>span:first-child{border-bottom:1px solid rgba(214,173,85,.22);padding-bottom:6px}.port-building.hire .wage-note{text-align:center}.market-body{grid-template-columns:1fr}.market-cargo{border-right:none;border-bottom:1px solid rgba(214,173,85,.15);padding-right:0;padding-bottom:8px}.market-cargo>ul{grid-template-columns:repeat(3,minmax(0,1fr))}.market-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:5px}.market-good .good-art,.cargo-chip .chip-art{width:48px;height:48px}.market-good .good-name,.cargo-chip .chip-name,.market-good .good-price,.cargo-chip .chip-sub{font-size:.7rem}.market-good .good-badge{font-size:.54rem;padding:0 3px}.port-building>span:first-child{font-size:.76rem;letter-spacing:.18em}.port-ui button{min-height:42px;white-space:normal}.action-button{min-height:64px;padding:8px 12px;gap:10px}.action-button .icon-bg{width:44px;height:44px}.action-button strong{font-size:.95rem}.action-button small{font-size:.72rem}.action-button:before,.action-button:after{width:8px;height:8px}.town-ui{grid-template-columns:1fr;left:12px;right:12px;bottom:calc(12px + env(safe-area-inset-bottom,0px));width:auto;max-height:calc(100svh - 132px);gap:10px;padding:14px 14px 12px;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.town-section .icon-bg svg{max-width:130px;max-height:130px}.town-return{min-height:64px}.town-return strong{font-size:1rem;letter-spacing:.04em}.route-ui{left:12px;right:12px;top:104px;width:auto}.danger-hud{left:12px;top:112px}.combat{left:12px;right:12px;bottom:178px;width:auto;z-index:22}.wind-dial{right:12px;top:196px;bottom:auto;padding:8px}.wind-ring{width:72px}.wind-arrow{width:58px;font-size:1.05rem}.target-arrow{height:29px}.wind-dial small{font-size:.72rem}.helm{left:12px;bottom:12px;z-index:12}.boarding{inset:10vh 3vw}.fighter{width:48vw;height:64vh}.fighter.ally{left:0}.fighter.enemy{right:-4%}.slash{left:32%;width:210px}}.npc-view{position:fixed;inset:0;z-index:20;pointer-events:none;display:grid;grid-template-rows:1fr auto}.npc-portrait{position:absolute;right:2vw;bottom:0;width:min(640px,46vw);height:min(92vh,880px);margin:0;overflow:hidden;pointer-events:none;filter:drop-shadow(0 24px 28px rgba(0,0,0,.58));-webkit-mask-image:linear-gradient(180deg,#000 0%,#000 78%,rgba(0,0,0,.35) 94%,transparent 100%);mask-image:linear-gradient(180deg,#000 0%,#000 78%,rgba(0,0,0,.35) 94%,transparent 100%);animation:npcEnter .42s ease-out}.npc-portrait img{width:100%;height:100%;object-fit:contain;object-position:bottom center}.npc-id-genova-tavern .npc-portrait{right:4vw;width:min(560px,40vw)}.npc-id-genova-tavern .npc-portrait img{transform:scale(1.32);transform-origin:52% 18%;object-position:52% 8%}@keyframes npcEnter{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}.npc-header{position:absolute;left:32px;top:96px;z-index:2;display:grid;gap:6px;padding:14px 20px;border-left:3px solid var(--gold);background:linear-gradient(90deg,rgba(8,14,18,.76),transparent);color:var(--cream);text-shadow:0 4px 16px rgba(0,0,0,.8);pointer-events:auto;max-width:420px}.npc-header h1{margin:0;font-family:var(--font-display);font-size:clamp(2rem,3.4vw,2.8rem);font-weight:900;color:var(--gold-bright);letter-spacing:.02em}.npc-subtitle{margin:0;font-size:.92rem;color:var(--gold);letter-spacing:.04em}.npc-affinity{display:flex;align-items:center;gap:10px;margin:4px 0 0;font-size:.82rem;color:var(--ink)}.npc-affinity span{color:var(--gold-bright);font-weight:900;letter-spacing:.02em}.npc-affinity .bar{position:relative;flex:1;height:6px;border:1px solid rgba(214,173,85,.55);border-radius:999px;background:#0000006b;overflow:hidden}.npc-affinity .bar:after{content:"";position:absolute;inset:0;width:calc(var(--stage, 0) * 25%);background:linear-gradient(90deg,var(--gold-deep),var(--gold-bright));transition:width .35s ease}.npc-affinity small{color:var(--gold);font-family:var(--font-num);font-weight:700}.npc-line{position:absolute;left:32px;right:calc(min(520px,38vw) + 8vw);bottom:198px;margin:0;padding:18px 22px;border:1px solid rgba(212,170,80,.6);border-radius:6px;background:linear-gradient(180deg,rgba(255,226,146,.08),transparent 30%),linear-gradient(135deg,#24170cd1,#061112d1);box-shadow:0 18px 36px #0000007a;color:var(--ink);font-family:var(--font-roman);font-size:1.12rem;line-height:1.6;pointer-events:auto;animation:npcLineEnter .32s ease-out}.npc-line:before{content:"“";position:absolute;left:8px;top:-14px;color:var(--gold);font-family:var(--font-display);font-size:2.4rem;line-height:1}@keyframes npcLineEnter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.npc-actions{position:absolute;left:32px;right:32px;bottom:26px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;pointer-events:auto}.npc-actions button{display:grid;gap:4px;padding:14px 16px;border:1px solid rgba(212,170,80,.6);border-radius:4px;background:linear-gradient(180deg,rgba(255,226,146,.08),transparent 30%),linear-gradient(135deg,#24170cad,#061112ad);color:var(--cream);font-family:var(--font-roman);cursor:pointer;transition:transform .12s ease,border-color .18s ease,background .18s ease}.npc-actions button:hover:not(:disabled){border-color:var(--gold-bright);transform:translateY(-2px)}.npc-actions button:disabled{opacity:.42;cursor:not-allowed}.npc-actions button strong{font-family:var(--font-display);font-weight:900;font-size:1.05rem;color:var(--gold-bright);letter-spacing:.02em}.npc-actions button small{color:var(--ink);font-size:.78rem}.npc-actions .npc-leave strong{color:var(--ink)}@media(max-width:720px){.npc-portrait{right:2vw;bottom:280px;width:50vw;height:56vh}.npc-id-genova-tavern .npc-portrait{right:3vw;width:48vw}.npc-header{top:84px;left:16px;max-width:60vw}.npc-line{left:16px;right:16px;bottom:232px;font-size:.98rem}.npc-actions{left:12px;right:12px;bottom:16px;grid-template-columns:repeat(2,1fr)}}.npc-veil{position:fixed;inset:0;z-index:0;pointer-events:auto;background:radial-gradient(ellipse at 50% 35%,rgba(20,12,6,.35),transparent 65%),linear-gradient(180deg,#00000052,#00000094);animation:npcEnter .26s ease-out}.npc-eyebrow{display:inline-block;margin-bottom:4px;font-family:var(--font-display);font-size:.68rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);text-shadow:0 1px 0 rgba(0,0,0,.55)}.npc-line-footer{display:block;margin-top:12px;padding-top:12px;border-top:1px dashed rgba(214,173,85,.35);font-size:.92rem;font-style:italic;color:#f4e4bad1;font-family:var(--font-roman);line-height:1.55}.npc-pips{display:flex;gap:5px;align-items:center;background:transparent;border:none;height:auto;padding:0;flex:0 1 auto;overflow:visible}.npc-pips:after{content:none}.npc-pips em{display:block;width:13px;height:13px;border-radius:50%;border:1px solid rgba(214,173,85,.55);background:#0000006b;font-style:normal;transition:background .22s ease,box-shadow .22s ease}.npc-pips em.is-on{background:radial-gradient(circle at 32% 28%,var(--gold-bright),var(--gold) 60%,var(--gold-deep) 100%);border-color:var(--gold-bright);box-shadow:0 0 8px #f4d97c8c}.npc-rewards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;pointer-events:auto}.npc-reward{display:flex;flex-direction:column;gap:4px;padding:10px 12px;border-radius:4px;border:1px solid rgba(214,173,85,.42);background:linear-gradient(180deg,rgba(255,226,146,.08),transparent 30%),linear-gradient(135deg,#24170cb8,#061112b8);color:var(--ink);font-family:var(--font-roman);position:relative}.npc-reward svg{color:var(--gold-bright);flex-shrink:0}.npc-reward small{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:#f4e4ba94}.npc-reward b{font-family:var(--font-display);font-size:1.2rem;font-weight:700;color:var(--gold-bright);letter-spacing:.02em;line-height:1}.npc-reward.is-cost b,.npc-reward.is-cost svg{color:#d8a274}.npc-reward.is-cost{border-color:#d8a2746b}.npc-reward.is-gain{animation:npcRewardPulse 2.4s ease-in-out infinite}@keyframes npcRewardPulse{0%,to{box-shadow:0 0 #f4d97c00}50%{box-shadow:0 0 12px #f4d97c59}}.npc-portrait-fallback{display:grid;place-content:center;width:100%;height:100%;text-align:center;background:radial-gradient(ellipse at 50% 35%,rgba(214,173,85,.22),transparent 55%),linear-gradient(180deg,#2a1c10,#0e0805);padding:28px;gap:14px;border-radius:4px;border:2px solid var(--gold-deep);box-shadow:0 0 0 1px #0009,0 18px 36px -10px #000c}.npc-portrait-monogram{font-family:var(--font-display);font-size:clamp(4rem,9vw,8rem);font-weight:900;color:var(--gold-bright);text-shadow:0 2px 0 rgba(0,0,0,.55),0 0 24px rgba(214,173,85,.35);letter-spacing:.02em;line-height:1}.npc-portrait-subline{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:#f4e4ba94;border-top:1px solid rgba(214,173,85,.25);padding-top:10px}.npc-magistrate{z-index:30}.npc-magistrate .npc-line{border-left-color:var(--seal-hue, var(--gold));border-left-width:3px;border-left-style:solid}.npc-magistrate .npc-header h1{font-size:clamp(1.6rem,2.8vw,2.2rem);line-height:1.05}.npc-magistrate .npc-header{max-width:540px}.npc-magistrate .npc-actions{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;align-items:stretch}@media(max-width:720px){.npc-magistrate .npc-actions{grid-template-columns:1fr}.npc-rewards{gap:6px}.npc-reward{padding:8px 10px}.npc-reward b{font-size:1rem}.npc-reward small{font-size:.62rem;letter-spacing:.12em}}.lang-switcher{display:inline-flex;align-items:baseline;gap:12px;font-family:var(--font-display, var(--font-body));letter-spacing:.14em;text-transform:uppercase}.lang-switcher-inline{margin-top:18px;padding-left:4px;font-size:11px;color:#f3e5b86b}.lang-switcher-label{color:#f3e5b852}.lang-switcher-label:after{content:":";margin-left:2px;opacity:.55}.lang-switcher-list{display:inline-flex;align-items:baseline;gap:6px}.lang-switcher-sep{opacity:.3;-webkit-user-select:none;user-select:none}.title .lang-switcher-item,.lang-switcher-item{position:static;width:auto;min-height:0;margin:0;padding:0;overflow:visible;border:0;border-radius:0;background:none;box-shadow:none;font:inherit;letter-spacing:inherit;text-transform:inherit;font-size:inherit;color:#f3e5b88c;cursor:pointer;transition:color .15s ease}.title .lang-switcher-item:before,.title .lang-switcher-item:after,.lang-switcher-item:before,.lang-switcher-item:after{content:none;display:none;background:none;border:0;animation:none}.title .lang-switcher-item:hover,.title .lang-switcher-item:focus-visible,.lang-switcher-item:hover,.lang-switcher-item:focus-visible{color:#f3e5b8;outline:none;background:none;border-color:transparent}.title .lang-switcher-item.is-active,.lang-switcher-item.is-active{color:var(--gold, #d2b572);text-decoration:underline;text-decoration-color:var(--gold, #d2b572);text-decoration-thickness:1.5px;text-underline-offset:5px;pointer-events:none}@media(max-width:720px){.lang-switcher-inline{font-size:10px;gap:8px;margin-top:14px}.lang-switcher-list{gap:4px}}html[lang=ja] body{font-family:"Noto Serif JP","Hiragino Mincho ProN","Yu Mincho",var(--font-body)}html[lang=zh] body{font-family:"Noto Serif SC","Source Han Serif SC","PingFang SC",var(--font-body)}.vibejam-event-card,.leaderboard-panel{position:relative;display:grid;gap:10px;padding:14px;border:1px solid rgba(244,217,124,.42);border-radius:4px;background:linear-gradient(180deg,rgba(244,217,124,.08),transparent 42%),#041316b8;color:var(--cream)}.vibejam-event-card header,.leaderboard-panel header{display:flex;align-items:center;gap:8px}.vibejam-event-card h2,.leaderboard-panel h2{margin:0;color:#ffe8a3;font-family:var(--font-display);font-size:1.1rem}.vibejam-event-card header small{margin-left:auto;color:var(--gold);font-weight:900}.vibejam-event-card p,.leaderboard-panel p{margin:0;color:#fff0c4cc;line-height:1.45}.leaderboard-panel header button{margin-left:auto;min-height:30px;padding:5px 9px}.leaderboard-panel ol{display:grid;gap:5px;margin:0;padding:0;list-style:none}.leaderboard-panel li{display:grid;grid-template-columns:28px 1fr auto;align-items:center;gap:8px;min-height:30px;padding:5px 8px;border:1px solid rgba(244,217,124,.16);background:#0000002e}.leaderboard-panel li b{color:var(--gold)}.leaderboard-panel li strong{color:#ffe8a3}.leaderboard-empty,.leaderboard-error,.leaderboard-score{color:#fff0c4c2}.leaderboard-error{display:inline-flex;align-items:center;gap:6px}.vibejam-row{grid-template-columns:minmax(220px,.72fr) minmax(280px,1fr);align-items:start}.vibejam-row>.leaderboard-panel:only-child{grid-column:1 / -1}.leaderboard-ticker{grid-column:1 / -1;position:relative;display:grid;grid-template-columns:minmax(170px,auto) minmax(220px,1fr) auto;align-items:center;gap:10px 14px;min-height:72px;padding:10px 12px;border:1px solid rgba(244,217,124,.4);border-radius:4px;background:linear-gradient(90deg,rgba(244,217,124,.12),transparent 38%),#041316c7;color:var(--cream);overflow:hidden}.leaderboard-ticker header{display:flex;align-items:center;gap:8px;min-width:0}.leaderboard-ticker header svg{flex:0 0 auto;color:var(--gold)}.leaderboard-ticker h2{margin:0;color:#ffe8a3;font-family:var(--font-display);font-size:1rem;line-height:1.1}.leaderboard-ticker header button{min-height:30px;margin-left:auto;padding:4px 9px;font-size:.76rem}.leaderboard-open{min-width:84px;min-height:42px;padding:8px 12px;border-color:#f4d97c94}.leaderboard-ticker-window{position:relative;height:34px;overflow:hidden;border:1px solid rgba(244,217,124,.16);background:#0000002e}.leaderboard-ticker ol{--rank-count: 1;display:grid;margin:0;padding:0;list-style:none;animation:rankTicker calc(max(var(--rank-count),1)/.4s) steps(var(--rank-count)) infinite}.leaderboard-ticker li{display:grid;grid-template-columns:34px 1fr auto;align-items:center;gap:10px;height:34px;padding:0 12px;color:#fff0c4e0}.leaderboard-ticker li b{color:var(--gold);font-family:var(--font-display)}.leaderboard-ticker li strong{color:#ffe8a3}.leaderboard-ticker .leaderboard-score,.leaderboard-ticker .leaderboard-error{grid-column:2;margin:-4px 0 0;color:#fff0c4b3;font-size:.78rem}.leaderboard-ticker .leaderboard-empty{height:34px;margin:0;display:flex;align-items:center;padding:0 12px;color:#fff0c4b3}.leaderboard-dialog{position:fixed;inset:0;z-index:55;display:grid;place-items:center;padding:24px;background:#02080ab8;-webkit-backdrop-filter:blur(7px);backdrop-filter:blur(7px)}.leaderboard-dialog-panel{position:relative;width:min(680px,calc(100vw - 32px));max-height:calc(100vh - 40px);display:grid;gap:16px;padding:26px;overflow:auto;border:1px solid rgba(244,217,124,.68);border-radius:6px;background:radial-gradient(circle at 24% 0%,rgba(244,217,124,.2),transparent 34%),linear-gradient(155deg,#05181cfa,#2a1b0efa);color:var(--cream);box-shadow:inset 0 0 0 1px #fff6c41f,0 28px 78px #000000a3}.leaderboard-dialog-panel>header{display:grid;grid-template-columns:auto 1fr;gap:4px 12px;align-items:center;padding-right:42px}.leaderboard-dialog-panel>header svg{grid-row:1 / span 2;color:var(--gold)}.leaderboard-dialog-panel>header span{color:var(--gold);font-family:var(--font-display);font-weight:900;letter-spacing:.08em}.leaderboard-dialog-panel>header h2{margin:0;color:#ffe8a3;font-family:var(--font-display);font-size:clamp(1.7rem,3.6vw,2.8rem);line-height:1}.leaderboard-dialog-panel .leaderboard-dialog-close{position:absolute;top:14px;right:14px;width:38px;height:38px;min-width:38px;min-height:38px;max-width:38px;max-height:38px;display:grid;place-items:center;padding:0;border-radius:50%;aspect-ratio:1}.leaderboard-dialog-list{display:grid;gap:8px;margin:0;padding:0;list-style:none}.leaderboard-dialog-list li{display:grid;grid-template-columns:42px 1fr auto;align-items:center;gap:12px;min-height:48px;padding:9px 12px;border:1px solid rgba(244,217,124,.22);background:linear-gradient(90deg,rgba(244,217,124,.12),transparent 52%),#0003;color:#fff0c4e6;opacity:0;transform:translateY(12px);animation:leaderboardRise .36s ease forwards;animation-delay:var(--rank-delay)}.leaderboard-dialog-list li:nth-child(1){border-color:#ffe78b94;background:linear-gradient(90deg,rgba(255,231,139,.22),transparent 54%),#00000038}.leaderboard-dialog-list b{color:var(--gold);font-family:var(--font-display);font-size:1.1rem}.leaderboard-dialog-list span{min-width:0;overflow:hidden;font-weight:900;text-overflow:ellipsis;white-space:nowrap}.leaderboard-dialog-list strong{color:#ffe8a3;font-family:var(--font-display)}@keyframes leaderboardRise{to{opacity:1;transform:translateY(0)}}@keyframes rankTicker{to{transform:translateY(calc(-34px * var(--rank-count)))}}.route-ui .portal-select{position:relative;overflow:hidden;border-color:#7ee8ffb8;background:radial-gradient(90% 140% at 12% 0%,rgba(126,232,255,.35),transparent 50%),linear-gradient(180deg,#ffe39a,#b86f2a 64%,#234a54);box-shadow:inset 0 0 0 1px #fff7c459,0 0 26px #7ee8ff47}.route-ui .portal-select:after{content:"";position:absolute;inset:-60% -35%;background:conic-gradient(from 30deg,transparent,rgba(126,232,255,.42),transparent 34%,rgba(255,231,139,.42),transparent 68%);opacity:.5;animation:portalSpin 7s linear infinite;pointer-events:none}.route-ui .portal-select>*{position:relative;z-index:1}.route-ui .locked-select{filter:grayscale(.45) brightness(.75)}@keyframes portalSpin{to{transform:rotate(360deg)}}@media(max-width:760px){.vibejam-row{grid-template-columns:1fr}.leaderboard-ticker{grid-template-columns:1fr auto}.leaderboard-ticker header{grid-column:1 / -1}.leaderboard-ticker-window,.leaderboard-ticker .leaderboard-score,.leaderboard-ticker .leaderboard-error{grid-column:1}}.portal-return-modal{position:fixed;inset:0;z-index:60;pointer-events:none;background:linear-gradient(180deg,#0206091a,#0206092e 45%,#02060994),radial-gradient(circle at 52% 38%,rgba(124,236,255,.1),transparent 42%);animation:portalReturnFade .4s ease both}.portal-return-scene{position:relative;width:100%;height:100%;color:var(--cream)}.portal-return-scene-head{position:absolute;left:max(28px,4vw);top:max(28px,4vh);width:min(430px,42vw);display:flex;align-items:center;justify-content:space-between;gap:10px;padding-bottom:10px;border-bottom:1px solid rgba(244,217,124,.22);text-shadow:0 4px 18px rgba(0,0,0,.75)}.portal-return-scene-head span{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-display);font-size:.82rem;letter-spacing:.14em;color:var(--gold);text-transform:uppercase}.portal-return-scene-head small{font-family:var(--font-roman);color:#fff0c4b8;font-size:.78rem;letter-spacing:.14em}.portal-return-cast{pointer-events:auto;position:absolute;top:max(28px,4vh);right:max(22px,3vw);display:flex;gap:10px;max-width:min(520px,48vw);padding:10px;border:1px solid rgba(244,217,124,.35);border-radius:7px;background:#071010b8;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);box-shadow:0 12px 28px #00000059;overflow-x:auto}.portal-return-cast figure{flex:0 0 78px;height:92px;margin:0;position:relative;border:1px solid rgba(244,217,124,.28);border-radius:7px;overflow:hidden;background:#ffe8a30f;opacity:.72;transition:opacity .18s ease,border-color .18s ease,transform .18s ease}.portal-return-cast figure.is-active{opacity:1;border-color:var(--gold);transform:translateY(-2px)}.portal-return-cast img{width:100%;height:100%;object-fit:cover}.portal-return-cast figcaption{position:absolute;left:4px;right:4px;bottom:4px;padding:3px 4px;border-radius:3px;background:#100a04ad;color:#fff0c4;font-family:var(--font-display);font-size:.72rem;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-shadow:0 2px 8px rgba(0,0,0,.85)}.portal-return-portrait{position:absolute;right:clamp(18px,7vw,140px);bottom:clamp(118px,18vh,190px);max-width:min(38vw,410px);max-height:64vh;object-fit:contain;filter:drop-shadow(0 24px 36px rgba(0,0,0,.7));animation:portalReturnRise .45s cubic-bezier(.2,.9,.2,1) both}.portal-return-speaker{margin:0;font-family:var(--font-display);font-size:.9rem;letter-spacing:.12em;color:#ffe8a3;text-transform:uppercase}.portal-return-dialogue{pointer-events:auto;position:absolute;left:max(28px,4vw);right:max(28px,4vw);bottom:max(26px,4vh);min-height:168px;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:10px 24px;padding:30px 34px 26px;border:1px solid rgba(244,217,124,.62);border-radius:8px;background:linear-gradient(90deg,#150d04e6,#041212d1),#04080ac7;box-shadow:0 22px 48px #0000008c,0 0 0 1px #f4d97c24 inset;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.portal-return-quote{position:absolute;left:22px;top:-16px;font-family:var(--font-display);font-size:3rem;color:var(--gold);text-shadow:0 6px 16px rgba(0,0,0,.6)}.portal-return-dialogue h3{grid-column:1;margin:0;font-family:var(--font-display);font-size:clamp(1.3rem,2.1vw,2rem);letter-spacing:.03em;color:var(--gold-bright, #ffe8a3);text-shadow:0 6px 22px rgba(0,0,0,.65)}.portal-return-text{grid-column:1;margin:0;color:#fff0c4e0;line-height:1.58;font-size:clamp(1rem,1.35vw,1.22rem)}.portal-return-ship{grid-column:1;margin:4px 0 0;padding:8px 10px;border:1px dashed rgba(127,231,255,.42);border-radius:3px;font-family:var(--font-display);letter-spacing:.12em;color:#cfeeff;background:#7fe7ff0f;text-align:center}.portal-return-next{grid-column:2;grid-row:1 / span 4;align-self:end;min-width:132px;min-height:54px;padding:11px 24px;border:1px solid rgba(244,217,124,.55);border-radius:6px;background:linear-gradient(180deg,#3c2610d1,#140c06d1);color:var(--gold-bright, #ffe8a3);font-family:var(--font-display);letter-spacing:.14em;text-transform:uppercase;cursor:pointer;transition:background .14s ease,border-color .14s ease,transform .14s ease}.portal-return-next:hover{border-color:var(--gold);background:linear-gradient(180deg,#503416eb,#1c1008eb);transform:translateY(-1px)}.portal-return-next:focus-visible{outline:2px solid var(--gold);outline-offset:2px}@keyframes portalReturnFade{0%{opacity:0}to{opacity:1}}@keyframes portalReturnRise{0%{opacity:0;transform:translateY(18px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@media(max-width:820px){.portal-return-scene-head{width:auto;right:18px;top:18px}.portal-return-cast{top:76px;left:18px;right:18px;max-width:none}.portal-return-cast figure{flex-basis:64px;height:78px}.portal-return-portrait{right:2vw;bottom:210px;max-width:48vw;max-height:42vh}.portal-return-dialogue{left:14px;right:14px;bottom:14px;min-height:172px;grid-template-columns:1fr;padding:24px 20px 18px}.portal-return-next{grid-column:1;grid-row:auto;justify-self:end}}.title-update-log{position:absolute;top:9vh;right:4vw;width:min(320px,28vw);max-height:min(76vh,720px);display:grid;grid-template-rows:auto 1fr;gap:12px;padding:18px 20px 20px;border:1px solid rgba(244,217,124,.36);border-radius:4px;background:linear-gradient(180deg,rgba(244,217,124,.08),transparent 60%),#080e12ad;color:var(--cream);z-index:2;animation:titleEnter .9s cubic-bezier(.2,.9,.2,1) .2s both;pointer-events:auto;overflow:hidden}.title-update-log ol{overflow-y:auto;padding-right:4px;scrollbar-width:thin;scrollbar-color:rgba(244,217,124,.42) transparent}.title-update-log ol::-webkit-scrollbar{width:6px}.title-update-log ol::-webkit-scrollbar-track{background:transparent}.title-update-log ol::-webkit-scrollbar-thumb{background:#f4d97c52;border-radius:999px}.title-update-log ol::-webkit-scrollbar-thumb:hover{background:#f4d97c8f}.title-update-log header{display:flex;align-items:center;gap:8px;padding-bottom:8px;border-bottom:1px solid rgba(244,217,124,.22)}.title-update-log header span{font-family:var(--font-display);letter-spacing:.14em;color:var(--gold);font-size:.82rem;text-transform:uppercase}.title-update-log header svg{color:var(--gold-bright, #ffe8a3)}.title-update-log ol{display:grid;gap:14px;margin:0;padding:0;list-style:none}.title-update-log li{display:grid;gap:4px;padding-left:10px;border-left:1px solid rgba(244,217,124,.26)}.title-update-tag{display:flex;align-items:baseline;gap:8px;margin:0;font-family:var(--font-display);font-size:.78rem;letter-spacing:.14em;color:var(--gold);text-transform:uppercase}.title-update-tag b{color:var(--gold-bright, #ffe8a3)}.title-update-tag small{color:#fff0c485;font-weight:500;letter-spacing:.1em}.title-update-headline{margin:0;font-family:var(--font-display);font-size:1rem;color:#ffe8a3;letter-spacing:.02em}.title-update-body{margin:0;color:#fff0c4c2;font-size:.82rem;line-height:1.55}@media(max-width:980px){.title-update-log{display:none}}.topleft-popover-link{text-decoration:none;border-top:1px solid rgba(214,173,85,.18);margin-top:2px;padding-top:10px}.topleft-popover-link:hover{background:#d6ad551a}.topleft-popover-link small{color:var(--gold);font-size:.68rem;letter-spacing:.12em;text-transform:lowercase}
