.page { height: 100vh; padding: 16px; display: grid; grid-template-columns: 280px 1fr; gap: 16px; } .remote { padding: 12px; height: 100%; min-height: 0; display: flex; flex-direction: column; } .remoteTitle { font-size: var(--text-xs); font-weight: 900; letter-spacing: 0.8px; color: var(--text1); } .spacer12 { height: 12px; } .spacer8 { height: 8px; } .spacer10 { height: 10px; } .sectionLabel { font-size: var(--text-xs); font-weight: 800; color: var(--text2); } .effectsStack { display: flex; flex-direction: column; gap: 12px; } .effectsGroup { display: flex; flex-direction: column; gap: 8px; } .subsectionLabel { font-size: var(--text-xs); font-weight: 700; letter-spacing: 0.02em; color: var(--text2); } .iconRow { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; } .iconGlyph { font-size: 18px; line-height: 1; display: block; } .clearIcon { display: flex; width: 20px; height: 20px; align-items: center; justify-content: center; } .radiusRow { display: grid; grid-template-columns: 100px 1fr 44px; align-items: center; gap: 8px; } .radiusLabel { color: var(--text2); font-size: var(--text-xs); font-weight: 800; } .range { width: 100%; } .radiusValue { text-align: right; font-variant-numeric: tabular-nums; color: var(--text2); font-size: var(--text-xs); } .storyWrap { flex: 1; min-height: 0; display: flex; flex-direction: column; } .storyScroll { flex: 0 0 70%; min-height: 0; border-radius: var(--radius-lg); border: 1px solid var(--stroke); background: var(--color-overlay-dark-2); overflow: auto; padding: 10px; display: flex; flex-direction: column; align-items: stretch; justify-content: flex-start; gap: 10px; } .historyBtn { text-align: left; padding: 10px; border-radius: var(--scene-tile-radius); border: none; background: transparent; color: inherit; cursor: pointer; opacity: 0.9; } .historyBtn:not(:disabled):not(.historyBtnCurrent):hover { background: var(--scene-list-hover-bg); } .historyBtn:disabled { cursor: default; opacity: 0.9; } .historyBtnCurrent { border: 1px solid var(--scene-list-selected-border); background: var(--scene-list-selected-bg); cursor: default; } .historyBadge { color: var(--accent2); font-size: var(--text-xs); font-weight: 900; } .historyMuted { color: var(--text2); font-size: var(--text-xs); } .historyTitle { font-weight: 800; } .emptyStory { color: var(--text2); font-size: var(--text-xs); } .rightStack { min-width: 0; display: grid; grid-template-rows: auto auto auto; gap: 16px; } .surfacePad { padding: 12px; } .previewHeader { display: flex; align-items: center; justify-content: space-between; } .previewTitle { font-size: var(--text-md); font-weight: 900; } .previewActions { display: flex; gap: 10px; } .videoHint { color: var(--text2); font-size: var(--text-xs); line-height: 1.45; margin-bottom: 8px; } .previewFrame { border-radius: 18px; border: 1px solid var(--stroke); height: 360px; overflow: hidden; background: var(--color-overlay-dark-2); position: relative; } .previewHost { position: absolute; inset: 0; } .brushCursor { position: absolute; z-index: 2; will-change: left, top; transform: translate(-50%, -50%); border-radius: 50%; border: 1px solid rgba(255, 255, 255, 0.55); box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.3), 0 0 18px rgba(255, 140, 40, 0.12), inset 0 0 18px rgba(255, 140, 40, 0.1); background: rgba(255, 160, 60, 0.03); pointer-events: none; } .brushLayer { position: absolute; inset: 0; z-index: 3; cursor: crosshair; } .branchTitle { font-size: var(--text-md); font-weight: 900; margin-bottom: 10px; } .branchGrid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 12px; } .branchCard { border-radius: var(--scene-tile-radius); border: 1px solid var(--stroke); background: var(--color-overlay-dark-2); padding: 12px; display: grid; gap: 10px; } .branchCardHeader { display: flex; justify-content: space-between; gap: 12px; color: var(--text2); } .branchOption { font-size: 11px; font-weight: 900; } .branchName { font-weight: 900; } .musicHeader { display: flex; align-items: center; justify-content: space-between; gap: 12px; } .musicEmpty { color: var(--text2); font-size: var(--text-xs); } .audioMeta { min-width: 0; } .audioBadges { display: flex; gap: 10px; color: var(--text2); font-size: var(--text-xs); } .audioName { font-weight: 800; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } .audioTransport { display: flex; gap: 10px; flex-shrink: 0; } .scrubFill { height: 100%; background: var(--accent-fill-solid); } .timeRow { margin-top: 6px; display: flex; justify-content: space-between; color: var(--text2); font-size: 11px; } .branchEmpty { grid-column: 1 / -1; display: flex; align-items: center; justify-content: space-between; gap: 12px; color: var(--text2); font-size: var(--text-xs); padding: 6px 2px; } .audioList { display: grid; gap: 8px; max-height: 210px; overflow: auto; } .audioCard { padding: 10px; border-radius: 14px; border: 1px solid var(--stroke); background: var(--color-overlay-dark-2); display: grid; grid-template-columns: 1fr auto; gap: 12px; } .audioScrub { margin-top: 10px; height: 10px; border-radius: var(--radius-pill); border: 1px solid var(--stroke); background: rgba(0, 0, 0, 0.22); overflow: hidden; } .audioScrubPointer { cursor: pointer; } .audioScrubDefault { cursor: default; }