:root{color-scheme:dark;--bg:#090a0b;--panel:#111316;--panel-strong:#171a1f;--line:#2a2f37;--line-soft:#1d2229;--text:#f4f4f4;--muted:#a8a8a8;--accent:#f4f4f4;--accent-dark:#242424;--danger:#e0e0e0;--danger-dark:#262626;--heading-font:"config-mono-vf",system-ui,sans-serif;--body-font:"neuzeit-grotesk",system-ui,sans-serif}*{box-sizing:border-box}body,html{min-height:100%;margin:0;background:var(--bg);color:var(--text);font-family:var(--body-font)}body{overflow:hidden}button,input,select,textarea{font:inherit}button{min-height:40px;border:1px solid var(--line);border-radius:6px;background:var(--text);color:var(--bg);cursor:pointer;font-weight:700;padding:0 14px}button:disabled{cursor:not-allowed;opacity:.55}button.quiet{background:transparent;color:var(--text)}button.danger{background:var(--danger-dark);border-color:#5c5c5c;color:var(--danger)}.icon-button{display:inline-flex;align-items:center;justify-content:center;gap:8px}.icon-button svg{flex:0 0 auto}.icon-only-button{width:42px;min-width:42px;padding:0;display:inline-flex;align-items:center;justify-content:center}.icon-only-button svg{flex:0 0 auto}.eyebrow,.message-role,h1,h2,h3{font-family:var(--heading-font)}h1,h2,h3,p{margin:0}h1{font-size:clamp(2rem,4vw,4.4rem);font-weight:780;line-height:.95;overflow-wrap:anywhere}h2{font-size:1.35rem;line-height:1.1}h3{font-size:1rem;line-height:1.2}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:6px;background:#0c0e11;color:var(--text);outline:none;padding:11px 12px}textarea{min-height:76px;resize:vertical}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(244,244,244,.1)}.loading,.unlock-screen{min-height:100vh;display:grid;place-items:center;padding:24px}.unlock-card{width:min(440px,100%);border:1px solid var(--line);border-radius:8px;background:var(--panel);padding:28px;display:grid;gap:16px}.unlock-card h1{margin-bottom:16px}.eyebrow{color:var(--accent);font-size:.74rem;font-weight:800;letter-spacing:0;text-transform:uppercase}.app-shell{width:100vw;height:100vh;font-family:var(--body-font);background:linear-gradient(180deg,rgba(255,255,255,.035),transparent 32%),var(--bg)}.simple-shell{display:grid;grid-template-columns:minmax(260px,330px) minmax(0,1fr)}.simple-shell.sidebar-collapsed{grid-template-columns:minmax(0,1fr)}.mobile-tabs{display:none}.chat-panel,.roster-panel{min-height:0}.roster-panel{border-right:1px solid var(--line-soft);background:rgba(17,19,22,.94);display:flex;flex-direction:column;gap:18px;overflow:auto;padding:18px}.sidebar-collapsed .roster-panel{display:none}.sidebar-peek{position:fixed;left:12px;top:12px;z-index:15;min-height:34px;background:var(--panel-strong);color:var(--text)}.chat-header,.modal-header,.panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.character-list,.field,.guided-builder,.history-list,.settings-stack,.wizard,.wizard-page{display:grid;gap:10px}.character-row{width:100%;min-height:auto;display:grid;gap:5px;padding:12px;text-align:left;background:transparent;color:var(--text)}.character-row span{font-weight:800}.character-row small{color:var(--muted);overflow-wrap:anywhere}.character-row.active,.choice-grid button.active,.history-row button.active,.mode-tabs button.active,.stepper button.active{background:var(--accent-dark);border-color:#6a6a6a}.field span{color:var(--muted);font-size:.9rem}.chat-panel{display:grid;grid-template-rows:auto minmax(0,1fr) auto auto;gap:14px;padding:18px}.mini-chatbar{display:none;align-items:center;justify-content:flex-end;gap:8px;min-height:42px;border-bottom:1px solid var(--line-soft);padding-bottom:10px}.mini-chatbar strong{min-width:0;margin-right:auto;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar-collapsed .chat-header{display:none}.topbar-collapsed .mini-chatbar{display:flex}.empty-toolbar{display:flex;justify-content:flex-end}.chat-header{align-items:center}.chat-header h1{margin-top:6px}.header-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.header-actions,.submenu-wrap{position:relative}.submenu{position:absolute;top:calc(100% + 8px);right:0;z-index:20;width:min(220px,72vw);border:1px solid var(--line);border-radius:8px;background:var(--panel-strong);box-shadow:0 18px 60px rgba(0,0,0,.45);display:grid;gap:8px;padding:10px}.submenu button{width:100%}.messages{min-height:0;overflow:auto;display:flex;flex-direction:column;gap:14px;padding:8px 4px 16px}.message{width:min(760px,88%);border:1px solid var(--line-soft);border-radius:8px;background:rgba(17,19,22,.92);padding:14px;line-height:1.55;overflow-wrap:anywhere;white-space:pre-wrap}.message p{color:inherit}.message.user{align-self:flex-end;background:#1d1d1d;border-color:#4d4d4d}.message.pending{color:var(--muted)}.message-role{margin-bottom:8px;color:var(--accent);font-size:.74rem;font-weight:800;text-transform:uppercase}.composer{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:10px;align-items:end;border-top:1px solid var(--line-soft);padding-top:14px}.composer-tools{display:flex;gap:8px}.composer-tools button.active{background:var(--accent-dark);border-color:#6a6a6a;color:var(--text)}.turn-controls{display:flex;justify-content:flex-end;gap:8px}.composer textarea{max-height:30vh}.empty-state,.first-run,.settings-preview{border:1px solid var(--line-soft);border-radius:8px;background:rgba(17,19,22,.8);padding:18px}.empty-state,.first-run{width:min(560px,100%);margin:auto;display:grid;gap:12px}.settings-preview{display:grid;gap:10px}.empty-state p,.first-run p,.form-error,.settings-preview p,.status{color:var(--muted);line-height:1.5}.form-error,.status{color:var(--danger)}.modal-backdrop{position:fixed;inset:0;z-index:30;display:grid;place-items:center;padding:18px;background:rgba(4,5,6,.72)}.modal{width:min(680px,100%);max-height:min(760px,calc(100vh - 36px));border:1px solid var(--line);border-radius:8px;background:var(--panel);box-shadow:0 24px 90px rgba(0,0,0,.55);display:grid;grid-template-rows:auto minmax(0,1fr);gap:18px;overflow:auto;padding:18px}.stepper{grid-template-columns:repeat(3,1fr)}.mode-tabs,.stepper{display:grid;gap:8px}.mode-tabs{grid-template-columns:repeat(2,1fr)}.choice-grid button,.mode-tabs button,.stepper button{background:transparent;color:var(--text)}.guide-field{display:grid;gap:10px}.guide-field>p{color:var(--muted);font-size:.9rem}.choice-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.markdown-body{display:grid;gap:.75rem;font-size:1rem;line-height:1.62}.markdown-body>*{margin:0}.markdown-body ol,.markdown-body ul{margin:0;padding-left:1.25rem}.markdown-body code{border:1px solid var(--line-soft);border-radius:4px;background:#0c0c0c;padding:.1rem .28rem;font-family:forma-djr-mono,ui-monospace,monospace;font-size:.92em}.markdown-body pre{overflow:auto;border:1px solid var(--line-soft);border-radius:6px;background:#0c0c0c;padding:12px}.markdown-body pre code{border:0;padding:0}.modal-actions{display:flex;justify-content:flex-end;gap:8px}.history-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px}.history-row button{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width:840px){body{overflow:auto}.simple-shell{height:100dvh;grid-template-columns:1fr;grid-template-rows:auto minmax(0,1fr)}.mobile-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;padding:7px 10px;border-bottom:1px solid var(--line-soft);background:var(--bg)}.mobile-settings-button{color:var(--text)}.mobile-tabs button{min-height:32px;padding:0 8px;font-size:.88rem}.mobile-settings-button span{display:none}.chat-panel,.roster-panel{height:auto;min-height:0;border:0}.roster-panel{display:none}.show-roster .roster-panel{display:flex}.show-roster .chat-panel{display:none}.chat-header{align-items:stretch;flex-direction:column}.header-actions{justify-content:stretch}.header-actions>button,.submenu-wrap,.submenu-wrap>button{flex:1 1 120px}.composer{grid-template-columns:1fr}.composer-tools{justify-content:flex-end;order:-1}.turn-controls{justify-content:stretch}.turn-controls button{flex:1 1;min-height:34px}.mini-chatbar{min-height:34px;padding-bottom:6px}.mini-chatbar button{min-height:32px}.sidebar-peek{display:none}.message{width:100%}}@media (max-width:560px){.chat-panel,.modal,.roster-panel,.unlock-card{padding:14px}h1{font-size:2.2rem}.modal-header,.panel-header{align-items:stretch;flex-direction:column}.history-row,.stepper{grid-template-columns:1fr}}