:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg:#15152a;--panel:#14182ceb;--accent:#93c5fd}*{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg);color:#e2e8f0;touch-action:none;width:100%;height:100%;font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;overflow:hidden}#game-container{width:100%;height:100%}#game-container canvas{image-rendering:pixelated;display:block}.modal{z-index:100;background:#020617b3;place-items:center;display:none;position:fixed;inset:0}.modal.visible{display:grid}.panel{background:var(--panel);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);border:1px solid #93c5fd66;border-radius:14px;width:min(560px,92vw);max-height:90vh;padding:1rem;overflow-y:auto}.panel h2{margin:0 0 .5rem}.credit{text-align:center;color:#64748b;margin-top:.6rem;font-size:.75rem}label,fieldset{margin:.8rem 0;display:block}fieldset{border:1px solid #94a3b866;border-radius:10px;padding:.5rem}input{width:100%;color:inherit;background:#0f172a;border:1px solid #334155;border-radius:8px;margin-top:.4rem;padding:.6rem;font-size:16px}.character-creator{margin:.8rem 0}.creator-preview{justify-content:center;margin-bottom:.8rem;display:flex}.preview-canvas{image-rendering:pixelated;background:#0f172acc;border:1px solid #334155;border-radius:10px}.creator-tabs{-webkit-overflow-scrolling:touch;border-bottom:2px solid #334155;gap:0;margin-bottom:.5rem;display:flex;overflow-x:auto}.creator-tab{color:#64748b;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex-shrink:0;margin-bottom:-2px;padding:.4rem .7rem;font-size:.85rem;transition:color .15s,border-color .15s}.creator-tab:hover{color:#94a3b8}.creator-tab.active{border-bottom-color:var(--accent);color:#e2e8f0;background:#2563eb14}.creator-tab-content{min-height:80px}.style-grid{flex-wrap:wrap;gap:.35rem;display:flex}.style-option{color:#94a3b8;cursor:pointer;background:#0f172a99;border:1px solid #334155;border-radius:6px;align-items:center;gap:.3rem;padding:.35rem .6rem;font-size:.8rem;display:flex}.style-option.active{border-color:var(--accent);color:#e2e8f0;background:#2563eb4d}.option-thumb{width:24px;height:24px;image-rendering:pixelated;border-radius:3px;flex-shrink:0}.color-label{color:#94a3b8;margin:.5rem 0 .3rem;font-size:.8rem}.color-grid{flex-wrap:wrap;gap:.3rem;display:flex}.color-swatch{color:#94a3b8;cursor:pointer;background:#0f172a99;border:1px solid #334155;border-radius:6px;place-items:center;width:28px;height:28px;font-size:.7rem;display:grid}.color-swatch.active{border-color:var(--accent);color:#e2e8f0;background:#2563eb4d}button[type=submit]{color:#fff;cursor:pointer;background:linear-gradient(120deg,#2563eb,#1d4ed8);border:0;border-radius:10px;width:100%;padding:.75rem .9rem;font-size:1rem;font-weight:600;display:block}.config-btn{z-index:40;color:#94a3b8;cursor:pointer;background:#0f172ad9;border:1px solid #334155;border-radius:50%;place-items:center;width:36px;height:36px;font-size:18px;display:grid;position:fixed;top:.5rem;left:.5rem}.config-btn:hover{border-color:var(--accent);color:#e2e8f0}.leaderboard{z-index:40;background:#0f172ae0;border:1px solid #334155;border-radius:10px;min-width:140px;max-width:200px;padding:.5rem .7rem;position:fixed;top:.5rem;right:.5rem}.lb-title{color:gold;text-align:center;margin-bottom:.3rem;font-size:.75rem;font-weight:700}.lb-list{flex-direction:column;gap:.15rem;display:flex}.lb-entry{background:#ffffff0a;border-radius:4px;justify-content:space-between;align-items:center;padding:.15rem .3rem;font-size:.75rem;display:flex}.lb-name{color:#e2e8f0;text-overflow:ellipsis;white-space:nowrap;max-width:100px;overflow:hidden}.lb-score{color:gold;margin-left:auto;padding-left:.3rem;font-weight:700}.lb-donate-btn{cursor:pointer;opacity:.5;background:0 0;border:none;margin-left:.2rem;padding:0 .15rem;font-size:.65rem;line-height:1;transition:opacity .15s,transform .15s}.lb-donate-btn:hover{opacity:1;transform:scale(1.3)}.lb-buy-btn{color:#0f172a;cursor:pointer;background:linear-gradient(#ffd84a,#f0b90b);border:1px solid #c89500;border-radius:6px;width:100%;margin-top:.45rem;padding:.35rem .5rem;font-family:inherit;font-size:.72rem;font-weight:700;transition:filter .12s,transform .12s;display:block}.lb-buy-btn:hover:not(:disabled){filter:brightness(1.08);transform:translateY(-1px)}.lb-buy-btn:disabled{opacity:.6;cursor:default}.purchase-toast{z-index:60;color:gold;pointer-events:none;opacity:0;background:#0f172af2;border:1px solid gold;border-radius:8px;padding:.6rem 1rem;font-size:.85rem;font-weight:600;transition:transform .25s,opacity .25s;position:fixed;top:1rem;left:50%;transform:translate(-50%,-120%);box-shadow:0 6px 20px #0006}.purchase-toast.purchase-toast-visible{opacity:1;transform:translate(-50%)}.purchase-toast.purchase-toast-error{color:#fca5a5;border-color:#fca5a5}.donate-dialog{z-index:100;text-align:center;background:#0f172af2;border:1px solid gold;border-radius:10px;min-width:180px;padding:.8rem 1rem;font-family:Inter,system-ui,sans-serif;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 4px 24px #00000080}.donate-title{color:gold;margin-bottom:.5rem;font-size:.8rem;font-weight:700}.donate-row{gap:.3rem;margin-bottom:.4rem;display:flex}.donate-input{color:#e2e8f0;text-align:center;background:#ffffff14;border:1px solid #475569;border-radius:5px;outline:none;flex:1;padding:.3rem .4rem;font-family:inherit;font-size:.75rem}.donate-input:focus{border-color:gold}.donate-send-btn{color:#0f172a;cursor:pointer;background:gold;border:none;border-radius:5px;padding:.3rem .6rem;font-family:inherit;font-size:.75rem;font-weight:700;transition:background .15s}.donate-send-btn:hover{background:#facc15}.donate-warning{color:#ff6b6b;margin-bottom:.3rem;font-size:.65rem}.donate-cancel-btn{color:#94a3b8;cursor:pointer;background:0 0;border:none;padding:.2rem;font-family:inherit;font-size:.65rem}.donate-cancel-btn:hover{color:#e2e8f0}.chat-container{z-index:50;pointer-events:none;padding:.5rem;position:fixed;bottom:0;left:0;right:0}.chat-history{pointer-events:auto;max-height:150px;margin-bottom:.4rem;padding:0 .3rem;overflow-y:auto}.chat-history-entry{color:#e2e8f0;background:#02061799;border-radius:4px;margin:2px 0;padding:2px 6px;font-size:.85rem}.chat-history-entry .chat-name{color:var(--accent);font-weight:700}.chat-input-row{pointer-events:auto;gap:.3rem;display:flex}.chat-input{color:#e2e8f0;background:#0f172ae6;border:1px solid #334155;border-radius:8px;outline:none;flex:1;padding:.5rem .6rem;font-size:14px}.chat-input:focus{border-color:var(--accent)}.emote-btn,.chat-send-btn,.chat-close-btn{color:#e2e8f0;cursor:pointer;background:#0f172ae6;border:1px solid #334155;border-radius:8px;padding:.5rem .7rem;font-size:14px}.chat-close-btn{color:#94a3b8;padding:.5rem;font-size:12px}.chat-close-btn:hover{color:#e2e8f0;border-color:var(--accent)}.chat-send-btn{background:#2563ebcc;border-color:#2563eb99;font-weight:600}.emote-picker{z-index:60;background:#0f172af2;border:1px solid #334155;border-radius:10px;padding:.5rem;position:fixed;bottom:60px;left:.5rem}.emote-grid{grid-template-columns:repeat(5,40px);gap:4px;display:grid}.emote-cell{cursor:pointer;background:0 0;border:1px solid #0000;border-radius:6px;place-items:center;width:40px;height:40px;padding:0;display:grid}.emote-cell:hover{border-color:var(--accent);background:#2563eb33}.emote-cell canvas{image-rendering:pixelated}.shop-btn{z-index:40;color:#94a3b8;cursor:pointer;background:#0f172ad9;border:1px solid #334155;border-radius:50%;place-items:center;width:36px;height:36px;font-size:18px;display:grid;position:fixed;top:.5rem;left:3rem}.shop-btn:hover{color:gold;border-color:gold}.building-shop{z-index:50;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0f172af2;border:1px solid #334155;border-radius:10px;flex-direction:column;width:260px;max-height:70vh;padding:.5rem;display:flex;position:fixed;top:3rem;left:.5rem}.shop-header{border-bottom:1px solid #334155;align-items:center;gap:.4rem;margin-bottom:.4rem;padding-bottom:.3rem;display:flex}.shop-title{color:gold;flex:1;font-size:.85rem;font-weight:700}.shop-balance{color:gold;background:#ffd7001a;border-radius:6px;padding:.15rem .4rem;font-size:.75rem;font-weight:700}.shop-close-btn{color:#64748b;cursor:pointer;background:0 0;border:none;padding:0 .2rem;font-size:14px}.shop-close-btn:hover{color:#e2e8f0}.shop-list{flex-direction:column;flex:1;gap:.3rem;display:flex;overflow-y:auto}.shop-item{cursor:pointer;background:#ffffff08;border:1px solid #334155;border-radius:8px;align-items:center;gap:.5rem;padding:.4rem;transition:border-color .15s,background .15s;display:flex}.shop-item:hover{border-color:var(--accent);background:#2563eb1a}.shop-item.selected{background:#ffd70014;border-color:gold}.shop-item.owned{background:#22c55e0f;border-color:#22c55e}.shop-item.owned-by-me{background:#3b82f614;border-color:#3b82f6}.shop-item.listed-for-sale{background:#f59e0b14;border-color:#f59e0b}.shop-item-thumb{width:40px;height:40px;image-rendering:pixelated;background:#0003;border-radius:4px;flex-shrink:0}.shop-item-info{flex:1;min-width:0}.shop-item-name{color:#e2e8f0;white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;font-weight:600;overflow:hidden}.shop-item-owner{color:#22c55e;white-space:nowrap;text-overflow:ellipsis;font-size:.65rem;overflow:hidden}.shop-item-price{color:gold;white-space:nowrap;flex-shrink:0;font-size:.75rem;font-weight:700}.shop-item-price.affordable{color:#4ade80}.shop-item-price.too-expensive{color:#f87171}.shop-buy-btn{color:gold;cursor:pointer;white-space:nowrap;background:#ffd70026;border:1px solid gold;border-radius:6px;flex-shrink:0;padding:.25rem .5rem;font-size:.7rem;font-weight:700}.shop-buy-btn:hover{background:#ffd7004d}.shop-buy-btn:disabled{opacity:.4;cursor:not-allowed}.shop-buy-btn.cant-afford{color:#f87171;background:#f871711a;border-color:#f87171;font-size:.6rem;font-weight:600}.shop-item-actions{flex-shrink:0;align-items:center;gap:.3rem;display:flex}.shop-listing-input{color:#e2e8f0;text-align:center;background:#3b82f61a;border:1px solid #3b82f6;border-radius:5px;outline:none;width:55px;padding:.2rem .3rem;font-size:.65rem}.shop-listing-input::placeholder{color:#64748b}.shop-listing-input:focus{background:#3b82f62e;border-color:#60a5fa}.shop-list-btn{color:#60a5fa!important;background:#3b82f626!important;border-color:#3b82f6!important}.shop-list-btn:hover{background:#3b82f64d!important}.shop-unlist-btn{color:#94a3b8!important;background:#94a3b81a!important;border-color:#94a3b8!important}.shop-unlist-btn:hover{background:#94a3b840!important}.shop-item-owner.listed-label{color:#f59e0b}.shop-status{color:#94a3b8;text-align:center;min-height:1.2em;padding:.3rem 0 0;font-size:.75rem}.shop-status-error{color:#f87171;font-weight:700}.shop-status-shake{animation:.4s ease-in-out shop-shake}@keyframes shop-shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.stock-btn{z-index:40;color:#94a3b8;cursor:pointer;background:#0f172ad9;border:1px solid #334155;border-radius:50%;place-items:center;width:36px;height:36px;font-size:18px;display:grid;position:fixed;top:.5rem;left:5.5rem}.stock-btn:hover{color:#22c55e;border-color:#22c55e}.stock-market{z-index:50;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0f172af2;border:1px solid #334155;border-radius:10px;flex-direction:column;width:300px;max-height:80vh;padding:.5rem;display:flex;position:fixed;top:3rem;left:.5rem;overflow-y:auto}.stock-header{border-bottom:1px solid #334155;align-items:center;gap:.4rem;margin-bottom:.4rem;padding-bottom:.3rem;display:flex}.stock-title{color:#22c55e;flex:1;font-size:.85rem;font-weight:700}.stock-balance{color:gold;background:#ffd7001a;border-radius:6px;padding:.15rem .4rem;font-size:.75rem;font-weight:700}.stock-close-btn{color:#64748b;cursor:pointer;background:0 0;border:none;padding:0 .2rem;font-size:14px}.stock-close-btn:hover{color:#e2e8f0}.stock-portfolio{color:#94a3b8;border-bottom:1px solid #334155;margin-bottom:.3rem;padding:.3rem 0;font-size:.75rem}.stock-portfolio-value{color:#22c55e;font-weight:700}.stock-list{flex-direction:column;flex:1;gap:.4rem;display:flex;overflow-y:auto}.stock-item{background:#ffffff08;border:1px solid #334155;border-radius:8px;padding:.4rem}.stock-item-header{align-items:center;gap:.4rem;margin-bottom:.3rem;display:flex}.stock-item-ticker{min-width:42px;font-size:.85rem;font-weight:700}.stock-item-name{color:#64748b;flex:1;font-size:.7rem}.stock-item-price{color:#e2e8f0;font-size:.85rem;font-weight:700}.stock-item-change{text-align:center;border-radius:4px;min-width:48px;padding:.1rem .3rem;font-size:.7rem;font-weight:600}.stock-item-change.up{color:#22c55e;background:#22c55e1f}.stock-item-change.down{color:#ef4444;background:#ef44441f}.stock-chart{height:32px;margin:.25rem 0}.stock-chart canvas{background:#0003;border-radius:4px;width:100%;height:100%}.stock-item-holdings{color:#94a3b8;margin-bottom:.25rem;font-size:.7rem}.stock-item-holdings span{color:#e2e8f0;font-weight:600}.stock-item-pl{border-radius:4px;margin-left:.25rem;padding:.05rem .3rem;font-size:.7rem}.stock-item-holdings span.stock-item-pl.up{color:#22c55e;background:#22c55e1f}.stock-item-holdings span.stock-item-pl.down{color:#ef4444;background:#ef44441f}.stock-item-actions{align-items:center;gap:.3rem;display:flex}.stock-qty-input{color:#e2e8f0;text-align:center;background:#0f172acc;border:1px solid #334155;border-radius:5px;outline:none;width:42px;padding:.2rem .3rem;font-size:.7rem}.stock-qty-input:focus{border-color:var(--accent)}.stock-buy-btn,.stock-sell-btn{cursor:pointer;border:1px solid;border-radius:5px;padding:.2rem .5rem;font-size:.7rem;font-weight:700}.stock-buy-btn{color:#22c55e;background:#22c55e26;border-color:#22c55e}.stock-buy-btn:hover{background:#22c55e4d}.stock-sell-btn{color:#ef4444;background:#ef444426;border-color:#ef4444}.stock-sell-btn:hover{background:#ef44444d}.stock-buy-btn:disabled,.stock-sell-btn:disabled{opacity:.35;cursor:not-allowed}.stock-status{color:#94a3b8;text-align:center;min-height:1.2em;padding:.3rem 0 0;font-size:.75rem}.stock-status-error{color:#f87171;font-weight:700}.stock-status-success{color:#22c55e;font-weight:700}.inventory-btn{z-index:40;color:#94a3b8;cursor:pointer;background:#0f172ad9;border:1px solid #334155;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;padding:0;font-size:18px;display:none;position:fixed;top:.5rem;left:8rem}.inventory-btn .inv-btn-icon{line-height:1}.inventory-btn:hover{color:#f59e0b;border-color:#f59e0b}.inventory-btn.active{color:#f59e0b;background:#f59e0b2e;border-color:#f59e0b}.inventory-btn .inv-btn-badge{color:#0b1020;text-align:center;background:#f59e0b;border:1px solid #0f172ad9;border-radius:10px;min-width:16px;padding:0 5px;font-family:Inter,system-ui,sans-serif;font-size:10px;font-weight:700;line-height:16px;position:absolute;top:-4px;right:-4px}.inventory-panel{z-index:50;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#e2e8f0;background:#0f172af2;border:1px solid #334155;border-radius:10px;flex-direction:column;width:280px;max-height:70vh;padding:.5rem;font-family:Inter,system-ui,sans-serif;display:flex;position:fixed;top:3rem;left:.5rem}.inv-panel-header{border-bottom:1px solid #334155;align-items:center;gap:.4rem;margin-bottom:.4rem;padding-bottom:.3rem;display:flex}.inv-panel-title{flex:1;font-size:.85rem;font-weight:700}.inv-panel-count{color:#94a3b8;font-size:.7rem}.inv-panel-close{color:#94a3b8;cursor:pointer;background:0 0;border:1px solid #334155;border-radius:4px;place-items:center;width:20px;height:20px;padding:0;font-size:11px;display:grid}.inv-panel-close:hover{color:#f87171;border-color:#f87171}.inv-panel-items{grid-template-columns:repeat(auto-fill,minmax(60px,1fr));align-content:start;gap:.4rem;display:grid;overflow-y:auto}.inv-cell{background:#0b1020;border:1px solid #334155;border-radius:6px;flex-direction:column;align-items:center;gap:2px;padding:6px 4px 4px;display:flex;position:relative}.inv-cell canvas{image-rendering:pixelated}.inv-cell-name{color:#cbd5e1;text-align:center;word-break:break-word;font-size:.6rem;line-height:1.1}.inv-cell-count{color:#0b1020;text-align:center;background:#f59e0b;border-radius:8px;min-width:14px;padding:0 4px;font-size:10px;font-weight:700;line-height:14px;position:absolute;top:-4px;right:-4px}.inv-panel-empty{color:#64748b;text-align:center;padding:1rem .5rem;font-size:.75rem;font-style:italic}.interior-banner{z-index:50;color:#e2e8f0;background:#0f172af0;border:1px solid #3b82f6;border-radius:10px;align-items:center;gap:12px;padding:6px 12px;font-family:Inter,system-ui,sans-serif;font-size:13px;font-weight:600;display:flex;position:fixed;top:12px;left:50%;transform:translate(-50%);box-shadow:0 4px 16px #0006}.interior-banner .ib-exit{color:#fff;cursor:pointer;font:inherit;background:#3b82f6;border:none;border-radius:6px;padding:4px 10px;font-size:12px}.interior-banner .ib-exit:hover{background:#2563eb}.suggestions-btn{z-index:40;color:#94a3b8;cursor:pointer;background:#0f172ad9;border:1px solid #334155;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;padding:0;font-size:18px;display:none;position:fixed;top:.5rem;left:10.5rem}.suggestions-btn:hover{color:#a78bfa;border-color:#a78bfa}.suggestions-btn.active{color:#a78bfa;background:#a78bfa2e;border-color:#a78bfa}.suggestions-panel{z-index:50;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#e2e8f0;background:#0f172af2;border:1px solid #334155;border-radius:10px;flex-direction:column;width:320px;max-height:75vh;padding:.5rem;font-family:Inter,system-ui,sans-serif;display:flex;position:fixed;top:3rem;left:.5rem}.suggestions-header{border-bottom:1px solid #334155;align-items:center;gap:.4rem;margin-bottom:.4rem;padding-bottom:.3rem;display:flex}.suggestions-title{color:#a78bfa;flex:1;font-size:.85rem;font-weight:700}.suggestions-close-btn{color:#94a3b8;cursor:pointer;background:0 0;border:1px solid #334155;border-radius:4px;place-items:center;width:20px;height:20px;padding:0;font-size:11px;display:grid}.suggestions-close-btn:hover{color:#f87171;border-color:#f87171}.suggestions-compose{border-bottom:1px solid #334155;flex-direction:column;gap:.3rem;margin-bottom:.4rem;padding-bottom:.4rem;display:flex}.suggestion-input{resize:vertical;color:#e2e8f0;width:100%;min-height:56px;max-height:160px;font:inherit;background:#0b1020;border:1px solid #334155;border-radius:6px;outline:none;padding:.4rem;font-size:13px}.suggestion-input:focus{border-color:#a78bfa}.suggestions-compose-row{align-items:center;gap:.4rem;display:flex}.suggestion-status{color:#94a3b8;flex:1;min-height:1em;font-size:.7rem}.suggestion-status-error{color:#f87171;font-weight:700}.suggestion-send-btn{color:#c4b5fd;cursor:pointer;background:#a78bfa26;border:1px solid #a78bfa;border-radius:6px;padding:.3rem .7rem;font-size:.75rem;font-weight:700}.suggestion-send-btn:hover{background:#a78bfa4d}.suggestion-send-btn:disabled{opacity:.5;cursor:not-allowed}.suggestions-list{flex-direction:column;flex:1;gap:.3rem;display:flex;overflow-y:auto}.suggestions-empty{color:#64748b;text-align:center;padding:.6rem 0;font-size:.75rem}.suggestion-item{background:#ffffff08;border:1px solid #334155;border-radius:6px;flex-direction:column;gap:.2rem;padding:.4rem;display:flex}.suggestion-meta{justify-content:space-between;align-items:baseline;gap:.4rem;font-size:.7rem;display:flex}.suggestion-name{color:#c4b5fd;font-weight:700}.suggestion-time{color:#64748b}.suggestion-body{color:#e2e8f0;white-space:pre-wrap;word-wrap:break-word;font-size:.8rem}
