:root{--font-ui: "DM Sans", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;--font-gameplay: "Crimson Pro", "Times New Roman", serif;--fantasy-bg: #0f0d0a;--fantasy-surface: #1a1612;--fantasy-surface-elevated: #231e18;--fantasy-border: #3d352b;--fantasy-border-subtle: #2a2520;--fantasy-text: #e8e0d5;--fantasy-text-muted: #a09888;--fantasy-text-dim: #6b6358;--fantasy-parchment: #2d2620;--fantasy-parchment-border: #4a4035;--fantasy-gold: #c9a227;--fantasy-gold-soft: #e8d48b;--fantasy-magic: #6b4a7a;--fantasy-magic-border: #8b6a9a;--fantasy-roll: #1e3329;--fantasy-roll-border: #2d4a3a;--fantasy-player: #1a2a35;--fantasy-player-border: #2d4a5a;--fantasy-focus: var(--fantasy-gold);--fantasy-link: var(--fantasy-gold-soft);--fantasy-success: #3d6b4a;--fantasy-error: #8b3a3a}html,body{margin:0;min-height:100%;background:var(--fantasy-bg);color:var(--fantasy-text);font-family:var(--font-ui)}#root{min-height:100vh}button,input,textarea{font-family:inherit}.nav{position:sticky;top:0;z-index:10;border-bottom:1px solid var(--fantasy-border);padding:.75rem 1.5rem;background:var(--fantasy-surface);display:flex;align-items:center;flex-wrap:wrap;gap:1rem;box-shadow:0 1px #c9a22714}.nav__link{color:var(--fantasy-text-muted);text-decoration:none;font-weight:500;margin-right:1rem;transition:color .2s}.nav__link:hover{color:var(--fantasy-gold-soft)}.nav__link--active{color:var(--fantasy-gold);font-weight:600}.nav__status{margin-left:auto;display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--fantasy-text-muted)}.nav__status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--fantasy-text-dim);transition:background .2s}.nav__status-dot--connected{background:var(--fantasy-success);box-shadow:0 0 8px #3d6b4a80}.nav__character{color:var(--fantasy-text);max-width:min(280px,45vw);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lobby{min-height:calc(100vh - 60px);padding:2rem 1.5rem 3rem;max-width:960px;margin:0 auto}.lobby__hero{text-align:center;margin-bottom:2.5rem}.lobby__title{font-size:clamp(1.75rem,4vw,2.25rem);font-weight:700;color:var(--fantasy-text);margin:0 0 .5rem;letter-spacing:.02em}.lobby__subtitle{font-size:1rem;color:var(--fantasy-text-muted);margin:0;font-weight:400}.lobby__card{background:var(--fantasy-surface-elevated);border:1px solid var(--fantasy-border);border-radius:8px;padding:1.75rem;margin-bottom:1.5rem;box-shadow:0 2px 8px #0003}.lobby__card-title{font-size:1.1rem;font-weight:600;color:var(--fantasy-gold-soft);margin:0 0 .5rem}.lobby__card-desc{color:var(--fantasy-text-muted);font-size:.95rem;margin:0 0 1.25rem;line-height:1.5}.lobby__card-actions{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.lobby__btn{padding:.6rem 1.25rem;font-size:1rem;font-weight:600;border:none;border-radius:6px;cursor:pointer;transition:transform .15s,box-shadow .15s;font-family:inherit}.lobby__btn--primary{background:linear-gradient(180deg,var(--fantasy-gold) 0%,#a8841f 100%);color:#1a1612}.lobby__btn--primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #c9a22759}.lobby__btn--primary:active:not(:disabled){transform:translateY(0)}.lobby__btn--primary:disabled{background:var(--fantasy-border);color:var(--fantasy-text-dim);cursor:not-allowed;opacity:.8}.lobby__btn--secondary{background:var(--fantasy-surface-elevated);color:var(--fantasy-gold-soft);border:1px solid var(--fantasy-border)}.lobby__btn--secondary:hover{transform:translateY(-1px);box-shadow:0 2px 8px #00000026}.lobby__loading{display:flex;align-items:center;gap:.5rem;padding:1rem 0;font-size:.9rem;color:var(--fantasy-text-muted)}.lobby__loading-icon{flex-shrink:0;animation:lobby-loading-spin 1.2s linear infinite}.lobby__loading-text{animation:lobby-loading-pulse 1.2s ease-in-out infinite}@keyframes lobby-loading-spin{to{transform:rotate(360deg)}}@keyframes lobby-loading-pulse{0%,to{opacity:.7}50%{opacity:1}}.lobby__session-list{list-style:none;margin:0 0 1rem;padding:0}.lobby__session-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 0;border-bottom:1px solid var(--fantasy-border)}.lobby__session-item:last-child{border-bottom:none}.lobby__load-more-sentinel{min-height:1px;pointer-events:none}.lobby__load-more-hint{text-align:center;padding:.5rem 0 0}.lobby__session-meta{font-size:.9rem;color:var(--fantasy-text-muted)}.lobby__hint{font-size:.85rem;color:var(--fantasy-text-dim);margin:0}.lobby__hint--error{color:var(--fantasy-error)}.lobby__character-badge{display:flex;flex-wrap:wrap;align-items:center;gap:.25rem .5rem;padding:.35rem .6rem;background:var(--fantasy-parchment);border:1px solid var(--fantasy-parchment-border);border-radius:6px;font-size:.8rem;color:var(--fantasy-text-muted);margin-top:1rem}.lobby__character-name{flex:0 1 100%;min-width:0}.lobby__character-sep{flex:0 0 auto}.lobby__character-race{flex:0 1 auto;min-width:0}.lobby__character-classes{flex:1 1 55%;min-width:0}.lobby__character-badge strong{color:var(--fantasy-gold-soft)}.play-page{display:flex;flex-direction:column;flex:1;min-height:0;gap:.75rem;background:var(--fantasy-bg);font-family:var(--font-gameplay)}.play-combat-banner{display:flex;align-items:center;gap:1rem;padding:.5rem 1rem;background:linear-gradient(135deg,var(--fantasy-magic) 0%,var(--fantasy-magic-border) 100%);border:1px solid var(--fantasy-magic-border);border-radius:10px;font-size:.9rem;font-weight:600;color:var(--fantasy-text);flex-shrink:0;margin:0 1rem}.play-combat-banner__round{color:var(--fantasy-gold)}.play-combat-banner__turn{flex:1}.play-combat-banner__end-turn{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;padding:.4rem .75rem;font-size:.85rem;font-weight:600;font-family:inherit;color:var(--fantasy-text);background:var(--fantasy-surface-elevated);border:1px solid var(--fantasy-magic-border);border-radius:8px;cursor:pointer;transition:background .15s,border-color .15s}.play-combat-banner__end-turn:hover:not(:disabled){background:var(--fantasy-gold-soft);border-color:var(--fantasy-gold);color:#0f0d0a}.play-combat-banner__end-turn:disabled{opacity:.5;cursor:not-allowed}.play-roll-queue{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:var(--fantasy-roll);border:1px solid var(--fantasy-roll-border);border-radius:12px;flex-shrink:0;margin:1rem}.play-roll-queue__header{display:flex;align-items:center;gap:.5rem;font-weight:600;font-size:.9rem}.play-roll-queue__icon{color:#5a9a6a}.play-roll-queue__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.35rem}.play-roll-queue__item{display:flex;align-items:center;justify-content:space-between;padding:.35rem .5rem;background:#ffffff40;border-radius:6px;font-size:.9rem}.play-roll-queue__remove{background:none;border:none;color:var(--fantasy-text-muted);cursor:pointer;font-size:1.2rem;line-height:1;padding:0 .25rem}.play-roll-queue__remove:hover{color:var(--fantasy-text)}.play-roll-queue__actions{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:.25rem}.play-roll-queue__manual{display:flex;gap:.35rem;align-items:center}.play-roll-queue__input{padding:.4rem .6rem;border:1px solid var(--fantasy-border);border-radius:6px;font-size:.85rem;width:5rem;background:var(--fantasy-surface);color:var(--fantasy-text)}.play-roll-queue__input::placeholder{color:var(--fantasy-text-dim)}.play-roll-queue__add{padding:.4rem .75rem;background:var(--fantasy-surface-elevated);border:1px solid var(--fantasy-border);border-radius:6px;font-size:.85rem;cursor:pointer;color:var(--fantasy-text)}.play-roll-queue__add:hover:not(:disabled){background:var(--fantasy-gold-soft);border-color:var(--fantasy-gold);color:#0f0d0a}.play-roll-queue__add:disabled{opacity:.6;cursor:not-allowed}.play-roll-queue__submit{padding:.5rem 1rem;background:var(--fantasy-gold);color:#0f0d0a;border:none;border-radius:8px;font-weight:600;font-size:.9rem;cursor:pointer}.play-roll-queue__submit:hover:not(:disabled){background:var(--fantasy-gold-soft)}.play-roll-queue__submit:disabled{opacity:.6;cursor:not-allowed}.play-chat-area{flex:1;min-height:0;overflow:auto;display:flex;flex-direction:column;gap:.75rem;padding:1rem;background:linear-gradient(180deg,var(--fantasy-surface) 0%,var(--fantasy-bg) 100%);border:1px solid var(--fantasy-border-subtle);border-radius:0 0 12px 12px;box-shadow:inset 0 1px #c9a2270f}.play-chat-virtuoso-wrap{flex:1;min-height:0;display:flex;flex-direction:column;position:relative}.play-chat-loading-more{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.85rem;color:var(--fantasy-text-muted);justify-content:center}.play-chat-empty{color:var(--fantasy-text-muted);font-size:.95rem;padding:1rem .5rem;text-align:center}@keyframes play-msg-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.play-chat-entry{animation:play-msg-in .3s ease-out;max-width:85%}.play-chat-entry--player{align-self:flex-end}.play-chat-entry--gm,.play-chat-entry--roll-request,.play-chat-entry--roll{align-self:flex-start}.play-bubble{padding:.75rem 1rem;border-radius:14px;font-size:.95rem;line-height:1.5;white-space:pre-wrap;word-break:break-word;border:1px solid;box-shadow:0 2px 8px #0003}.play-bubble-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.4rem;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:var(--fantasy-text-muted)}.play-bubble-header__icon{flex-shrink:0;color:inherit}.play-bubble-header__label{flex:1}.play-bubble-header__time{font-weight:500;font-size:.7rem;opacity:.85}.play-bubble--gm{background:var(--fantasy-parchment);border-color:var(--fantasy-parchment-border);color:var(--fantasy-text)}.play-bubble--gm .play-bubble-header{color:var(--fantasy-gold-soft)}.play-bubble--player{background:var(--fantasy-player);border-color:var(--fantasy-player-border);color:var(--fantasy-text)}.play-bubble--player .play-bubble-header{color:#7eb8d4}.play-bubble--roll-request{background:var(--fantasy-magic);border-color:var(--fantasy-magic-border);color:var(--fantasy-text)}.play-bubble--roll-request .play-bubble-header{color:#c9b0d9}.play-bubble--roll{background:var(--fantasy-roll);border-color:var(--fantasy-roll-border);color:var(--fantasy-text)}.play-bubble--roll .play-bubble-header{color:#8fcc9e}.play-bubble--system{background:var(--fantasy-surface-elevated);border-color:var(--fantasy-border);color:var(--fantasy-text-muted)}.play-bubble-body--formula{font-size:.8rem;font-family:ui-monospace,monospace;opacity:.9;margin-top:.35rem}.play-input-wrap{display:flex;gap:.5rem;align-items:flex-end;flex-shrink:0;padding:.25rem 0;margin:0 1rem}.play-input{flex:1;min-height:56px;max-height:200px;padding:.75rem 1rem;background:var(--fantasy-surface);border:1px solid var(--fantasy-border);border-radius:12px;color:var(--fantasy-text);font-size:1rem;resize:vertical;transition:border-color .2s,box-shadow .2s,opacity .2s}.play-input::placeholder{color:var(--fantasy-text-dim)}.play-input:focus{outline:none;border-color:var(--fantasy-gold);box-shadow:0 0 0 2px #c9a22733}.play-input:disabled{opacity:.6;cursor:not-allowed}.play-send{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;padding:.75rem 1.25rem;background:var(--fantasy-gold);color:#0f0d0a;border:none;border-radius:12px;font-weight:600;font-size:.95rem;cursor:pointer;transition:background .2s,transform .15s,opacity .2s;box-shadow:0 2px 8px #c9a2274d}.play-send:hover:not(:disabled){background:var(--fantasy-gold-soft);transform:translateY(-1px)}.play-send:active:not(:disabled){transform:translateY(0)}.play-send:disabled{background:var(--fantasy-border);color:var(--fantasy-text-dim);cursor:not-allowed;box-shadow:none}@keyframes play-loading-pulse{0%,to{opacity:.6}50%{opacity:1}}@keyframes play-loading-spin{to{transform:rotate(360deg)}}.play-loading{display:flex;align-items:center;gap:.5rem;padding:.6rem 1rem;margin-left:0;align-self:flex-start;background:var(--fantasy-parchment);border:1px solid var(--fantasy-parchment-border);border-radius:12px;font-size:.85rem;color:var(--fantasy-text-muted);animation:play-msg-in .3s ease-out}.play-loading__icon{animation:play-loading-spin 1.2s linear infinite;flex-shrink:0}.play-loading__text{animation:play-loading-pulse 1.2s ease-in-out infinite}.play-chat-area::-webkit-scrollbar{width:8px}.play-chat-area::-webkit-scrollbar-track{background:var(--fantasy-surface);border-radius:4px}.play-chat-area::-webkit-scrollbar-thumb{background:var(--fantasy-border);border-radius:4px}.play-chat-area::-webkit-scrollbar-thumb:hover{background:var(--fantasy-gold)}
