*{margin:0;padding:0;box-sizing:border-box}:root{--bg-dark: #1a1a2e;--bg-card: #16213e;--bg-input: #0f3460;--accent: #e94560;--text: #eee;--text-dim: #999;--border: #333;--narrative-bg: #1e2a4a;--info-bg: #2a1e3a;--option-bg: #1a3a5c;--option-hover: #2a4a6c}html,body{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Noto Sans SC,sans-serif;background:var(--bg-dark);color:var(--text);font-size:15px;-webkit-font-smoothing:antialiased}#app{height:100%}.login-page{height:100%;display:flex;align-items:center;justify-content:center;padding:20px}.login-card{width:100%;max-width:360px;background:var(--bg-card);border-radius:16px;padding:40px 28px;text-align:center}.logo{font-size:28px;font-weight:700;color:var(--accent);margin-bottom:8px}.subtitle{color:var(--text-dim);font-size:13px;margin-bottom:32px}.form-group{display:flex;flex-direction:column;gap:12px;text-align:left}.form-group label{font-size:13px;color:var(--text-dim);font-weight:600}.form-group input{width:100%;padding:14px 16px;border:1px solid var(--border);border-radius:10px;background:var(--bg-input);color:var(--text);font-size:16px;outline:none;transition:border-color .2s}.form-group input:focus{border-color:var(--accent)}.hint{font-size:12px;color:var(--text-dim);text-align:center}.btn-primary{width:100%;padding:14px;background:var(--accent);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:opacity .2s}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-link{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:13px;text-align:center}.error{color:var(--accent);font-size:13px;text-align:center}.game-page{height:100%;display:flex;flex-direction:column}.top-bar{display:flex;align-items:center;gap:12px;padding:10px 16px;background:var(--bg-card);border-bottom:1px solid var(--border);flex-shrink:0}.menu-btn{display:flex;flex-direction:column;gap:4px;background:none;border:none;cursor:pointer;padding:4px}.menu-btn span{display:block;width:20px;height:2px;background:var(--text);border-radius:1px}.player-info{flex:1;display:flex;flex-direction:column}.player-name{font-weight:600;font-size:14px}.player-location{font-size:12px;color:var(--text-dim)}.phase-badge{background:var(--accent);color:#fff;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600}.menu-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:99}.side-menu{position:fixed;top:0;left:-260px;width:260px;height:100%;background:var(--bg-card);z-index:100;padding:20px;transition:left .25s;display:flex;flex-direction:column;gap:4px;overflow-y:auto}.side-menu.open{left:0}.side-menu h3{font-size:12px;color:var(--text-dim);text-transform:uppercase;margin:8px 0 4px;letter-spacing:1px}.side-menu button{display:block;width:100%;padding:10px 12px;background:none;border:none;color:var(--text);font-size:14px;text-align:left;border-radius:8px;cursor:pointer;transition:background .15s}.side-menu button:hover{background:var(--bg-input)}.side-menu hr{border:none;border-top:1px solid var(--border);margin:8px 0}.logout-btn{color:var(--accent)!important;margin-top:auto}.messages{flex:1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:10px}.message{max-width:90%;padding:12px 16px;border-radius:14px;font-size:14px;line-height:1.6;word-break:break-word}.message.narrative{background:var(--narrative-bg);border-bottom-left-radius:4px;align-self:flex-start}.message.info{background:var(--info-bg);align-self:center;text-align:center;font-size:13px;max-width:80%}.message.status{background:var(--bg-input);align-self:flex-end;font-size:13px}.msg-content b,.msg-content strong{color:var(--accent)}.msg-content i,.msg-content em{color:#ccc}.msg-content pre,.msg-content code{background:#0000004d;padding:2px 6px;border-radius:4px;font-size:13px}.msg-content pre{display:block;padding:8px 12px;margin:6px 0;overflow-x:auto}.msg-content blockquote{border-left:3px solid var(--accent);padding-left:10px;color:var(--text-dim);margin:6px 0}.typing:after{content:"";animation:dots 1.2s steps(4) infinite}@keyframes dots{0%{content:""}25%{content:"."}50%{content:".."}75%{content:"..."}}.options{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.option-btn{padding:8px 14px;background:var(--option-bg);color:var(--text);border:1px solid var(--border);border-radius:20px;font-size:13px;cursor:pointer;transition:background .15s}.option-btn:hover{background:var(--option-hover)}.status-bar{display:flex;gap:0;background:var(--bg-card);border-top:1px solid var(--border);flex-shrink:0;overflow-x:auto;-webkit-overflow-scrolling:touch}.status-section{flex-shrink:0;padding:6px 12px;border-right:1px solid var(--border);min-width:0}.status-section:last-child{border-right:none}.status-label{font-size:10px;color:var(--accent);font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}.status-values{display:flex;flex-wrap:wrap;gap:4px 10px;align-items:center}.stat{font-size:12px;white-space:nowrap}.stat.dim{color:var(--text-dim)}.stat.warn{color:#f0a040}.stat.npc{display:inline-flex;align-items:center;gap:3px}.npc-name{font-weight:600;font-size:11px}.npc-bar{display:inline-block;width:28px;height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden}.npc-bar span{display:block;height:100%;border-radius:2px;transition:width .3s}.npc-bar.trust span{background:#4a9eff}.npc-bar.affection span{background:var(--accent)}.stat.mission{color:#7ecfff;font-weight:600}.input-bar{display:flex;gap:8px;padding:10px 16px;background:var(--bg-card);border-top:1px solid var(--border);flex-shrink:0}.input-bar input{flex:1;padding:12px 16px;border:1px solid var(--border);border-radius:10px;background:var(--bg-input);color:var(--text);font-size:15px;outline:none}.input-bar input:focus{border-color:var(--accent)}.input-bar button{padding:12px 20px;background:var(--accent);color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer}.input-bar button:disabled{opacity:.5;cursor:not-allowed}
