:root{--ink:#111827;--muted:#667085;--line:#e5e7eb;--paper:#fffdf8;--panel:#fff;--wash:#f4f6fb;--accent:#5b5ef7;--accent-soft:#eef0ff;--good:#0f766e;color:var(--ink);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#eef0f5;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{overscroll-behavior:none;margin:0}button{border:1px solid var(--line);color:var(--ink);font:inherit;cursor:pointer;background:#fff;border-radius:999px;padding:.65rem .9rem;font-size:.9rem;transition:all .15s}button:hover:not(:disabled){border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}button:disabled{cursor:not-allowed;opacity:.45}button.active{background:var(--accent);border-color:var(--accent);color:#fff}#root{min-height:100vh}.app-shell{width:min(1720px,100vw - 20px);margin:0 auto;padding:16px 0}.hero-bar{margin-bottom:22px}.eyebrow{color:var(--accent);letter-spacing:.11em;text-transform:uppercase;margin:0 0 8px;font-size:.78rem;font-weight:800}h1,h2{margin:0}h1{letter-spacing:-.07em;max-width:840px;font-size:clamp(2.4rem,5vw,5.5rem);line-height:.95}.lede{max-width:780px;color:var(--muted);margin:18px 0 0;font-size:1.05rem}.status-card,.canvas-panel,.transcript-panel{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffffdb;border:1px solid #11182714;box-shadow:0 24px 70px #10182814}.status-card{border-radius:28px;padding:22px}.status-card span,.scene-read span{color:var(--muted);letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px;font-size:.78rem;font-weight:800;display:block}.status-card strong{line-height:1.25;display:block}.workspace{grid-template-columns:minmax(0,1fr) 380px;gap:14px;display:grid}.canvas-panel,.transcript-panel{border-radius:30px;overflow:hidden}.toolbar{border-bottom:1px solid var(--line);background:var(--panel);flex-wrap:wrap;align-items:center;gap:8px;padding:14px;display:flex}.control-label{border:1px solid var(--line);background:var(--wash);color:var(--muted);white-space:nowrap;border-radius:999px;align-items:center;gap:8px;padding:.45rem .75rem;font-size:.78rem;font-weight:700;display:inline-flex}.control-label input{width:90px}.zoom-pill{background:var(--accent-soft);min-height:38px;color:var(--accent);white-space:nowrap;border:1px solid #5b5ef72e;border-radius:999px;align-items:center;padding:.45rem .75rem;font-size:.78rem;font-weight:800;display:inline-flex}.status-card small{color:var(--muted);margin-top:10px;font-size:.85rem;display:block}.canvas-panel{overscroll-behavior:contain;touch-action:none}.drawing-canvas{background:var(--paper);touch-action:none;cursor:crosshair;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;overscroll-behavior:contain;width:100%;height:clamp(560px,82svh,900px);min-height:0;display:block}.draft-shape{fill:#5b5ef714;stroke:var(--accent);stroke-width:3px;stroke-dasharray:8 8;stroke-linecap:round;stroke-linejoin:round}.draft-point{fill:var(--accent);stroke:none}.selection-box{fill:none;stroke:var(--accent);stroke-width:1.5px;stroke-dasharray:6 5;pointer-events:none}.selected-shape{filter:drop-shadow(0 0 6px #5b5ef752)}.transcript-panel{background:#fbfcff;flex-direction:column;display:flex;overflow-y:auto}.panel-header{border-bottom:1px solid var(--line);background:var(--panel);justify-content:space-between;align-items:center;gap:16px;padding:20px;display:flex}.panel-header h2{font-size:1.35rem}.narrator{color:var(--good);background:#effcf9;border:1px solid #0f766e2e;border-radius:22px;margin:18px;padding:18px}.narrator p{color:#134e4a;margin:0;line-height:1.35}.narrator-latest{color:#0f766e;margin:10px 0 0;font-size:.9rem;line-height:1.35}.narrator-placeholder{color:#5eaca0;margin:0;font-style:italic;line-height:1.35}.narrator-timestamp{color:#5eaca0;letter-spacing:.03em;margin-top:10px;font-size:.75rem;font-weight:600;display:block}.narrator-force-btn{border-radius:999px;margin-top:12px;padding:.35rem .85rem;font-size:.78rem}.phase-idle-card{background:var(--wash);border:1px solid var(--line);border-radius:22px;margin:18px;padding:24px 20px}.phase-idle-card p{color:var(--ink);margin:0;font-size:1.25rem;font-weight:700;line-height:1.2}.phase-idle-hint{color:var(--muted)!important;margin-top:10px!important;font-size:.92rem!important;font-weight:400!important;line-height:1.45!important}.phase-card{border-radius:18px;margin:0 18px 18px;padding:16px 18px}.phase-card p{margin:0;font-size:.9rem;line-height:1.45}.phase-card-label{letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px;font-size:.72rem;font-weight:800;display:block}.phase-twist{background:#fff8f0;border:1px solid #f9731638}.phase-twist .phase-card-label{color:#ea580c}.phase-twist p{color:#7c2d12}.phase-twist-analyzing{background:#fefce8;border:1px solid #eab30866;transition:background .3s,border-color .3s}.phase-twist-analyzing .phase-card-label{color:#a16207}.phase-twist-analyzing p{color:#713f12}.phase-wrap{background:#f0fdf4;border:1px solid #16a34a33}.phase-wrap .phase-card-label{color:#16a34a}.phase-wrap p{color:#14532d}.phase-done-card{background:var(--accent-soft);border:1px solid #5b5ef729;border-radius:22px;margin:18px;padding:20px}.phase-done-card>p{color:#344054;margin:0 0 14px;font-size:.92rem;line-height:1.4}.phase-done-card .phase-card-label{color:var(--accent);margin-bottom:10px}.handoff-steps{color:#344054;margin:0 0 18px;padding-left:20px;font-size:.88rem}.handoff-steps li{margin-bottom:10px;line-height:1.45}.handoff-steps code{background:#5b5ef71a;border-radius:4px;padding:.1em .4em;font-size:.9em}.handoff-steps em{color:var(--ink);font-style:italic}.start-over-btn{text-align:center;width:100%;display:block}.timeline-section{margin:0 18px 14px}.timeline-toggle{text-align:left;width:100%;color:var(--muted);background:var(--wash);border-color:var(--line);border-radius:12px;padding:.5rem .85rem;font-size:.78rem;font-weight:700}.timeline-toggle:hover:not(:disabled){color:var(--accent);border-color:var(--accent);transform:none}.handoff-row{margin:auto 18px 18px;padding-top:14px}.handoff-btn{background:var(--accent);border-color:var(--accent);color:#fff;width:100%;padding:.75rem 1rem;font-size:.95rem;font-weight:700}.handoff-btn:hover:not(:disabled){color:#fff;background:#4547e0;border-color:#4547e0;transform:translateY(-1px)}.handoff-btn:disabled{background:var(--accent);border-color:var(--accent);color:#fff}.scene-read{background:#f5f6ff;border:1px solid #5b5ef729;border-radius:18px;margin:0 18px 18px;padding:14px 16px}.scene-read ul{color:#344054;margin:0;padding-left:18px;font-size:.86rem}.scene-read li{margin-bottom:8px;line-height:1.35}.timeline{color:#344054;max-height:340px;margin:0;padding:0 22px 18px 42px;overflow-y:auto}.timeline li{margin:0 0 13px;padding-left:4px;line-height:1.4}.timeline .empty{color:var(--muted);margin-left:-20px;list-style:none}.json-toggle{margin:0 18px 14px}.json-block{color:#d1d5db;text-align:left;background:#111827;border-radius:16px;max-height:220px;margin:0 18px 18px;padding:14px;font-size:.72rem;overflow:auto}@media (width<=1100px){.workspace{grid-template-columns:1fr}.transcript-panel{max-height:70svh}}@media (width<=640px){.app-shell{width:100vw;padding:10px 8px 18px}.hero-bar{margin-bottom:12px}h1{font-size:clamp(2rem,12vw,3.2rem)}.lede{font-size:.95rem}.canvas-panel,.transcript-panel,.status-card{border-radius:20px}.toolbar{gap:6px;padding:10px}.toolbar button,.control-label,.zoom-pill{min-height:44px}.control-label{flex:100%;justify-content:space-between}.control-label input{width:min(180px,46vw)}.drawing-canvas{height:min(72svh,720px)}}
