@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600&family=Playfair+Display:wght@400;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg-deep:#0a0a0a;--bg-surface:#1e1e1e;--bg-elevated:#252525;--bg-hover:#2a2a2a;--text-primary:#ededed;--text-secondary:#aaa;--text-muted:#888;--accent:#d4a574;--accent-dim:#d4a57426;--accent-blue:#6ba3d6;--accent-blue-dim:#6ba3d626;--danger:#e85d5d;--success:#5dae72;--border:#2a2a2a;--border-focus:#d4a57480;--font-serif:"Playfair Display", Georgia, serif;--font-sans:"Inter", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;overflow:hidden}body{font-family:var(--font-sans);background:var(--bg-deep);color:var(--text-primary);-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.game-layout{height:100vh;max-height:100vh;display:flex}.sidebar{background:var(--bg-surface);border-right:1px solid var(--border);flex-direction:column;width:280px;min-width:280px;padding:24px 20px;display:flex;overflow-y:auto}.sidebar-title{font-family:var(--font-serif);color:var(--accent);letter-spacing:.02em;margin-bottom:4px;font-size:1.4rem;font-weight:700}.sidebar-subtitle{color:var(--text-muted);text-transform:uppercase;letter-spacing:.15em;margin-bottom:24px;font-size:.75rem;font-weight:500}.sidebar-section{margin-bottom:20px}.sidebar-section-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;margin-bottom:10px;font-size:.65rem;font-weight:600}.stat-row{justify-content:space-between;align-items:center;padding:6px 0;font-size:.85rem;display:flex}.stat-label{color:var(--text-secondary)}.stat-value{color:var(--text-primary);font-family:var(--font-mono);font-size:.8rem}.stat-value.hp{color:var(--success)}.stat-value.danger{color:var(--danger)}.stat-value.currency{color:var(--accent)}.hp-bar-container{background:var(--bg-deep);border-radius:2px;width:100%;height:4px;margin-top:4px;overflow:hidden}.hp-bar{border-radius:2px;height:100%;transition:width .4s,background .4s}.city-badge{background:var(--bg-elevated);border:1px solid var(--border);color:var(--accent);font-size:.75rem;font-family:var(--font-mono);border-radius:4px;margin-top:2px;padding:2px 8px;display:inline-block}.inventory-list{list-style:none}.inventory-item{color:var(--text-secondary);align-items:center;gap:6px;padding:3px 0;font-size:.8rem;display:flex}.inventory-item .equipped-badge{color:var(--accent);background:var(--accent-dim);border-radius:3px;padding:1px 5px;font-size:.6rem}.sidebar-divider{border:none;border-top:1px solid var(--border);margin:16px 0}.visited-cities{flex-wrap:wrap;gap:4px;margin-top:4px;display:flex}.visited-city{color:var(--text-muted);background:var(--bg-elevated);border:1px solid var(--border);font-size:.7rem;font-family:var(--font-mono);border-radius:3px;padding:1px 6px}.main-viewport{flex-direction:column;flex:1;min-width:0;display:flex}.chat-feed{flex-direction:column;flex:1;gap:16px;padding:24px 32px;display:flex;overflow-y:auto}.message{max-width:720px;animation:.3s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.message.user{background:var(--bg-elevated);border:1px solid var(--border);font-family:var(--font-mono);color:var(--text-primary);border-radius:16px 16px 4px;align-self:flex-end;padding:10px 16px;font-size:.85rem}.message.system{color:var(--text-secondary);align-self:flex-start;padding:4px 0;font-size:.9rem;line-height:1.65}.message.system h1{font-family:var(--font-serif);color:var(--accent);margin-bottom:8px;font-size:1.8rem;font-weight:700}.message.system h2{font-family:var(--font-serif);color:var(--text-primary);margin-top:4px;margin-bottom:6px;font-size:1.25rem;font-weight:600}.message.system h3{font-family:var(--font-serif);color:var(--text-primary);margin-bottom:4px;font-size:1.05rem;font-weight:600}.message.system strong{color:var(--text-primary);font-weight:600}.message.system em{color:var(--text-muted);font-style:italic}.message.system hr{border:none;border-top:1px solid var(--border);margin:12px 0}.message.system table{border-collapse:collapse;width:100%;max-width:480px;margin:8px 0;font-size:.85rem}.message.system th{text-align:left;border-bottom:1px solid var(--border);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;padding:6px 12px;font-size:.75rem;font-weight:500}.message.system td{color:var(--text-secondary);border-bottom:1px solid #2a2a2a80;padding:5px 12px}.message.system ul,.message.system ol{margin:6px 0;padding-left:20px}.message.system li{padding:2px 0}.message.system code{font-family:var(--font-mono);background:var(--bg-elevated);color:var(--accent-blue);border-radius:3px;padding:2px 6px;font-size:.82rem}.message.system p{margin-bottom:6px}.message.system p:last-child{margin-bottom:0}.input-container{background:linear-gradient(to top, var(--bg-deep) 60%, transparent);padding:16px 32px 24px}.input-wrapper{background:var(--bg-surface);border:1px solid var(--border);border-radius:24px;align-items:center;max-width:720px;padding:4px 6px 4px 20px;transition:border-color .2s,box-shadow .2s;display:flex}.input-wrapper:focus-within{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-dim), 0 0 20px #d4a57414}.command-input{font-family:var(--font-mono);color:var(--text-primary);caret-color:var(--accent);background:0 0;border:none;outline:none;flex:1;padding:10px 0;font-size:.9rem}.command-input::placeholder{color:var(--text-muted);font-family:var(--font-sans)}.command-input:disabled{opacity:.5}.send-button{background:var(--accent);width:36px;height:36px;color:var(--bg-deep);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:opacity .2s;display:flex}.send-button:hover{opacity:.85}.send-button:disabled{opacity:.4;cursor:default}.send-button svg{width:16px;height:16px}.typewriter-cursor{background:var(--accent);vertical-align:text-bottom;width:2px;height:1em;margin-left:2px;animation:.8s infinite blink;display:inline-block}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}@media (width<=768px){.sidebar{display:none}.chat-feed{padding:16px}.input-container{padding:12px 16px 16px}}
