:root{color-scheme:dark;--bg: #0e0f12;--panel: #161821;--panel-2: #1d2030;--border: #2a2e3f;--text: #e6e8ef;--muted: #8b90a6;--accent: #c69b6d;--accent-2: #6d8fc6;--warn: #d3624a;--ok: #6cae6c;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;background:var(--bg);color:var(--text)}.app{display:grid;grid-template-columns:60% 40%;height:100vh;width:100vw;overflow:hidden}.story{display:flex;flex-direction:column;border-right:1px solid var(--border);background:linear-gradient(180deg,#11131a,#0e0f12);min-height:0;overflow:hidden}.scene-banner{padding:14px 20px;border-bottom:1px solid var(--border);background:var(--panel)}.scene-banner h1{margin:0;font-size:18px;font-weight:600}.scene-banner .meta{color:var(--muted);font-size:12px;margin-top:4px;display:flex;gap:14px;flex-wrap:wrap}.scene-banner .meta span b{color:var(--text);font-weight:500}.character-strip{display:flex;gap:8px;padding:8px 20px;border-bottom:1px solid var(--border);background:var(--panel);flex-wrap:wrap;font-size:12px}.char-chip{padding:4px 10px;border-radius:12px;background:var(--panel-2);border:1px solid var(--border);display:flex;gap:4px;align-items:center;transition:opacity .2s,border-color .2s}.char-chip.absent{opacity:.45;border-style:dashed}.char-chip.present{border-color:var(--accent-2)}.char-chip .name{font-weight:500}.char-chip .emotion{color:var(--muted);font-size:11px}.char-toggle{background:transparent;color:var(--muted);border:1px dashed var(--border);border-radius:12px;padding:3px 10px;font-size:11.5px;cursor:pointer;font-family:inherit}.char-toggle:hover{color:var(--text);border-color:var(--accent-2)}.char-empty{color:var(--muted);font-style:italic;font-size:12px}.transcript{flex:1;overflow-y:auto;padding:18px 22px;display:flex;flex-direction:column;gap:14px}.bubble{max-width:85%;padding:10px 14px;border-radius:10px;line-height:1.45;font-size:14px;white-space:pre-wrap}.bubble .who{font-size:11px;text-transform:uppercase;letter-spacing:.06em;opacity:.7;margin-bottom:4px}.bubble.player{align-self:flex-end;background:#2a3042;border:1px solid var(--border)}.bubble.actor{align-self:flex-start;background:var(--panel);border:1px solid var(--border)}.bubble.actor .action{display:block;font-style:italic;color:var(--muted);margin-top:6px;font-size:13px}.bubble.actor .action-inline,.bubble.streaming .action-inline{font-style:italic;color:var(--muted)}.bubble.narrator{align-self:center;background:transparent;color:var(--muted);font-style:italic;border:1px dashed var(--border);font-size:13px}.bubble.system-error{align-self:stretch;background:#2a1818;border:1px solid var(--warn);color:#f0b9af}.composer{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--border);background:var(--panel)}.composer textarea{flex:1;resize:none;min-height:44px;max-height:120px;background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:10px 12px;font-family:inherit;font-size:14px;line-height:1.4}.composer button{background:var(--accent);color:#1a1208;border:none;border-radius:8px;padding:0 18px;font-weight:600;cursor:pointer;font-size:14px}.composer button:disabled{opacity:.5;cursor:not-allowed}.debug{display:flex;flex-direction:column;background:var(--panel);overflow:hidden;min-height:0}.debug header{padding:12px 16px;border-bottom:1px solid var(--border);font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);display:flex;align-items:center;justify-content:space-between}.debug-tabs{display:flex;border-bottom:1px solid var(--border);background:var(--panel);padding:0 6px;gap:2px}.debug-tabs button{background:transparent;border:none;color:var(--muted);font-size:11px;padding:8px 10px;cursor:pointer;border-bottom:2px solid transparent;text-transform:uppercase;letter-spacing:.08em;font-weight:600;font-family:inherit;transition:color .12s,border-color .12s}.debug-tabs button:hover{color:var(--text)}.debug-tabs button.active{color:var(--text);border-bottom-color:var(--accent)}.debug .scroll{flex:1;overflow-y:auto;padding:12px 16px;font-size:13px}.section{margin-bottom:18px;padding-bottom:14px;border-bottom:1px dashed var(--border)}.section:last-child{border-bottom:none}.section h3{margin:0 0 8px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--accent)}.kv{display:grid;grid-template-columns:130px 1fr;gap:4px 10px;font-size:12.5px}.kv .k{color:var(--muted)}.beat-card{background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding:10px 12px;font-size:12.5px;line-height:1.45}.beat-card.muted{opacity:.55}.beat-card.active{border-color:var(--accent)}.beat-card .title{font-weight:600;font-size:13px;margin-bottom:4px}.beat-card .label{color:var(--muted);font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;margin-top:6px}.tag{display:inline-block;padding:2px 6px;border-radius:4px;font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;font-weight:600}.tag.continue{background:#243;color:#a0d8a0}.tag.advance{background:#234;color:#a0c8e8}.tag.inject{background:#432;color:#e0c890}.tag.end{background:#422;color:#e8a0a0}.tag.fold{background:#324;color:#c8a0e8}.eval-row{display:grid;grid-template-columns:50px 1fr;gap:8px;margin:6px 0;font-size:12px;line-height:1.4}.eval-row .pill{text-align:center;font-weight:700;border-radius:4px;padding:2px 0;font-size:11px;height:fit-content}.pill.YES{background:#1d3a1d;color:#8fd48f}.pill.NO{background:#2a2a2a;color:#999}.staging-row{font-family:ui-monospace,SF Mono,monospace;font-size:11.5px;padding:4px 0;border-bottom:1px solid var(--border);color:#cfd2dd}.staging-row:last-child{border-bottom:none}.staging-row .ts{color:var(--muted);margin-right:8px}.setup{max-width:560px;margin:80px auto;background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:28px}.setup h1{margin:0 0 6px;font-size:22px}.setup p{color:var(--muted);margin:0 0 18px;font-size:13.5px;line-height:1.5}.setup label{display:block;margin:14px 0 6px;font-size:12px;color:var(--muted)}.setup input{width:100%;padding:10px 12px;background:var(--panel-2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:ui-monospace,SF Mono,monospace;font-size:13px}.setup button{margin-top:18px;width:100%;background:var(--accent);color:#1a1208;border:none;border-radius:8px;padding:11px;font-weight:600;cursor:pointer}.setup button.ghost{margin-top:14px;background:transparent;color:var(--muted);border:1px solid var(--border);font-weight:500}.setup button.ghost:hover{color:var(--text);border-color:var(--accent-2)}.novel-grid{display:flex;flex-direction:column;gap:12px;margin-top:4px}.setup .novel-card{display:block;width:100%;text-align:left;margin-top:0;background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:10px;padding:14px 16px;cursor:pointer;transition:border-color .12s,transform .12s}.setup .novel-card:hover{border-color:var(--accent);transform:translateY(-1px)}.setup .novel-card .novel-title{font-size:16px;font-weight:600;color:var(--accent);margin-bottom:4px}.setup .novel-card .novel-tag{font-size:13px;color:var(--text);line-height:1.45}.setup .novel-card .novel-meta{margin-top:8px;font-size:11.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.banner-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.banner-link{background:transparent;color:var(--muted);border:1px solid var(--border);border-radius:6px;padding:4px 10px;font-size:11.5px;cursor:pointer}.banner-link:hover{color:var(--text);border-color:var(--accent-2)}.thinking{align-self:flex-start;color:var(--muted);font-size:12.5px;font-style:italic;padding:4px 8px}.bubble.streaming{opacity:.92}.bubble.streaming .caret{display:inline-block;width:7px;height:1em;margin-left:2px;vertical-align:text-bottom;background:var(--accent);animation:caret-blink 1s steps(2,end) infinite}@keyframes caret-blink{0%,50%{opacity:1}51%,to{opacity:0}}.thinking:after{content:"";display:inline-block;animation:dots 1.2s steps(3,end) infinite}@keyframes dots{0%{content:""}33%{content:"."}66%{content:".."}to{content:"..."}}.ending-banner{margin:14px 22px;padding:14px 16px;border:1px solid var(--accent);border-radius:8px;background:#1d1812;color:#f0d8b4;font-size:14px}.ending-banner b{color:var(--accent)}.convo-hint{color:var(--muted);font-size:11.5px;margin:0 0 10px;line-height:1.45}.convo-turn{margin-bottom:14px;padding-bottom:10px;border-bottom:1px dashed var(--border)}.convo-turn:last-child{border-bottom:none}.convo-turn-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.convo-turn-header .ts{color:var(--muted);font-size:11px}.convo-turn-header .count{margin-left:auto;color:var(--muted);font-size:11px}.trace{background:var(--panel-2);border:1px solid var(--border);border-radius:6px;padding:8px 10px;margin-bottom:6px;font-size:12px}.trace-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.trace-header .kind{background:var(--accent-2);color:#0e0f12;border-radius:3px;padding:2px 6px;font-size:10px;text-transform:uppercase;font-weight:700;letter-spacing:.04em}.trace-header .kind.signal_eval{background:#5d8e7a}.trace-header .kind.plan{background:var(--accent);color:#1a1208}.trace-header .trace-label{font-family:ui-monospace,SF Mono,monospace;color:var(--muted);font-size:11px}.trace-header .trace-duration{margin-left:auto;color:var(--muted);font-size:10.5px;font-family:ui-monospace,SF Mono,monospace}.trace details{margin-top:4px}.trace details summary{cursor:pointer;font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;padding:2px 0;font-weight:600;list-style:none}.trace details summary::-webkit-details-marker{display:none}.trace details summary:before{content:"▸ ";display:inline-block;width:12px;transition:transform .1s}.trace details[open] summary:before{content:"▾ "}.trace details summary:hover{color:var(--text)}.trace details pre{background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:6px 8px;font-size:11px;white-space:pre-wrap;word-break:break-word;margin:4px 0;color:#cfd2dd;font-family:ui-monospace,SF Mono,monospace;line-height:1.5;max-height:300px;overflow:auto}.trace .trace-toolcall{margin-top:6px}.trace .trace-toolname{font-size:10.5px;color:var(--accent);text-transform:uppercase;letter-spacing:.06em;margin-top:4px}
