@import "https://fonts.googleapis.com/css2?family=Noto+Serif+SC:wght@400;500;600;700;900&family=Noto+Sans+SC:wght@300;400;500;700&family=Cinzel:wght@400;500;600;700&family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap";:root{--pane-left:280px;--pane-right:320px;--bg-void:#06080f;--bg-deep:#0a0e1a;--bg-base:#0f1424;--bg-raised:#141929;--bg-elevated:#1a2038;--glass-1:#14192973;--glass-2:#14192999;--glass-3:#0f1424bf;--stroke-1:#ffffff0f;--stroke-2:#ffffff1a;--stroke-3:#ffffff29;--stroke-glow:#8b5cf673;--stroke-gold:#f59e0b8c;--violet-300:#c4b5fd;--violet-400:#a78bfa;--violet-500:#8b5cf6;--violet-600:#7c3aed;--cyan-300:#67e8f9;--cyan-400:#22d3ee;--cyan-500:#06b6d4;--cyan-600:#0891b2;--gold-300:#fcd34d;--gold-400:#fbbf24;--gold-500:#f59e0b;--gold-600:#d97706;--grad-spine:linear-gradient(180deg, #c4b5fd 0%, #8b5cf6 35%, #06b6d4 100%);--grad-primary:linear-gradient(135deg, #8b5cf6 0%, #06b6d4 100%);--grad-fork:linear-gradient(135deg, #fbbf24 0%, #f59e0b 60%, #d97706 100%);--grad-nebula:radial-gradient(120% 80% at 20% 10%, #8b5cf64d 0%, transparent 55%), radial-gradient(90% 70% at 85% 90%, #06b6d433 0%, transparent 60%), radial-gradient(60% 50% at 50% 50%, #f59e0b0f 0%, transparent 70%), linear-gradient(180deg, #06080f 0%, #0a0e1a 100%);--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--ai-active:#a78bfa;--fg-1:#e5e7eb;--fg-2:#9ca3af;--fg-3:#6b7280;--glow-violet:0 0 0 1px #8b5cf659, 0 0 24px #8b5cf673;--glow-cyan:0 0 0 1px #06b6d466, 0 0 28px #06b6d466;--glow-gold:0 0 0 1px #f59e0b8c, 0 0 32px #f59e0b8c;--font-serif:"Noto Serif SC", "Source Han Serif SC", "Songti SC", "STSong", serif;--font-display:"Cinzel", "Noto Serif SC", serif;--font-sans:"Inter", "Noto Sans SC", "PingFang SC", "Hiragino Sans GB", sans-serif;--font-mono:"JetBrains Mono", ui-monospace, "SF Mono", monospace;--ease-out:cubic-bezier(.22, 1, .36, 1);--ease-bounce:cubic-bezier(.34, 1.56, .64, 1);--bg:var(--bg-base);--bg-pane:var(--bg-raised);--bg-pane-2:var(--bg-elevated);--fg:var(--fg-1);--fg-dim:var(--fg-2);--fg-faint:var(--fg-3);--accent:#a78bfa;--border:#ffffff14}html,body,#root{background:var(--bg-deep);background-image:var(--grad-nebula);height:100%;color:var(--fg-1);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;background-attachment:fixed;margin:0;font-size:14px}body{flex-direction:column;width:100%;max-width:100vw;height:100dvh;display:flex;overflow:hidden}#root{flex-direction:column;flex:1;min-height:0;display:flex}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-thumb{background:#a78bfa40;border-radius:999px}::-webkit-scrollbar-thumb:hover{background:#a78bfa73}::-webkit-scrollbar-track{background:0 0}::selection{color:#fff;background:#f59e0b59}.three-pane{grid-template-columns:var(--pane-left) 4px minmax(0, 1fr) 4px var(--pane-right);flex:1;grid-template-rows:44px 1fr;width:100%;min-width:0;max-width:100%;min-height:0;display:grid;overflow:hidden}.titlebar{background:var(--glass-2);-webkit-backdrop-filter:blur(20px)saturate(140%);border-bottom:1px solid var(--stroke-1);font-family:var(--font-display);letter-spacing:.18em;text-transform:uppercase;background-image:linear-gradient(135deg,#a78bfa1a 0%,#22d3ee0f 100%);grid-column:1/-1;align-items:center;min-width:0;padding:0 18px;font-size:14px;font-weight:600;display:flex;overflow:hidden}.titlebar .badge{font-family:var(--font-display);letter-spacing:.08em;text-transform:none;color:var(--violet-300);background:var(--glass-1);border:1px solid var(--stroke-2);text-overflow:ellipsis;white-space:nowrap;border-radius:999px;min-width:0;max-width:min(46vw,560px);margin-left:14px;padding:3px 14px;font-size:12px;font-weight:500;overflow:hidden}.glass{background:var(--glass-2);-webkit-backdrop-filter:blur(20px)saturate(140%);border:1px solid var(--stroke-2);border-radius:16px;box-shadow:inset 0 1px #ffffff0a,0 24px 60px #00000073}.pane{background:var(--glass-2);-webkit-backdrop-filter:blur(16px)saturate(130%);min-width:0;min-height:0;display:grid;overflow:clip}.pane>*{min-width:0}.pane-left{border-right:1px solid var(--stroke-1);grid-area:2/1;grid-template-rows:auto minmax(0,1fr)}.pane-center{background:0 0;grid-area:2/3;grid-template-rows:minmax(0,1fr)}.pane-right{border-left:1px solid var(--stroke-1);grid-area:2/5;grid-template-rows:minmax(0,1fr)}.resizer{cursor:col-resize;transition:background .2s var(--ease-out);background:0 0;grid-row:2;position:relative}.resizer:hover{background:linear-gradient(#0000 0%,#a78bfa73 50%,#0000 100%)}.resizer-left{grid-column:2}.resizer-right{grid-column:4}.pane-header{font-family:var(--font-sans);text-transform:uppercase;letter-spacing:.22em;color:var(--fg-2);border-bottom:1px solid var(--stroke-1);justify-content:space-between;align-items:center;padding:14px 18px;font-size:11px;font-weight:600;display:flex}.pane-body{overscroll-behavior:contain;flex:1;min-height:0;padding:12px 16px;overflow:hidden auto}.pane-body p.empty{color:var(--fg-3);margin:8px 0;font-size:12px}.manuscript-content{min-width:0;overflow-x:hidden}.manuscript-header{flex-wrap:wrap;min-width:0}.manuscript-title,.manuscript-meta{overflow-wrap:anywhere;min-width:0}.manuscript-actions{justify-content:flex-end;min-width:0}.manuscript-content p{overflow-wrap:anywhere;word-break:break-word}.pane-header-icon-button{cursor:pointer;letter-spacing:0;text-transform:none;color:var(--fg-1);background:0 0;border:0;border-radius:6px;margin:-4px -6px;padding:4px 6px;font-size:16px;line-height:1;transition:background .12s}.pane-header-icon-button:hover{background:var(--glass-1)}.pane-header-icon-button:focus-visible{outline:2px solid var(--violet-500);outline-offset:2px}.feedback-trigger,.feedback-panel{bottom:20px}.brick-form-root{padding:24px}@media (max-width:900px){.brick-form-root{padding:16px}.brick-form-identity-row{justify-items:center;grid-template-columns:1fr!important}.brick-form-identity-row>div{width:100%}.pane-header-path-mobile-hide{display:none}.feedback-trigger,.feedback-panel{bottom:calc(56px + env(safe-area-inset-bottom) + 12px)}}.brick-row{cursor:pointer;transition:background .16s var(--ease-out), border-color .16s var(--ease-out);border:1px solid #0000;border-radius:8px;margin-bottom:4px;padding:9px 11px;font-size:13px}.brick-row:hover{border-color:var(--stroke-2);background:#a78bfa0f}.brick-row .name{font-family:var(--font-serif);letter-spacing:.005em;font-weight:500}.brick-row .summary{color:var(--fg-2);text-overflow:ellipsis;white-space:nowrap;margin-top:2px;font-size:11px;overflow:hidden}.brick-row .kind{font-family:var(--font-mono);color:var(--fg-3);text-transform:uppercase;letter-spacing:.18em;margin-bottom:2px;font-size:10px}.editor-empty{height:100%;color:var(--fg-3);text-align:center;justify-content:center;align-items:center;padding:24px;font-size:14px;display:flex}.error-banner{color:var(--gold-300);border-top:1px solid var(--stroke-gold);border-bottom:1px solid var(--stroke-gold);background:#f59e0b1f;padding:10px 14px;font-size:12px}.error-banner:before{content:"※ ";color:var(--gold-400);margin-right:4px;font-weight:600}.button{background:var(--grad-primary);color:#fff;font-family:var(--font-sans);letter-spacing:.02em;cursor:pointer;transition:filter .2s var(--ease-out), transform .12s var(--ease-out), box-shadow .2s var(--ease-out);border:1px solid #0000;border-radius:8px;padding:7px 16px;font-size:12px;font-weight:500;box-shadow:inset 0 1px #ffffff1f,0 6px 16px #8b5cf640}.button:hover{filter:brightness(1.08);box-shadow:inset 0 1px #ffffff29,0 8px 24px #8b5cf666}.button:active{filter:brightness(.95);transform:scale(.98)}.button:disabled{opacity:.5;cursor:not-allowed;filter:grayscale(.3)}.button.secondary{background:var(--glass-1);color:var(--fg-1);border:1px solid var(--stroke-2);box-shadow:none}.button.secondary:hover{background:var(--glass-2);border-color:var(--stroke-3);filter:none}.branch-row{font-size:12px;font-family:var(--font-mono);cursor:pointer;transition:background .16s var(--ease-out);border-radius:6px;align-items:center;padding:7px 10px;display:flex}.branch-row:hover{background:#a78bfa0f}.branch-row.current{border:1px solid var(--stroke-glow);color:var(--violet-300);background:#a78bfa1f;font-weight:600}.branch-row .dot{background:var(--fg-3);border-radius:50%;width:6px;height:6px;margin-right:8px}.branch-row.current .dot{background:var(--violet-400);transform-origin:50%;animation:4s ease-in-out infinite pulse-spine;box-shadow:0 0 8px #a78bfab3}@keyframes breathe-mark{0%,to{transform:scale(1);box-shadow:0 0 0 1px #ffffff1a,0 0 12px #a78bfa59}50%{transform:scale(1.025);box-shadow:0 0 0 1px #ffffff24,0 0 18px #a78bfa8c}}@keyframes pulse-spine{0%,to{box-shadow:0 0 8px #a78bfa8c}50%{box-shadow:0 0 14px #a78bfaf2}}.brand-mark{transform-origin:50%;animation:4s ease-in-out infinite breathe-mark}.collapsible-panel-header{cursor:pointer;width:100%;color:var(--fg-2);text-align:left;-webkit-tap-highlight-color:transparent;transition:background .16s var(--ease-out);background:0 0;border:0;outline:0;align-items:center;gap:8px;padding:8px 12px;font-family:inherit;font-size:12px;display:flex}.collapsible-panel-header:hover{background:var(--glass-2)}.collapsible-panel-header:focus-visible{box-shadow:inset 0 0 0 2px var(--violet-300)}@keyframes stream-pulse{0%,to{opacity:1;transform:scale(1);box-shadow:0 0 8px #63b3edb3}50%{opacity:.45;transform:scale(1.4);box-shadow:0 0 14px #63b3ed}}.stream-dot{background:var(--cyan-400);border-radius:50%;width:8px;height:8px;animation:1.2s ease-in-out infinite stream-pulse;display:inline-block}@keyframes avatar-shimmer{0%{background-position:-100% 0}to{background-position:200% 0}}@media (prefers-reduced-motion:reduce){.brand-mark,.branch-row.current .dot,.stream-dot,.avatar-shimmer{animation:none}.collapsible-panel-header,.collapsible-panel-header [aria-hidden=true][data-cp-chevron]{transition:none!important}}.mobile-tabbar{display:none}.beta-banner{color:var(--gold-300);border-bottom:1px solid var(--stroke-gold);font-size:11px;font-family:var(--font-mono);letter-spacing:.04em;text-align:center;background:#f59e0b14;justify-content:center;align-items:center;gap:12px;padding:6px 16px;display:flex}.beta-banner-text-full{display:inline}.beta-banner-text-mobile{display:none}.editor-empty-hint-desktop{display:block}.editor-empty-hint-mobile,.manuscript-chapters-toggle{display:none}.beta-banner-reset{border:1px solid var(--stroke-gold);color:var(--gold-300);font-family:var(--font-mono);cursor:pointer;letter-spacing:.06em;background:0 0;border-radius:999px;flex-shrink:0;padding:2px 10px;font-size:10px}.beta-banner-reset-full{display:inline}.beta-banner-reset-mobile{display:none}@media (max-width:900px){.three-pane{grid-template-columns:1fr;grid-template-rows:44px 1fr calc(56px + env(safe-area-inset-bottom))}.titlebar{letter-spacing:.1em;grid-column:1;gap:6px;padding:0 12px;font-size:12px}.titlebar-tagline{display:none}.titlebar .badge{margin-left:6px;padding:2px 10px;font-size:11px}.pane-left,.pane-center,.pane-right{border:none;grid-area:2/1}.three-pane[data-mobile-pane=left] .pane-center,.three-pane[data-mobile-pane=left] .pane-right,.three-pane[data-mobile-pane=center] .pane-left,.three-pane[data-mobile-pane=center] .pane-right,.three-pane[data-mobile-pane=right] .pane-left,.three-pane[data-mobile-pane=right] .pane-center,.resizer{display:none}.mobile-tabbar{background:var(--glass-2);-webkit-backdrop-filter:blur(20px)saturate(140%);border-top:1px solid var(--stroke-1);padding-bottom:env(safe-area-inset-bottom);z-index:10;grid-area:3/1;justify-content:space-around;align-items:stretch;display:flex}.mobile-tab{color:var(--fg-3);font-family:var(--font-sans);cursor:pointer;transition:color .2s var(--ease-out);-webkit-tap-highlight-color:transparent;background:0 0;border:0;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;min-height:56px;padding:6px 0;display:flex;position:relative}.mobile-tab[aria-pressed=true]{color:var(--violet-200)}.mobile-tab[aria-pressed=true]:before{content:"";background:linear-gradient(90deg, var(--violet-400), var(--cyan-400));border-radius:0 0 2px 2px;width:32px;height:2px;position:absolute;top:0;left:50%;transform:translate(-50%)}.mobile-tab-icon{font-size:18px;line-height:1;font-family:var(--font-display)}.mobile-tab-label{letter-spacing:.08em;font-size:10px}.pane{min-height:0}.beta-banner{gap:8px;padding:5px 10px}.beta-banner-text-full,.beta-banner-reset-full{display:none}.beta-banner-text-mobile,.beta-banner-reset-mobile{display:inline}.editor-empty-hint-desktop{display:none}.editor-empty-hint-mobile{display:block}.center-tab-bricks{display:none}.manuscript-sidebar{border-right:0!important;width:100%!important}.manuscript-layout[data-chapters-open=yes] .manuscript-content,.manuscript-layout[data-chapters-open=no] .manuscript-sidebar{display:none}.manuscript-content{padding:12px 16px!important}.manuscript-chapters-toggle{border:1px solid var(--stroke-2);color:var(--fg-2);font-family:var(--font-mono);letter-spacing:.06em;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border-radius:999px;align-items:center;min-height:32px;margin-bottom:12px;padding:6px 12px;font-size:11px;display:inline-flex}.manuscript-chapters-toggle:active{background:var(--glass-1)}.manuscript-header{flex-direction:column;align-items:stretch!important}.manuscript-title{margin-bottom:12px!important;font-size:22px!important;line-height:1.35!important}.manuscript-actions{gap:6px!important}.manuscript-actions .button{min-height:32px;padding:6px 12px!important;font-size:12px!important}}.animation-modal-backdrop,.long-form-modal-backdrop{-webkit-backdrop-filter:blur(8px);z-index:1000;background:#06080fb8;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.animation-modal,.long-form-modal{background:var(--bg-pane);border:1px solid var(--stroke-2);width:min(960px,100%);max-height:calc(100vh - 48px);font-family:var(--font-sans);color:var(--fg-1);border-radius:12px;flex-direction:column;display:flex;overflow:hidden;box-shadow:0 24px 80px #0000008c}.animation-modal-header,.long-form-modal-header{border-bottom:1px solid var(--stroke-1);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.animation-modal-header h2,.long-form-modal-header h2{letter-spacing:.01em;margin:0;font-size:16px;font-weight:600}.animation-modal-close,.long-form-modal-close{color:var(--fg-2);cursor:pointer;background:0 0;border:0;border-radius:6px;padding:4px 8px;font-size:22px;line-height:1}.animation-modal-close:hover,.long-form-modal-close:hover{background:var(--glass-1);color:var(--fg-1)}.animation-modal-body{flex:auto;min-height:0;padding:16px 20px;overflow-y:auto}.animation-modal-empty{text-align:center;color:var(--fg-2);padding:48px 16px;font-size:14px;line-height:1.6}.animation-modal-empty p{margin:0 0 12px}.animation-modal-empty .hint{color:var(--fg-3);margin-bottom:20px;font-size:12px}.animation-modal-detect-error{color:#ff7676;margin-top:12px;font-size:12px}.animation-timeline header{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.animation-timeline header h2{color:var(--fg-2);margin:0;font-size:14px;font-weight:500}.timeline-stats{font-family:var(--font-mono);color:var(--fg-3);letter-spacing:.04em;font-size:11px}.timeline-actions{flex-wrap:wrap;gap:8px;display:flex}.timeline-actions button{background:var(--bg-elevated);border:1px solid var(--stroke-2);color:var(--fg-1);cursor:pointer;font-size:12px;font-family:var(--font-sans);border-radius:6px;padding:6px 12px}.timeline-actions button:hover:not(:disabled){border-color:var(--stroke-3);background:var(--bg-raised)}.timeline-actions button:disabled{opacity:.45;cursor:not-allowed}.timeline-error{color:#ff9b9b;background:#ff76761a;border:1px solid #ff76764d;border-radius:6px;padding:8px 12px;font-size:12px}.timeline-warning{color:#ffd87a;background:#ffc40014;border:1px solid #ffc40040;border-radius:6px;padding:8px 12px;font-size:12px}.timeline-stage-banner{color:#b8f0c8;background:#22c55e1a;border:1px solid #22c55e4d;border-radius:6px;align-items:flex-start;gap:10px;margin-top:6px;padding:10px 12px;font-size:12.5px;line-height:1.5;display:flex}.timeline-stage-banner-icon{color:#0a1f12;background:#22c55ed9;border-radius:50%;flex:none;justify-content:center;align-items:center;width:18px;height:18px;margin-top:1px;font-size:12px;font-weight:700;display:inline-flex}.timeline-stage-banner-body strong{color:#d8fae3;font-family:var(--font-serif)}.timeline-row-editor{background:#7c3aed0f;border:1px solid #7c3aed40;border-radius:6px;flex-direction:column;gap:4px;margin-top:6px;padding:8px;display:flex}.timeline-row-editor-label{font-size:11px;font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--fg-2)}.timeline-row-editor-input{background:var(--bg);width:100%;color:var(--fg);border:1px solid var(--border);font-family:var(--font-sans);resize:vertical;border-radius:4px;padding:6px 8px;font-size:13px;line-height:1.45}.timeline-row-editor-input:focus{border-color:#7c3aed8c;outline:1px solid #7c3aed8c}.timeline-row-editor-actions{justify-content:flex-end;gap:6px;margin-top:4px;display:flex}.timeline-row-editor-actions button{border:1px solid var(--border);color:var(--fg);cursor:pointer;background:0 0;border-radius:4px;padding:4px 10px;font-size:12px}.timeline-row-editor-actions button:disabled{opacity:.5;cursor:not-allowed}.timeline-row-editor-actions button.primary{background:var(--violet-500,#7c3aed);color:#fff;border-color:var(--violet-500,#7c3aed)}.timeline-subtitle-toggle{color:var(--fg-2);-webkit-user-select:none;user-select:none;cursor:pointer;align-items:center;gap:4px;padding:0 6px;font-size:12px;display:inline-flex}.timeline-subtitle-toggle input[type=checkbox]{cursor:pointer;accent-color:var(--violet-500,#7c3aed);margin:0}.timeline-aspect-picker{color:var(--fg-2);align-items:center;gap:4px;padding:0 6px;font-size:12px;display:inline-flex}.timeline-aspect-picker select{color:var(--fg);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:4px;padding:2px 4px;font-family:inherit;font-size:12px}.timeline-aspect-picker select:disabled{opacity:.5;cursor:not-allowed}.timeline-list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.timeline-row{background:var(--glass-1);border:1px solid var(--stroke-1);border-radius:8px;grid-template-columns:80px 1fr auto;align-items:start;gap:12px;padding:10px 12px;display:grid}.timeline-row-thumb{background:var(--glass-2);border:1px solid var(--stroke-1);border-radius:6px;justify-content:center;align-items:center;width:80px;height:80px;display:flex;position:relative;overflow:hidden}.timeline-row-thumb img{object-fit:cover;width:100%;height:100%;display:block}button.timeline-row-thumb-playable{cursor:pointer;font:inherit;color:inherit;padding:0}button.timeline-row-thumb-playable:hover .timeline-row-thumb-play,button.timeline-row-thumb-playable:focus-visible .timeline-row-thumb-play{background:#000000bf;transform:translate(-50%,-50%)scale(1.08)}button.timeline-row-thumb-playable:focus-visible{outline:2px solid var(--violet-500);outline-offset:2px}button.timeline-row-thumb-playable:disabled{cursor:not-allowed;opacity:.55}.timeline-row-thumb-play{color:#fff;text-align:center;pointer-events:none;text-shadow:0 1px 2px #00000073;box-sizing:border-box;background:#0000008c;border-radius:50%;width:32px;height:32px;padding-left:2px;font-size:14px;line-height:32px;transition:background .12s,transform .12s;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.timeline-thumb-pending{width:100%;height:100%;color:var(--fg-3);background:linear-gradient(135deg,#8b5cf60d 0%,#22d3ee0a 100%);flex-direction:column;justify-content:center;align-items:center;gap:4px;animation:2.4s ease-in-out infinite timeline-thumb-pulse;display:flex}.timeline-thumb-pending-icon{color:var(--violet-300);opacity:.55;font-size:18px}.timeline-thumb-pending-label{font-size:10px;font-family:var(--font-mono);letter-spacing:.05em;color:var(--fg-3)}@keyframes timeline-thumb-pulse{0%,to{opacity:.85}50%{opacity:1}}.timeline-thumb-progress{background:#8b5cf614;flex-direction:column;justify-content:center;align-items:center;gap:6px;width:100%;height:100%;padding:0 8px;display:flex}.timeline-thumb-progress-label{font-size:10px;font-family:var(--font-mono);color:var(--violet-300);letter-spacing:.05em}.timeline-thumb-progress-bar{background:var(--glass-3);border-radius:3px;width:100%;height:6px;position:relative;overflow:hidden}.timeline-thumb-progress-fill{background:linear-gradient(90deg, var(--violet-500) 0%, var(--violet-400) 100%);border-radius:3px;height:100%;transition:width .2s ease-out}.timeline-thumb-progress-bar--indeterminate:after{content:"";background:linear-gradient(90deg, transparent 0%, var(--violet-500) 50%, transparent 100%);width:40%;animation:1.2s linear infinite timeline-thumb-progress-sweep;position:absolute;inset:0}@keyframes timeline-thumb-progress-sweep{0%{transform:translate(-100%)}to{transform:translate(250%)}}.timeline-thumb-progress-pct{font-size:11px;font-family:var(--font-mono);color:var(--violet-300);font-weight:500}.timeline-row-body{flex-direction:column;gap:4px;min-width:0;display:flex}.timeline-row-id{font-family:var(--font-mono);color:var(--fg-3);font-size:11px}.timeline-row-prompt{color:var(--fg-1);text-overflow:ellipsis;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:13px;display:-webkit-box;overflow:hidden}.timeline-row-motion{color:var(--fg-2);font-size:12px}.timeline-row-duration{color:var(--fg-2);font-variant-numeric:tabular-nums;font-size:12px}.timeline-row-lines{border-left:2px solid var(--accent-3,#9ca3af);background:var(--bg-2);border-radius:3px;margin:4px 0 0;padding:4px 8px;font-size:12px;list-style:none}.timeline-row-line{align-items:baseline;gap:4px;padding:2px 0;display:flex}.timeline-row-line.is-narration{color:var(--fg-2);font-style:italic}.timeline-row-line-speaker{color:var(--accent,#3b82f6);white-space:nowrap;font-weight:600}.timeline-row-line.is-narration .timeline-row-line-speaker{color:var(--fg-3,#6b7280);font-weight:500}.timeline-row-line-text{flex:1;min-width:0}.timeline-row-line-emotion{color:var(--fg-3,#9ca3af);white-space:nowrap;font-size:11px}.timeline-row-badges{gap:8px;margin-top:4px;display:flex}.timeline-row-actions{flex-direction:column;gap:4px;display:flex}.timeline-row-actions button{border:1px solid var(--stroke-2);color:var(--fg-2);cursor:pointer;font-size:11px;font-family:var(--font-sans);white-space:nowrap;background:0 0;border-radius:4px;padding:4px 8px}.timeline-row-actions button:hover:not(:disabled){color:var(--fg-1);border-color:var(--stroke-3)}.timeline-row-actions button:disabled{opacity:.4;cursor:not-allowed}.badge{font-size:11px;font-family:var(--font-mono);letter-spacing:.02em;border:1px solid #0000;border-radius:10px;padding:2px 8px;display:inline-block}.badge-done{color:var(--cyan-300);background:#22d3ee1a;border-color:#22d3ee4d}.badge-pending{background:var(--glass-2);border-color:var(--stroke-1);color:var(--fg-3)}.badge-inflight{color:var(--violet-300);background:#8b5cf61f;border-color:#8b5cf659}.long-form-video-wrap{background:#000}.long-form-video-wrap video{outline:none;width:100%;max-height:60vh;display:block}.shot-clip-modal-subtitle{color:var(--fg-3);margin-left:8px;font-size:12px;font-weight:400}.shot-clip-modal-loading{color:var(--fg-3);text-align:center;padding:48px 16px;font-size:12px}.long-form-scrubber{border-top:1px solid var(--stroke-1);flex-direction:column;gap:8px;padding:12px 20px;display:flex}.long-form-time{font-family:var(--font-mono);color:var(--fg-2);font-size:12px}.long-form-current-shot{color:var(--cyan-300);margin-left:8px}.long-form-shot-strip{flex-wrap:wrap;gap:4px;margin:0;padding:0;list-style:none;display:flex}.long-form-shot-tick button{background:var(--glass-1);border:1px solid var(--stroke-2);color:var(--fg-2);font-size:10px;font-family:var(--font-mono);cursor:pointer;border-radius:4px;padding:3px 8px}.long-form-shot-tick button:hover{border-color:var(--stroke-3);color:var(--fg-1)}.long-form-shot-tick-active button{border-color:var(--violet-500);color:var(--violet-300);background:#8b5cf62e}.long-form-modal-footer{border-top:1px solid var(--stroke-1);justify-content:flex-end;gap:12px;padding:12px 20px;display:flex}.long-form-download,.long-form-share{background:var(--bg-elevated);border:1px solid var(--stroke-2);color:var(--fg-1);cursor:pointer;font-size:12px;font-family:var(--font-sans);border-radius:6px;padding:6px 14px;text-decoration:none;display:inline-block}.long-form-download:hover,.long-form-share:hover{border-color:var(--stroke-3);background:var(--bg-raised)}@media (max-width:768px){.animation-modal,.long-form-modal{border-radius:8px;width:100%;max-height:calc(100vh - 16px)}.timeline-row{grid-template-columns:60px 1fr}.timeline-row-actions{flex-flow:wrap;grid-column:1/-1}.long-form-modal-footer{flex-direction:column-reverse}}.codex-modal{width:min(1120px,100%)}.codex-modal-backdrop{animation:.15s ease-out codex-backdrop-in}.codex-modal-backdrop .codex-modal{transform-origin:50%;animation:.15s ease-out codex-modal-in}.codex-modal-backdrop.codex-modal-closing{animation:.12s ease-in forwards codex-backdrop-out}.codex-modal-backdrop.codex-modal-closing .codex-modal{animation:.12s ease-in forwards codex-modal-out}@keyframes codex-backdrop-in{0%{opacity:0}to{opacity:1}}@keyframes codex-backdrop-out{0%{opacity:1}to{opacity:0}}@keyframes codex-modal-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes codex-modal-out{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.96)}}@media (prefers-reduced-motion:reduce){.codex-modal-backdrop,.codex-modal-backdrop .codex-modal,.codex-modal-backdrop.codex-modal-closing,.codex-modal-backdrop.codex-modal-closing .codex-modal{animation:none}}.codex-empty-state{color:var(--fg-2);flex-direction:column;align-items:center;gap:8px;padding:60px 24px;display:flex}.codex-empty-state-glyph{opacity:.6;margin-bottom:4px;font-size:48px;line-height:1}.codex-empty-state-text{font-family:var(--font-serif);color:var(--fg-1);font-size:16px}.codex-empty-state-hint{color:var(--fg-3);text-align:center;max-width:360px;font-size:12px}.codex-empty-state-action{background:var(--glass-2);border:1px solid var(--stroke-2);color:var(--fg-1);font-size:12px;font-family:var(--font-sans);cursor:pointer;border-radius:8px;margin-top:12px;padding:8px 16px}.codex-empty-state-action:hover{background:var(--glass-3);border-color:var(--stroke-3)}.brick-form-tier-picker{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.brick-form-tier-button{background:var(--glass-1);border:1px solid var(--stroke-2);color:var(--fg-2);font-size:12px;font-family:var(--font-sans);cursor:pointer;letter-spacing:.04em;border-radius:6px;padding:6px 10px;transition:background .12s,border-color .12s,color .12s}.brick-form-tier-button:hover{background:var(--glass-2);border-color:var(--stroke-3)}.brick-form-tier-button-1{color:#d1d5db}.brick-form-tier-button-2{color:#d6a981}.brick-form-tier-button-3{color:#6ee7b7}.brick-form-tier-button-4{color:#d8b4fe}.brick-form-tier-button-5{color:#fcd34d}.brick-form-tier-button-active{background:var(--glass-3);border-color:var(--stroke-3)}.brick-form-tier-button-1.brick-form-tier-button-active{background:#6b72802e;border-color:#6b7280}.brick-form-tier-button-2.brick-form-tier-button-active{background:#a079552e;border-color:#a07955}.brick-form-tier-button-3.brick-form-tier-button-active{background:#3eb4892e;border-color:#3eb489}.brick-form-tier-button-4.brick-form-tier-button-active{background:#a855f72e;border-color:#a855f7}.brick-form-tier-button-5.brick-form-tier-button-active{background:#f5b3422e;border-color:#f5b342}.brick-form-tier-button-none.brick-form-tier-button-active{border-color:var(--violet-500);color:var(--violet-300)}.brick-row-tier{vertical-align:middle;-webkit-user-select:none;user-select:none;margin-left:6px;font-size:14px;line-height:1;display:inline-block}.brick-row-tier-1{color:#9ca3af}.brick-row-tier-2{color:#c69a78}.brick-row-tier-3{color:#5ed4a4}.brick-row-tier-4{color:#c084fc;text-shadow:0 0 6px #c084fc80}.brick-row-tier-5{color:#fcd34d;text-shadow:0 0 6px #fcd34d8c}.codex-tabs{border-bottom:1px solid var(--stroke-1);background:var(--bg-deep);flex-wrap:wrap;gap:4px;padding:10px 20px;display:flex}.codex-tab{color:var(--fg-2);font-size:12px;font-family:var(--font-sans);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:999px;align-items:center;gap:6px;padding:6px 12px;transition:background .12s,color .12s,border-color .12s;display:inline-flex}.codex-tab:hover{background:var(--glass-1);color:var(--fg-1)}.codex-tab-active{background:var(--glass-2);color:var(--fg-1);border-color:var(--stroke-2)}.codex-tab-count{color:var(--fg-3);font-size:10px;font-family:var(--font-mono)}.codex-search{border-bottom:1px solid var(--stroke-1);background:var(--bg-deep);padding:8px 20px}.codex-search-input{background:var(--glass-1);border:1px solid var(--stroke-2);width:100%;color:var(--fg-1);font-size:12px;font-family:var(--font-sans);box-sizing:border-box;border-radius:8px;padding:7px 12px}.codex-search-input:focus{border-color:var(--violet-500);background:var(--glass-2);outline:none}.codex-search-input::placeholder{color:var(--fg-3)}.codex-toolbar{background:var(--bg-deep);border-bottom:1px solid var(--stroke-1);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:6px 20px 10px;display:flex}.codex-tier-filter{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.codex-tier-pip{background:var(--glass-1);border:1px solid var(--stroke-2);width:24px;height:24px;color:var(--fg-3);font-size:11px;font-family:var(--font-mono);cursor:pointer;border-radius:50%;padding:0;transition:background .12s,border-color .12s,color .12s}.codex-tier-pip:hover{background:var(--glass-2);border-color:var(--stroke-3);color:var(--fg-1)}.codex-tier-pip-1.codex-tier-pip-active{color:#d1d5db;background:#6b72804d;border-color:#6b7280}.codex-tier-pip-2.codex-tier-pip-active{color:#d6a981;background:#a079554d;border-color:#a07955}.codex-tier-pip-3.codex-tier-pip-active{color:#6ee7b7;background:#3eb4894d;border-color:#3eb489}.codex-tier-pip-4.codex-tier-pip-active{color:#d8b4fe;background:#a855f74d;border-color:#a855f7}.codex-tier-pip-5.codex-tier-pip-active{color:#fcd34d;background:#f5b3424d;border-color:#f5b342}.codex-tier-include-untied{color:var(--fg-3);font-size:11px;font-family:var(--font-sans);cursor:pointer;align-items:center;gap:4px;margin-left:8px;display:inline-flex}.codex-tier-include-untied input{accent-color:var(--violet-500);cursor:pointer}.codex-sort-toggle{background:var(--glass-2);border:1px solid var(--stroke-2);color:var(--fg-2);font-size:11px;font-family:var(--font-mono);cursor:pointer;letter-spacing:.04em;border-radius:6px;padding:4px 10px}.codex-sort-toggle:hover{background:var(--glass-3);border-color:var(--stroke-3);color:var(--fg-1)}.codex-body{flex:1;min-height:0;padding:16px 20px;overflow-y:auto}.codex-empty{color:var(--fg-3);text-align:center;margin:24px 0;font-size:13px}.codex-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;margin:0;padding:0;list-style:none;display:grid}.codex-card{background:var(--bg-raised);border:1px solid var(--stroke-2);font-family:var(--font-sans);color:var(--fg-1);border-radius:10px;flex-direction:column;transition:transform .12s,border-color .12s,box-shadow .12s;display:flex;overflow:hidden}.codex-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000059}.codex-card-tier-1{border-color:#6b7280}.codex-card-tier-2{border-color:#a07955;box-shadow:inset 0 0 0 1px #c49a6d59}.codex-card-tier-3{border-color:#3eb489;box-shadow:0 0 8px #3eb4894d}.codex-card-tier-4{border-color:#a855f7;animation:3s ease-in-out infinite codex-tier4-breathe}.codex-card-tier-5{isolation:isolate;border-color:#f5b3428c;position:relative;overflow:visible}.codex-card-tier-5:before{content:"";z-index:-1;filter:blur(6px);opacity:.7;background:conic-gradient(#fbbf24,#fef3c7,#fbbf24,#f59e0b,#ffd382,#fbbf24);border-radius:13px;animation:6s linear infinite codex-tier5-rotate;position:absolute;inset:-3px}.codex-card-tier-1:hover{border-color:#9ca3af}.codex-card-tier-2:hover{border-color:#c69a78}.codex-card-tier-3:hover{border-color:#5ed4a4;box-shadow:0 0 14px #5ed4a473}.codex-card-tier-4:hover{border-color:#c084fc}.codex-card-tier-5:hover:before{opacity:.9;filter:blur(4px)}@keyframes codex-tier4-breathe{0%,to{box-shadow:0 0 8px #a855f759}50%{box-shadow:0 0 20px #a855f7a6}}@keyframes codex-tier5-rotate{to{transform:rotate(360deg)}}@media (prefers-reduced-motion:reduce){.codex-card-tier-4{animation:none;box-shadow:0 0 14px #a855f780}.codex-card-tier-5:before{animation:none}}.codex-card-kind-character:not([class*=\ codex-card-tier-]){border-color:#a78bfa8c}.codex-card-kind-scene:not([class*=\ codex-card-tier-]){border-color:#06b6d48c}.codex-card-kind-prop:not([class*=\ codex-card-tier-]){border-color:#f59e0b8c}.codex-card-tier-badge{color:#fef3c7;letter-spacing:.04em;text-shadow:0 1px 2px #0009;pointer-events:none;-webkit-user-select:none;user-select:none;background:#0000008c;border-radius:6px;padding:3px 6px;font-size:12px;line-height:1;position:absolute;top:6px;right:8px}.codex-card-avatar{aspect-ratio:3/4;background:var(--bg-deep);justify-content:center;align-items:center;width:100%;display:flex;position:relative;overflow:hidden}.codex-card-avatar img{object-fit:cover;width:100%;height:100%;display:block}.codex-card-placeholder{font-family:var(--font-serif);color:var(--fg-3);letter-spacing:0;-webkit-user-select:none;user-select:none;font-size:56px;line-height:1}.codex-card-meta{flex-direction:column;gap:4px;padding:10px 12px;display:flex}.codex-card-name{font-family:var(--font-serif);color:var(--fg-1);text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:600;line-height:1.25;overflow:hidden}.codex-card-summary{color:var(--fg-3);-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;font-size:11px;line-height:1.4;display:-webkit-box;overflow:hidden}.codex-card-button{all:unset;cursor:pointer;color:inherit;font:inherit;text-align:left;flex-direction:column;display:flex}.codex-card-button:focus-visible{outline:2px solid var(--violet-500);outline-offset:-2px;border-radius:9px}.codex-detail{flex-direction:column;gap:16px;max-width:960px;margin:0 auto;display:flex}.codex-detail-toolbar{justify-content:space-between;align-items:center;display:flex}.codex-detail-back,.codex-detail-edit{background:var(--glass-2);border:1px solid var(--stroke-2);color:var(--fg-1);font-size:12px;font-family:var(--font-sans);cursor:pointer;border-radius:8px;padding:6px 12px}.codex-detail-back:hover,.codex-detail-edit:hover{background:var(--glass-3);border-color:var(--stroke-3)}.codex-detail-edit{background:var(--violet-600);border-color:var(--violet-500);color:#fff}.codex-detail-edit:hover{background:var(--violet-500)}.codex-detail-grid{grid-template-columns:minmax(220px,40%) 1fr;align-items:start;gap:24px;display:grid}.codex-detail-aside{flex-direction:column;gap:12px;display:flex;position:sticky;top:0}.codex-detail-main{flex-direction:column;gap:18px;min-width:0;display:flex}.codex-detail-art{aspect-ratio:3/4;background:var(--bg-deep);border:1px solid var(--stroke-2);border-radius:12px;justify-content:center;align-items:center;width:100%;display:flex;overflow:hidden}.codex-detail-art img{object-fit:contain;width:100%;height:100%;display:block}.codex-detail-art-placeholder{font-family:var(--font-serif);color:var(--fg-3);-webkit-user-select:none;user-select:none;font-size:96px}.codex-detail-pills{flex-wrap:wrap;gap:6px;display:flex}.codex-detail-pill{font-size:11px;font-family:var(--font-sans);background:var(--glass-2);border:1px solid var(--stroke-2);color:var(--fg-2);letter-spacing:.02em;border-radius:999px;align-items:center;padding:3px 10px;display:inline-flex}.codex-detail-pill-id{font-family:var(--font-mono);color:var(--fg-3)}.codex-detail-pill-kind-character{color:var(--violet-300);background:#8b5cf62e;border-color:#a78bfa8c}.codex-detail-pill-kind-scene{color:#67e8f9;background:#06b6d42e;border-color:#06b6d48c}.codex-detail-pill-kind-prop{color:var(--gold-300);background:#f59e0b2e;border-color:#f59e0b8c}.codex-detail-pill-tier-1{color:#d1d5db;border-color:#6b7280}.codex-detail-pill-tier-2{color:#d6a981;border-color:#a07955}.codex-detail-pill-tier-3{color:#6ee7b7;border-color:#3eb489}.codex-detail-pill-tier-4{color:#d8b4fe;border-color:#a855f7}.codex-detail-pill-tier-5{color:#fcd34d;border-color:#f5b342}.codex-detail-summary{font-family:var(--font-serif);color:var(--fg-1);margin:0;font-size:14px;line-height:1.7}.codex-detail-section{border-top:1px solid var(--stroke-1);flex-direction:column;gap:8px;padding-top:12px;display:flex}.codex-detail-section-title{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.18em;color:var(--fg-3);margin:0;font-size:11px}.codex-detail-kv{flex-direction:column;gap:6px;margin:0;display:flex}.codex-detail-kv-row{grid-template-columns:140px 1fr;align-items:start;gap:12px;display:grid}.codex-detail-kv-row dt{font-family:var(--font-sans);color:var(--fg-3);font-size:12px}.codex-detail-kv-row dd{color:var(--fg-2);font-size:12px;font-family:var(--font-sans);white-space:pre-wrap;overflow-wrap:anywhere;margin:0}.codex-detail-list{color:var(--fg-2);flex-direction:column;gap:4px;margin:0;padding-left:18px;font-size:12px;display:flex}.codex-detail-list li{white-space:pre-wrap;overflow-wrap:anywhere;line-height:1.5}.readable-fields{flex-direction:column;gap:10px;margin:0;display:flex}.readable-fields-row{grid-template-columns:132px 1fr;align-items:start;gap:14px;display:grid}.readable-fields-label{font-family:var(--font-sans);color:var(--fg-dim);font-size:12px;font-weight:600;line-height:1.5}.readable-fields-value{color:var(--fg);margin:0;font-size:13px;line-height:1.6}.readable-fields-text{white-space:pre-wrap;overflow-wrap:anywhere}.readable-fields-empty{color:var(--fg-faint)}.readable-fields-list{flex-direction:column;gap:3px;margin:0;padding-left:18px;display:flex}.readable-fields-list li{overflow-wrap:anywhere;line-height:1.55}.readable-fields-nested{border-left:1px solid var(--stroke-1);gap:5px;padding:6px 0 2px 10px}.readable-fields-nested .readable-fields-row{grid-template-columns:110px 1fr;gap:10px}.readable-fields-nested .readable-fields-label{font-size:11px;font-weight:500}.readable-fields-nested .readable-fields-value{font-size:12px}@media (max-width:768px){.readable-fields-row,.readable-fields-nested .readable-fields-row{grid-template-columns:1fr;gap:2px}.codex-detail-grid{grid-template-columns:1fr}.codex-detail-aside{position:static}}.sprite-studio-modal{background:var(--surface,#15151c);border:1px solid #ffffff1f;border-radius:14px;width:min(880px,92vw);max-height:88vh;padding:20px 22px;overflow:auto;box-shadow:0 24px 64px #00000080}.sprite-studio-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.sprite-studio-header h2{margin:0;font-size:1.05rem}.sprite-studio-controls{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:12px;display:flex}.sprite-studio-controls label{align-items:center;gap:6px;font-size:.85rem;display:flex}.sprite-studio-error{color:#ff8080;margin:8px 0;font-size:.85rem}.sprite-studio-preview{background-image:linear-gradient(45deg,#ffffff0d 25%,#0000 25%),linear-gradient(-45deg,#ffffff0d 25%,#0000 25%),linear-gradient(45deg,#0000 75%,#ffffff0d 75%),linear-gradient(-45deg,#0000 75%,#ffffff0d 75%);background-position:0 0,0 10px,10px -10px,-10px 0;background-size:20px 20px;border:1px dashed #ffffff26;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:10px;min-height:220px;padding:16px;display:flex}.sprite-studio-sheet{max-width:100%;max-height:60vh;image-rendering:pixelated}.sprite-studio-empty{color:#fff9;text-align:center;max-width:460px;font-size:.88rem}.sprite-studio-meta{color:#ffffffb3;font-size:.8rem}.pack-studio-list{border:1px solid #ffffff1f;border-radius:10px;max-height:46vh;margin:10px 0;padding:6px;overflow:auto}.pack-studio-list ul{margin:0;padding:0;list-style:none}.pack-studio-row{border-radius:6px;justify-content:space-between;align-items:center;gap:10px;padding:6px 8px;display:flex}.pack-studio-row:hover{background:#ffffff0d}.pack-studio-row label{cursor:pointer;flex:1;align-items:center;gap:8px;display:flex}.pack-studio-row-type{text-transform:uppercase;letter-spacing:.04em;color:#ffffff8c;min-width:92px;font-size:.72rem}.pack-studio-row-name{font-size:.9rem}.button-small{padding:2px 8px;font-size:.8rem}.bookshelf{max-width:1040px;margin:0 auto;padding:48px 24px 80px}.bookshelf-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:32px;display:flex}.bookshelf-head h1{font-family:var(--font-serif);margin:4px 0 6px;font-size:28px}.bookshelf-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:22px;display:grid}.book-card{flex-direction:column;gap:8px;display:flex}.book-cover{aspect-ratio:3/4;border:1px solid var(--stroke-2);cursor:pointer;text-align:left;width:100%;color:var(--fg-1);background:linear-gradient(135deg, hsl(var(--book-hue,265) 45% 22%), hsl(calc(var(--book-hue,265) + 24) 40% 14%));box-shadow:inset 0 0 0 1px hsl(var(--book-hue,265) 50% 40% / .25);transition:transform .14s var(--ease-out), box-shadow .14s var(--ease-out);border-radius:10px;padding:16px 16px 16px 22px;position:relative;overflow:hidden}.book-cover:hover{box-shadow:0 10px 30px -14px hsl(var(--book-hue,265) 60% 40% / .7);transform:translateY(-3px)}.book-cover-readonly{background:linear-gradient(135deg, hsl(var(--book-hue,194) 36% 20%), hsl(calc(var(--book-hue,194) + 30) 28% 12%))}.book-spine{background:hsl(var(--book-hue,265) 55% 50% / .85);border-radius:10px 0 0 10px;width:8px;position:absolute;top:0;bottom:0;left:0}.book-title{font-family:var(--font-serif);text-shadow:0 1px 8px #0006;word-break:break-word;font-size:17px;font-weight:600;line-height:1.4;display:block}.book-badge{color:var(--fg-2);background:#00000059;border-radius:999px;padding:1px 7px;font-size:10px;position:absolute;bottom:10px;right:10px}.book-rename-input{border:1px solid var(--stroke-glow);width:100%;color:var(--fg-1);font-family:var(--font-serif);background:#00000059;border-radius:6px;padding:4px 6px;font-size:16px}.book-cloud-meta{min-height:14px;color:var(--fg-faint);font-family:var(--font-mono);text-overflow:ellipsis;white-space:nowrap;font-size:10px;line-height:1.3;overflow:hidden}.book-actions{opacity:0;transition:opacity .12s var(--ease-out);gap:6px;display:flex}.book-card:hover .book-actions{opacity:1}.book-badge-pub{color:#d7f7e6;background:#26734d99;left:10px;right:auto}.home-hero{text-align:center;border-bottom:1px solid var(--stroke-2);margin-bottom:36px;padding:24px 0 44px}.home-hero-emblem{object-fit:contain;opacity:.95;border-radius:16px;width:64px;height:64px;margin-bottom:14px}.home-hero-title{font-family:var(--font-serif);margin:8px 0 10px;font-size:34px;line-height:1.2}.home-hero-sub{color:var(--fg-2,var(--fg-dim));max-width:620px;margin:0 auto;font-size:15px;line-height:1.7}.home-hero-cta{flex-wrap:wrap;justify-content:center;gap:12px;margin-top:22px;display:flex}.button-ghost{border:1px solid var(--stroke-2);color:var(--fg-2,var(--fg-dim));background:0 0;border-radius:8px;align-items:center;padding:0 16px;text-decoration:none;display:inline-flex}.button-ghost:hover{border-color:var(--stroke-glow,var(--accent));color:var(--fg-1,var(--fg))}.home-section{margin-bottom:44px;scroll-margin-top:24px}.home-section-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:22px;display:flex}.home-section-head h2{font-family:var(--font-serif);margin:4px 0 0;font-size:22px}.showcase-grid{grid-template-columns:repeat(auto-fill,minmax(min(220px,100%),1fr));gap:20px;display:grid}.showcase-card{border:1px solid var(--stroke-2);background:var(--bg-pane);transition:transform .14s var(--ease-out), box-shadow .14s var(--ease-out);border-radius:12px;flex-direction:column;display:flex;overflow:hidden}.showcase-card:hover{box-shadow:0 14px 36px -18px hsl(var(--case-hue,265) 60% 40% / .7);transform:translateY(-3px)}.showcase-cover{aspect-ratio:16/9;cursor:pointer;background:linear-gradient(135deg, hsl(var(--case-hue,265) 48% 26%), hsl(calc(var(--case-hue,265) + 30) 42% 15%));border:none;justify-content:center;align-items:center;width:100%;padding:0;display:flex;position:relative;overflow:hidden}.showcase-cover-img{object-fit:cover;width:100%;height:100%}.showcase-cover-genre{font-family:var(--font-serif);color:#fff;text-shadow:0 2px 12px #00000073;letter-spacing:.08em;font-size:22px;font-weight:700}.showcase-source{color:var(--fg-2,#ddd);background:#00000073;border-radius:999px;padding:2px 8px;font-size:10px;position:absolute;top:8px;right:8px}.showcase-body{flex-direction:column;gap:7px;padding:12px 14px 14px;display:flex}.showcase-title{font-family:var(--font-serif);font-size:16px;font-weight:600}.showcase-hook{color:var(--fg-2,var(--fg-dim));-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:12.5px;line-height:1.55;display:-webkit-box;overflow:hidden}.showcase-tags{flex-wrap:wrap;gap:6px;display:flex}.showcase-tag{border:1px solid var(--stroke-2);color:var(--fg-faint);border-radius:999px;padding:1px 8px;font-size:10.5px}.showcase-actions{gap:8px;margin-top:4px;display:flex}.showcase-actions .button{flex:1}.page-scroll{flex:1;min-height:0;overflow:hidden auto}.landing{background:var(--bg-base);flex-direction:column;flex:1;min-height:0;display:flex;position:relative;overflow:hidden auto}.landing-aurora{z-index:0;pointer-events:none;filter:blur(24px);will-change:transform;background:radial-gradient(600px 420px at 18% 14%,#a78bfa42,#0000 60%),radial-gradient(560px 440px at 84% 26%,#22d3ee2e,#0000 60%),radial-gradient(560px 520px at 62% 96%,#7c3aed29,#0000 62%);animation:24s ease-in-out infinite alternate aurora-drift;position:fixed;inset:-15%}.landing-nav,.landing-body,.landing-footer{z-index:1;position:relative}@keyframes aurora-drift{0%{transform:translate(0,0)scale(1)}50%{transform:translate(2.5%,-2%)scale(1.06)}to{transform:translate(-2%,1.5%)scale(1.03)}}@keyframes fade-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.landing-hero>*{animation:fade-up .7s var(--ease-out) both}.landing-hero>:first-child{animation-delay:20ms}.landing-hero>:nth-child(2){animation-delay:.1s}.landing-hero>:nth-child(3){animation-delay:.18s}.landing-hero>:nth-child(4){animation-delay:.26s}.landing-hero>:nth-child(5){animation-delay:.34s}.landing-hero>:nth-child(6){animation-delay:.42s}.landing-hero .home-hero-emblem{animation:fade-up .7s var(--ease-out) both, emblem-glow 5s ease-in-out .8s infinite}@keyframes emblem-glow{0%,to{filter:drop-shadow(0 0 14px #a78bfa59)}50%{filter:drop-shadow(0 0 28px #22d3ee80)}}@supports (animation-timeline:view()){@media (prefers-reduced-motion:no-preference){.landing .home-section{animation:fade-up .8s var(--ease-out) both;animation-timeline:view();animation-range:entry 2% cover 22%}}}.landing .button-primary{position:relative;overflow:hidden}.landing .button-primary:after{content:"";transition:transform .6s var(--ease-out);background:linear-gradient(115deg,#0000 30%,#ffffff47 50%,#0000 70%);position:absolute;inset:0;transform:translate(-120%)}.landing .button-primary:hover:after{transform:translate(120%)}.howit-card{transition:transform .14s var(--ease-out), border-color .14s var(--ease-out), box-shadow .14s var(--ease-out)}.howit-card:hover{border-color:var(--stroke-glow,#a78bfa);transform:translateY(-3px);box-shadow:0 16px 40px -22px #a78bfa99}@media (prefers-reduced-motion:reduce){.landing-aurora,.landing-hero>*,.landing-hero .home-hero-emblem,.landing .button-primary:after{transition:none;animation:none}}.landing-nav{z-index:20;border-bottom:1px solid var(--stroke-2);background:color-mix(in srgb, var(--bg-base) 82%, transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);justify-content:space-between;align-items:center;gap:16px;padding:12px 24px;display:flex;position:sticky;top:0}.landing-brand{font-family:var(--font-serif);align-items:center;gap:10px;font-size:16px;font-weight:600;display:flex}.landing-brand-mark{object-fit:cover;border-radius:8px;width:28px;height:28px}.landing-nav-links{align-items:center;gap:18px;display:flex}.landing-nav-link{color:var(--fg-2,var(--fg-dim));font-size:13px;text-decoration:none}.landing-nav-link:hover{color:var(--fg-1,var(--fg))}.landing-body{flex:1;width:100%;max-width:1040px;margin:0 auto;padding:8px 24px 64px}.landing-hero{border-bottom:none;padding-top:52px}.landing-hero-note{color:var(--fg-faint);font-size:12px;font-family:var(--font-mono);margin-top:14px}.howit-grid{grid-template-columns:repeat(auto-fit,minmax(min(240px,100%),1fr));gap:18px;display:grid}.howit-card{border:1px solid var(--stroke-2);background:var(--bg-pane);border-radius:12px;padding:22px 20px}.howit-num{width:34px;height:34px;font-family:var(--font-serif);color:#0f1424;background:linear-gradient(135deg,#c4b5fd,#22d3ee);border-radius:9px;justify-content:center;align-items:center;margin-bottom:14px;font-weight:700;display:flex}.howit-title{font-family:var(--font-serif);margin-bottom:8px;font-size:17px;font-weight:600}.howit-desc{color:var(--fg-2,var(--fg-dim));font-size:13px;line-height:1.7}.pd{border:1px solid var(--stroke-2);background:var(--bg-pane);border-radius:14px;align-items:stretch;gap:10px;margin-bottom:28px;padding:20px;display:flex}.pd-col{opacity:.42;transition:opacity .55s var(--ease-out), transform .55s var(--ease-out), border-color .55s var(--ease-out), box-shadow .55s var(--ease-out), background .55s var(--ease-out);border:1px solid #0000;border-radius:12px;flex-direction:column;flex:1;gap:10px;padding:16px;display:flex;transform:scale(.98)}.pd-on{opacity:1;border-color:var(--stroke-glow,#a78bfa);background:color-mix(in srgb, var(--accent,#a78bfa) 7%, transparent);transform:scale(1);box-shadow:0 14px 38px -22px #a78bfab3}.pd-static .pd-col{opacity:1;transform:none}.pd-step{font-family:var(--font-serif);color:var(--fg-1,var(--fg));font-size:14px;font-weight:600}.pd-arrow{color:var(--fg-faint);flex:none;align-self:center;font-size:20px}.pd-bricks{flex-direction:column;gap:7px;display:flex}.pd-brick{border-left:3px solid var(--stroke-2);background:var(--bg);color:var(--fg-2,var(--fg-dim));border-radius:7px;padding:6px 10px;font-size:12px}.pd-brick-char{border-left-color:#c4b5fd}.pd-brick-world{border-left-color:#22d3ee}.pd-brick-rel{border-left-color:#fbbf24}.pd-cand{background:var(--bg);border:1px solid var(--stroke-2);color:var(--fg-2,var(--fg-dim));border-radius:8px;padding:9px 11px;font-size:12px;line-height:1.5}.pd-cand-pick{color:var(--fg-1,var(--fg));border-color:#34d399}.pd-pick{color:#34d399;margin-right:6px;font-weight:700}.pd-tree{flex-direction:column;align-items:center;gap:12px;padding-top:6px;display:flex}.pd-node{background:var(--bg);border:1px solid var(--stroke-2);color:var(--fg-1,var(--fg));border-radius:999px;padding:6px 12px;font-size:12px}.pd-node-root{color:#0f1424;background:linear-gradient(135deg,#c4b5fd,#22d3ee);border-color:#0000;font-weight:600}.pd-fork{gap:12px;display:flex;position:relative}.pd-fork:before{content:"";background:var(--stroke-2);width:1px;height:12px;position:absolute;top:-12px;left:50%}.pd-branch-a{border-color:#c4b5fd}.pd-branch-b{border-color:#fbbf24}@media (max-width:640px){.pd{flex-direction:column}.pd-arrow{transform:rotate(90deg)}}.landing-footer{border-top:1px solid var(--stroke-2);background:var(--bg-deep,var(--bg-pane));padding:28px 24px}.landing-footer-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;max-width:1040px;margin:0 auto;display:flex}.landing-footer-links{flex-wrap:wrap;gap:18px;display:flex}.landing-footer-copy{border-top:1px solid var(--divider,var(--stroke-2));max-width:1040px;color:var(--fg-faint);font-size:11px;font-family:var(--font-mono);margin:16px auto 0;padding-top:14px}.case-hero{border-bottom:1px solid var(--border,var(--stroke-2));margin-bottom:28px;padding-bottom:24px}.case-hero-back{color:var(--fg-2,var(--fg-dim));font-size:13px;font-family:var(--font-serif);margin-bottom:18px;text-decoration:none;display:inline-block}.case-hero-back:hover{color:var(--fg-1,var(--fg))}.case-hero-eyebrow{font-size:11px;font-family:var(--font-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--fg-faint);align-items:center;gap:10px;display:flex}.case-hero-genre{color:#0f1424;letter-spacing:.04em;background:linear-gradient(135deg,#c4b5fd,#22d3ee);border-radius:999px;padding:2px 10px;font-weight:700}.case-hero-title{font-family:var(--font-serif);color:var(--fg);margin:12px 0 8px;font-size:30px}.case-hero-logline{color:var(--fg-2,var(--fg-dim));max-width:640px;margin:0 0 14px;font-size:15px;line-height:1.7}.case-hero-stats{color:var(--fg-faint);font-size:12px;font-family:var(--font-mono);gap:8px;margin-bottom:18px;display:flex}.case-hero-cta .button{text-decoration:none}.onboarding-card{border:1px dashed var(--stroke-glow,var(--accent));text-align:center;background:linear-gradient(180deg, color-mix(in srgb, var(--accent,#a78bfa) 8%, transparent), transparent);border-radius:14px;margin-bottom:24px;padding:28px 24px}.onboarding-emoji{margin-bottom:8px;font-size:26px}.onboarding-title{font-family:var(--font-serif);font-size:20px;font-weight:600}.onboarding-sub{color:var(--fg-2,var(--fg-dim));margin:6px 0 20px;font-size:13px}.onboarding-steps{grid-template-columns:repeat(auto-fit,minmax(min(240px,100%),1fr));gap:14px;max-width:620px;margin:0 auto;display:grid}.onboarding-step{text-align:left;border:1px solid var(--stroke-2);background:var(--bg-pane);color:var(--fg-1,var(--fg));cursor:pointer;transition:transform .12s var(--ease-out), border-color .12s var(--ease-out);border-radius:10px;flex-direction:column;gap:6px;padding:16px;text-decoration:none;display:flex}.onboarding-step:hover{border-color:var(--stroke-glow,var(--accent));transform:translateY(-2px)}.onboarding-step-num{width:24px;height:24px;font-family:var(--font-serif);color:#0f1424;background:linear-gradient(135deg,#c4b5fd,#22d3ee);border-radius:7px;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.onboarding-step-title{font-family:var(--font-serif);font-size:15px;font-weight:600}.onboarding-step-desc{color:var(--fg-2,var(--fg-dim));font-size:12px;line-height:1.55}.onboarding-step-form{cursor:default}.onboarding-step-form:hover{transform:none}.onboarding-seed-input{box-sizing:border-box;background:var(--bg);width:100%;color:var(--fg-1,var(--fg));border:1px solid var(--stroke-2);border-radius:7px;margin-top:2px;padding:7px 10px;font-family:inherit;font-size:12.5px}.onboarding-seed-input:focus{border-color:var(--stroke-glow,#a78bfa);outline:none}@media (hover:none){.book-actions{opacity:1}}@media (max-width:640px){.home-hero-title{font-size:26px}.home-hero{padding:14px 0 30px}.landing-hero{padding-top:28px}.home-hero-sub{font-size:14px}.home-hero-cta{flex-direction:column;align-items:stretch}.home-hero-cta .button,.home-hero-cta .button-ghost{justify-content:center}.landing-nav{padding:10px 16px}.landing-nav-links{gap:12px}.landing-nav-links .landing-nav-link{display:none}.landing-body{padding:8px 16px 48px}.bookshelf{padding:28px 16px 64px}.home-section-head,.landing-footer-inner{flex-direction:column;align-items:flex-start}}.outline-panel{flex-direction:column;flex:1;gap:12px;min-width:0;min-height:0;padding:14px 16px;display:flex;overflow:hidden auto}.outline-panel input,.outline-panel textarea{box-sizing:border-box}.outline-controls{flex-direction:column;gap:8px;display:flex}.outline-premise{background:var(--bg-pane-2);border:1px solid var(--stroke-2);width:100%;color:var(--fg-1);border-radius:8px;padding:8px 10px;font-size:14px}.outline-controls-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.outline-genre{background:var(--bg-pane-2);border:1px solid var(--stroke-2);min-width:120px;color:var(--fg-1);border-radius:8px;flex:1;padding:6px 10px}.outline-count{color:var(--fg-2);align-items:center;gap:6px;font-size:12px;display:flex}.outline-count input{background:var(--bg-pane-2);border:1px solid var(--stroke-2);width:56px;color:var(--fg-1);border-radius:8px;padding:6px 8px}.outline-error{color:var(--red-400,#f87171);margin:0;font-size:13px}.outline-seed-info{color:var(--fg-2);margin:0;font-size:13px}.outline-empty{text-align:center;color:var(--fg-2);padding:24px 8px}.outline-meta{flex-wrap:wrap;align-items:center;gap:10px;font-size:12px;display:flex}.outline-list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.outline-chapter{background:var(--glass-1);border:1px solid var(--stroke-2);border-radius:10px;padding:8px 10px}.outline-chapter-head{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.outline-chapter-n{background:var(--bg-pane-2);width:24px;height:24px;color:var(--fg-2);text-align:center;font-size:12px;line-height:24px;font-family:var(--font-mono);border-radius:6px;flex:none}.outline-chapter-title{min-width:0;color:var(--fg-1);font-family:var(--font-serif);background:0 0;border:0;border-bottom:1px solid #0000;flex:1;padding:2px 0;font-size:15px}.outline-chapter-title:focus{border-bottom-color:var(--stroke-glow);outline:none}.outline-chapter-summary{background:var(--bg-pane-2);border:1px solid var(--stroke-2);width:100%;color:var(--fg-2);resize:vertical;border-radius:6px;margin-top:6px;padding:6px 8px;font-size:13px}.consistency-report{margin:8px 0 14px}.consistency-list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.consistency-issue{background:var(--glass-1);border:1px solid var(--stroke-2);border-left:3px solid var(--fg-faint);border-radius:8px;padding:8px 10px;font-size:13px}.consistency-issue.sev-high{border-left-color:#f87171}.consistency-issue.sev-medium{border-left-color:#fbbf24}.consistency-issue.sev-low{border-left-color:#60a5fa}.consistency-sev{background:var(--bg-pane-2);color:var(--fg-2);font-size:10px;font-family:var(--font-mono);border-radius:999px;margin-right:6px;padding:1px 6px;display:inline-block}.consistency-problem{color:var(--fg-1)}.consistency-where{color:var(--fg-3);margin-top:3px;font-size:12px}.consistency-fix{color:var(--cyan-300,#67e8f9);margin-top:3px;font-size:12px}
