*{box-sizing:border-box;margin:0;padding:0}body{color:#fff;-webkit-user-select:none;user-select:none;background:#000;font-family:Courier New,monospace;overflow:hidden}.screen{justify-content:center;align-items:center;display:none;position:fixed;inset:0}.screen.active{display:flex}#screen-login{background:#000;flex-direction:column;justify-content:center;align-items:center}#login-box{text-align:center;background:#080818;border:3px solid gold;min-width:300px;max-width:88vw;padding:2rem 2.2rem;font-family:Courier New,monospace}#login-box h1{color:gold;letter-spacing:.25em;margin:0 0 .3rem;font-size:1.3rem}#login-box p{color:#555;margin:0 0 1.2rem;font-size:.68rem}#login-error{color:#f44;min-height:1.1em;margin-bottom:.6rem;font-size:.73rem}#login-username,#login-pin{box-sizing:border-box;color:#eee;background:#0d0d2a;border:1px solid #333;width:100%;margin-bottom:.65rem;padding:.5rem .7rem;font-family:inherit;font-size:.85rem;display:block}#login-username:focus,#login-pin:focus{border-color:gold;outline:none}#login-main-btns{gap:.5rem;margin-bottom:.5rem;display:flex}#btn-login,#btn-register{color:gold;cursor:pointer;letter-spacing:.1em;background:#111130;border:2px solid gold;flex:1;padding:.55rem;font-family:inherit;font-size:.72rem}#btn-login:hover,#btn-register:hover{background:#1a1a50}#btn-guest{color:#333;cursor:pointer;letter-spacing:.05em;background:0 0;border:1px solid #222;width:100%;padding:.35rem;font-family:inherit;font-size:.63rem}#btn-guest:hover{color:#555;border-color:#444}#login-connecting{color:#555;margin-top:.8rem;font-size:.65rem}#screen-title{background:#000;flex-direction:column}#title-canvas{width:100%;height:100%;position:absolute;inset:0}#title-ui{text-align:center;z-index:2;position:relative}.game-title{letter-spacing:.2em;color:gold;text-shadow:0 0 20px gold,0 0 40px #ff8c00,4px 4px #8b4500;font-size:clamp(2rem,8vw,5rem);animation:2s ease-in-out infinite alternate pulse}.game-subtitle{letter-spacing:.3em;color:#87ceeb;margin:.5rem 0 2rem;font-size:clamp(.7rem,2vw,1.1rem)}@keyframes pulse{0%{text-shadow:0 0 20px gold,0 0 40px #ff8c00,4px 4px #8b4500}to{text-shadow:0 0 40px gold,0 0 80px #ff8c00,4px 4px #8b4500}}#btn-start{color:gold;letter-spacing:.2em;cursor:pointer;background:0 0;border:3px solid gold;padding:.6rem 2rem;font-family:inherit;font-size:1.2rem;animation:1s step-end infinite blink}#btn-start:hover{background:#ffd70022}@keyframes blink{50%{opacity:0}}#screen-create{background:#0a0a1a;flex-direction:row;justify-content:center;align-items:flex-start;padding:1.5rem;overflow-y:auto}#screen-create h2{color:gold;letter-spacing:.2em;font-size:1.3rem}.species-btn,.class-btn{color:#aaa;cursor:pointer;white-space:nowrap;letter-spacing:.05em;background:#111;border:2px solid #333;border-radius:3px;padding:.3rem .5rem;font-family:inherit;font-size:.72rem}.species-btn:hover,.class-btn:hover{border-color:#888}.species-btn.selected,.class-btn.selected{color:gold;background:#1a1600;border-color:gold}.create-row{flex-wrap:wrap;justify-content:center;align-items:center;gap:1rem;display:flex}.create-label{color:#87ceeb;letter-spacing:.1em;min-width:120px;font-size:.85rem}input[type=text]{color:#fff;background:#111;border:2px solid #333;width:180px;padding:.4rem .8rem;font-family:inherit;font-size:.9rem}input[type=text]:focus{border-color:gold;outline:none}.color-btn{cursor:pointer;border:3px solid #333;border-radius:3px;width:36px;height:36px}.color-btn.selected{border-color:gold;transform:scale(1.15)}.stat-row{align-items:center;gap:.5rem;display:flex}.stat-name{color:#ccc;width:80px;font-size:.8rem}.stat-bar{gap:2px;display:flex}.stat-pip{cursor:pointer;border:1px solid #444;border-radius:1px;width:8px;height:14px}.stat-pip.filled{background:gold;border-color:#c90}.stat-pip.capped{cursor:default;background:#252535;border-color:#404060}.stat-pip.filled.capped{background:#3a3000;border-color:#555000}.stat-pip.class-lock{cursor:default;background:#c60;border-color:#ff8c00}.stat-pip.class-lock.capped{cursor:default;background:#6a3300;border-color:#8b4400}.stat-pts{color:gold;text-align:right;min-width:60px;font-size:.8rem}#btn-create{color:#000;letter-spacing:.15em;cursor:pointer;background:gold;border:none;margin-top:1rem;padding:.6rem 2.5rem;font-family:inherit;font-size:1.1rem;font-weight:700}#btn-create:hover{background:orange}.persist-row{color:#888;align-items:center;gap:.5rem;font-size:.8rem;display:flex}.persist-row input{cursor:pointer}#screen-game{background:#000;flex-direction:column}#game-wrap{image-rendering:pixelated;position:relative}#game-wrap canvas{image-rendering:pixelated;position:absolute;top:0;left:0}#cv-bg{z-index:1}#cv-tiles{z-index:2}#cv-sprites{z-index:3}#cv-fg{z-index:4;pointer-events:none}#cv-ceiling{z-index:5;pointer-events:none}#cv-ui{z-index:6;pointer-events:none}#cv-ui[style*="pointer-events: auto"]{cursor:pointer}#hud{z-index:10;background:linear-gradient(#000a,#0006);align-items:center;gap:16px;height:36px;padding:0 12px;font-size:.75rem;display:flex;position:fixed;top:0;left:0;right:0}#hud-zone{color:#87ceeb;letter-spacing:.1em;flex:1}#hud-hearts,#hud-mp{gap:2px;display:flex}#hud-spacebucks,#hud-alusd,#hud-alcx{font-size:.75rem}#hud-players{color:#888;font-size:.7rem}#hud-level{color:#8bc34a;text-align:center;min-width:36px;font-size:.75rem;font-weight:700}#hud-xp-bar{z-index:10;background:#111;height:5px;position:fixed;top:36px;left:0;right:0}#hud-xp-fill{background:linear-gradient(90deg,#4caf50,#cddc39);width:0%;height:100%;transition:width .4s}#hud-quest{z-index:10;pointer-events:none;background:0 0;align-items:center;min-height:0;padding:0 10px;font-family:monospace;font-size:.68rem;transition:opacity .3s;display:flex;position:fixed;top:41px;left:0;right:0}#hud-quest:empty{display:none}#hud-quest .q-label{color:gold;margin-right:6px}#hud-quest .q-progress{color:#8bc34a}#hud-quest .q-ready{color:gold;font-weight:700;animation:1.2s infinite questPulse}@keyframes questPulse{0%,to{opacity:1}50%{opacity:.5}}#chat-panel{z-index:10;background:#0008;width:min(320px,100vw);padding:6px;position:fixed;bottom:0;left:0}#chat-log{height:80px;margin-bottom:4px;font-size:.72rem;line-height:1.4;overflow-y:auto}#chat-log .msg{padding:1px 0}#chat-log .msg .who{color:gold}#chat-input{color:#fff;background:#111;border:1px solid #444;width:100%;padding:3px 6px;font-family:inherit;font-size:.75rem;display:none}body.touch #screen-game{justify-content:flex-start}body.touch #game-wrap{justify-content:center;align-items:flex-start;width:100%;height:100%;display:flex;position:absolute;inset:0}body.touch .touch-only{display:inline!important}body.touch #chat-panel{max-width:55vw;bottom:90px}@media (width<=400px){#hud-players{display:none}}#mobile-act{z-index:30;flex-direction:column;gap:8px;display:none;position:fixed;bottom:12px;left:8px}body.touch #mobile-act{display:flex}.act-btn{letter-spacing:.03em;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:none;color:gold;background:#0008;border:2px solid #ffd70099;border-radius:50%;justify-content:center;align-items:center;width:54px;height:54px;font-size:.65rem;font-weight:700;display:flex}.act-btn:active{background:#ffd70033}#btn-fullscreen{letter-spacing:0;font-size:1.2rem}body.fullscreen #btn-fullscreen{color:#fff;background:#fff2;border-color:#fff}#fs-toast{color:gold;text-align:center;z-index:999;pointer-events:none;white-space:nowrap;white-space:normal;background:#111c;border:1px solid gold;border-radius:8px;max-width:92vw;padding:8px 14px;font-family:monospace;font-size:.78rem;line-height:1.4;display:none;position:fixed;bottom:80px;left:50%;transform:translate(-50%)}#fs-toast.show{animation:.25s fsToastIn;display:block}#pause-overlay{z-index:20;background:#000c;justify-content:center;align-items:center;display:none;position:fixed;inset:0}#pause-overlay.open{display:flex}#pause-box{box-sizing:border-box;background:#0d0d1f;border:3px solid gold;width:min(480px,96vw);min-width:300px;max-width:96vw;max-height:90vh;padding:1rem;overflow-y:auto}#pause-box h2{color:gold;letter-spacing:.2em;margin:0;font-size:1.1rem}#inv-grid{flex-direction:column;gap:4px;width:100%;margin-bottom:.75rem;display:flex}.inv-slot{cursor:pointer;background:#111;border:2px solid #333;justify-content:center;align-items:center;width:36px;height:36px;font-size:.7rem;display:flex}.inv-slot.has-item{border-color:gold}#stats-box{color:#ccc;flex-direction:column;gap:3px;width:100%;font-size:.78rem;display:flex}.stat-line{justify-content:space-between;gap:6px;min-width:0;display:flex}.stat-line span:first-child{flex-shrink:0}.stat-line span:last-child{color:gold;text-align:right;text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}#godmode-badge{color:#000;z-index:15;letter-spacing:.1em;background:gold;padding:2px 8px;font-size:.65rem;display:none;position:fixed;top:40px;right:8px}#godmode-badge.on{display:block}#queue-panel{z-index:15;background:#050510;border:2px solid gold;min-width:185px;max-width:210px;font-family:Courier New,monospace;display:none;position:fixed;bottom:90px;right:10px;box-shadow:0 0 24px #ffd70044}#queue-header{color:#000;letter-spacing:.15em;background:gold;padding:4px 8px;font-size:.63rem;font-weight:700}#queue-ticket-num{color:gold;text-align:center;letter-spacing:.05em;padding:8px 0 2px;font-size:2.2rem;line-height:1}#queue-serving-line{color:#aaa;text-align:center;padding:1px 0;font-size:.67rem}#queue-ahead-line{color:#888;text-align:center;padding-bottom:5px;font-size:.65rem}#queue-locked-line{color:#ff8c00;text-align:center;border-top:1px solid #1a1a30;padding:3px 8px;font-size:.65rem}#queue-list{border-top:1px solid #1a1a30;max-height:80px;padding:4px 8px;font-size:.61rem;overflow-y:auto}#queue-list div{white-space:nowrap;text-overflow:ellipsis;padding:1px 0;overflow:hidden}#queue-enter-btn{color:#0d7;letter-spacing:.1em;cursor:pointer;background:#002a14;border:2px solid #0d7;width:calc(100% - 16px);margin:6px 8px 2px;padding:6px;font-family:inherit;font-size:.7rem;animation:.7s step-end infinite blink;display:none}#queue-leave-btn{color:#644;cursor:pointer;letter-spacing:.05em;background:#1a0000;border:1px solid #400;width:calc(100% - 16px);margin:4px 8px 8px;padding:3px;font-family:inherit;font-size:.6rem}#npc-dialog{z-index:20;background:#07071a;border:3px solid #4a90d9;border-radius:3px;width:88%;max-width:540px;font-family:Courier New,monospace;display:none;position:fixed;bottom:18px;left:50%;transform:translate(-50%);box-shadow:0 0 28px #4a90d944}#npc-dialog-inner{align-items:flex-start;gap:10px;padding:10px 12px 6px;display:flex}#npc-portrait-cv{image-rendering:pixelated;background:#0a0a1a;border:2px solid #4a90d9;flex-shrink:0}#npc-dialog-body{flex:1;min-width:0}#npc-dialog-name{color:gold;letter-spacing:.08em;margin-bottom:4px;font-size:.72rem;font-weight:700}#npc-dialog-text{color:#d8d8ee;min-height:36px;font-size:.75rem;line-height:1.55}#npc-dialog-hint{text-align:right;color:#445;border-top:1px solid #1a1a3a;margin-top:3px;padding:3px 12px 6px;font-size:.6rem}#shop-overlay{z-index:25;background:#000d;justify-content:center;align-items:center;display:none;position:fixed;inset:0}#shop-overlay.open{display:flex}#shop-box{background:#080818;border:3px solid gold;min-width:360px;max-width:94vw;max-height:82vh;padding:1.2rem;font-family:Courier New,monospace;overflow-y:auto}#shop-header-row{border-bottom:1px solid #333;justify-content:space-between;align-items:center;margin-bottom:.8rem;padding-bottom:.5rem;display:flex}#shop-title{color:gold;letter-spacing:.15em;font-size:.9rem;font-weight:700}#shop-gold-display{color:gold;font-size:.8rem}.shop-row{border-bottom:1px solid #12122a;align-items:center;gap:10px;padding:7px 4px;display:flex}.shop-row-icon{text-align:center;flex-shrink:0;width:26px;font-size:1.3rem}.shop-row-info{flex:1;min-width:0}.shop-row-name{color:#ddd;font-size:.78rem;font-weight:700}.shop-row-desc{color:#666;margin-top:1px;font-size:.67rem}.shop-row-req{margin-top:2px;font-size:.62rem}.shop-row-right{text-align:right;flex-shrink:0}.shop-row-price{color:gold;margin-bottom:3px;font-size:.78rem}.shop-buy-btn{color:#4caf50;cursor:pointer;letter-spacing:.05em;background:#1a4a1a;border:1px solid #4caf50;padding:3px 10px;font-family:inherit;font-size:.68rem}.shop-buy-btn:hover:not(:disabled){background:#2a6a2a}.shop-buy-btn:disabled{color:#444;cursor:default;background:#1a1a1a;border-color:#333}.bank-pos{background:#111;border:1px solid #2a2a2a;border-radius:6px;margin:6px 0;padding:10px;font-size:.8rem}.bank-bar{background:#1a1a1a;border-radius:4px;height:7px;margin:6px 0}.bank-bar-fill{background:linear-gradient(90deg,#388e3c,#81c784);border-radius:4px;height:7px}@keyframes fsToastIn{0%{opacity:0;transform:translate(-50%)translateY(8px)}to{opacity:1;transform:translate(-50%)translateY(0)}}#tx-toast{color:#fff;text-align:center;z-index:1200;pointer-events:none;white-space:nowrap;background:#0e1a0e;border:2px solid #4caf50;border-radius:10px;max-width:88vw;padding:10px 20px;font-family:monospace;font-size:.88rem;font-weight:700;line-height:1.4;display:none;position:fixed;top:54px;left:50%;transform:translate(-50%);box-shadow:0 0 18px #4caf5066}#tx-toast.show{animation:.2s txToastIn;display:block}#tx-toast.tx-sell{background:#1a1500;border-color:#fdd835;box-shadow:0 0 18px #fdd83559}#tx-toast.tx-drop{background:#1a0808;border-color:#cf6679;box-shadow:0 0 18px #cf66794d}#tx-toast.tx-use{background:#071520;border-color:#4fc3f7;box-shadow:0 0 18px #4fc3f74d}@keyframes txToastIn{0%{opacity:0;transform:translate(-50%)translateY(-10px)}to{opacity:1;transform:translate(-50%)translateY(0)}}#hud-changelog{cursor:pointer;opacity:.8;color:inherit;background:0 0;border:none;padding:0 3px;font-size:.9rem;position:relative}#hud-changelog:hover{opacity:1}#hud-changelog-badge{color:#fff;letter-spacing:.02em;background:#f44;border-radius:4px;padding:1px 3px;font-size:6px;font-weight:700;animation:1.2s infinite questPulse;position:absolute;top:-3px;right:-2px}.cl-entry{border-bottom:1px solid #1e1e2e;margin-bottom:18px;padding-bottom:14px}.cl-entry:last-child{border-bottom:none;margin-bottom:0}.cl-version{color:gold;margin-bottom:4px;font-size:.82rem;font-weight:700}.cl-date{color:#666;margin-left:8px;font-size:.7rem}.cl-section{color:#87ceeb;margin:7px 0 3px;font-size:.72rem;font-weight:700}.cl-item{color:#ccc;margin:2px 0 2px 10px;font-size:.72rem;line-height:1.4}.cl-item:before{content:"▸ ";color:#666}
