.login-screen{flex:1;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:var(--void);min-height:0}.login-vignette{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at center,transparent 20%,rgba(0,0,0,.4) 60%,rgba(0,0,0,.85) 100%);pointer-events:none;z-index:0}.login-rune-border{position:absolute;top:12px;right:12px;bottom:12px;left:12px;border:1px solid rgba(212,175,55,.12);pointer-events:none;z-index:1;animation:border-breathe 6s ease-in-out infinite}.login-rune-border:before{content:"";position:absolute;top:4px;right:4px;bottom:4px;left:4px;border:1px solid rgba(212,175,55,.06)}@keyframes border-breathe{0%,to{border-color:#d4af3714;box-shadow:inset 0 0 60px #0000004d}50%{border-color:#d4af372e;box-shadow:inset 0 0 80px #00000080,inset 0 0 120px #8b00000d}}.login-content{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:24px;width:100%;max-width:480px;padding:20px}.login-title-wrap{text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px}.login-skull{font-size:48px;color:var(--accent-gold);animation:glow-gold 3s ease-in-out infinite;line-height:1;filter:drop-shadow(0 0 12px rgba(212,175,55,.5))}.login-title{font-family:UnifrakturMaguntia,serif;font-size:clamp(28px,5vw,52px);color:var(--accent-gold);animation:glow-gold 4s ease-in-out infinite;text-shadow:0 0 8px rgba(212,175,55,.5),0 0 20px rgba(212,175,55,.2),0 0 40px rgba(139,0,0,.2),0 2px 4px rgba(0,0,0,.8);letter-spacing:1px;line-height:1.1}.login-subtitle{font-family:Cinzel Decorative,serif;font-size:10px;letter-spacing:5px;color:var(--text-aged);text-transform:uppercase;opacity:.75}.login-divider{width:100%;display:flex;align-items:center;justify-content:center}.login-divider-text{color:var(--accent-gold);opacity:.35;font-size:12px;letter-spacing:3px}.login-flavor{font-family:IM Fell English,serif;font-size:15px;font-style:italic;color:var(--text-aged);text-align:center;opacity:.9;max-width:380px;line-height:1.8}.login-form{width:100%;padding:24px 28px;display:flex;flex-direction:column;gap:18px;position:relative}.login-form-title{text-align:center;font-size:11px;letter-spacing:3px;color:var(--text-aged);border-bottom:1px solid var(--border);padding-bottom:12px}.cinzel{font-family:Cinzel,serif}.login-fields{display:flex;gap:12px}.login-field{display:flex;flex-direction:column;gap:6px;flex:1}.login-field-port{flex:0 0 100px}.login-label{font-size:10px;letter-spacing:2px;color:var(--text-aged);text-transform:uppercase}.login-input{background:var(--surface);border:1px solid var(--border-bright);color:var(--text-light);font-family:Share Tech Mono,monospace;font-size:14px;padding:8px 10px;outline:none;transition:border-color .2s,box-shadow .2s;width:100%}.login-input::placeholder{color:var(--text-aged);opacity:.4}.login-input:focus{border-color:var(--accent-gold);box-shadow:0 0 0 1px #d4af3733,inset 0 0 8px #0000004d}.login-btn{background:transparent;border:1px solid var(--accent-gold);color:var(--accent-gold);font-family:Cinzel,serif;font-size:13px;font-weight:700;letter-spacing:4px;padding:13px 24px;cursor:pointer;text-transform:uppercase;transition:background .2s,box-shadow .2s,color .2s;position:relative;overflow:hidden}.login-btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--accent-gold);opacity:0;transition:opacity .2s}.login-btn:hover:before{opacity:.08}.login-btn:hover{box-shadow:0 0 12px #d4af3766,0 0 30px #d4af371a}.login-btn:active{box-shadow:none}.login-btn:disabled{opacity:.5;cursor:not-allowed}.login-btn-text{position:relative;z-index:1}.login-hint{font-family:IM Fell English,serif;font-size:12px;color:var(--text-aged);text-align:center;line-height:1.7;opacity:.8}.login-code{color:var(--phosphor);background:#00e5a012;padding:1px 5px;border-radius:2px;font-size:11px}.login-google-btn{display:flex;align-items:center;justify-content:center;gap:12px;background:#fff;color:#1f1f1f;border:1px solid var(--accent-gold);font-family:Cinzel,serif;font-size:13px;font-weight:600;letter-spacing:1.5px;padding:12px 18px;cursor:pointer;text-transform:uppercase;transition:box-shadow .2s,transform .1s;box-shadow:0 0 12px #d4af3726}.login-google-btn:hover:not(:disabled){box-shadow:0 0 18px #d4af3773,0 0 30px #d4af3726}.login-google-btn:active:not(:disabled){transform:translateY(1px)}.login-google-btn:disabled{opacity:.5;cursor:not-allowed}.google-g{flex-shrink:0}.login-google-text{color:#1f1f1f}.login-fallback-toggle{background:none;border:none;color:var(--text-aged);font-family:IM Fell English,serif;font-style:italic;font-size:12px;cursor:pointer;padding:4px;text-align:center;opacity:.65;transition:opacity .2s,color .2s}.login-fallback-toggle:hover{opacity:1;color:var(--accent-gold)}.login-fallback-form{display:flex;flex-direction:column;gap:14px;border-top:1px solid var(--border);padding-top:14px;margin-top:-4px}.login-remember{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--text-aged);cursor:pointer;-webkit-user-select:none;user-select:none}.login-remember input[type=checkbox]{accent-color:var(--accent-gold)}.login-advanced{font-size:11px}.login-advanced-summary{color:var(--text-aged);cursor:pointer;font-size:10px;letter-spacing:2px;text-transform:uppercase;padding:4px 0;outline:none;opacity:.6}.login-advanced-summary:hover{opacity:1;color:var(--accent-gold)}.login-advanced[open] .login-fields{margin-top:8px}.login-runes{font-size:14px;color:var(--border-bright);letter-spacing:6px;opacity:.4;-webkit-user-select:none;user-select:none}.charsel-screen{flex:1;display:flex;align-items:center;justify-content:center;position:relative;overflow-y:auto;background:var(--void);min-height:0;padding:32px 20px}.charsel-vignette{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at center,transparent 30%,rgba(0,0,0,.5) 70%,rgba(0,0,0,.9) 100%);pointer-events:none;z-index:0}.charsel-content{position:relative;z-index:1;width:100%;max-width:1100px;display:flex;flex-direction:column;align-items:center;gap:28px}.charsel-header{text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px}.charsel-title{font-family:UnifrakturMaguntia,serif;font-size:clamp(28px,4vw,44px);color:var(--accent-gold);letter-spacing:2px;text-shadow:0 0 12px rgba(212,175,55,.5),0 0 30px rgba(212,175,55,.2),0 2px 4px rgba(0,0,0,.8);margin:0}.charsel-divider{color:var(--accent-gold);opacity:.4;font-size:12px;letter-spacing:3px}.charsel-flavor{font-family:IM Fell English,serif;font-style:italic;font-size:14px;color:var(--text-aged);opacity:.85;max-width:480px;line-height:1.7;margin:0}.charsel-loading,.charsel-error{color:var(--text-aged);font-family:IM Fell English,serif;font-style:italic;text-align:center;padding:24px}.charsel-error{color:var(--blood-bright, #c93838);font-style:normal}.charsel-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px;width:100%}.charsel-card{background:linear-gradient(180deg,#2d2d2dd9,#141414f2);border:1px solid var(--border-bright);padding:18px;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;transition:border-color .2s,box-shadow .2s,transform .15s;position:relative;text-align:center;font-family:inherit;color:var(--text-light)}.charsel-card:hover{border-color:var(--accent-gold);box-shadow:0 0 18px #d4af3759,0 0 40px #d4af371a;transform:translateY(-2px)}.charsel-card:active{transform:translateY(0)}.charsel-portrait{width:110px;height:110px;border:1px solid var(--border-bright);background:radial-gradient(circle at center,#d4af3714,#00000080);display:flex;align-items:center;justify-content:center;overflow:hidden;margin-bottom:4px;box-shadow:inset 0 0 20px #0009}.charsel-portrait img{width:100%;height:100%;object-fit:cover;filter:brightness(1.1)}.charsel-portrait-empty{font-size:56px;color:var(--accent-gold);opacity:.4}.charsel-card-name{font-size:20px;color:var(--accent-gold);letter-spacing:1.5px;margin-top:4px}.charsel-card-archetype{font-family:IM Fell English,serif;font-style:italic;font-size:12px;color:var(--text-aged);opacity:.85}.charsel-card-stats{display:flex;gap:18px;margin-top:6px;padding:6px 10px;border-top:1px solid var(--border);border-bottom:1px solid var(--border);width:100%;justify-content:center}.charsel-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.charsel-stat-label{font-family:Cinzel,serif;font-size:9px;letter-spacing:1.5px;color:var(--text-aged);opacity:.7}.charsel-stat-value{font-family:Share Tech Mono,monospace;font-size:16px;color:var(--text-light)}.charsel-stat-max{font-size:12px;color:var(--text-aged);opacity:.6}.charsel-card-location{font-size:11px;color:var(--text-aged);font-family:IM Fell English,serif;font-style:italic;margin-top:4px}.charsel-loc-icon{font-style:normal}.charsel-card-created{font-size:10px;color:var(--text-aged);opacity:.55;font-family:Share Tech Mono,monospace}.charsel-card-chargen-tag{font-size:9px;letter-spacing:2px;color:var(--accent-gold);border:1px solid var(--accent-gold);padding:2px 8px;margin-top:6px;background:#d4af371a}.charsel-card-play{margin-top:8px;padding:6px 18px;border:1px solid var(--accent-gold);color:var(--accent-gold);font-family:Cinzel,serif;font-size:11px;letter-spacing:3px;background:transparent;transition:background .15s}.charsel-card:hover .charsel-card-play{background:#d4af3726}.charsel-card-create{background:linear-gradient(180deg,#1e1e1eb3,#0f0f0fd9);border-style:dashed;justify-content:center;min-height:320px}.charsel-create-icon{font-size:56px;color:var(--accent-gold);opacity:.55;margin-bottom:8px}.charsel-create-label{font-family:Cinzel,serif;font-size:14px;color:var(--accent-gold);letter-spacing:2px}.charsel-create-sub{font-family:IM Fell English,serif;font-style:italic;font-size:11px;color:var(--text-aged);opacity:.7}.charsel-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:100;animation:charsel-fade .2s ease-out}@keyframes charsel-fade{0%{opacity:0}to{opacity:1}}.charsel-modal{width:90%;max-width:440px;padding:24px 28px;display:flex;flex-direction:column;gap:16px;animation:charsel-rise .25s ease-out}@keyframes charsel-rise{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.charsel-modal-header{text-align:center;font-size:13px;letter-spacing:3px;color:var(--accent-gold);border-bottom:1px solid var(--border);padding-bottom:12px}.charsel-modal-body{display:flex;flex-direction:column;gap:14px}.charsel-modal-flavor{font-family:IM Fell English,serif;font-style:italic;color:var(--text-aged);font-size:14px;text-align:center;margin:0;line-height:1.6}.charsel-modal-input{background:var(--surface);border:1px solid var(--border-bright);color:var(--text-light);font-family:IM Fell English,serif;font-size:18px;padding:12px 14px;outline:none;text-align:center;letter-spacing:1px}.charsel-modal-input:focus{border-color:var(--accent-gold);box-shadow:0 0 0 1px #d4af3733}.charsel-modal-buttons{display:flex;gap:12px;justify-content:flex-end}.charsel-modal-cancel,.charsel-modal-submit{padding:8px 18px;font-family:Cinzel,serif;font-size:11px;letter-spacing:2px;cursor:pointer;border:1px solid var(--border-bright);background:transparent;color:var(--text-aged);text-transform:uppercase;transition:border-color .2s,color .2s}.charsel-modal-cancel:hover{color:var(--text-light)}.charsel-modal-submit{border-color:var(--accent-gold);color:var(--accent-gold)}.charsel-modal-submit:hover:not(:disabled){background:#d4af3726}.charsel-modal-submit:disabled,.charsel-modal-cancel:disabled{opacity:.4;cursor:not-allowed}.game-output-wrap{flex:1;position:relative;overflow:hidden;display:flex;flex-direction:column;min-height:0;border-bottom:1px solid var(--border)}.game-output{flex:1;overflow-y:auto;padding:12px 16px 16px;background:var(--parchment);min-height:0;position:relative;z-index:1;scroll-behavior:smooth}.crt-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:2;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.04) 2px,rgba(0,0,0,.04) 4px)}.game-output *{text-shadow:0 0 3px rgba(0,229,160,.06)}.game-output-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-aged);font-family:Cinzel,serif;font-size:13px;opacity:.5;letter-spacing:1px}.msg{font-family:Share Tech Mono,monospace;font-size:13px;line-height:1.6;padding:1px 0;color:var(--text-light);word-break:break-word;white-space:pre-wrap;animation:fade-in .15s ease-out both;position:relative}.msg:hover:after{content:attr(data-time);position:absolute;right:0;top:50%;transform:translateY(-50%);font-size:10px;color:var(--text-aged);opacity:.5;pointer-events:none;background:var(--parchment);padding:0 4px}.msg-system{color:var(--accent-gold);font-style:italic;opacity:.85}.msg-combat{color:#d44040;border-left:2px solid rgba(139,0,0,.5);padding-left:8px}.msg-error{color:var(--neon-warn);background:#c9ff0008;padding-left:4px;border-left:2px solid rgba(201,255,0,.3)}.msg-game{color:var(--text-light)}.msg-empty{display:block;height:4px}.game-output-wrap.in-combat .game-output{background:#1c1510}.color-000{color:#000}.color-001{color:#a00}.color-002{color:#0a0}.color-003{color:#a50}.color-004{color:#00a}.color-005{color:#a0a}.color-006{color:#0aa}.color-007{color:#aaa}.color-008{color:#555}.color-009{color:#f55}.color-010{color:#5f5}.color-011{color:#ff5}.color-012{color:#55f}.color-013{color:#f5f}.color-014{color:#5ff}.color-015{color:#fff}.bgcolor-000{background-color:#000}.bgcolor-001{background-color:#a00}.bgcolor-002{background-color:#0a0}.bgcolor-003{background-color:#a50}.bgcolor-004{background-color:#00a}.bgcolor-005{background-color:#a0a}.bgcolor-006{background-color:#0aa}.bgcolor-007{background-color:#aaa}.bgcolor-008{background-color:#555}.msg-game span,.msg-system span{display:inline}.msg br{display:block;content:""}.msg-with-exits{animation:fade-in .15s ease-out both}.exit-buttons{display:flex;flex-wrap:wrap;align-items:center;gap:6px;padding:6px 0 4px}.exit-label{font-family:Cinzel,serif;font-size:11px;color:var(--text-aged);letter-spacing:1px;text-transform:uppercase;margin-right:4px}.exit-btn{font-family:Share Tech Mono,monospace;font-size:12px;color:var(--text-light);background:#d4af370f;border:1px solid var(--border-bright);padding:4px 10px;cursor:pointer;transition:all .15s;white-space:nowrap}.exit-btn:hover{border-color:var(--accent-gold);color:var(--accent-gold);background:#d4af371f;box-shadow:0 0 8px #d4af3726}.exit-btn:active{background:#d4af3733}.exit-dir{color:var(--accent-gold);font-size:10px;opacity:.7;margin-left:3px}.login-overlay{position:sticky;top:8px;background:#1e1a14f2;border:1px solid var(--accent-gold);border-radius:0;padding:10px 14px;margin-bottom:8px;font-family:Barlow Condensed,sans-serif;font-size:13px;color:var(--accent-gold);letter-spacing:.5px;box-shadow:0 0 12px #d4af371a;z-index:10}.combat-tracker{flex-shrink:0;margin:0 8px;padding:10px 12px;background:#120808f2;border:1px solid rgba(139,0,0,.5);border-top:2px solid var(--blood-bright);box-shadow:0 -4px 20px #cc221126,inset 0 0 20px #00000080;animation:fade-in .2s ease-out}.combat-tracker-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid rgba(139,0,0,.3)}.combat-active-dot{width:8px;height:8px;border-radius:50%;background:var(--blood-bright);flex-shrink:0;animation:pulse-blood 1.2s infinite}.combat-tracker-title{font-family:Cinzel,serif;font-size:11px;letter-spacing:3px;color:var(--blood-bright);text-transform:uppercase}.combat-your-turn{margin-left:auto;font-family:Barlow Condensed,sans-serif;font-size:11px;letter-spacing:2px;color:var(--accent-gold);background:#d4af371a;border:1px solid rgba(212,175,55,.3);padding:2px 8px;animation:glow-gold 1.5s infinite}.combat-turn-list{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.combat-empty{font-size:11px;color:var(--text-aged);font-style:italic;opacity:.6}.combat-combatant{display:flex;align-items:center;gap:8px;padding:3px 4px;border-radius:0;transition:background .15s}.combat-combatant.current-turn{background:#cc22111a;border-left:2px solid var(--blood-bright);padding-left:6px}.combat-combatant.dead{opacity:.35;text-decoration:line-through;color:var(--text-aged)}.combat-combatant.is-me .combat-combatant-name{color:var(--phosphor)}.combat-turn-arrow{font-size:11px;color:var(--blood-bright);width:16px;text-align:center;flex-shrink:0;font-family:Share Tech Mono,monospace}.combat-combatant-name{font-family:Share Tech Mono,monospace;font-size:12px;color:var(--text-light);min-width:80px;flex-shrink:0}.combat-combatant.current-turn .combat-combatant-name{color:#f88}.hp-bar-track{flex:1;height:6px;background:#00000080;border:1px solid rgba(255,255,255,.05);overflow:hidden}.hp-bar-fill{height:100%;transition:width .4s ease}.hp-bar-fill.hp-high{background:var(--phosphor);box-shadow:0 0 4px #00e5a080}.hp-bar-fill.hp-mid{background:var(--accent-gold);box-shadow:0 0 4px #d4af3780}.hp-bar-fill.hp-low{background:var(--blood-bright);box-shadow:0 0 4px #c219;animation:pulse-blood 1s infinite}.combat-hp-pct{font-family:Share Tech Mono,monospace;font-size:10px;color:var(--text-aged);width:32px;text-align:right;flex-shrink:0}.combat-log{display:flex;flex-direction:column;gap:2px;border-top:1px solid rgba(139,0,0,.2);padding-top:6px}.combat-log-entry{display:flex;align-items:flex-start;gap:6px;font-family:Share Tech Mono,monospace;font-size:11px;line-height:1.5;animation:fade-in .15s ease-out}.combat-log-icon{flex-shrink:0;width:14px;text-align:center}.combat-log-text{color:var(--text-aged);flex:1}.entry-hit .combat-log-text{color:#d44040}.entry-miss .combat-log-text{color:var(--text-aged)}.entry-bleed .combat-log-text{color:#c66}.entry-dying .combat-log-text{color:var(--blood-bright)}.entry-start .combat-log-text{color:var(--neon-warn)}.entry-end .combat-log-text{color:var(--text-aged);font-style:italic}.cmd-sidebar{width:270px;flex-shrink:0;display:flex;flex-direction:column;border-right:1px solid var(--border);border-top:none;border-left:none;border-bottom:none;background:var(--surface);overflow:hidden;position:relative}.cmd-sidebar-header{flex-shrink:0;padding:10px 14px 8px;border-bottom:1px solid var(--border);background:var(--parchment)}.cmd-sidebar-title{font-family:Cinzel,serif;font-size:11px;letter-spacing:3px;color:var(--accent-gold);text-transform:uppercase}.combat-banner{flex-shrink:0;padding:7px 14px;text-align:center;font-family:Barlow Condensed,sans-serif;font-size:12px;font-weight:600;letter-spacing:2px;text-transform:uppercase}.combat-banner.my-turn{background:#8b000040;border-bottom:1px solid var(--blood-bright);color:#f88;animation:pulse-blood 1.5s infinite}.combat-banner.waiting{background:#d4af370f;border-bottom:1px solid rgba(212,175,55,.2);color:var(--text-aged)}.cmd-sidebar-body{flex:1;overflow-y:auto;padding:8px 0}.cmd-category{margin-bottom:12px}.cmd-category-header{font-family:Cinzel,serif;font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--text-aged);padding:4px 14px;border-bottom:1px solid rgba(212,175,55,.15);margin-bottom:4px;position:relative}.cmd-category-header:after{content:"";position:absolute;bottom:0;left:14px;width:30px;height:1px;background:var(--accent-gold);opacity:.4}.cmd-category-list{display:flex;flex-direction:column}.cmd-entry{display:flex;align-items:center;gap:6px;padding:4px 14px;cursor:default;transition:background .1s;-webkit-user-select:none;user-select:none}.cmd-entry.cmd-enabled{cursor:pointer}.cmd-entry.cmd-enabled:hover{background:#8b00001f;box-shadow:inset 3px 0 #c216}.cmd-entry.cmd-enabled:hover .cmd-key{color:var(--accent-gold)}.cmd-entry.cmd-disabled{opacity:.4}.cmd-entry.cmd-disabled .cmd-key{text-decoration:line-through;color:var(--text-aged)}.cmd-arrow{color:var(--accent-gold);font-size:12px;width:10px;flex-shrink:0;opacity:.7}.cmd-key{font-family:Share Tech Mono,monospace;font-size:12px;color:var(--text-light);flex:1;min-width:0}.cmd-args{font-family:Share Tech Mono,monospace;font-size:10px;color:var(--text-aged);opacity:.6;flex-shrink:0;max-width:90px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cmd-reason{font-size:10px;color:var(--text-aged);opacity:.5;flex-shrink:0}.cmd-sidebar-footer{flex-shrink:0;padding:8px 14px;border-top:1px solid var(--border);text-align:center}.cmd-footer-text{font-size:10px;color:var(--accent-gold);opacity:.25;letter-spacing:3px}.char-status{width:220px;flex-shrink:0;display:flex;flex-direction:column;border-left:1px solid var(--border);border-right:none;border-top:none;border-bottom:none;background:var(--surface);overflow:hidden;position:relative}.char-status-header{flex-shrink:0;padding:10px 14px 8px;border-bottom:1px solid var(--border);background:var(--parchment)}.char-status-title{font-family:Cinzel,serif;font-size:11px;letter-spacing:3px;color:var(--accent-gold);text-transform:uppercase}.char-status-body{flex:1;overflow-y:auto;padding:12px 14px;display:flex;flex-direction:column;gap:10px}.char-name-row{text-align:center;padding-bottom:4px;border-bottom:1px solid var(--border)}.char-name{font-family:Cinzel,serif;font-size:15px;color:var(--accent-gold);animation:glow-gold 5s ease-in-out infinite}.char-name-empty{font-family:Share Tech Mono,monospace;font-size:12px;color:var(--text-aged);opacity:.5;font-style:italic}.status-tags{display:flex;flex-direction:column;gap:4px}.status-tag{font-family:Barlow Condensed,sans-serif;font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;padding:3px 8px;text-align:center;animation:fade-in .2s ease-out}.tag-combat{background:#8b000033;border:1px solid rgba(204,34,17,.4);color:#f88;animation:pulse-blood 1.5s infinite}.tag-bleeding{background:#cc221126;border:1px solid rgba(204,34,17,.3);color:#c66}.tag-dying{background:#32000066;border:1px solid var(--blood-bright);color:var(--blood-bright);animation:pulse-blood .8s infinite}.tag-unconscious{background:#1e1e3c4d;border:1px solid rgba(100,100,200,.3);color:#88c}.status-section-label{font-family:Cinzel,serif;font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:var(--text-aged);border-bottom:1px solid var(--border);padding-bottom:4px;opacity:.7}.stat-bars{display:flex;flex-direction:column;gap:7px}.stat-bar-row{display:flex;align-items:center;gap:6px}.stat-bar-label{font-family:Cinzel,serif;font-size:9px;letter-spacing:1px;color:var(--text-aged);width:38px;flex-shrink:0;text-transform:uppercase}.stat-bar-track{flex:1;height:8px;background:#00000080;border:1px solid rgba(255,255,255,.04);overflow:hidden}.stat-bar-fill{height:100%;transition:width .5s ease}.bar-health{background:var(--phosphor);box-shadow:0 0 4px #00e5a066}.bar-danger{background:var(--blood-bright);animation:pulse-blood 1s infinite}.bar-bleed{background:#c44;box-shadow:0 0 4px #c446}.bar-death{background:#822}.stat-bar-value{font-family:Share Tech Mono,monospace;font-size:10px;color:var(--text-aged);width:32px;text-align:right;flex-shrink:0}.av-row{display:flex;align-items:center;justify-content:space-between;padding:4px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.av-label{font-family:Cinzel,serif;font-size:10px;letter-spacing:1px;color:var(--text-aged);text-transform:uppercase}.av-value{font-family:Share Tech Mono,monospace;font-size:16px;color:var(--text-light);font-weight:700}.equip-slots{display:flex;flex-direction:column;gap:5px}.equip-slot{display:flex;align-items:center;gap:6px}.equip-icon{font-size:13px;width:16px;flex-shrink:0;text-align:center}.equip-slot-label{font-family:Cinzel,serif;font-size:9px;letter-spacing:1px;color:var(--text-aged);width:46px;flex-shrink:0;text-transform:uppercase}.equip-item{font-family:Share Tech Mono,monospace;font-size:11px;color:var(--accent-gold);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.equip-empty{color:var(--text-aged);opacity:.4;font-style:italic}.status-hint{font-size:10px;color:var(--text-aged);text-align:center;opacity:.7;line-height:1.5;margin-top:auto}.hint-code{color:var(--phosphor);background:#00e5a012;padding:1px 4px;font-size:10px}.char-actions{margin-top:12px}.char-action-btn{display:block;width:100%;font-family:Cinzel,serif;font-size:10px;letter-spacing:1px;text-transform:uppercase;padding:6px 10px;margin-bottom:4px;border:1px solid var(--border-bright);background:transparent;color:var(--text-aged);cursor:pointer;transition:all .15s}.char-action-btn:hover{border-color:var(--accent-gold);color:var(--accent-gold);background:#d4af370f}.chargen-btn-link{color:var(--accent-gold);border-color:var(--accent-gold);background:#d4af370a}.world-map-link{color:var(--phosphor);border-color:#00e5a04d;background:#00e5a008}.world-map-link:hover{border-color:var(--phosphor);color:var(--phosphor);background:#00e5a014}.char-status-footer{flex-shrink:0;padding:8px 14px;border-top:1px solid var(--border);text-align:center}.char-status-footer .cinzel{font-size:10px;color:var(--accent-gold);opacity:.25;letter-spacing:2px}.detail-panel{width:220px;flex-shrink:0;display:flex;flex-direction:column;border-left:1px solid var(--border);border-right:none;border-top:none;border-bottom:none;background:var(--surface);overflow:hidden;position:relative;animation:fade-in .2s ease-out}.detail-panel-header{flex-shrink:0;padding:10px 14px 8px;border-bottom:1px solid var(--border);background:var(--parchment);display:flex;align-items:center;justify-content:space-between}.detail-panel-title{font-family:Cinzel,serif;font-size:11px;letter-spacing:3px;color:var(--accent-gold);text-transform:uppercase}.detail-panel-close{background:transparent;border:1px solid rgba(139,0,0,.4);color:var(--text-aged);font-size:10px;padding:2px 7px;cursor:pointer;transition:border-color .15s,color .15s;font-family:Cinzel,serif;letter-spacing:1px;line-height:1}.detail-panel-close:hover{border-color:var(--blood-bright);color:var(--blood-bright)}.detail-panel-body{flex:1;overflow-y:auto;padding:12px 14px;display:flex;flex-direction:column;gap:10px}.detail-portrait{width:100%;height:140px;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at center,#00000080,#000000d9);border:1px solid var(--border);position:relative;overflow:hidden}.detail-portrait:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at center,transparent 40%,rgba(10,8,7,.7));pointer-events:none}.detail-portrait:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border:1px solid rgba(212,175,55,.15);pointer-events:none}.detail-portrait.type-npc:after,.detail-portrait.type-character:after{border-color:#00e5a040}.detail-portrait.type-item:after{border-color:#d4af3740}.detail-portrait-img{width:110px;height:110px;object-fit:contain;filter:brightness(1.1) contrast(1.05) drop-shadow(0 0 6px rgba(0,0,0,.6));z-index:1}.detail-name-row{text-align:center;padding-bottom:4px;border-bottom:1px solid var(--border)}.detail-name{font-family:Cinzel,serif;font-size:15px;color:var(--accent-gold);animation:glow-gold 5s ease-in-out infinite}.detail-type-row{display:flex;justify-content:center}.detail-type-tag{font-family:Barlow Condensed,sans-serif;font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;padding:2px 10px;text-align:center}.detail-type-tag.type-npc{background:#00e5a01a;border:1px solid rgba(0,229,160,.3);color:var(--phosphor)}.detail-type-tag.type-item{background:#d4af3714;border:1px solid rgba(212,175,55,.3);color:var(--accent-gold)}.detail-type-tag.type-player{background:#6464c81a;border:1px solid rgba(100,100,200,.3);color:#88c}.detail-description{font-family:Share Tech Mono,monospace;font-size:11px;line-height:1.6;color:var(--text-light);opacity:.85;max-height:160px;overflow-y:auto;padding:6px 0}.detail-desc-empty{color:var(--text-aged);opacity:.5;font-style:italic;font-size:10px}.detail-actions{margin-top:auto;display:flex;flex-direction:column;gap:4px}.detail-actions .status-section-label{margin-bottom:2px}.detail-action-btn{display:flex;align-items:center;gap:8px;width:100%;font-family:Cinzel,serif;font-size:10px;letter-spacing:1px;text-transform:uppercase;padding:6px 10px;border:1px solid var(--border-bright);background:transparent;color:var(--text-aged);cursor:pointer;transition:all .15s}.detail-action-btn:hover{border-color:var(--accent-gold);color:var(--accent-gold);background:#d4af370f}.detail-action-btn:active{background:#d4af371f}.detail-action-icon{font-size:12px;width:16px;text-align:center;flex-shrink:0}.detail-action-label{flex:1;text-align:left}.detail-panel-footer{flex-shrink:0;padding:8px 14px;border-top:1px solid var(--border);text-align:center}.detail-panel-footer .cinzel{font-size:10px;color:var(--accent-gold);opacity:.25;letter-spacing:2px}.context-menu{position:fixed;z-index:10000;animation:fade-in .1s ease-out}.context-menu-inner{min-width:140px;padding:4px 0;background:var(--surface);border:1px solid var(--border-bright);box-shadow:0 4px 16px #0009,0 0 0 1px #d4af3714}.context-menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:7px 14px;border:none;background:transparent;color:var(--text-light);font-family:Share Tech Mono,monospace;font-size:12px;cursor:pointer;transition:all .1s;text-align:left}.context-menu-item:hover{background:#d4af371a;color:var(--accent-gold)}.context-menu-item:active{background:#d4af372e}.context-menu-icon{font-size:12px;width:18px;text-align:center;flex-shrink:0;opacity:.8}.context-menu-label{flex:1;white-space:nowrap}.cmd-input-wrap{flex-shrink:0;position:relative;background:var(--surface);border-top:1px solid var(--border)}.cmd-input-row{display:flex;align-items:center;gap:0;padding:0;background:var(--surface);transition:box-shadow .15s}.cmd-input-row:focus-within{box-shadow:inset 0 1px #d4af3726}.cmd-input-row.disabled{opacity:.5}.cmd-prompt{font-family:Share Tech Mono,monospace;font-size:18px;color:var(--phosphor);padding:10px 0 10px 14px;-webkit-user-select:none;user-select:none;flex-shrink:0;line-height:1;text-shadow:0 0 6px rgba(0,229,160,.5)}.cmd-input{flex:1;background:transparent;border:none;outline:none;color:var(--text-light);font-family:Share Tech Mono,monospace;font-size:14px;padding:10px 10px 10px 8px;caret-color:var(--phosphor);min-width:0}.cmd-input::placeholder{color:var(--text-aged);opacity:.35}.cmd-input:not(:placeholder-shown){text-shadow:0 0 4px rgba(0,229,160,.12)}.cmd-send-btn{flex-shrink:0;background:transparent;border:none;border-left:1px solid var(--border);color:var(--text-aged);font-size:14px;padding:0 14px;height:100%;cursor:pointer;min-height:42px;transition:color .15s,background .15s}.cmd-send-btn:hover:not(:disabled){color:var(--accent-gold);background:#d4af370f}.cmd-send-btn:disabled{opacity:.25;cursor:default}.cmd-completions{position:absolute;bottom:100%;left:14px;right:14px;background:var(--parchment);border:1px solid var(--border-bright);border-bottom:none;box-shadow:0 -4px 16px #00000080;z-index:100;max-height:160px;overflow-y:auto}.cmd-completion-item{font-family:Share Tech Mono,monospace;font-size:12px;color:var(--text-light);padding:5px 12px;cursor:pointer;transition:background .1s}.cmd-completion-item:hover,.cmd-completion-item.active{background:#d4af371a;color:var(--accent-gold)}.chargen-wizard{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--void)}.chargen-wizard-header{flex-shrink:0;padding:10px 24px;border-bottom:1px solid var(--border);background:var(--surface);display:flex;align-items:center;justify-content:space-between;gap:16px}.chargen-back-btn{padding:5px 12px;font-size:10px;flex-shrink:0}.step-indicator{display:flex;gap:4px;align-items:center}.step-item{display:flex;align-items:center;gap:4px}.step-item+.step-item:before{content:"─";color:var(--border-bright);font-size:10px;margin-right:4px}.step-dot{width:8px;height:8px;border-radius:50%;border:1px solid var(--border-bright);transition:background .3s,border-color .3s}.step-dot.active{background:var(--accent-gold);border-color:var(--accent-gold)}.step-dot.completed{background:var(--phosphor);border-color:var(--phosphor)}.step-label{font-family:Cinzel,serif;font-size:10px;color:var(--text-aged);letter-spacing:.5px;text-transform:uppercase}.step-label.active{color:var(--accent-gold)}.cp-tracker{display:flex;align-items:center;gap:10px}.cp-pips{display:flex;gap:4px}.cp-pip{width:14px;height:14px;border-radius:50%;border:2px solid var(--accent-gold);transition:background .3s,box-shadow .3s}.cp-pip.spent{background:var(--accent-blood);border-color:var(--accent-blood);box-shadow:0 0 6px #8b000080}.cp-pip.available{background:transparent;box-shadow:inset 0 0 4px #d4af374d}.cp-label{font-family:Share Tech Mono,monospace;font-size:13px;color:var(--accent-gold);white-space:nowrap}.admin-tracker .admin-label{font-family:Cinzel,serif;font-size:12px;letter-spacing:2px;color:var(--phosphor);text-shadow:0 0 8px rgba(0,229,160,.5);border:1px solid var(--phosphor);padding:3px 10px}.chargen-wizard-body{flex:1;overflow-y:auto;padding:24px;scroll-behavior:smooth}.chargen-step{animation:fade-in .3s ease-out;max-width:1100px;margin:0 auto}.chargen-wizard-nav{flex-shrink:0;display:flex;justify-content:space-between;padding:12px 24px;border-top:1px solid var(--border);background:var(--surface)}.chargen-btn{font-family:Cinzel,serif;font-size:13px;letter-spacing:1px;text-transform:uppercase;padding:10px 24px;border:1px solid var(--accent-gold);background:transparent;color:var(--accent-gold);cursor:pointer;transition:all .2s}.chargen-btn:hover:not(:disabled){background:#d4af371a;box-shadow:0 0 12px #d4af3733}.chargen-btn:disabled{opacity:.3;cursor:not-allowed}.chargen-btn.primary{background:#d4af3714}.chargen-btn.secondary{border-color:var(--border-bright);color:var(--text-aged)}.chargen-btn.secondary:hover:not(:disabled){border-color:var(--text-aged);background:#9a82661a}.chargen-title{font-family:UnifrakturMaguntia,serif;font-size:42px;color:var(--accent-gold);text-align:center;animation:glow-gold 4s ease-in-out infinite;margin:0 0 8px}.chargen-divider{text-align:center;color:var(--border-bright);font-size:14px;letter-spacing:3px;margin:8px 0 16px}.chargen-flavor{font-family:IM Fell English,serif;font-style:italic;font-size:15px;color:var(--text-aged);text-align:center;line-height:1.7;max-width:600px;margin:0 auto 24px}.chargen-label{font-family:Cinzel,serif;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--accent-gold);margin:0 0 8px}.chargen-section-title{font-family:Cinzel,serif;font-size:22px;color:var(--accent-gold);text-align:center;letter-spacing:2px;margin:0 0 4px}.chargen-section-desc{font-family:IM Fell English,serif;font-style:italic;color:var(--text-aged);text-align:center;margin:0 0 24px;font-size:14px}.welcome-step{display:flex;justify-content:center;align-items:center;min-height:100%}.welcome-content{max-width:600px;text-align:center;padding:40px 32px}.welcome-rules{text-align:left;margin:20px 0;font-family:Share Tech Mono,monospace;font-size:13px;color:var(--text-light);line-height:1.7}.welcome-rules h3{margin-bottom:8px}.welcome-rules ul{padding-left:20px;margin:8px 0}.welcome-rules li{margin:4px 0}.welcome-rules strong{color:var(--accent-gold)}.archetype-tier{margin-bottom:28px}.tier-label{font-family:Cinzel,serif;font-size:14px;color:var(--text-light);letter-spacing:1px;border-bottom:1px solid var(--border);padding-bottom:6px;margin-bottom:12px}.tier-cost{color:var(--accent-gold);font-size:12px}.archetype-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px}.archetype-card{cursor:pointer;transition:border-color .2s,box-shadow .2s,transform .15s;overflow:hidden;padding:0;background:var(--parchment);border:1px solid var(--border)}.archetype-card:hover:not(.disabled){border-color:var(--accent-gold);box-shadow:0 0 14px #d4af3740;transform:translateY(-2px)}.archetype-card.selected{border-color:var(--accent-gold);box-shadow:0 0 20px #d4af3766,inset 0 0 20px #d4af370a}.archetype-card.disabled{opacity:.35;pointer-events:none;filter:grayscale(.5)}.archetype-card-art-wrap{position:relative;width:100%;height:200px;overflow:hidden;background:var(--surface)}.archetype-card-art{width:100%;height:100%;object-fit:contain;object-position:center;filter:invert(1) sepia(.15) contrast(1.1) brightness(.85);mix-blend-mode:screen;transition:filter .3s,transform .3s}.archetype-card:hover:not(.disabled) .archetype-card-art{filter:invert(1) sepia(0) contrast(1.15) brightness(.9);transform:scale(1.03)}.archetype-card-cost{position:absolute;top:8px;right:8px;background:#0a0807d9;color:var(--accent-gold);font-family:Cinzel,serif;font-size:11px;letter-spacing:1px;padding:3px 8px;border:1px solid var(--accent-gold)}.archetype-card-check{position:absolute;top:8px;left:8px;color:var(--accent-gold);font-size:20px;text-shadow:0 0 8px rgba(212,175,55,.8);animation:fade-in .2s}.archetype-card-body{padding:12px 14px 14px}.archetype-card-name{font-family:Cinzel,serif;font-size:15px;color:var(--text-light);margin:0 0 4px}.archetype-card-flavor{font-family:IM Fell English,serif;font-style:italic;font-size:12px;color:var(--text-aged);margin:0 0 6px;line-height:1.4}.archetype-card-desc{font-family:Share Tech Mono,monospace;font-size:11px;color:var(--text-light);margin:0 0 6px;line-height:1.5}.archetype-card-gear,.archetype-card-skills{font-family:Share Tech Mono,monospace;font-size:11px;color:var(--text-aged);margin:2px 0}.gear-label{color:var(--accent-gold);font-size:10px;text-transform:uppercase;letter-spacing:.5px}.archetype-card-prereq{font-family:Share Tech Mono,monospace;font-size:10px;color:var(--blood-bright);margin-top:6px;padding-top:6px;border-top:1px solid var(--border)}.skip-btn{display:block;margin:20px auto 0}.skills-layout{display:flex;gap:20px}.skills-categories{flex:1}.skill-category{margin-bottom:20px}.skill-category-name{font-family:Cinzel,serif;font-size:13px;color:var(--accent-gold);letter-spacing:1px;text-transform:uppercase;border-bottom:1px solid var(--border);padding-bottom:4px;margin-bottom:8px}.skill-row{padding:8px 12px;margin-bottom:2px;background:var(--parchment);border:1px solid transparent;transition:border-color .2s}.skill-row:hover{border-color:var(--border)}.skill-info{display:flex;align-items:center;justify-content:space-between;margin-bottom:2px}.skill-name{font-family:Cinzel,serif;font-size:13px;color:var(--text-light)}.skill-pips{display:flex;gap:3px}.skill-pip{width:10px;height:10px;border-radius:50%;border:1px solid var(--accent-gold);transition:background .2s}.skill-pip.filled{background:var(--accent-gold)}.skill-pip.granted{background:var(--phosphor);border-color:var(--phosphor)}.skill-pip.empty{background:transparent}.skill-controls{display:flex;align-items:center;gap:8px;margin:4px 0}.skill-btn{width:28px;height:28px;border:1px solid var(--border-bright);background:transparent;color:var(--text-light);font-family:Share Tech Mono,monospace;font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.skill-btn:hover:not(:disabled){border-color:var(--accent-gold);color:var(--accent-gold);background:#d4af3714}.skill-btn:disabled{opacity:.25;cursor:not-allowed}.skill-btn.plus{font-size:11px}.skill-level{font-family:Share Tech Mono,monospace;font-size:15px;color:var(--accent-gold);width:16px;text-align:center}.skill-desc{font-family:Share Tech Mono,monospace;font-size:10px;color:var(--text-aged);margin:2px 0 0;line-height:1.4}.review-layout{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px}.review-card{padding:20px}.review-archetype{display:flex;gap:14px;margin-bottom:16px}.review-art{width:100px;height:130px;object-fit:contain;filter:invert(1) brightness(.85);mix-blend-mode:screen}.review-archetype-info h3{font-family:Cinzel,serif;font-size:16px;color:var(--text-light);margin:0 0 4px}.review-tag{display:inline-block;font-family:Share Tech Mono,monospace;font-size:10px;letter-spacing:1px;text-transform:uppercase;padding:2px 6px;margin-bottom:6px}.review-tag.basic{color:var(--accent-gold);border:1px solid var(--accent-gold)}.review-tag.advanced{color:var(--phosphor);border:1px solid var(--phosphor)}.review-archetype-info p{font-size:12px;color:var(--text-aged);margin:0}.review-skills{padding:20px}.review-skill-cat{margin-bottom:12px}.review-skill-cat h4{font-family:Cinzel,serif;font-size:11px;color:var(--text-aged);letter-spacing:1px;text-transform:uppercase;margin:0 0 6px}.review-skill-row{display:flex;align-items:center;justify-content:space-between;padding:3px 0;font-family:Share Tech Mono,monospace;font-size:12px;color:var(--text-light)}.review-actions{display:flex;justify-content:center;gap:16px}@media (max-width: 768px){.archetype-grid,.review-layout{grid-template-columns:1fr}.step-label{display:none}.chargen-wizard-header{padding:8px 12px}.chargen-wizard-body{padding:16px}}.character-sheet-header{text-align:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border)}.character-sheet-name{font-family:Cinzel,serif;font-size:22px;color:var(--accent-gold);margin:0 0 8px;letter-spacing:2px;text-transform:uppercase}.character-sheet-archetypes{display:flex;justify-content:center;align-items:center;gap:8px;font-family:Share Tech Mono,monospace;font-size:12px;color:var(--text-aged, #c9b899);margin:0 0 8px}.character-sheet-archetype{text-transform:uppercase;letter-spacing:1px}.character-sheet-archetype.basic{color:var(--text-light, #e8e8e8)}.character-sheet-archetype.advanced{color:var(--accent-gold)}.character-sheet-archetype-sep{color:var(--border-bright, #5a5a5a)}.character-sheet-hint{font-family:Share Tech Mono,monospace;font-size:11px;color:var(--text-aged, #c9b899);font-style:italic;margin:0;opacity:.8}.room-view{flex:1;padding:14px 20px 10px;background:var(--parchment);border-bottom:1px solid var(--border);position:relative;overflow-y:auto;min-height:0;display:flex;flex-direction:column;--biome-tint: transparent;--biome-accent: var(--accent-gold)}.room-biome-tint{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at top,var(--biome-tint),transparent 70%);pointer-events:none;z-index:0}.room-view>*:not(.room-biome-tint){position:relative;z-index:1}.room-view:after{content:"";position:absolute;bottom:0;left:0;right:0;height:20px;background:linear-gradient(to bottom,transparent,rgba(10,8,7,.3));pointer-events:none}.room-view-empty{text-align:center;padding:20px;color:var(--text-aged);opacity:.5;font-size:12px}.room-view-empty code{color:var(--phosphor);background:#00e5a012;padding:1px 4px}.room-header{position:relative;display:flex;align-items:center;gap:14px;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--border);min-height:130px;overflow:hidden}.room-header-text{flex:1;min-width:0;z-index:2;position:relative}.room-name{font-family:Cinzel,serif;font-size:22px;font-weight:600;color:var(--accent-gold);letter-spacing:2px;text-transform:uppercase;margin:0;text-shadow:0 0 12px rgba(0,0,0,.9),0 0 6px rgba(212,175,55,.4)}.room-biome-backdrop{position:absolute;right:0;top:50%;transform:translateY(-50%);width:180px;height:180px;object-fit:contain;opacity:.55;filter:brightness(1.05) contrast(1.05) drop-shadow(0 0 14px rgba(0,0,0,.7));pointer-events:none;z-index:1;mask-image:linear-gradient(to right,transparent 0%,black 30%,black 100%);-webkit-mask-image:linear-gradient(to right,transparent 0%,black 30%,black 100%)}.room-desc{font-family:Share Tech Mono,monospace;font-size:12px;line-height:1.6;color:var(--text-light);margin:0 0 10px;flex:1;overflow-y:auto;opacity:.85}.room-details{display:flex;flex-wrap:wrap;gap:16px}.room-section{flex:1;min-width:150px}.room-section-label{display:block;font-family:Cinzel,serif;font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--text-aged);margin-bottom:6px;border-bottom:1px solid var(--border);padding-bottom:3px}.room-exits{display:flex;flex-wrap:wrap;gap:6px}.room-exit-btn{display:flex;align-items:center;gap:6px;font-family:Share Tech Mono,monospace;font-size:12px;color:var(--text-light);background:#d4af370a;border:1px solid var(--border-bright);padding:5px 12px;cursor:pointer;transition:all .15s}.room-exit-btn:hover{border-color:var(--accent-gold);color:var(--accent-gold);background:#d4af371a;box-shadow:0 0 10px #d4af3726;transform:translateY(-1px)}.room-exit-btn:active{transform:translateY(0);background:#d4af372e}.room-exit-name{color:inherit}.room-exit-dir{font-size:10px;color:var(--accent-gold);opacity:.6;padding:1px 4px;border:1px solid rgba(212,175,55,.2);letter-spacing:1px}.room-entities{display:flex;flex-wrap:wrap;gap:6px}.room-entity-btn{display:flex;align-items:center;gap:6px;font-family:Share Tech Mono,monospace;font-size:11px;padding:5px 10px;border:1px solid var(--border);background:#14121080;cursor:pointer;transition:all .15s}.room-entity-btn:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0000004d}.room-entity-btn.character{color:var(--phosphor);border-color:#00e5a040}.room-entity-btn.character:hover{border-color:var(--phosphor);background:#00e5a014}.room-entity-btn.item{color:var(--text-aged);border-color:var(--border)}.room-entity-btn.item:hover{border-color:var(--accent-gold);color:var(--accent-gold);background:#d4af370f}.entity-icon{font-size:10px;opacity:.6}.entity-name{white-space:nowrap}.world-map-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0807eb;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:40px;animation:fade-in .2s ease-out}.world-map-content{background:var(--parchment);border:1px solid var(--accent-gold);box-shadow:0 0 60px #d4af3733,inset 0 0 40px #0009;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;position:relative}.world-map-content:before,.world-map-content:after{content:"✦";position:absolute;color:var(--accent-gold);font-size:16px;opacity:.7}.world-map-content:before{top:-10px;left:-10px}.world-map-content:after{bottom:-10px;right:-10px}.world-map-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}.world-map-title{font-family:UnifrakturMaguntia,serif;font-size:24px;color:var(--accent-gold);letter-spacing:2px;animation:glow-gold 4s ease-in-out infinite}.world-map-close{background:transparent;border:1px solid rgba(139,0,0,.4);color:var(--text-aged);font-size:12px;padding:4px 10px;cursor:pointer;transition:all .15s;font-family:Cinzel,serif}.world-map-close:hover{border-color:var(--blood-bright);color:var(--blood-bright)}.world-map-body{flex:1;overflow:auto;padding:16px;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at center,rgba(212,175,55,.04),transparent 70%),var(--void);min-height:0}.world-map-image{max-width:100%;max-height:100%;object-fit:contain;filter:brightness(.95) contrast(1.05);box-shadow:0 4px 30px #000000b3}.world-map-footer{padding:8px 20px;border-top:1px solid var(--border);background:var(--surface);text-align:center;flex-shrink:0}.world-map-hint{font-family:IM Fell English,serif;font-style:italic;font-size:11px;color:var(--text-aged);letter-spacing:.5px}@media (max-width: 768px){.world-map-modal{padding:12px}.world-map-title{font-size:18px}}.command-prompt-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0807c7;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:24px;animation:fade-in .15s ease-out}.command-prompt-modal{width:100%;max-width:480px;background:var(--parchment);border:1px solid var(--accent-gold);box-shadow:0 0 50px #d4af3733,inset 0 0 30px #0009;position:relative;animation:prompt-rise .2s ease-out}@keyframes prompt-rise{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.command-prompt-modal:before,.command-prompt-modal:after{content:"✦";position:absolute;color:var(--accent-gold);font-size:14px;opacity:.7}.command-prompt-modal:before{top:-8px;left:-8px}.command-prompt-modal:after{bottom:-8px;right:-8px}.command-prompt-header{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--surface)}.command-prompt-icon{font-size:18px;flex-shrink:0}.command-prompt-title{flex:1;font-family:Cinzel,serif;font-size:14px;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent-gold)}.command-prompt-close{background:transparent;border:1px solid rgba(139,0,0,.4);color:var(--text-aged);font-size:11px;padding:3px 8px;cursor:pointer;transition:all .15s;font-family:Cinzel,serif;line-height:1}.command-prompt-close:hover{border-color:var(--blood-bright);color:var(--blood-bright)}.command-prompt-body{padding:20px 20px 16px;display:flex;flex-direction:column;gap:10px}.command-prompt-label{font-family:IM Fell English,serif;font-size:15px;color:var(--text-light);font-style:italic;line-height:1.4}.command-prompt-input{width:100%;font-family:Share Tech Mono,monospace;font-size:14px;padding:10px 12px;background:#0a080799;border:1px solid var(--border-bright);color:var(--text-light);outline:none;transition:border-color .15s,box-shadow .15s}.command-prompt-input:focus{border-color:var(--accent-gold);box-shadow:0 0 8px #d4af3733}.command-prompt-input::placeholder{color:var(--text-aged);opacity:.5}.command-prompt-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:4px}.command-prompt-btn{font-family:Cinzel,serif;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;padding:8px 18px;background:transparent;cursor:pointer;transition:all .15s;border:1px solid}.command-prompt-btn.primary{border-color:var(--accent-gold);color:var(--accent-gold);background:#d4af3714}.command-prompt-btn.primary:hover:not(:disabled){background:#d4af372e;box-shadow:0 0 10px #d4af3733}.command-prompt-btn.primary:disabled{opacity:.3;cursor:not-allowed}.command-prompt-btn.secondary{border-color:var(--border-bright);color:var(--text-aged)}.command-prompt-btn.secondary:hover{border-color:var(--text-aged);color:var(--text-light)}.command-prompt-hint{text-align:center;font-family:Share Tech Mono,monospace;font-size:10px;color:var(--text-aged);opacity:.6;margin-top:4px}.command-prompt-hint kbd{font-family:Share Tech Mono,monospace;font-size:10px;background:#d4af3714;border:1px solid var(--border-bright);padding:1px 5px;margin:0 2px;color:var(--accent-gold)}:root{--void: #0a0807;--surface: #141210;--parchment: #1e1a14;--primary-dark: #141210;--accent-gold: #d4af37;--accent-blood: #8b0000;--blood-bright: #cc2211;--neon-warn: #c9ff00;--phosphor: #00e5a0;--text-light: #e8e4d0;--text-aged: #9a8266;--border: #2e2418;--border-bright: #4a3828}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%;overflow:hidden}body{background:var(--void);color:var(--text-light);font-family:Share Tech Mono,monospace;height:100vh;overflow:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");opacity:.025;pointer-events:none;z-index:9999}@keyframes flicker{0%,to{opacity:1}92%{opacity:1}93%{opacity:.85}94%{opacity:1}96%{opacity:.9}97%{opacity:1}}@keyframes pulse-blood{0%,to{box-shadow:0 0 4px var(--blood-bright),0 0 8px #c216}50%{box-shadow:0 0 8px var(--blood-bright),0 0 20px #c219}}@keyframes fade-in{0%{opacity:0;transform:translateY(3px)}to{opacity:1;transform:translateY(0)}}@keyframes scanline{0%{transform:translateY(-100%)}to{transform:translateY(100vh)}}@keyframes glow-gold{0%,to{text-shadow:0 0 4px rgba(212,175,55,.6),0 0 10px rgba(212,175,55,.2)}50%{text-shadow:0 0 8px rgba(212,175,55,.9),0 0 20px rgba(212,175,55,.4)}}@keyframes blink-cursor{0%,to{opacity:1}50%{opacity:0}}@keyframes combat-pulse{0%,to{background-color:var(--blood-bright)}50%{background-color:#c216}}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:var(--surface)}::-webkit-scrollbar-thumb{background:var(--border-bright);border-radius:2px}::-webkit-scrollbar-thumb:hover{background:var(--text-aged)}.panel{border:1px solid var(--border);box-shadow:inset 0 0 30px #00000080,0 0 0 1px #d4af370f;background:var(--parchment)}.panel-decorated{position:relative}.panel-decorated:before{content:"✦";position:absolute;top:-7px;left:-7px;color:var(--accent-gold);opacity:.5;font-size:13px;z-index:1;pointer-events:none}.panel-decorated:after{content:"✦";position:absolute;top:-7px;right:-7px;color:var(--accent-gold);opacity:.5;font-size:13px;z-index:1;pointer-events:none}.app-container{display:flex;flex-direction:column;height:100vh;width:100vw;background:var(--void);overflow:hidden}.app-header{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:6px 16px;background:var(--surface);border-bottom:1px solid var(--border);height:44px}.app-header-title{font-family:UnifrakturMaguntia,serif;font-size:22px;color:var(--accent-gold);animation:glow-gold 4s ease-in-out infinite;letter-spacing:1px;-webkit-user-select:none;user-select:none}.app-header-title .skull{margin-right:6px;opacity:.9}.app-header-rule{flex:1;margin:0 12px;height:1px;background:linear-gradient(to right,transparent,var(--border-bright) 20%,var(--accent-gold) 50%,var(--border-bright) 80%,transparent);position:relative;overflow:visible;display:flex;align-items:center;justify-content:center}.app-header-rule:before{content:"╌╌✦╌╌";position:absolute;color:var(--accent-gold);opacity:.5;font-size:11px;background:var(--surface);padding:0 6px;letter-spacing:1px}.app-header-status{display:flex;align-items:center;gap:8px;font-family:Cinzel,serif;font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot.connected{background:var(--phosphor);box-shadow:0 0 6px var(--phosphor);animation:flicker 8s infinite}.status-dot.connecting{background:var(--accent-gold);animation:pulse-blood 1.5s infinite}.status-dot.disconnected{background:var(--text-aged);opacity:.5}.status-label.connected{color:var(--phosphor)}.status-label.connecting{color:var(--accent-gold)}.status-label.disconnected{color:var(--text-aged)}.status-latency{color:var(--text-aged);font-size:10px;opacity:.7}.header-disconnect-btn{background:transparent;border:1px solid rgba(139,0,0,.4);color:var(--text-aged);font-size:10px;padding:2px 7px;cursor:pointer;transition:border-color .15s,color .15s;font-family:Cinzel,serif;letter-spacing:1px}.header-disconnect-btn:hover{border-color:var(--blood-bright);color:var(--blood-bright)}.app-body{flex:1;display:flex;min-height:0;overflow:hidden}.app-connecting{flex:1;display:flex;align-items:center;justify-content:center;background:var(--void)}.app-connecting-text{font-family:Cinzel,serif;font-size:18px;letter-spacing:3px;color:var(--accent-gold);animation:glow-gold 1.5s ease-in-out infinite;text-transform:uppercase}.app-main{display:flex;flex-direction:column;flex:1;min-width:0;min-height:0}.app-log-area{flex:0 0 200px;display:flex;flex-direction:column;min-height:0;border-top:1px solid var(--border)}
