:root{color-scheme:dark;font-family:Inter,Pretendard,Segoe UI,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;background:#070a12;color:#e8edf3;font-synthesis:none;text-rendering:optimizeLegibility;--ink: #e8edf3;--muted: #9aa8b8;--faint: #6f7d8f;--panel: #101622;--panel-2: #151b27;--panel-3: #1c2431;--line: #263449;--cyan: #78d9ff;--teal: #3fbda4;--gold: #d9a441;--violet: #aa85ff;--red: #e86878;--green: #80c76f;--shadow: 0 24px 70px rgba(0, 0, 0, .42)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:linear-gradient(180deg,#131923d1,#070a12),repeating-linear-gradient(90deg,rgba(255,255,255,.015) 0 1px,transparent 1px 80px),#070a12}button,input,select{font:inherit}button{border:1px solid var(--line);color:var(--ink);background:#121b29;cursor:pointer;transition:border-color .16s ease,background .16s ease,transform .16s ease}button:hover:not(:disabled){border-color:var(--cyan);background:#172638}button:active:not(:disabled){transform:translateY(1px)}button:disabled{cursor:not-allowed;opacity:.58}input,select{width:100%;min-height:46px;border:1px solid var(--line);border-radius:8px;background:#0b111d;color:var(--ink);padding:0 14px;outline:none}input:focus,select:focus{border-color:var(--cyan);box-shadow:0 0 0 3px #78d9ff1f}label{display:block;color:#c6d0dc;font-size:13px;margin-bottom:8px}.login-page{min-height:100vh;display:grid;place-items:center;padding:36px 18px;background:linear-gradient(90deg,rgba(120,217,255,.06),transparent 30%,rgba(217,164,65,.05)),#070a12}.login-shell{width:min(430px,100%);text-align:center}.brand-mark{width:64px;height:64px;margin:0 auto 18px;border:1px solid var(--line);border-radius:8px;display:grid;place-items:center;color:var(--cyan);background:#0d1421}.brand-mark svg{width:34px;height:34px}.login-shell h1{margin:0 0 8px;font-size:32px;letter-spacing:0}.login-shell p{margin:0 0 30px;color:var(--muted)}.login-card{text-align:left;border:1px solid var(--line);border-radius:8px;padding:30px;background:#101622f0;box-shadow:var(--shadow)}.login-card button,.primary,.ghost,.action-row button,.room-card button{min-height:46px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 16px}.login-card>button,.primary{width:100%;margin-top:18px;border-color:#78d9ff85;color:#d9f7ff;background:#1b4557}.primary.small{width:auto;margin-top:0}.login-divider{display:grid;grid-template-columns:1fr auto 1fr;gap:12px;align-items:center;margin:24px 0;color:var(--faint);font-size:12px}.login-divider span{height:1px;background:var(--line)}.social-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.social-row button{width:100%}.form-error,.panel-error{color:#ffd0d5;background:#e868781f;border:1px solid rgba(232,104,120,.34);border-radius:8px;padding:12px;margin:14px 0 0}.app-shell{min-height:100vh;display:grid;grid-template-columns:280px minmax(0,1fr)}.sidebar{border-right:1px solid var(--line);background:#080c14f0;padding:24px 16px;display:flex;flex-direction:column;gap:22px}.sidebar-brand{display:flex;align-items:center;gap:10px;color:var(--cyan);font-size:20px;font-weight:800}.profile{display:flex;align-items:center;gap:12px;padding:14px;border:1px solid var(--line);border-radius:8px;background:#0f1725}.profile strong,.profile span{display:block}.profile span,.topbar span,.party-member span,.initiative-item span,.character-summary span{color:var(--muted);font-size:13px}.portrait,.avatar{width:44px;height:44px;border-radius:8px;display:grid;place-items:center;color:#071018;background:var(--cyan);font-weight:800}.portrait.mini{width:36px;height:36px;font-size:14px}.side-nav{display:grid;gap:8px}.side-nav button,.logout-button{min-height:46px;border-radius:8px;padding:0 14px;display:flex;align-items:center;gap:10px;text-align:left}.side-nav button.active{border-color:#78d9ff8c;color:var(--cyan);background:#17344a}.logout-button{margin-top:auto;color:#c4ccd7}.workspace{min-width:0;display:grid;grid-template-rows:72px minmax(0,1fr)}.topbar{border-bottom:1px solid var(--line);background:#090e17e6;padding:0 32px;display:flex;align-items:center;justify-content:space-between;gap:24px}.topbar strong,.topbar span{display:block}.topbar-right{display:flex;align-items:center;gap:14px}.status{min-width:104px;border:1px solid var(--line);border-radius:999px;padding:8px 12px;text-align:center}.status.online{border-color:#80c76f94;color:#cff6c4;background:#80c76f1a}.content-grid{min-height:0;padding:32px;display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:24px}.lobby-main{min-width:0}.page-title{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:26px}.eyebrow{display:block;color:var(--cyan);font-size:13px;font-weight:700;margin-bottom:8px}.page-title h2,.scene-header h2{margin:0;font-size:clamp(26px,3vw,40px);letter-spacing:0}.featured-room{min-height:260px;border:1px solid var(--line);border-radius:8px;padding:32px;display:flex;align-items:flex-end;justify-content:space-between;gap:24px;background:linear-gradient(90deg,#0b111deb 0,#0b111deb 46%,#0b111d73),repeating-linear-gradient(135deg,rgba(120,217,255,.08) 0 2px,transparent 2px 22px),#29323d}.badge{display:inline-flex;align-items:center;min-height:28px;padding:0 12px;border-radius:999px;color:#f1dcad;background:#d9a44129;border:1px solid rgba(217,164,65,.34)}.featured-room h3{margin:20px 0 10px;font-size:clamp(28px,4vw,46px);letter-spacing:0}.featured-room p,.room-card p,.scene-text p,.log-entry p{color:#b6c2cf;line-height:1.7}.meta-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}.meta-row span,.round-pill{border:1px solid var(--line);border-radius:999px;padding:8px 12px;color:#c9d4df;background:#101622cc}.ghost{color:var(--cyan);background:#1b4557b8}.room-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;margin-top:24px}.room-card,.action-card,.log-panel,.initiative-panel,.scene-text,.party-strip{border:1px solid var(--line);border-radius:8px;background:#101622f0}.room-card{min-height:220px;padding:22px;display:flex;flex-direction:column}.room-top{display:flex;justify-content:space-between;color:var(--muted)}.room-top strong{color:var(--gold)}.room-card h3,.action-card h3,.scene-text h3,.initiative-panel h2{margin:14px 0 8px;letter-spacing:0}.room-card button{margin-top:auto;width:fit-content;color:var(--cyan)}.control-panel{min-width:0;display:grid;align-content:start;gap:16px}.action-card{padding:18px}.action-card h3{margin-top:0}.action-card input,.action-card select{margin-bottom:14px}.form-pair{display:grid;grid-template-columns:1fr 1fr;gap:12px}.character-summary{display:grid;gap:6px;padding:14px;border:1px solid var(--line);border-radius:8px;background:#0c1220}.log-panel{min-height:0;overflow:hidden}.log-panel.compact{max-height:320px}.log-tabs{min-height:54px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 18px}.log-tabs span{color:var(--cyan)}.log-list{max-height:100%;overflow:auto;padding:14px;display:grid;gap:12px}.log-entry{border:1px solid var(--line);border-radius:8px;padding:14px;background:#0d1421}.log-entry.socket{border-color:#78d9ff59}.log-entry.rest{border-color:#80c76f59}.log-entry.action{border-color:#d9a44161}.log-entry>div{display:flex;justify-content:space-between;gap:12px;color:#d9e2eb}.log-entry time{color:var(--faint);font-size:12px}.log-entry p{margin:8px 0 0;font-size:14px}.empty-text{color:var(--muted);line-height:1.6}.play-layout{min-height:0;padding:28px;display:grid;grid-template-columns:290px minmax(0,1fr) 340px;gap:18px}.initiative-panel{padding:18px}.initiative-list{display:grid;gap:12px}.initiative-item{min-height:62px;border:1px solid var(--line);border-radius:8px;background:#0c1320;padding:10px;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:10px}.initiative-item b{color:var(--gold)}.scene-panel{min-width:0;min-height:0;display:grid;grid-template-rows:auto minmax(320px,1fr) auto;gap:16px}.scene-header{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}.battle-map{min-height:360px;border:1px solid var(--line);border-radius:8px;position:relative;overflow:hidden;background:#111722}.battle-map svg{width:100%;height:100%;display:block}.battle-map rect{fill:#17202c}.battle-map path{fill:none;stroke:#e8edf31f;stroke-width:3}.battle-map g path{fill:#e8edf31a;stroke:#e8edf31f;stroke-width:2}.battle-map line{stroke:var(--cyan);stroke-width:2;stroke-dasharray:8 8}.battle-map text{fill:var(--cyan);font-size:18px}.map-token{position:absolute;width:42px;height:42px;border:2px solid var(--cyan);border-radius:999px;display:grid;place-items:center;color:#061017;font-weight:900;box-shadow:0 10px 24px #0006}.map-token.hostile{right:28%;top:34%;border-color:var(--red);color:#fff0f2;background:#55202b}.tone-1{background:var(--cyan)}.tone-2{background:var(--violet)}.tone-3{background:var(--gold)}.tone-4{background:var(--green)}.scene-bottom{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(220px,.8fr);gap:16px}.scene-text,.party-strip{padding:18px}.action-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}.action-row button{color:#d9f7ff}.party-strip{display:grid;gap:10px}.party-member{border-bottom:1px solid var(--line);padding-bottom:10px}.party-member strong{display:block}.log-dock{min-height:0;display:grid}.login-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:20px;background:#101622f0;border:1px solid var(--line);border-radius:8px;padding:6px}.login-tabs button{border:1px solid transparent;background:transparent;border-radius:6px;min-height:38px;color:var(--muted);margin-top:0;width:100%}.login-tabs button.active{background:#17344a;color:var(--cyan);border-color:#78d9ff8c}.login-card label{margin-top:16px;display:block}.login-card label:first-of-type{margin-top:0}@media (max-width: 1180px){.app-shell{grid-template-columns:88px minmax(0,1fr)}.sidebar{align-items:center}.sidebar-brand span,.profile div,.side-nav button:not(.active),.logout-button{font-size:0}.side-nav button,.logout-button{width:52px;justify-content:center;padding:0}.content-grid,.play-layout,.room-list{grid-template-columns:1fr}}@media (max-width: 760px){.app-shell{grid-template-columns:1fr}.sidebar{position:static;min-height:auto;flex-direction:row;border-right:0;border-bottom:1px solid var(--line);overflow-x:auto}.workspace{grid-template-rows:auto minmax(0,1fr)}.topbar{padding:16px;align-items:flex-start}.content-grid,.play-layout{padding:16px}.featured-room,.page-title,.scene-header,.scene-bottom{display:block}.featured-room .ghost,.primary.small{width:100%;margin-top:16px}.form-pair,.social-row{grid-template-columns:1fr}}.app-shell-topnav{grid-template-columns:1fr;grid-template-rows:auto minmax(0,1fr)}.app-shell-session{grid-template-columns:1fr}.workspace-topnav{min-height:100vh;grid-template-rows:minmax(0,1fr)}.workspace-session{grid-template-rows:minmax(0,1fr)}.topbar-shell{position:sticky;top:0;z-index:20;padding:12px 16px;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.topbar-left,.topbar-brand{display:flex;align-items:center;gap:12px}.topbar-left{min-width:0;flex:1}.topbar-brand{color:var(--cyan)}.topbar-brand strong{display:block}.topbar-brand span{display:block;color:var(--faint);font-size:12px}.top-nav{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.top-nav button{min-height:40px;padding:0 14px;border-radius:999px}.top-nav button.active{border-color:#78d9ff8c;color:var(--cyan);background:#17344a}.status-pill{min-width:104px;border:1px solid var(--line);border-radius:999px;padding:8px 12px;text-align:center}.status-pill.online{border-color:#80c76f94;color:#cff6c4;background:#80c76f1a}.page-with-sidebar{min-height:0;padding:20px 16px 24px;display:grid;grid-template-columns:204px minmax(0,1fr) 320px;gap:16px}.page-sidebar{display:grid;align-content:start;gap:12px}.page-sidebar-block,.sidebar-status-card{padding:14px;border:1px solid rgba(38,52,73,.9);border-radius:20px;background:#101622f0;box-shadow:var(--shadow)}.page-sidebar-block h2{margin:8px 0;font-size:18px}.page-sidebar-block p,.sidebar-status-card p{margin:0;color:var(--muted);line-height:1.7}.section-nav{display:grid;gap:8px}.section-nav button{min-height:42px;padding:0 14px;display:flex;align-items:center;justify-content:space-between;text-align:left;border-radius:14px}.section-nav button span{color:var(--cyan);font-size:12px}.sidebar-status-card strong{display:block;margin:8px 0;font-size:18px}.sidebar-log-dock{min-height:0}.hero-panel,.current-session-banner,.section-block,.form-card,.empty-card,.session-card,.character-card{border:1px solid rgba(38,52,73,.9);border-radius:22px;background:#101622f0;box-shadow:var(--shadow)}.hero-panel{padding:22px;display:grid;grid-template-columns:minmax(0,1.3fr) 260px;gap:12px;background:linear-gradient(135deg,#13263deb,#0e1829f5)}.hero-copy h1{margin:8px 0 12px;font-size:clamp(32px,4vw,56px);letter-spacing:-.03em}.hero-copy p{width:min(720px,100%);margin:0;color:var(--muted);line-height:1.8}.hero-stats{margin-top:24px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.hero-stats>div,.status-panel{border:1px solid rgba(38,52,73,.9);border-radius:18px;background:#0b131fd1;padding:14px}.hero-stats strong{display:block;font-size:28px;margin-bottom:4px}.hero-stats span,.session-meta dt{color:var(--faint);font-size:12px;text-transform:uppercase;letter-spacing:.08em}.hero-aside{display:grid;gap:10px}.status-panel strong{display:block;margin-top:16px;font-size:20px}.quick-action-panel{display:grid;gap:10px}.current-session-banner,.section-block,.form-card,.empty-card{padding:18px}.current-session-banner{display:flex;justify-content:space-between;align-items:center;gap:16px}.section-heading{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:18px}.section-heading.compact{align-items:center;margin-bottom:14px}.current-session-banner h2,.section-heading h2{margin:8px 0;font-size:24px}.banner-actions{display:flex;flex-wrap:wrap;gap:10px}.card-grid{display:grid;grid-template-columns:1fr;gap:16px}.joinable-room-grid{grid-template-columns:repeat(5,minmax(0,1fr));grid-auto-rows:1fr}.pagination-row{margin-top:18px;display:flex;align-items:center;justify-content:center;gap:14px}.pagination-row span{color:var(--muted);font-size:14px}.session-card,.character-card{padding:18px;display:flex;flex-direction:column;gap:14px}.session-card-top,.character-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.character-head{justify-content:flex-start}.status-chip{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;border-radius:999px;border:1px solid rgba(120,217,255,.28);background:#78d9ff1a;color:#dff8ff;font-size:12px}.status-chip.muted{color:var(--muted);border-color:var(--line);background:#0e1929db}.session-card h3,.character-card h3,.empty-card h3{margin:0;font-size:22px}.session-meta{margin:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.session-meta div{padding:12px;border:1px solid rgba(38,52,73,.9);border-radius:16px;background:#070e188f}.session-meta dd{margin:8px 0 0;color:var(--ink);font-weight:600}.form-card.wide{padding:22px}@media (max-width: 1180px){.page-with-sidebar,.hero-panel,.session-stage{grid-template-columns:1fr}}@media (max-width: 860px){.topbar-shell,.page-with-sidebar,.play-layout{padding:12px}.topbar-shell,.topbar-left,.current-session-banner{align-items:flex-start;flex-direction:column}.hero-stats,.field-row,.session-meta{grid-template-columns:1fr}}.main-column,.side-column{min-width:0;display:grid;align-content:start;gap:16px}.main-column-wide{grid-column:2 / -1}.side-column{gap:16px}.sidebar-action-button,.quick-link-card,.character-create-card,.character-selection-create,.character-selection-card,.participant-strip-card,.modal-close{border-radius:18px}.sidebar-action-button{margin-top:14px;width:100%;min-height:42px}.lobby-quick-grid{display:grid;gap:12px}.quick-link-card{min-height:96px;padding:16px;text-align:left;display:grid;gap:6px;background:#0a111bdb}.quick-link-card strong,.character-create-card strong,.character-selection-card strong,.participant-strip-card strong,.character-library-card h3,.placeholder-view h1,.character-focus-card h2,.character-hero h1,.session-ready-card h2,.session-prep-topbar h1{margin:0}.quick-link-card span,.character-create-card span,.character-selection-card span,.participant-strip-card span,.character-library-card p,.placeholder-view p,.character-focus-card p,.character-hero p,.session-ready-card p,.session-prep-topbar p,.session-log-item p,.session-info-panel p,.session-settings-panel p{color:var(--muted)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;padding:24px;background:#03080ec7;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:grid;place-items:start center;overflow-y:auto}.modal-card{width:min(560px,100%);max-height:calc(100vh - 48px);overflow-y:auto;padding:22px;border:1px solid rgba(38,52,73,.9);border-radius:28px;background:linear-gradient(180deg,#111927fa,#0a101bfa);box-shadow:var(--shadow)}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}.modal-header h2{margin:8px 0 0}.modal-close{min-height:40px;padding:0 14px}.modal-form{display:grid;gap:14px}.toggle-field{display:flex;align-items:center;gap:10px;margin:0}.toggle-field input{width:18px;min-height:18px;margin:0}.toggle-field span{color:var(--ink);font-size:14px}.field-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.placeholder-view,.character-page,.character-hero,.character-focus-card,.character-library,.session-prep-topbar,.session-ready-canvas,.session-ready-card,.character-selection-board,.session-sidebar,.session-sidebar-panel,.participant-strip-card{border:1px solid rgba(38,52,73,.9);background:#101622f0;box-shadow:var(--shadow)}.placeholder-view,.character-page{margin:20px 16px 24px;padding:22px;border-radius:28px}.character-page{display:grid;gap:18px;align-content:start}.character-screen{padding-bottom:32px}.character-hero,.character-focus-card,.character-library{border-radius:24px;padding:20px}.character-hero{display:flex;justify-content:space-between;gap:18px;background:linear-gradient(135deg,#142942f0,#0d1523f5)}.character-hero-actions{display:flex;gap:10px;align-items:flex-start;flex-wrap:wrap}.character-library-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}.character-create-card,.character-library-card{min-height:220px;padding:18px;border:1px solid rgba(38,52,73,.9);background:#09101adb}.character-create-card{display:grid;align-content:center;justify-items:start;gap:10px}.character-create-card svg{color:var(--cyan)}.character-library-card{border-radius:20px;display:grid;gap:16px}.character-library-card.active{border-color:#78d9ff8c;background:#12293dcc}.character-overview-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.character-overview-card,.character-detail-card{padding:18px;border:1px solid rgba(38,52,73,.9);border-radius:22px;background:#101622f0;box-shadow:var(--shadow)}.character-overview-card strong{display:block;margin:10px 0 6px;font-size:30px}.character-screen-grid{display:grid;grid-template-columns:minmax(320px,1fr) minmax(360px,.95fr);gap:18px;align-items:start}.character-library-panel,.character-detail-shell{min-width:0}.character-detail-shell{display:grid;gap:16px}.character-detail-hero{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}.character-detail-hero-head{display:flex;gap:14px;align-items:center}.avatar-xl{width:72px;height:72px;font-size:30px;border-radius:22px}.character-detail-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}.character-detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.character-combat-grid,.character-ability-grid{display:grid;gap:12px}.character-combat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.character-combat-grid div,.character-ability-grid div{padding:12px;border:1px solid rgba(38,52,73,.9);border-radius:16px;background:#070e188f}.character-combat-grid dt,.character-ability-grid dt{font-size:11px;color:var(--faint);text-transform:uppercase;letter-spacing:.08em}.character-combat-grid dd,.character-ability-grid dd{margin:8px 0 0;font-size:26px;font-weight:800}.character-ability-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.character-ability-grid span{display:inline-block;margin-top:8px;color:var(--cyan);font-size:13px;font-weight:700}.character-card-tags,.character-chip-row{display:flex;flex-wrap:wrap;gap:10px}.character-chip-row span,.character-selected-chip{min-height:34px;padding:0 12px;border-radius:999px;border:1px solid rgba(38,52,73,.9);background:#0a121de0;display:inline-flex;align-items:center;gap:8px;color:var(--ink)}.character-selected-chip button{min-height:auto;width:22px;height:22px;padding:0;border-radius:999px;border-color:#ffffff14}.character-inventory-list{list-style:none;padding:0;margin:0;display:grid;gap:10px}.character-inventory-list li{padding:12px 14px;border:1px solid rgba(38,52,73,.9);border-radius:16px;background:#070e188f;display:flex;justify-content:space-between;gap:12px}.character-equipped-note,.character-empty-note{margin:14px 0 0;color:var(--muted);line-height:1.6}.modal-card-wide{width:min(920px,100%)}.character-create-form{gap:18px}.character-form-section{padding:18px;border:1px solid rgba(38,52,73,.9);border-radius:20px;background:#09101ac7}.field-row-3{grid-template-columns:repeat(3,minmax(0,1fr))}.field-row-4{grid-template-columns:repeat(4,minmax(0,1fr))}.character-skill-picker{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px}.character-skill-chip{min-height:34px;padding:0 12px;border-radius:999px;background:#0c1724e6}.character-inventory-editor{display:grid;gap:10px}.character-inventory-row{display:grid;grid-template-columns:minmax(0,1fr) 120px auto;gap:10px}.character-library-head{display:flex;gap:12px;align-items:center}.character-library-meta,.character-selection-meta{margin:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.character-library-meta div,.character-selection-meta div{padding:10px;border:1px solid rgba(38,52,73,.9);border-radius:14px;background:#070e188f}.character-library-meta dt,.character-selection-meta dt{font-size:11px;color:var(--faint);text-transform:uppercase}.character-library-meta dd,.character-selection-meta dd{margin:6px 0 0;font-weight:700}.session-prep-layout{height:100vh;padding:16px;display:grid;grid-template-columns:minmax(0,1fr) 380px;gap:16px;overflow:hidden}.session-prep-stage{min-width:0;display:grid;grid-template-rows:minmax(0,1fr) auto auto;gap:12px;overflow:hidden}.session-prep-layout-tight .session-prep-stage{grid-template-rows:minmax(0,1fr) auto auto}.session-stage-canvas{min-height:0;border-radius:32px;border:1px solid rgba(38,52,73,.9);background:radial-gradient(circle at top,rgba(120,217,255,.09),transparent 38%),linear-gradient(180deg,#0b111df5,#080d16fa);position:relative;overflow:hidden}.session-room-overlay{position:absolute;inset:24px 24px auto 24px;z-index:2;border-radius:20px;border:1px solid rgba(38,52,73,.9);background:#0d1522eb;box-shadow:var(--shadow);padding:12px 14px}.session-room-overlay.collapsed{inset:24px auto auto 24px;min-width:280px;padding:12px 16px;cursor:pointer}.session-room-overlay-collapsed{display:flex;align-items:center;min-height:44px}.session-room-overlay-collapsed strong{font-size:20px}.session-room-overlay-row{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.session-room-overlay-title{display:grid;gap:2px}.session-room-overlay-title .eyebrow{margin-bottom:0;font-size:11px}.session-room-overlay-title strong{font-size:18px;line-height:1.2}.session-room-overlay-actions,.session-room-invite,.session-ready-controls{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.invite-inline{display:inline-flex;align-items:center;gap:8px;padding:6px 8px 6px 12px;border:1px solid rgba(38,52,73,.9);border-radius:999px;background:#070e1894}.invite-copy-button{width:28px;height:28px;padding:0;border-radius:8px;display:grid;place-items:center}.gm-ready-card{width:min(880px,calc(100% - 80px));min-height:280px;margin:0 auto;align-content:center}.session-main-ready{position:absolute;inset:50% auto auto 50%;transform:translate(-50%,-50%);z-index:1}.session-ready-card{border-radius:28px;padding:32px 28px;background:#0e1522eb;text-align:center}.session-ready-card h2{margin:12px 0;font-size:clamp(30px,4vw,50px);letter-spacing:-.04em}.character-selection-board{position:absolute;top:24px;right:24px;bottom:24px;left:24px;border-radius:28px;padding:20px;overflow:auto}.player-ready-board{padding-top:28px}.session-stage-placeholder{position:absolute;top:24px;right:24px;bottom:24px;left:24px;border-radius:28px;padding:28px;border:1px solid rgba(38,52,73,.9);background:#0a101b94;display:grid;align-content:end;gap:8px}.character-selection-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}.ready-toggle-button{min-height:44px;min-width:124px;border-radius:999px;font-weight:800}.ready-toggle-button.active{border-color:#80c76f94;color:#cff6c4;background:#80c76f1f}.character-selection-create,.character-selection-card{min-height:220px;padding:18px;border:1px solid rgba(38,52,73,.9);background:#09101adb;text-align:left}.character-selection-create{display:grid;align-content:center;justify-items:start;gap:10px}.character-selection-card{display:grid;align-content:start;gap:16px}.character-selection-card.active{border-color:#78d9ff99;background:linear-gradient(180deg,#173d5aeb,#0c1421f0)}.character-selection-head{display:flex;gap:12px;align-items:center}.avatar-large{width:58px;height:58px;font-size:22px;border-radius:18px}.participant-strip{display:grid;grid-auto-flow:column;grid-auto-columns:calc((100% - 36px)/4);gap:12px;overflow-x:auto;overflow-y:hidden;padding-bottom:4px;scrollbar-width:thin}.participant-strip-card{border-radius:24px;padding:14px;display:grid;grid-template-columns:72px minmax(0,1fr) auto;gap:12px;align-items:center;position:relative;overflow:hidden;min-height:118px}.participant-strip-four-up{grid-auto-columns:calc((100% - 36px)/4)}.participant-strip-card.empty{grid-template-columns:1fr}.participant-avatar{width:72px;height:72px;border-radius:18px;display:grid;place-items:center;font-size:28px;font-weight:800;color:#061017;background:linear-gradient(135deg,var(--cyan),#9cf0e8)}.participant-card-body{display:grid;gap:6px}.participant-state{min-width:108px;min-height:44px;padding:0 18px;border-radius:999px;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;display:inline-flex;align-items:center;justify-content:center;font-weight:800}.participant-state.ready{border-color:#80c76f80;background:#80c76f24;color:#d9fbd2}.participant-index{position:absolute;top:12px;right:14px;color:#ffffff14;font-size:48px;font-weight:900}.participant-special-badge{position:absolute;top:10px;left:10px;z-index:1;min-height:28px;padding:0 10px;border-radius:999px;border:1px solid rgba(120,217,255,.42);background:#78d9ff24;color:#dff8ff;display:inline-flex;align-items:center;font-size:12px;font-weight:800}.session-sidebar{min-height:0;border-radius:32px;padding:0;overflow:hidden;display:grid;grid-template-rows:auto minmax(0,1fr)}.session-sidebar-tabs{display:grid;grid-template-columns:repeat(4,1fr);border-bottom:1px solid rgba(38,52,73,.9)}.session-sidebar-tabs button{min-height:56px;border-radius:0;background:#080e18f0;border-top:0;border-left:0;border-bottom:0}.session-sidebar-tabs button:last-child{border-right:0}.session-sidebar-tabs button.active{background:#12293df0;color:var(--cyan)}.session-sidebar-panel{min-height:0;padding:18px;display:grid;grid-template-rows:auto minmax(0,1fr) auto;gap:16px;overflow:hidden}.message-card{display:grid;grid-template-columns:auto minmax(0,1fr);gap:12px;align-items:flex-start}.message-badge{width:46px;height:46px;border-radius:999px;display:grid;place-items:center;color:#071018;background:#d9dde4;font-weight:800}.message-bubble{padding:18px;border:1px solid rgba(38,52,73,.9);border-radius:24px;background:#ffffff0a;line-height:1.6}.session-log-stack{min-height:0;overflow:auto;display:grid;gap:10px;align-content:start;padding-right:4px;padding-bottom:6px}.session-log-item{padding:14px;border:1px solid rgba(38,52,73,.9);border-radius:18px;background:#070e1894}.session-log-item strong,.session-settings-panel strong{display:block}.session-log-item p{margin:8px 0 0;line-height:1.7}.session-log-item span{display:inline-block;margin-top:10px;font-size:12px;color:var(--faint)}.main-log-card{padding:14px;border:1px solid rgba(38,52,73,.9);border-radius:18px;background:#070e1894}.main-log-card.rest{border-color:#80c76f59}.main-log-card.socket{border-color:#78d9ff59}.main-log-card.action{border-color:#d9a44161}.main-log-card.system{border-color:#ffffff14}.main-log-head{display:flex;justify-content:space-between;gap:12px;align-items:baseline}.main-log-head strong{font-size:14px}.main-log-head span{font-size:12px;color:var(--faint);white-space:nowrap}.main-log-card p{margin:10px 0 0;line-height:1.7;color:#c8d2dd}.chat-thread-row{display:grid;grid-template-columns:36px minmax(0,1fr) auto;gap:10px;align-items:end}.chat-thread-row.outgoing{grid-template-columns:minmax(0,1fr) auto;justify-items:end}.chat-thread-row.notice{grid-template-columns:1fr}.chat-thread-avatar{width:34px;height:34px;border-radius:12px;display:grid;place-items:center;background:#78d9ff2e;color:#dff8ff;font-size:13px;font-weight:800}.chat-thread-stack{display:grid;gap:0;min-width:0;max-width:min(82%,320px)}.chat-thread-bubble{max-width:100%;padding:12px 14px;border-radius:18px;line-height:1.55;word-break:break-word;border:1px solid rgba(38,52,73,.9);background:#0c1421eb}.chat-thread-time{font-size:11px;color:var(--faint);white-space:nowrap;align-self:end}.chat-thread-row.incoming .chat-thread-bubble{border-top-left-radius:8px;background:linear-gradient(180deg,#122032f5,#0c1421f5)}.chat-thread-row.outgoing .chat-thread-stack{justify-items:end;text-align:right}.chat-thread-row.outgoing .chat-thread-bubble{border-top-right-radius:8px;background:linear-gradient(180deg,#1c526dfa,#133e56fa);color:#effcff}.chat-thread-row.outgoing .chat-thread-time{order:-1;margin-right:2px}.chat-thread-row.notice{justify-items:center}.chat-thread-row.notice .chat-thread-bubble{border-radius:999px;padding:8px 14px;background:#ffffff0f;color:var(--muted);font-size:12px}.session-sidebar-input{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center;position:sticky;bottom:0;padding-top:10px;background:linear-gradient(180deg,#10162200,#101622f5 30%)}.session-sidebar-input.compact{grid-template-columns:minmax(0,1fr) auto;justify-content:stretch}.session-info-panel,.session-settings-panel{display:grid;gap:14px;align-content:start}.danger-button{min-height:44px;border-color:#e8687866;color:#ffdbe1;background:#581c26db}.danger-button:hover:not(:disabled){border-color:#e86878b3;background:#752331eb}.session-info-panel textarea{width:100%;min-height:320px;resize:vertical;border-radius:20px;border:1px solid rgba(38,52,73,.9);background:#070e1894;color:var(--ink);padding:14px}@media (max-width: 1180px){.session-prep-layout{grid-template-columns:1fr;height:auto;min-height:100vh;overflow:visible}.joinable-room-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (max-width: 860px){.character-hero,.session-room-overlay-row{flex-direction:column;align-items:stretch}.participant-strip-card,.session-sidebar-input,.field-row,.character-overview-grid,.character-screen-grid,.character-detail-grid,.character-ability-grid,.character-combat-grid,.field-row-3,.field-row-4,.character-inventory-row,.character-skill-picker{grid-template-columns:1fr}.participant-strip,.participant-strip-four-up{grid-auto-columns:minmax(220px,80%)}.participant-state{width:100%}.session-room-overlay{top:16px;right:16px;bottom:16px;left:16px}.joinable-room-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
