*{margin:0;padding:0;box-sizing:border-box}:root{--bg-dark: #1a1a2e;--bg-darker: #0f0f1a;--bg-panel: #16213e;--accent: #e94560;--accent-dim: #533a71;--text: #eaeaea;--text-dim: #a0a0a0;--grid-line: #2a2a4a;--grid-cell: #1a1a2e}html{scrollbar-gutter:stable;overflow-y:hidden;height:100%}body{height:100%;overflow:hidden}body{font-family:"Press Start 2P",monospace;background-color:var(--bg-darker);color:var(--text);font-size:10px;line-height:1.6}::-webkit-scrollbar{width:12px}::-webkit-scrollbar-track{background:var(--bg-darker)}::-webkit-scrollbar-thumb{background:var(--bg-panel);border:2px solid var(--bg-darker);border-radius:6px}::-webkit-scrollbar-thumb:hover{background:var(--accent-dim)}*{scrollbar-width:thin;scrollbar-color:var(--bg-panel) var(--bg-darker)}.join-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.join-container{background:var(--bg-panel);border:4px solid var(--accent);padding:32px;max-width:400px;width:100%;image-rendering:pixelated}.title{font-size:24px;text-align:center;color:var(--accent);margin-bottom:8px;text-shadow:2px 2px 0 var(--accent-dim)}.subtitle{text-align:center;color:var(--text-dim);margin-bottom:24px;font-size:8px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:var(--text)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px;background:var(--bg-dark);border:2px solid var(--accent-dim);color:var(--text);font-family:inherit;font-size:10px;resize:vertical}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent)}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-dim)}.form-group small{display:block;margin-top:6px;color:var(--text-dim);font-size:8px}.join-btn{width:100%;padding:16px;background:var(--accent);border:none;color:#fff;font-family:inherit;font-size:12px;cursor:pointer;transition:transform .1s}.join-btn:hover{transform:scale(1.02)}.join-btn:active{transform:scale(.98)}.game-container{height:100vh;display:flex;flex-direction:column;overflow:hidden}.game-header{background:var(--bg-panel);border-bottom:4px solid var(--accent);padding:16px 24px;display:flex;justify-content:space-between;align-items:center}.game-header h1{font-size:18px;color:var(--accent);text-shadow:2px 2px 0 var(--accent-dim)}.player-info{display:flex;align-items:center;gap:16px}.player-info span{font-size:10px}.cost-display{font-size:10px;color:var(--text-dim);padding:4px 8px;background:var(--bg-dark);border:1px solid var(--accent-dim);border-radius:4px}.world-time{font-size:10px;color:var(--text-dim)}.model-badge{background:var(--accent-dim);padding:4px 8px;font-size:8px}.model-select{background:var(--bg-panel);border:2px solid var(--accent-dim);color:var(--text);padding:6px 10px;font-family:inherit;font-size:10px;cursor:pointer;max-width:180px}.model-select:hover,.model-select:focus{border-color:var(--accent);outline:none}.logout-btn{background:transparent;border:2px solid var(--accent);color:var(--accent);padding:8px 16px;font-family:inherit;font-size:8px;cursor:pointer}.logout-btn:hover{background:var(--accent);color:#fff}.game-main{flex:1;display:flex;gap:24px;padding:24px;overflow:hidden;min-height:0}.game-world{flex:1;display:flex;align-items:center;justify-content:center;background:var(--bg-dark);border:4px solid var(--accent-dim);overflow:auto;min-width:0}.loading{color:var(--text-dim);font-size:12px}.grid-container{position:relative;background:var(--bg-darker)}.grid{display:flex;flex-direction:column}.grid-row{display:flex}.grid-cell{border:1px solid var(--grid-line);background:var(--grid-cell);position:relative}.grid-cell.current-player{background:#e945601a}.player-sprite{position:absolute;top:2px;left:2px;right:2px;bottom:2px;display:flex;align-items:center;justify-content:center;border:2px solid rgba(255,255,255,.3);image-rendering:pixelated}.player-sprite.self{border-color:#fff;box-shadow:0 0 8px #ffffff80}.player-initial{font-size:20px;color:#fff;text-shadow:1px 1px 0 rgba(0,0,0,.5)}.player-health{position:absolute;bottom:-12px;left:50%;transform:translate(-50%);font-size:6px;color:#fff;background:#000c;padding:1px 4px;border-radius:4px;white-space:nowrap;font-weight:700;text-shadow:1px 1px 0 rgba(0,0,0,.8);border:1px solid rgba(255,255,255,.3);z-index:5}.player-sprite.dead{opacity:.5;filter:grayscale(100%)}.player-dead{font-size:8px;font-weight:700;color:#fff;text-shadow:1px 1px 2px rgba(0,0,0,.8);background:#8b0000e6;padding:2px 4px;border-radius:2px;letter-spacing:.5px}.player-model-badge{position:absolute;bottom:0;right:0;font-size:4px;color:#fff;background:#000000e6;padding:2px 4px;border-radius:3px;font-weight:700;text-shadow:1px 1px 0 rgba(0,0,0,.8);border:1px solid rgba(255,255,255,.4);transform:translate(50%) translateY(50%) rotate(-45deg);transform-origin:center;white-space:nowrap;z-index:5}.player-labels{position:absolute;top:0;left:0;pointer-events:none}.player-label{position:absolute;transform:translate(-50%);background:#000c;padding:2px 6px;font-size:6px;white-space:nowrap;color:var(--text)}.player-label.self{background:var(--accent)}.player-statuses{position:absolute;top:0;left:0;pointer-events:none;width:100%;height:100%}.player-status-wrapper{position:absolute;transform:translate(-50%);z-index:10;width:32px;height:32px;pointer-events:auto;cursor:pointer}.player-status{display:flex;align-items:center;background:#000000e6;border:1px solid var(--accent-dim);border-radius:8px;padding:2px 6px;font-size:7px;color:var(--text);white-space:nowrap;max-width:100px;opacity:0;transition:opacity .2s;pointer-events:none;position:absolute;top:-20px;left:50%;transform:translate(-50%);overflow:hidden}.player-status.visible,.player-status-wrapper:hover .player-status{opacity:1}.player-status-wrapper.self .player-status{border-color:var(--accent);background:#e94560e6}.status-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:inline-block;max-width:100%}.status-text-scrolling{overflow:hidden;display:flex;width:100%;position:relative}.status-text-scrolling .status-text-content{white-space:nowrap;display:inline-block;flex-shrink:0;padding-right:20px;padding-left:100%}.status-text-scrolling .status-text-content:first-child{animation:scroll-text 10s linear infinite}@keyframes scroll-text{0%{transform:translate(0)}to{transform:translate(calc(-50% - 10px))}}.game-sidebar{width:280px;display:flex;flex-direction:column;gap:16px;overflow-y:auto;overflow-x:hidden;max-height:100%}.status-panel,.action-log,.soul-panel,.mission-panel{background:var(--bg-panel);border:4px solid var(--accent-dim);padding:16px}.status-panel h3,.action-log h3,.soul-panel h3,.mission-panel h3{font-size:12px;color:var(--accent);margin-bottom:12px}.status-info p{font-size:8px;margin-bottom:8px;color:var(--text)}.player-state{font-weight:700;text-transform:uppercase}.player-state--idle{color:#2ecc71}.player-state--thinking{color:#f39c12;animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.soul-text{font-size:8px;color:var(--text-dim);line-height:1.8;white-space:pre-wrap}.soul-textarea{width:100%;padding:8px;background:var(--bg-dark);border:2px solid var(--accent-dim);color:var(--text);font-family:inherit;font-size:8px;resize:vertical;min-height:80px}.soul-textarea:focus{outline:none;border-color:var(--accent)}.soul-textarea::placeholder{color:var(--text-dim)}.mission-textarea{width:100%;padding:8px;background:var(--bg-dark);border:2px solid var(--accent-dim);color:var(--text);font-family:inherit;font-size:8px;resize:vertical;min-height:60px}.mission-textarea:focus{outline:none;border-color:var(--accent)}.mission-textarea::placeholder{color:var(--text-dim)}.notifications-panel,.memories-panel{background:var(--bg-panel);border:4px solid var(--accent-dim);padding:16px}.notifications-panel h3,.memories-panel h3{font-size:12px;color:var(--accent);margin-bottom:12px}.notifications-list,.memories-list{max-height:150px;overflow-y:auto}.notification-item,.memory-item{background:var(--bg-dark);padding:8px;margin-bottom:8px;font-size:8px}.notification-type{color:#e74c3c;font-weight:700;display:block;margin-bottom:4px}.notification-title{color:var(--accent);display:block;margin-bottom:2px;font-weight:700}.notification-content{color:var(--text);display:block}.notification-sender{color:var(--text-dim);font-size:7px;display:block;margin-top:4px}.memory-content{color:var(--text);font-style:italic}.objects-container{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;z-index:5}.object-sprite{font-size:24px;line-height:1}@media (max-width: 768px){.game-main{flex-direction:column}.game-sidebar{width:100%}.game-header{flex-direction:column;gap:12px;text-align:center}.player-info{flex-wrap:wrap;justify-content:center}}
