:root{color:#1d1f22;background:#f3f1ea;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,.button-like{align-items:center;background:#1f2a2e;border:1px solid #1f2a2e;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font:inherit;font-weight:700;gap:8px;justify-content:center;min-height:42px;padding:0 14px;text-decoration:none}button:disabled{cursor:not-allowed;opacity:.6}button:hover,.button-like:hover{background:#2c3d42}button.primary{background:#b8472f;border-color:#b8472f}input,select,textarea{background:#fffdf8;border:1px solid #c9c1b2;border-radius:8px;color:#1d1f22;font:inherit;min-height:42px;padding:10px 12px;width:100%}textarea{min-height:120px;resize:vertical}label{color:#4f5457;display:grid;font-size:.86rem;font-weight:700;gap:6px}h1,h2,h3,p{margin:0}.home-shell{display:grid;min-height:100vh;padding:24px;place-items:center}.home-stack{display:grid;gap:18px;max-width:720px;width:100%}.home-board{background:#fffaf0;border:1px solid #d7c6a7;border-radius:8px;box-shadow:0 18px 60px #241f181f;display:grid;gap:22px;max-width:560px;padding:28px;width:100%}.create-board{max-width:720px}.language-board{justify-self:center;max-width:460px}.creator-session-board{justify-self:stretch;max-width:720px}.creator-session-board h2{font-size:1.05rem}.empty-state{color:#697074;font-weight:800}.creator-session-list{display:grid;gap:10px}.creator-session-row{align-items:center;background:#fffdf8;border:1px solid #d6cdbf;border-radius:8px;display:grid;gap:8px;grid-template-columns:minmax(0,1fr) auto;padding:12px}.creator-session-row div{align-items:center;display:flex;flex-wrap:wrap;gap:8px;min-width:0}.creator-session-row strong{overflow-wrap:anywhere}.creator-session-row p,.creator-session-row small{color:#697074;font-size:.88rem;font-weight:800;grid-column:1}.creator-session-row .button-like{grid-column:2;grid-row:1 / span 3}.creator-session-status{border-radius:999px;border:1px solid #b8ad9b;font-size:.78rem;font-weight:900;padding:3px 8px}.creator-session-status.draft{background:#fbf6e9;color:#6f5427}.creator-session-status.running{background:#e7f0dd;color:#355829}.creator-session-status.paused,.creator-session-status.error{background:#ffe6d9;color:#8a351f}.creator-session-status.completed{background:#e5edf2;color:#294b5a}.language-grid{border:0;display:grid;gap:10px;grid-template-columns:1fr 1fr;margin:0;padding:0}.language-grid legend{color:#4f5457;font-size:.86rem;font-weight:900;grid-column:1 / -1;margin-bottom:6px}.language-grid label{align-items:center;background:#fffdf8;border:1px solid #c9c1b2;border-radius:8px;color:#1f2a2e;cursor:pointer;display:flex;font-size:1rem;justify-content:center;min-height:54px}.language-grid label.selected{background:#eaf2f3;border-color:#2c7280}.language-grid input{height:16px;min-height:0;width:16px}.brand-row{align-items:center;color:#1f2a2e;display:inline-flex;font-size:2.2rem;font-weight:900;gap:10px;letter-spacing:0;text-decoration:none}.brand-row.small{font-size:1.1rem}.join-line{display:grid;gap:10px;grid-template-columns:1fr auto}.admin-link{align-items:center;color:#5f402f;display:inline-flex;font-weight:800;gap:8px;text-decoration:none}.admin-shell,.session-shell{min-height:100vh;padding:18px}.session-shell{height:100vh;overflow:hidden}.session-shell.has-table-background{--table-ui-surface: rgb(255 253 248 / 25%);--table-ui-warm-surface: rgb(255 246 239 / 25%);--table-ui-cool-surface: rgb(240 248 249 / 25%);--table-ui-muted-surface: rgb(251 246 233 / 25%);--table-ui-dark-surface: rgb(31 42 46 / 25%);--table-ui-border: rgb(255 255 255 / 48%);--table-ui-shadow: 0 18px 60px rgb(0 0 0 / 24%);--table-ui-backdrop: blur(10px) saturate(115%);background-image:linear-gradient(#13171861,#13171847),var(--table-background-image);background-position:center;background-size:cover}.session-shell.has-table-background .brand-row.small{-webkit-backdrop-filter:var(--table-ui-backdrop);backdrop-filter:var(--table-ui-backdrop);background:var(--table-ui-surface);border:1px solid var(--table-ui-border);border-radius:8px;padding:8px 12px}.session-shell.has-table-background input,.session-shell.has-table-background select,.session-shell.has-table-background textarea{background:var(--table-ui-surface);border-color:var(--table-ui-border)}.session-shell.has-table-background button,.session-shell.has-table-background .button-like{background:var(--table-ui-dark-surface);border-color:var(--table-ui-border)}.session-shell.has-table-background button:hover,.session-shell.has-table-background .button-like:hover{background:#2c3d4240}.session-shell.has-table-background button.primary{background:#b8472f40;border-color:#b8472fb3}.topbar{align-items:center;display:flex;justify-content:space-between;margin:0 auto 18px;max-width:1280px}.admin-grid{display:grid;gap:18px;grid-template-columns:minmax(280px,.8fr) minmax(320px,1.2fr);margin:0 auto;max-width:1280px}.panel{background:#fffdf8;border:1px solid #d6cdbf;border-radius:8px;display:grid;gap:14px;padding:18px}.create-panel{grid-template-columns:1fr 160px}.create-panel h2,.create-panel .wide,.create-panel button{grid-column:1 / -1}.button-row,.session-actions{display:flex;flex-wrap:wrap;gap:10px}.state,.error{border-radius:8px;font-weight:800;padding:10px 12px}.state.ok{background:#e5f3e5;color:#24502a}.state.warn,.error{background:#fff0df;color:#8a351f}.login-box{background:#f5efe1;border:1px solid #d9c8aa;border-radius:8px;display:grid;gap:10px;padding:12px}.login-box.compact{padding:10px}.login-box a{color:#1d5362;overflow-wrap:anywhere}.codex-auth-panel{align-items:stretch}.codex-auth-panel p,.codex-auth-panel ol,.codex-auth-panel small{color:#4f5457;font-weight:800}.codex-auth-panel ol{margin:0;padding-left:20px}.codex-auth-panel strong a{color:#1d5362}.codex-auth-approved-row{align-items:center;display:grid;gap:10px;grid-template-columns:minmax(0,1fr) auto}.codex-auth-approved-status{color:#4f5457;font-weight:800;min-width:0}.codex-auth-approved-row button{min-height:36px;padding:0 12px;white-space:nowrap}.device-code-box{border-top:1px solid #d9c8aa;display:grid;gap:8px;padding-top:10px}.session-list{display:grid;gap:12px;margin:18px auto 0;max-width:1280px}.session-item{align-items:center;background:#fffdf8;border:1px solid #d6cdbf;border-radius:8px;display:flex;gap:12px;justify-content:space-between;padding:14px}.session-item p{color:#697074;font-size:.92rem}.session-top{background:#fffdf8;border:1px solid #d6cdbf;border-bottom:2px solid #b8ad9b;border-radius:8px;box-shadow:0 10px 30px #241f181a;gap:12px;max-width:1500px;padding:10px 12px;position:relative;z-index:20}.session-top-left{align-items:center;display:flex;flex:1;gap:12px;min-width:0}.session-title-card{align-items:center;background:#fffdf8;border:1px solid #d6cdbf;border-radius:8px;color:#1f2a2e;display:flex;flex:1;gap:0;min-height:42px;min-width:0;padding:0;position:relative}.session-title-card h1{align-items:center;align-self:stretch;display:flex;flex:1;font-size:1.08rem;line-height:1.2;min-width:0;overflow:hidden;padding:0 14px;text-overflow:ellipsis;white-space:nowrap}.title-menu-toggle{align-items:center;align-self:stretch;background:transparent;border:0;border-radius:0;border-right:1px solid #d6cdbf;display:inline-flex;flex:0 0 42px;height:auto;justify-content:center;min-height:40px;padding:0}.title-menu-toggle:hover{background:#eef4f1}.session-shell.has-table-background .session-top{-webkit-backdrop-filter:var(--table-ui-backdrop);backdrop-filter:var(--table-ui-backdrop);background:var(--table-ui-surface);border-color:var(--table-ui-border);border-bottom-color:#ffffff94;box-shadow:var(--table-ui-shadow)}.session-shell.has-table-background .session-title-card{-webkit-backdrop-filter:var(--table-ui-backdrop);backdrop-filter:var(--table-ui-backdrop);background:var(--table-ui-surface);border-color:var(--table-ui-border)}.session-shell.has-table-background .session-title-card .title-menu-toggle{background:transparent;border-color:var(--table-ui-border)}.session-shell.has-table-background .session-title-card .title-menu-toggle:hover{background:#1f2a2e1f}.session-top-status{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}.spectator-pill{align-items:center;background:#fffdf8;border:1px solid #d6cdbf;border-radius:8px;color:#1f2a2e;display:inline-flex;gap:8px;min-height:38px;padding:8px 12px}.spectator-pill span{color:#566064;font-size:.85rem;font-weight:900}.spectator-pill strong{font-size:1rem}.session-shell.has-table-background .spectator-pill{background:var(--table-ui-surface);border-color:var(--table-ui-border)}.status-pill{border-radius:8px;border:1px solid #b8ad9b;font-weight:900;min-width:104px;padding:8px 12px;text-align:center}.status-pill.running{background:#e7f0dd;color:#355829}.status-pill.draft{background:#fbf6e9;color:#6f5427}.status-pill.paused,.status-pill.error{background:#ffe6d9;color:#8a351f}.status-pill.completed{background:#e5edf2;color:#294b5a}.session-shell.has-table-background .status-pill.running{background:#e7f0dd40;border-color:var(--table-ui-border)}.session-shell.has-table-background .status-pill.draft{background:var(--table-ui-muted-surface);border-color:var(--table-ui-border)}.session-shell.has-table-background .status-pill.paused,.session-shell.has-table-background .status-pill.error{background:#ffe6d940;border-color:var(--table-ui-border)}.session-shell.has-table-background .status-pill.completed{background:#e5edf240;border-color:var(--table-ui-border)}.table-layout{align-items:stretch;display:grid;gap:18px;grid-template-columns:minmax(280px,340px) minmax(0,1fr);height:calc(100vh - 92px);margin:0 auto;max-width:1500px}.roster,.log-panel{background:#fffdf8;border:1px solid #d6cdbf;border-radius:8px}.session-shell.has-table-background .roster,.session-shell.has-table-background .log-panel{-webkit-backdrop-filter:var(--table-ui-backdrop);backdrop-filter:var(--table-ui-backdrop);background:var(--table-ui-surface);border-color:var(--table-ui-border);box-shadow:var(--table-ui-shadow)}.roster{align-self:start;display:grid;gap:16px;max-height:100%;min-height:0;overflow:auto;padding:18px}.round-box{align-items:center;background:#1f2a2e;border-radius:8px;color:#fff;display:grid;grid-template-columns:1fr auto auto;min-height:68px;padding:12px}.round-box span,.round-box em{color:#d8e1df;font-style:normal;font-weight:800}.round-box strong{font-size:2rem;line-height:1;padding:0 12px}.top-round-box{align-self:stretch;background:transparent;border-left:1px solid #d6cdbf;border-radius:0;color:#1f2a2e;flex:0 0 auto;gap:6px;grid-template-columns:auto auto auto;min-height:40px;padding:0 12px}.top-round-box span,.top-round-box em{color:#566064;font-size:.75rem}.top-round-box strong{font-size:1.15rem;padding:0 4px}.session-shell.has-table-background .top-round-box{background:transparent;border-color:var(--table-ui-border);color:#1f2a2e}.seat-grid{display:grid;gap:10px}.seat{align-items:center;background:#fffdf8;border:1px solid #d6cdbf;border-radius:8px;display:grid;gap:8px;grid-template-columns:auto 1fr auto;min-height:48px;padding:10px}.seat-avatar{align-items:center;background:#eef4f1;border:1px solid #c9d5d2;border-radius:50%;display:inline-flex;height:34px;justify-content:center;overflow:hidden;width:34px}.seat-avatar img{height:100%;object-fit:cover;object-position:top center;width:100%}.seat.human{background:#eaf2f3;border-color:#a8c4c9}.seat.ai{background:#fffdf8}.seat.selectable{color:#1d1f22;cursor:pointer;font-weight:inherit;justify-content:stretch;text-align:left;width:100%}.seat.selectable:hover{border-color:#2c7280;box-shadow:inset 0 0 0 1px #2c7280}.seat.selected{background:#eaf2f3;border-color:#2c7280;box-shadow:inset 0 0 0 2px #2c7280}.seat small{color:#6d7478;font-weight:900}.seat em{color:#566064;font-size:.82rem;font-style:normal;font-weight:700;grid-column:2 / -1;overflow-wrap:anywhere}.join-form,.character-name-form{display:grid;gap:10px}.join-form{align-items:center;grid-template-columns:minmax(0,1fr) auto}.join-form input{min-width:0}.join-form small{grid-column:1 / -1}.character-profile-form textarea{min-height:96px}.choice-panel,.creator-panel{background:#fffdf8;border:1px solid #d6cdbf;border-radius:8px;display:grid;gap:10px;padding:12px}.creator-panel small{color:#566064;font-weight:800}.creator-panel-header{align-items:center;display:flex;gap:10px;justify-content:space-between}.creator-dropdown{left:0;max-height:calc(100vh - 120px);overflow:auto;position:absolute;top:calc(100% + 8px);width:min(340px,calc(100vw - 36px));z-index:40}.icon-toggle{border-radius:8px;font-size:1rem;min-height:32px;min-width:36px;padding:0}.creator-number-setting{align-items:center;background:#fffdf8;border:1px solid #d6cdbf;border-radius:8px;display:grid;gap:8px;grid-template-columns:minmax(0,1fr) 92px;padding:10px}.creator-number-setting span{color:#4f5457;font-size:.86rem;font-weight:800;min-width:0}.creator-number-setting input{min-width:0;text-align:right}.session-shell.has-table-background .creator-number-setting{-webkit-backdrop-filter:var(--table-ui-backdrop);backdrop-filter:var(--table-ui-backdrop);background:var(--table-ui-surface);border-color:var(--table-ui-border)}.log-panel{display:grid;grid-template-rows:auto minmax(0,1fr) auto;height:100%;min-height:0;overflow:hidden}.log-panel.has-background{background:var(--table-ui-surface)}.setup-panel,.waiting-panel{align-content:start;display:grid;gap:14px;grid-row:1 / -1;padding:18px}.log-panel.has-background .setup-panel,.log-panel.has-background .waiting-panel{background:var(--table-ui-surface)}.session-shell.has-table-background .waiting-summary>section,.session-shell.has-table-background .cast-card,.session-shell.has-table-background .seat-avatar,.session-shell.has-table-background .cast-portrait{-webkit-backdrop-filter:var(--table-ui-backdrop);backdrop-filter:var(--table-ui-backdrop);background:var(--table-ui-surface);border-color:var(--table-ui-border)}.setup-panel textarea{min-height:280px}.waiting-panel{color:#4d5559}.waiting-panel strong{color:#1f2a2e;font-size:1.25rem}.waiting-summary{display:grid;gap:14px;width:100%}.waiting-summary>section{background:#fffdf8;border:1px solid #d6cdbf;border-radius:8px;display:grid;gap:10px;padding:12px;width:100%}.waiting-summary strong{color:#1f2a2e}.waiting-summary p{color:#3f484c;overflow-wrap:anywhere}.cast-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.cast-card{align-items:center;background:#fffaf0;border:1px solid #d6cdbf;border-radius:8px;display:grid;gap:10px;grid-template-columns:58px minmax(0,1fr);min-height:74px;padding:10px}.cast-card span{color:#1f2a2e;display:block;font-weight:900;overflow-wrap:anywhere}.cast-card p{color:#566064;font-size:.82rem;font-weight:700}.cast-portrait{align-items:center;background:#eef4f1;border:1px solid #c9d5d2;border-radius:8px;display:inline-flex;height:58px;justify-content:center;overflow:hidden;width:58px}.cast-portrait img{height:100%;object-fit:cover;object-position:top center;width:100%}.world-state{background:#fffdf8;border-bottom:1px solid #d6cdbf;display:grid;gap:4px;padding:14px 16px}.world-state span{color:#6d7478;font-size:.78rem;font-weight:900;text-transform:uppercase}.voice-panel{align-items:center;background:#fffdf8;border:1px solid #d6cdbf;border-radius:8px;display:grid;gap:10px;grid-template-columns:1fr auto;padding:12px}.top-voice-panel{display:inline-flex;position:relative}.voice-control-group{align-items:center;background:#fffdf8;border:1px solid #d6cdbf;border-radius:8px;display:inline-flex;min-height:42px;overflow:hidden}.voice-control-group button{background:transparent;border:0;border-radius:0;color:#1f2a2e;min-height:40px}.voice-control-group button:hover{background:#eef4f1}.voice-control-group button+button{border-left:1px solid #d6cdbf}.voice-menu-toggle{min-width:42px;padding:0;white-space:nowrap}.voice-play-button{padding:0 12px}.session-shell.has-table-background .voice-control-group{-webkit-backdrop-filter:var(--table-ui-backdrop);backdrop-filter:var(--table-ui-backdrop);background:var(--table-ui-surface);border-color:var(--table-ui-border)}.session-shell.has-table-background .voice-control-group button{background:transparent;border-color:var(--table-ui-border)}.session-shell.has-table-background .voice-control-group button:hover{background:#1f2a2e1f}.voice-dropdown{background:#fffdf8;border:1px solid #d6cdbf;border-radius:8px;box-shadow:0 18px 60px #10121433;display:grid;gap:10px;padding:12px;position:absolute;right:0;top:calc(100% + 8px);width:min(360px,calc(100vw - 36px));z-index:30}.session-shell.has-table-background .voice-dropdown{-webkit-backdrop-filter:var(--table-ui-backdrop);backdrop-filter:var(--table-ui-backdrop);background:var(--table-ui-surface);border-color:var(--table-ui-border)}.voice-panel small{color:#6d7478;font-weight:800;grid-column:1 / -1}.voice-panel-header{align-items:center;display:flex;gap:10px;grid-column:1 / -1;justify-content:space-between}.voice-panel-actions{display:flex;flex-shrink:0;gap:8px}.voice-toggle{align-items:center;color:#1f2a2e;display:inline-flex;font-size:.92rem;gap:8px}.voice-toggle input{height:18px;min-height:0;width:18px}.voice-settings{display:grid;gap:8px;grid-column:1 / -1;grid-template-columns:1fr}.voice-setting-row{align-items:center;display:grid;gap:8px;grid-template-columns:44px minmax(0,1fr) 52px}.voice-setting-row span{color:#1f2a2e;font-weight:900}.voice-setting-row strong{color:#1f2a2e;font-size:.92rem;text-align:right}.voice-setting-row input[type=range]{width:100%;min-height:28px;padding:0}.message-list{display:grid;gap:10px;min-height:0;overflow:auto;padding:16px}.log-panel.has-background .message-list{background:var(--table-ui-surface)}.session-shell.has-table-background .choice-panel,.session-shell.has-table-background .creator-panel,.session-shell.has-table-background .voice-panel,.session-shell.has-table-background .seat,.session-shell.has-table-background .world-state,.session-shell.has-table-background .action-bar{-webkit-backdrop-filter:var(--table-ui-backdrop);backdrop-filter:var(--table-ui-backdrop);background:var(--table-ui-surface);border-color:var(--table-ui-border)}.session-shell.has-table-background .round-box{background:var(--table-ui-dark-surface)}.session-shell.has-table-background .message.gm{-webkit-backdrop-filter:var(--table-ui-backdrop);backdrop-filter:var(--table-ui-backdrop);border-color:var(--table-ui-border);border-left-color:#b8472f;background:var(--table-ui-warm-surface)}.session-shell.has-table-background .message.player{-webkit-backdrop-filter:var(--table-ui-backdrop);backdrop-filter:var(--table-ui-backdrop);border-color:var(--table-ui-border);border-left-color:#2c7280;background:var(--table-ui-cool-surface)}.session-shell.has-table-background .message.dice{-webkit-backdrop-filter:var(--table-ui-backdrop);backdrop-filter:var(--table-ui-backdrop);border-color:var(--table-ui-border);border-left-color:#8c6b2f;background:var(--table-ui-muted-surface)}.session-shell.has-table-background .message.dice span{background:#8c6b2f2e;border-color:#ffffff5c}.session-shell.has-table-background .message.system{-webkit-backdrop-filter:var(--table-ui-backdrop);backdrop-filter:var(--table-ui-backdrop);border-color:var(--table-ui-border);border-left-color:#6d7478;background:var(--table-ui-surface)}.message{background:#fffdf8;border:1px solid #d6cdbf;border-left:4px solid #b8ad9b;border-radius:8px;display:grid;gap:6px;padding:10px 12px}.message span{color:#566064;font-size:.82rem;font-weight:900}.message.gm{border-left-color:#b8472f;background:#fff6ef}.message.player{border-left-color:#2c7280;background:#f0f8f9}.message.dice{align-items:center;border-left-color:#8c6b2f;background:#fbf6e9;display:grid;gap:8px;grid-template-columns:auto minmax(0,1fr);min-height:34px;padding:6px 10px}.message.dice span{background:#8c6b2f1f;border:1px solid rgb(140 107 47 / 28%);border-radius:999px;color:#6f5427;font-size:.72rem;line-height:1;min-width:42px;padding:4px 8px;text-align:center}.message.dice p{font-weight:800;line-height:1.3;overflow-wrap:anywhere}.message.system{border-left-color:#6d7478;background:#fffdf8;color:#4d5559}.action-bar{background:#fffdf8;border-top:1px solid #d6cdbf;display:grid;gap:10px;grid-template-columns:minmax(0,1fr) auto auto auto;padding:12px}.action-input{display:grid;gap:6px;min-width:0}.action-bar textarea{height:64px;max-height:64px;min-height:64px;resize:none}.action-input small{color:#6d7478;font-weight:800}.voice-input.active{background:#2c7280;border-color:#2c7280}@media(max-width:860px){.admin-grid,.table-layout,.create-panel,.join-line,.creator-session-row,.action-bar,.voice-panel,.voice-settings{grid-template-columns:1fr}.creator-session-row .button-like{grid-column:1;grid-row:auto}.voice-panel-header{align-items:stretch;flex-direction:column}.voice-panel-actions{justify-content:stretch}.voice-panel-actions button:not(.icon-toggle){flex:1}.session-top,.session-top-left{align-items:stretch;flex-direction:column}.session-top-status{align-items:stretch;justify-content:flex-start}.top-voice-panel,.spectator-pill,.status-pill,.voice-control-group{width:100%}.voice-play-button{flex:1}.voice-dropdown{position:static;width:100%}.creator-dropdown{max-height:none;position:static;width:100%}.session-title-card{align-items:stretch;flex-wrap:wrap}.session-title-card h1{flex-basis:calc(100% - 44px);white-space:normal}.top-round-box{border-left:0;border-top:1px solid #d6cdbf;width:100%}.session-shell{height:auto;overflow:visible}.table-layout{height:auto}.roster{max-height:none;overflow:visible}.session-item{align-items:stretch;flex-direction:column}.log-panel{height:auto;min-height:auto;overflow:visible}.message-list{max-height:55vh;min-height:280px}}
