e39a72206d
- Экран загрузки (boot.html, bootWindow): статусы, ensureRoots и проверка лицензии, редактор после готовности; закрытие через destroy при closable:false. - Упакованное приложение на Windows: disableHardwareAcceleration, sandbox выкл. вне dev, отложенный показ редактора, ensureWindowBecomesVisible, фокус на splash при second-instance. - Vite: вход boot.html; eslint: игнор release/; тесты boot и maxFPS тикера. - Пульт: позиция курсора кисти через ref/DOM без setState на каждый move; черновик эффекта через rAF; Pixi: maxFPS 32, resolution cap, antialias off, debounce ResizeObserver, меньше частиц poisonCloud, contain на хосте. Made-with: Cursor
374 lines
5.6 KiB
CSS
374 lines
5.6 KiB
CSS
.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;
|
|
}
|