.landing-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:3rem 1.5rem 4rem;position:relative;overflow:hidden}.landing-bg-gradient{position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 50% 0%,rgba(60,40,10,.4) 0%,transparent 60%),radial-gradient(ellipse at 20% 100%,rgba(30,10,60,.3) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,rgba(10,30,60,.3) 0%,transparent 50%);pointer-events:none;z-index:-1}.landing-header{text-align:center;margin-bottom:3rem}.d20-icon{font-size:3rem;display:block;margin-bottom:.5rem;animation:float 3s ease-in-out infinite}.landing-title{font-family:var(--font-title);font-size:clamp(2rem,5vw,3.5rem);color:var(--gold-light);text-shadow:0 0 40px rgba(201,168,76,.5),0 2px 4px rgba(0,0,0,.8);letter-spacing:.05em;margin-bottom:.75rem}.landing-subtitle{font-family:var(--font-body);font-style:italic;color:var(--text-secondary);font-size:1.1rem}.landing-main{width:100%;max-width:900px;display:flex;flex-direction:column;gap:2rem}.landing-section{display:flex;flex-direction:column;gap:.75rem}.section-label{font-family:var(--font-heading);font-size:.85rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:.25rem}.genre-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem}.genre-card{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:1rem .75rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition);text-align:center;color:var(--text-primary)}.genre-card:hover{border-color:var(--gold-border);background:var(--bg-card-hover);transform:translateY(-2px);box-shadow:var(--shadow-gold)}.genre-card.selected{border-color:var(--gold);background:var(--gold-dim);box-shadow:0 0 20px #c9a84c40}.genre-icon{font-size:1.8rem}.genre-name{font-family:var(--font-heading);font-size:.85rem;font-weight:600;color:var(--gold-light)}.genre-desc{font-size:.72rem;color:var(--text-muted);line-height:1.3}.mode-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem}.mode-card{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition);text-align:left;color:var(--text-primary)}.mode-card:hover{border-color:var(--gold-border);background:var(--bg-card-hover);box-shadow:var(--shadow-gold)}.mode-card.selected{border-color:var(--gold);background:var(--gold-dim)}.mode-icon{font-size:1.5rem;flex-shrink:0}.mode-info{display:flex;flex-direction:column;gap:.2rem}.mode-name{font-family:var(--font-heading);font-size:.9rem;font-weight:600;color:var(--text-primary)}.mode-desc{font-size:.78rem;color:var(--text-muted)}.join-input-wrap{margin-top:.5rem}.input-code{font-family:var(--font-heading);font-size:1.4rem;letter-spacing:.3em;text-align:center;max-width:260px;text-transform:uppercase}.detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.6rem}.detail-card{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:.9rem .75rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition);text-align:center;color:var(--text-primary)}.detail-card:hover{border-color:var(--gold-border);background:var(--bg-card-hover);transform:translateY(-1px)}.detail-card.selected{border-color:var(--gold);background:var(--gold-dim);box-shadow:0 0 16px #c9a84c33}.detail-icon{font-size:1.5rem}.detail-name{font-family:var(--font-heading);font-size:.85rem;font-weight:600;color:var(--gold-light)}.detail-desc{font-size:.72rem;color:var(--text-muted);line-height:1.3}.btn-begin{margin-top:.5rem;align-self:flex-start;padding:.9rem 2.5rem;font-size:1rem}.cc-page{min-height:100vh;position:relative;padding:1.5rem}.cc-bg-gradient{position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 70% 30%,rgba(40,20,80,.3) 0%,transparent 60%),radial-gradient(ellipse at 20% 80%,rgba(10,40,30,.25) 0%,transparent 50%);pointer-events:none;z-index:-1}.cc-container{max-width:1100px;margin:0 auto}.cc-header{display:flex;align-items:center;gap:1.5rem;margin-bottom:2rem;flex-wrap:wrap}.cc-header-center{flex:1}.cc-header h1{font-family:var(--font-title);color:var(--gold-light);text-shadow:0 0 30px rgba(201,168,76,.4)}.cc-subtitle{display:flex;align-items:center;gap:.75rem;margin-top:.4rem;flex-wrap:wrap}.genre-badge{background:var(--gold-dim);border:1px solid var(--gold-border);color:var(--gold-light);font-family:var(--font-heading);font-size:.78rem;letter-spacing:.08em;padding:.2rem .7rem;border-radius:20px;text-transform:capitalize}.suggestion-text{font-style:italic;color:var(--text-secondary);font-size:.9rem}.btn-back{flex-shrink:0;font-size:.85rem;padding:.5rem 1rem}.cc-layout{display:grid;grid-template-columns:1fr 280px;gap:2rem;align-items:start}@media (max-width: 768px){.cc-layout{grid-template-columns:1fr}.cc-preview{order:-1}}.cc-form{display:flex;flex-direction:column;gap:1.75rem}.cc-section{display:flex;flex-direction:column;gap:.6rem}.section-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.section-selected{font-family:var(--font-heading);font-size:.85rem;color:var(--gold-light)}.select-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.5rem}.select-card{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.75rem .5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);text-align:center;color:var(--text-primary)}.select-card:hover{border-color:var(--gold-border);background:var(--bg-card-hover)}.select-card.selected{border-color:var(--gold);background:var(--gold-dim)}.select-icon{font-size:1.4rem}.select-name{font-family:var(--font-heading);font-size:.78rem;font-weight:600;color:var(--text-primary)}.select-bonus{font-size:.68rem;color:var(--text-muted);font-family:monospace}.btn-roll{padding:.45rem 1rem;font-size:.85rem;gap:.4rem}.roll-count{font-size:.75rem;color:var(--text-muted)}.stats-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:.5rem}@media (max-width: 600px){.stats-grid{grid-template-columns:repeat(3,1fr)}}.stat-box{display:flex;flex-direction:column;align-items:center;gap:.1rem;padding:.75rem .4rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);text-align:center;animation:fadeInScale .3s ease both}.stat-label{font-family:var(--font-heading);font-size:.7rem;letter-spacing:.08em;color:var(--gold);font-weight:600}.stat-full-label{font-size:.6rem;color:var(--text-muted);display:none}.stat-value{font-family:var(--font-heading);font-size:1.4rem;font-weight:700;color:var(--text-primary);line-height:1}.stat-mod{font-family:monospace;font-size:.8rem;font-weight:700}.stat-mod.positive{color:var(--green-light)}.stat-mod.negative{color:var(--red-light)}.stat-racial{font-size:.6rem;color:var(--gold);font-style:italic}.stats-placeholder{background:var(--bg-card);border:1px dashed var(--border);border-radius:var(--radius-md);padding:1.5rem;text-align:center;color:var(--text-muted);font-style:italic;font-size:.9rem}.char-count{font-size:.75rem;color:var(--text-muted);text-align:right}.btn-begin-adventure{font-size:1.05rem;padding:1rem 2rem;margin-top:.5rem}.cc-preview{position:sticky;top:1.5rem}.preview-card{background:var(--bg-card);border:1px solid var(--gold-border);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-gold)}.preview-title{font-family:var(--font-heading);font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem}.preview-name{font-family:var(--font-heading);font-size:1.4rem;color:var(--text-primary);margin-bottom:.75rem}.preview-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1rem}.preview-hp{display:flex;align-items:baseline;gap:.5rem;margin-bottom:1rem;padding:.5rem .75rem;background:#8b1a1a26;border:1px solid rgba(192,57,43,.3);border-radius:var(--radius-md)}.hp-label{font-family:var(--font-heading);font-size:.75rem;color:#e05555;letter-spacing:.08em;text-transform:uppercase}.hp-value{font-family:var(--font-heading);font-size:1.2rem;font-weight:700;color:#e05555}.hp-die{font-size:.78rem;color:var(--text-muted)}.preview-stats{display:flex;flex-direction:column;gap:.3rem;margin-bottom:1rem}.preview-stat{display:flex;align-items:center;gap:.5rem;padding:.25rem 0;border-bottom:1px solid var(--border)}.ps-label{font-family:var(--font-heading);font-size:.72rem;letter-spacing:.05em;color:var(--gold);width:32px;flex-shrink:0}.ps-val{font-family:var(--font-heading);font-size:.95rem;font-weight:600;color:var(--text-primary);flex:1}.ps-mod{font-family:monospace;font-size:.82rem;font-weight:700}.ps-mod.pos{color:var(--green-light)}.ps-mod.neg{color:var(--red-light)}.preview-bg{margin-top:.5rem}.preview-bg-label{font-family:var(--font-heading);font-size:.72rem;letter-spacing:.08em;color:var(--text-secondary);text-transform:uppercase;margin-bottom:.3rem}.preview-bg-text{font-style:italic;color:var(--text-muted);font-size:.85rem;line-height:1.5}.preview-empty{color:var(--text-muted);font-style:italic;font-size:.85rem;text-align:center;padding:1rem 0}.lobby-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem 1.5rem;position:relative}.lobby-bg-gradient{position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 50% 20%,rgba(40,30,10,.4) 0%,transparent 60%);pointer-events:none;z-index:-1}.lobby-container{width:100%;max-width:700px;display:flex;flex-direction:column;gap:1.75rem}.lobby-header{text-align:center}.lobby-title-row{display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap}.lobby-title-row h1{font-family:var(--font-title);color:var(--gold-light);text-shadow:0 0 30px rgba(201,168,76,.4)}.lobby-theme{font-style:italic;color:var(--text-secondary);margin-top:.4rem}.room-code-card{background:var(--bg-card);border:1px solid var(--gold-border);border-radius:var(--radius-lg);padding:1.75rem;text-align:center;box-shadow:var(--shadow-gold)}.room-code-label{font-family:var(--font-heading);font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:.5rem}.room-code{font-family:var(--font-heading);font-size:3.5rem;font-weight:700;color:var(--gold-light);letter-spacing:.4em;text-shadow:0 0 20px rgba(201,168,76,.4);margin-bottom:1rem}.room-code-actions{display:flex;justify-content:center;gap:.75rem;flex-wrap:wrap;margin-bottom:.75rem}.room-code-hint{font-size:.82rem;color:var(--text-muted);font-style:italic}.lobby-section-title{font-family:var(--font-heading);font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:.75rem}.player-list{display:flex;flex-direction:column;gap:.6rem}.player-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:.9rem 1.1rem;transition:border-color var(--transition);animation:fadeIn .3s ease both}.player-card.is-you{border-color:#27ae6066;background:#1a5c2a1a}.player-card-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.4rem}.player-name{font-family:var(--font-heading);font-size:1rem;font-weight:600;color:var(--text-primary)}.player-badges{display:flex;gap:.4rem}.player-char-info{display:flex;align-items:center;gap:.6rem}.char-name{font-family:var(--font-heading);font-size:.9rem;color:var(--gold-light)}.char-type{font-size:.8rem;color:var(--text-muted)}.char-bg-preview{font-style:italic;font-size:.82rem;color:var(--text-muted);margin-top:.3rem}.empty-slot{border-style:dashed;opacity:.5}.empty-slot-text{font-style:italic;color:var(--text-muted);font-size:.9rem}.lobby-footer{display:flex;flex-direction:column;align-items:center;gap:1rem}.lobby-host-controls{display:flex;flex-direction:column;align-items:center;gap:.75rem;width:100%}.host-hint{font-size:.9rem;color:var(--text-secondary);font-style:italic;text-align:center}.btn-start{font-size:1rem;padding:.9rem 2.5rem}.waiting-text{font-style:italic;color:var(--text-secondary);text-align:center}.animate-pulse{animation:pulse 2s ease-in-out infinite}.btn-leave{font-size:.85rem}.game-map{display:flex;flex-direction:column;height:100%;overflow:hidden;gap:.4rem}.map-hint-bar{flex-shrink:0;font-size:.7rem;font-family:var(--font-heading);letter-spacing:.05em;text-align:center;padding:.3rem .5rem 0;min-height:1.4rem}.map-hint{color:var(--text-muted)}.map-hint.moving{color:var(--gold-light);animation:pulse 1s ease-in-out infinite}.map-scroll-wrap{flex:1;overflow:auto;padding:.5rem}.map-grid{position:relative;flex-shrink:0}.map-tile{position:absolute;display:flex;align-items:center;justify-content:center;font-size:.75rem;box-sizing:border-box;transition:background .1s}.tile-wall{background:var(--map-wall, #0b0b18);box-shadow:inset 1px 1px #ffffff08,inset -1px -1px #0006}.tile-room,.tile-entrance,.tile-exit,.tile-special{background:var(--map-room, #1e1e32);cursor:default}.tile-room:hover{background:var(--map-room-hover, #232338)}.tile-corridor{background:var(--map-corridor, #141426);box-shadow:inset 0 2px #0000004d,inset 0 -2px #0000004d}.tile-door{background:var(--map-room, #1e1e32);box-shadow:inset 0 0 0 2px #b48c3280;cursor:default}.tile-door:after{content:"";display:block;width:35%;height:75%;background:linear-gradient(135deg,#6b4f10,#c9a84c,#8b6914);border-radius:2px 2px 0 0;box-shadow:0 0 4px #c9a84c66}.tile-pillar{background:var(--map-room, #1e1e32);cursor:default}.tile-pillar:after{content:"";display:block;width:55%;height:55%;background:var(--map-wall, #0b0b18);border-radius:3px;border:1px solid rgba(255,255,255,.08);box-shadow:2px 2px #00000080}.tile-entrance{box-shadow:inset 0 0 10px #27ae6040}.tile-exit{box-shadow:inset 0 0 10px #c9a84c4d}.tile-movable{background:var(--map-movable, rgba(201,168,76,.12))!important;cursor:crosshair;outline:1px solid rgba(201,168,76,.35)}.tile-movable:hover{background:#c9a84c38!important}.tile-emoji{font-size:.72rem;line-height:1;pointer-events:none}.char-token{position:absolute;border-radius:50%;border:2px solid rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-size:.65rem;font-weight:700;color:#0d0a00;transition:left .22s ease,top .22s ease,transform .15s,box-shadow .15s;z-index:10;-webkit-user-select:none;user-select:none;box-shadow:0 2px 6px #000000b3}.token-selected{border-color:#fff!important;transform:scale(1.3)!important;box-shadow:0 0 14px #ffffffb3!important;z-index:20}.token-you:hover{transform:scale(1.12)}.map-legend{flex-shrink:0;padding:.3rem .5rem .5rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.35rem}.map-legend-tokens{display:flex;flex-wrap:wrap;gap:.3rem .6rem}.legend-item{display:flex;align-items:center;gap:.3rem}.legend-dot{width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.58rem;font-weight:700;color:#0d0a00;flex-shrink:0}.legend-name{font-family:var(--font-heading);font-size:.68rem;color:var(--text-secondary)}.legend-you{font-size:.62rem;color:var(--text-muted);font-style:italic}.map-legend-keys{display:flex;gap:.75rem}.legend-key{display:flex;align-items:center;gap:.25rem;font-size:.65rem;color:var(--text-muted);font-family:var(--font-heading)}.key-door{display:inline-block;width:8px;height:12px;background:linear-gradient(135deg,#6b4f10,#c9a84c);border-radius:1px}.theme-dungeon{--map-wall:#0c0c1a;--map-room:#1d1d30;--map-room-hover:#232340;--map-corridor:#131325;--map-movable:rgba(201,168,76,.13)}.theme-dark{--map-wall:#090910;--map-room:#111118;--map-room-hover:#161620;--map-corridor:#0c0c14;--map-movable:rgba(180,50,50,.18)}.theme-void{--map-wall:#050509;--map-room:#0d0d16;--map-room-hover:#111120;--map-corridor:#090912;--map-movable:rgba(100,70,210,.22)}.theme-scifi{--map-wall:#08101a;--map-room:#0e1c28;--map-room-hover:#122030;--map-corridor:#0a1420;--map-movable:rgba(60,200,240,.18)}.theme-steampunk{--map-wall:#140e06;--map-room:#1e1608;--map-room-hover:#26200e;--map-corridor:#181204;--map-movable:rgba(180,130,50,.18)}.theme-western{--map-wall:#1a1208;--map-room:#28200e;--map-room-hover:#302814;--map-corridor:#201a0a;--map-movable:rgba(210,170,80,.18)}.theme-ship{--map-wall:#0a100c;--map-room:#101e14;--map-room-hover:#14261a;--map-corridor:#0c1610;--map-movable:rgba(60,180,130,.18)}.theme-wasteland{--map-wall:#141008;--map-room:#1e1a0c;--map-room-hover:#28220e;--map-corridor:#181406;--map-movable:rgba(150,210,50,.18)}.theme-scifi .tile-corridor{box-shadow:inset 0 1px #3cc8f01f,inset 0 -1px #3cc8f01f}.theme-scifi .tile-door:after{background:linear-gradient(135deg,#0a6080,#40c8f0,#0a6080)}.theme-dark .tile-door:after,.theme-void .tile-door:after{background:linear-gradient(135deg,#4a0808,#c03030,#4a0808);box-shadow:0 0 6px #c8323280}.theme-western .tile-door:after,.theme-ship .tile-door:after{background:linear-gradient(135deg,#5a3010,#9a6030,#5a3010)}.game-page{height:100vh;display:flex;flex-direction:column;overflow:hidden}.game-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem;background:var(--bg-secondary);border-bottom:1px solid var(--border);gap:.75rem;flex-shrink:0;flex-wrap:wrap;min-height:50px}.game-header-left{display:flex;align-items:center;gap:.6rem}.game-logo{font-size:1.3rem}.game-info{display:flex;flex-direction:column;gap:.05rem}.game-genre{font-family:var(--font-heading);font-size:.82rem;font-weight:600;color:var(--gold-light)}.game-theme{font-size:.72rem;font-style:italic;color:var(--text-muted)}.game-header-right{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.ctrl-group{display:flex;gap:2px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:2px}.ctrl-btn{background:none;border:none;cursor:pointer;padding:.28rem .42rem;border-radius:5px;font-size:.92rem;line-height:1;transition:background var(--transition);color:var(--text-muted)}.ctrl-btn:hover{background:var(--bg-card-hover)}.ctrl-btn.active{background:var(--gold-dim);color:var(--gold-light)}.tts-group{display:flex;align-items:center;gap:.4rem}.btn-icon{padding:.32rem .55rem;font-size:1.05rem;line-height:1;border-radius:var(--radius-md)}.btn-icon.tts-on{border-color:var(--gold);background:var(--gold-dim)}.voice-speed-wrap{display:flex;align-items:center;gap:.3rem}.vs-label{font-size:.8rem}.voice-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:80px;height:4px;background:var(--border);border-radius:2px;outline:none;cursor:pointer}.voice-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--gold);cursor:pointer;box-shadow:0 0 4px #c9a84c80}.voice-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--gold);cursor:pointer;border:none}.btn-panel{font-size:.78rem;padding:.35rem .75rem}.btn-panel.active{border-color:var(--gold);background:var(--gold-dim);color:var(--gold-light)}.btn-sm{font-size:.78rem;padding:.35rem .7rem}.room-code-badge{font-family:var(--font-heading);font-size:.78rem;letter-spacing:.1em;color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--border);padding:.28rem .65rem;border-radius:var(--radius-md)}.game-layout{display:flex;flex:1;overflow:hidden}.side-panel{flex-shrink:0;background:var(--bg-secondary);overflow-y:auto;display:flex;flex-direction:column;gap:.65rem}.party-panel{width:260px;border-right:1px solid var(--border);padding:.85rem}.map-panel{width:350px;border-left:1px solid var(--border);padding:0;overflow:hidden}.map-panel-title{padding:.6rem .85rem 0}.panel-title{font-family:var(--font-heading);font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);flex-shrink:0;padding:.75rem .85rem 0}.party-member{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:.75rem;display:flex;flex-direction:column;gap:.45rem;transition:border-color var(--transition)}.party-member:hover{border-color:var(--pc, var(--gold-border))}.pm-header{display:flex;align-items:center;gap:.45rem}.pm-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.pm-names{flex:1;display:flex;flex-direction:column;gap:.05rem}.pm-char{font-family:var(--font-heading);font-size:.88rem;font-weight:600;color:var(--text-primary)}.pm-player{font-size:.7rem;color:var(--text-muted)}.pm-tags{display:flex;gap:.3rem;flex-wrap:wrap}.pm-tag{font-size:.65rem;padding:.1rem .45rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;color:var(--text-secondary);font-family:var(--font-heading)}.pm-hp{display:flex;align-items:center;gap:.35rem}.pm-hp-label{font-family:var(--font-heading);font-size:.6rem;color:#e05555;text-transform:uppercase;width:16px;flex-shrink:0}.pm-hp-track{flex:1;height:4px;background:#ffffff12;border-radius:2px;overflow:hidden}.pm-hp-fill{height:100%;border-radius:2px;transition:width .5s ease}.pm-hp-val{font-family:monospace;font-size:.68rem;color:#e05555;width:32px;text-align:right;flex-shrink:0}.pm-stats{display:grid;grid-template-columns:repeat(6,1fr);gap:2px}.pm-stat{display:flex;flex-direction:column;align-items:center;gap:0;padding:.2rem 0;background:var(--bg-secondary);border-radius:3px}.pm-s-label{font-family:var(--font-heading);font-size:.55rem;color:var(--gold);letter-spacing:.04em}.pm-s-val{font-family:var(--font-heading);font-size:.75rem;font-weight:600;color:var(--text-primary)}.pm-s-mod{font-size:.58rem;font-family:monospace;font-weight:700}.pm-s-mod.pos{color:var(--green-light)}.pm-s-mod.neg{color:var(--red-light)}.pm-bg{font-style:italic;font-size:.72rem;color:var(--text-muted);line-height:1.4}.story-area{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.story-feed{flex:1;overflow-y:auto;padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.9rem;scroll-behavior:smooth}.feed-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:.75rem;color:var(--text-muted);font-style:italic}.feed-empty-icon{font-size:2.5rem;opacity:.4;animation:float 3s ease-in-out infinite}.msg{display:flex;flex-direction:column;gap:.35rem;max-width:860px}.msg-header{display:flex;align-items:center;gap:.45rem;font-size:.75rem}.msg-author{font-family:var(--font-heading);font-size:.8rem;font-weight:600}.msg-time{color:var(--text-muted);font-size:.68rem;margin-left:auto}.msg-body{line-height:1.75;padding:.85rem 1rem;border-radius:var(--radius-md);font-size:.95rem}.dm-icon{font-size:1rem}.dm-author{color:var(--gold-light)}.dm-body{background:linear-gradient(135deg,#1a1408f7,#120e04fc);border:1px solid var(--gold-border);border-left:3px solid var(--gold);color:var(--text-primary);font-family:var(--font-body);font-size:.97rem;white-space:pre-wrap;box-shadow:var(--shadow-sm),inset 0 0 40px #c9a84c08}.btn-speak{background:none;border:none;cursor:pointer;font-size:.9rem;padding:.1rem .3rem;border-radius:4px;opacity:.5;transition:opacity var(--transition),background var(--transition);margin-left:.25rem}.btn-speak:hover{opacity:1;background:var(--bg-card)}.btn-speak.speaking{opacity:1;color:var(--gold);animation:pulse 1s ease-in-out infinite}.player-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.msg-pname{font-size:.72rem;color:var(--text-muted)}.player-body{background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);font-style:italic}.system-msg{flex-direction:row;align-items:center;gap:.5rem;padding:.35rem .75rem;font-size:.78rem;color:var(--text-muted);font-style:italic;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);align-self:center}.warning-msg{flex-direction:row;align-items:flex-start;gap:.5rem;padding:.6rem .9rem;font-size:.85rem;color:#f0c080;background:#78501440;border:1px solid #a07030;border-radius:var(--radius-md);align-self:stretch;max-width:100%}.gameover-msg{flex-direction:column;align-items:center;gap:.5rem;padding:1rem 1.2rem;font-size:.92rem;color:#f0a0a0;background:#460f0f99;border:2px solid #8b1a1a;border-radius:var(--radius-md);align-self:stretch;text-align:center}.gameover-title{font-family:var(--font-heading);font-size:1.15rem;font-weight:700;letter-spacing:.08em;color:#ff8080}.gameover-body{line-height:1.5;font-style:italic}.cursor-blink{display:inline-block;color:var(--gold);animation:pulse .7s ease-in-out infinite;margin-left:1px}.typing-dots{display:flex;align-items:center;gap:5px;padding:.2rem 0}.typing-dots span{display:inline-block;width:7px;height:7px;background:var(--gold);border-radius:50%;animation:typingDot 1.4s ease-in-out infinite}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}.action-bar{flex-shrink:0;padding:.65rem 1rem;background:var(--bg-secondary);border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.35rem}.action-who{display:flex;align-items:center;gap:.5rem;font-family:var(--font-heading);font-size:.75rem}.action-who span:first-child{font-weight:600}.action-class{color:var(--text-muted)}.action-row{display:flex;gap:.5rem;align-items:flex-end}.action-input{flex:1;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-body);font-size:.95rem;padding:.55rem .85rem;resize:none;outline:none;transition:border-color var(--transition);min-height:56px;max-height:110px}.action-input:focus{border-color:var(--gold);box-shadow:0 0 0 2px var(--gold-dim)}.action-input:disabled{opacity:.45;cursor:not-allowed}.action-input::placeholder{color:var(--text-muted);font-style:italic}.btn-act{padding:.55rem 1.1rem;align-self:flex-end;height:56px;flex-direction:column;gap:.15rem;font-size:.8rem}.btn-act span:last-child{font-size:1rem}.action-hint{font-size:.68rem;color:var(--text-muted)}:root{--bg-primary: #080810;--bg-secondary: #0f0f1e;--bg-surface: #141428;--bg-card: #1a1a30;--bg-card-hover: #20203a;--gold: #c9a84c;--gold-light: #e8c97a;--gold-dim: rgba(201, 168, 76, .15);--gold-border: rgba(201, 168, 76, .3);--gold-glow: rgba(201, 168, 76, .15);--red: #8b1a1a;--red-light: #c0392b;--green: #1a5c2a;--green-light: #27ae60;--text-primary: #e8dcc8;--text-secondary: #a09070;--text-muted: #6a5f4a;--text-gold: #c9a84c;--border: rgba(201, 168, 76, .2);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .4);--shadow-md: 0 4px 20px rgba(0, 0, 0, .6);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .8);--shadow-gold: 0 0 20px rgba(201, 168, 76, .2);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--transition: .2s ease;--font-title: "Cinzel Decorative", "Cinzel", serif;--font-heading: "Cinzel", serif;--font-body: "Lora", Georgia, serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%}body{background-color:var(--bg-primary);color:var(--text-primary);font-family:var(--font-body);font-size:16px;line-height:1.6;overflow-x:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(1px 1px at 10% 20%,rgba(255,255,255,.4) 0%,transparent 100%),radial-gradient(1px 1px at 30% 60%,rgba(255,255,255,.3) 0%,transparent 100%),radial-gradient(1px 1px at 50% 10%,rgba(255,255,255,.35) 0%,transparent 100%),radial-gradient(1px 1px at 70% 80%,rgba(255,255,255,.25) 0%,transparent 100%),radial-gradient(1px 1px at 85% 35%,rgba(255,255,255,.4) 0%,transparent 100%),radial-gradient(1px 1px at 15% 75%,rgba(255,255,255,.3) 0%,transparent 100%),radial-gradient(1px 1px at 60% 50%,rgba(255,255,255,.2) 0%,transparent 100%),radial-gradient(1px 1px at 90% 15%,rgba(255,255,255,.35) 0%,transparent 100%),radial-gradient(1px 1px at 45% 90%,rgba(255,255,255,.3) 0%,transparent 100%),radial-gradient(1px 1px at 25% 40%,rgba(255,255,255,.2) 0%,transparent 100%);pointer-events:none;z-index:0}#root{position:relative;z-index:1}h1,h2,h3{font-family:var(--font-heading);font-weight:600;line-height:1.2}h1{font-size:clamp(1.8rem,4vw,3rem)}h2{font-size:clamp(1.3rem,3vw,2rem)}h3{font-size:clamp(1rem,2vw,1.4rem)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--gold-border);border-radius:3px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.7rem 1.6rem;border:1px solid var(--border);border-radius:var(--radius-md);background:transparent;color:var(--text-primary);font-family:var(--font-heading);font-size:.9rem;font-weight:600;letter-spacing:.05em;cursor:pointer;transition:all var(--transition);text-decoration:none}.btn:hover{border-color:var(--gold);color:var(--gold-light);background:var(--gold-dim)}.btn:active{transform:translateY(1px)}.btn-primary{background:linear-gradient(135deg,#8b6914,#c9a84c);border-color:var(--gold);color:#0d0a00;font-weight:700;box-shadow:var(--shadow-gold)}.btn-primary:hover{background:linear-gradient(135deg,#a07a18,#e8c97a);color:#0d0a00;box-shadow:0 0 30px #c9a84c59;transform:translateY(-1px)}.btn-danger{border-color:var(--red-light);color:var(--red-light)}.btn-danger:hover{background:#8b1a1a4d;border-color:var(--red-light);color:#e05555}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.divider{border:none;border-top:1px solid var(--border);margin:1.5rem 0}.gold-text{color:var(--gold);font-family:var(--font-heading)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;transition:all var(--transition)}.card:hover{border-color:var(--gold-border);box-shadow:var(--shadow-gold)}.input{width:100%;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-body);font-size:1rem;padding:.75rem 1rem;transition:border-color var(--transition);outline:none}.input:focus{border-color:var(--gold);box-shadow:0 0 0 2px var(--gold-dim)}.input::placeholder{color:var(--text-muted)}textarea.input{resize:vertical;min-height:80px}.label{display:block;font-family:var(--font-heading);font-size:.8rem;letter-spacing:.08em;color:var(--text-secondary);margin-bottom:.4rem;text-transform:uppercase}.error-msg{background:#8b1a1a33;border:1px solid var(--red-light);border-radius:var(--radius-md);color:#e05555;padding:.75rem 1rem;font-size:.9rem}.badge{display:inline-block;padding:.2rem .6rem;border-radius:20px;font-size:.75rem;font-family:var(--font-heading);letter-spacing:.05em;font-weight:600}.badge-gold{background:var(--gold-dim);border:1px solid var(--gold-border);color:var(--gold-light)}.badge-green{background:#1a5c2a4d;border:1px solid rgba(39,174,96,.4);color:var(--green-light)}.badge-red{background:#8b1a1a4d;border:1px solid rgba(192,57,43,.4);color:#e05555}.page{min-height:100vh;display:flex;flex-direction:column}.page-center{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}@keyframes typingDot{0%,80%,to{transform:scale(0);opacity:.3}40%{transform:scale(1);opacity:1}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.animate-in{animation:fadeIn .4s ease both}.animate-scale{animation:fadeInScale .3s ease both}
