*{box-sizing:border-box}[hidden]{display:none!important}body{color:#e8e0c8;background:radial-gradient(at top,#16324a 0%,#0b1c2c 70%);min-height:100vh;margin:0;font-family:system-ui,sans-serif}.panel{background:#0c1d2ed9;border:1px solid #3a5a78;border-radius:12px;max-width:560px;margin:8vh auto 0;padding:2rem;box-shadow:0 12px 40px #00000080}.panel h1{margin:0 0 .25rem;line-height:1.2}.tagline{opacity:.7;margin-top:.25rem}.row{gap:.5rem;margin:.75rem 0;display:flex}.field{margin:1rem 0;display:block}.field span{opacity:.8;margin-bottom:.25rem;font-size:.85rem;display:block}input,button{font:inherit;border:1px solid #3a5a78;border-radius:8px;padding:.6rem .9rem}input{color:inherit;background:#0c1d2e;flex:1;width:100%}input:focus{border-color:#0000;outline:2px solid #c8842a}button{color:#e8e0c8;cursor:pointer;white-space:nowrap;background:#29455e;font-weight:600}button:hover:not(:disabled){filter:brightness(1.2)}button:disabled{opacity:.5;cursor:not-allowed}button.primary{color:#1a1206;background:#c8842a;width:100%}button.danger{background:#6e2f2a}.menu{border-color:#c8842a;position:relative;overflow:hidden}.menu-hero{text-align:center;margin-bottom:1rem}.menu-flag{font-size:3rem;line-height:1;animation:3.2s ease-in-out infinite bob}@keyframes bob{0%,to{transform:translateY(0)rotate(-3deg)}50%{transform:translateY(-7px)rotate(3deg)}}.menu-hero h1{color:#ffd97a;text-shadow:0 2px #6b3e12,0 4px 12px #0000008c;margin:.3rem 0 .15rem;font-size:1.9rem}.menu button.big{margin-top:.4rem;padding:.8rem;font-size:1.1rem}.menu button.dice{flex:none;padding:.5rem .7rem;font-size:1.1rem}.menu button.rejoin{background:#1e4a3a;border-color:#2f7a5a;width:100%;margin-top:.5rem}.menu-features{opacity:.85;flex-wrap:wrap;justify-content:center;gap:.35rem .9rem;margin:1.1rem 0 1.6rem;font-size:.82rem;display:flex}.menu-waves{pointer-events:none;height:26px;position:absolute;bottom:0;left:0;right:0;overflow:hidden}.menu-waves .wave{opacity:.55;background:radial-gradient(circle at 10px -6px,#0000 12px,#2ba6c4 13px) 0 0/42px 30px repeat-x;width:200%;height:30px;animation:7s linear infinite drift;position:absolute;bottom:-14px;left:-50%}.menu-waves .w2{opacity:.7;background:radial-gradient(circle at 10px -6px,#0000 12px,#1273a8 13px) 0 0/58px 30px repeat-x;animation-duration:11s;animation-direction:reverse;bottom:-18px}@keyframes drift{0%{transform:translate(0)}to{transform:translate(42px)}}.menu .divider{text-align:center;opacity:.5;margin:1.25rem 0 .5rem;font-size:.9rem}.error{color:#ff9b8a;min-height:1.2em;margin:.5rem 0 0}.lobby-header{justify-content:space-between;align-items:center;gap:1rem;display:flex}.room-code{letter-spacing:.25em;color:#ffd97a;background:#0c1d2e;border:1px dashed #c8842a;border-radius:8px;padding:.35rem .7rem;font-size:1.6rem;font-weight:800}.roster{flex-direction:column;gap:.4rem;margin:1rem 0;padding:0;list-style:none;display:flex}.roster li{background:#0c1d2e;border:1px solid #23425e;border-radius:8px;align-items:center;gap:.6rem;padding:.5rem .75rem;display:flex}.roster li.away{opacity:.45}.swatch{border-radius:50%;flex-shrink:0;width:14px;height:14px}.crew-name{text-overflow:ellipsis;flex:1;overflow:hidden}.badge{color:#1a1206;text-transform:uppercase;background:#c8842a;border-radius:5px;padding:.1rem .4rem;font-size:.7rem;font-weight:800}.howto{background:#0c1d2ee6;border:1px dashed #3a5a78;border-radius:8px;margin-top:.75rem;padding:.6rem .8rem;font-size:.85rem;line-height:1.4}.howto-keys{flex-wrap:wrap;gap:.3rem;margin-top:.45rem;display:flex}.howto-keys span{opacity:.9;background:#16324a;border:1px solid #2a4a68;border-radius:5px;padding:.1rem .45rem;font-size:.72rem}.hud-clicklock{text-align:center;background:#0a1826e0;border:2px solid #ffd97a;border-radius:12px;padding:.9rem 1.6rem;font-size:1.15rem;animation:1.8s ease-in-out infinite pulse-glow;position:absolute;top:34%;left:50%;transform:translate(-50%)}@keyframes pulse-glow{0%,to{box-shadow:0 0 6px #ffd97a40}50%{box-shadow:0 0 22px #ffd97a99}}.q-tips{opacity:.85;padding:.3rem .2rem;font-size:.82rem;line-height:1.5}.chat-log{background:#0c1d2e;border:1px solid #23425e;border-radius:8px;height:9rem;margin-top:1rem;padding:.6rem .75rem;font-size:.9rem;overflow-y:auto}.chat-log div{margin-bottom:.2rem}.game-root{position:fixed;inset:0;overflow:hidden}.game-root canvas{width:100%;height:100%;display:block}.hud{pointer-events:none;flex-direction:column;justify-content:space-between;padding:.75rem 1rem;display:flex;position:absolute;inset:0}.hud-top{justify-content:space-between;align-items:center;display:flex}.hud-code{letter-spacing:.15em;background:#0c1d2eb3;border-radius:8px;padding:.3rem .7rem;font-weight:800}.hud-crew{background:#0c1d2eb3;border-radius:8px;padding:.3rem .7rem}.hud-bottom{flex-direction:column;align-items:center;gap:.4rem;display:flex}.hud-hint{color:#ffd97a;background:#0c1d2ecc;border-radius:8px;min-height:1.4em;padding:.35rem .8rem;font-size:1.05rem;font-weight:700}.hud-hint:empty{visibility:hidden}.hud-status{background:#0c1d2eb3;border-radius:8px;padding:.3rem .7rem}.hud-help{opacity:.7;background:#0c1d2eb3;border-radius:8px;padding:.25rem .6rem;font-size:.8rem}.worldmap{background:#0a1826eb;border:2px solid #c8842a;border-radius:12px;padding:.75rem;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.worldmap-title{text-align:center;margin-bottom:.5rem;font-weight:700}.worldmap canvas{border-radius:8px;display:block}.hud-gold{color:#ffd97a;background:#0c1d2eb3;border-radius:8px;padding:.3rem .7rem;font-weight:700}.hud-hp{background:#0c1d2ecc;border:1px solid #3a5a78;border-radius:6px;width:240px;height:16px;position:relative;overflow:hidden}.hud-hp-num{text-shadow:0 1px 2px #000c;justify-content:center;align-items:center;font-size:.72rem;font-weight:800;display:flex;position:absolute;inset:0}.hotbar-wrap{flex-direction:column;align-items:center;gap:3px;display:flex}.hotbar-label{color:#ffd97a;text-shadow:0 1px 3px #000000e6;min-height:1.2em;font-size:.85rem;font-weight:700}.hotbar{background:#0a1826bf;border:1px solid #3a5a78;border-radius:10px;gap:4px;width:max-content;padding:4px;flex-flow:row!important;display:flex!important}.hotbar .slot{background:#0c1d2ee6;border:2px solid #23425e;border-radius:8px;flex:0 0 46px;justify-content:center;align-items:center;width:46px;height:46px;transition:transform 80ms,border-color 80ms;display:flex;position:relative}.hotbar .slot.sel{background:#283c1ee6;border-color:#ffd97a;transform:translateY(-5px)scale(1.08);box-shadow:0 0 10px #ffd97a99,inset 0 0 6px #ffd97a40}.hotbar .slot.sel:after{content:"▲";color:#ffd97a;font-size:.55rem;position:absolute;bottom:-14px;left:50%;transform:translate(-50%)}.hotbar .slot-emoji{font-size:1.5rem}.hotbar .slot-key{opacity:.55;font-size:.6rem;position:absolute;top:1px;left:4px}.hotbar .slot-n{color:#ffd97a;text-shadow:0 1px 2px #000000e6;font-size:.72rem;font-weight:800;position:absolute;bottom:1px;right:4px}.hud-hp-fill{background:linear-gradient(90deg,#d04a3a,#e07a3a);width:100%;height:100%;transition:width .25s}.hud-toasts{pointer-events:none;flex-direction:column;align-items:center;gap:.3rem;display:flex;position:absolute;top:3.4rem;left:50%;transform:translate(-50%)}.toast{background:#0c1d2ed9;border:1px solid #3a5a78;border-radius:8px;padding:.3rem .8rem;font-weight:600;transition:opacity .7s}.toast.fade{opacity:0}.hud-down{text-align:center;color:#ff9b8a;background:#0a141ed9;border:2px solid #d04a3a;border-radius:14px;padding:1.2rem 2rem;font-size:2rem;font-weight:900;position:absolute;top:40%;left:50%;transform:translate(-50%,-50%)}.hud-down small{color:#e8e0c8;font-size:1rem;font-weight:500}@keyframes hurt-flash{0%{box-shadow:inset 0 0 120px #dc3228cc}to{box-shadow:inset 0 0 #dc322800}}.game-root.hurt:after{content:"";pointer-events:none;animation:.5s ease-out hurt-flash;position:absolute;inset:0;box-shadow:inset 0 0 #dc322800}.hud-chat{flex-direction:column;gap:.3rem;width:320px;display:flex;position:absolute;bottom:7.5rem;left:1rem}.hud-chatlog{text-shadow:0 1px 3px #000000e6;opacity:.9;word-break:break-word;font-size:.85rem;line-height:1.4}#hud-chatinput{pointer-events:auto;background:#0c1d2ee6;font-size:.9rem}.hud-mission{background:#0c1d2ecc;border:1px solid #3a5a78;border-radius:10px;max-width:300px;padding:.6rem .8rem;font-size:.92rem;line-height:1.35;position:absolute;top:3.4rem;left:1rem}.hud-mission:empty{display:none}.hud-dialogue{background:#141008eb;border:2px solid #c8842a;border-radius:12px;width:calc(100% - 2rem);max-width:620px;padding:.8rem 1.1rem;font-size:1rem;font-style:italic;line-height:1.45;position:absolute;bottom:7.5rem;left:50%;transform:translate(-50%)}.hud-shop{pointer-events:auto;background:#0a1826f2;border:2px solid #c8842a;border-radius:12px;width:440px;max-width:calc(100% - 2rem);padding:1rem 1.2rem;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.hud-shop h3{margin:0 0 .6rem}.shop-item{border-top:1px solid #23425e;justify-content:space-between;align-items:center;gap:.8rem;padding:.55rem 0;display:flex}.shop-item small{opacity:.75}.hud-victory{text-align:center;pointer-events:auto;background:#08121ce6;flex-direction:column;justify-content:center;align-items:center;gap:.8rem;padding:2rem;display:flex;position:absolute;inset:0}.hud-victory h1{color:#ffd97a;margin:0;font-size:2.6rem}.hud-victory p{max-width:640px;font-size:1.1rem;line-height:1.5}.hud-victory button{color:#1a1206;background:#c8842a;padding:.7rem 1.4rem;font-size:1.1rem}.hud-quests{background:#0a1826f2;border:2px solid #c8842a;border-radius:12px;width:460px;max-width:calc(100% - 2rem);padding:1rem 1.2rem;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.hud-quests h3{margin:0 0 .5rem}.q-section{letter-spacing:.14em;opacity:.6;margin:.8rem 0 .35rem;font-size:.72rem}.q-main{background:#0c1d2ee6;border:1px solid #3a5a78;border-radius:8px;padding:.55rem .75rem;line-height:1.4}.q-obj{color:#ffd97a}.q-side{border-top:1px solid #23425e;flex-wrap:wrap;align-items:baseline;gap:.4rem;padding:.35rem .2rem;font-size:.92rem;display:flex}.q-side.q-done{opacity:.55}.q-progress{color:#ffd97a;margin-left:auto;font-weight:700}.q-reward{opacity:.7;font-size:.85rem}
