Files
DndGamePlayer/app/renderer/control/ControlApp.module.css
T

360 lines
5.4 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: 10px;
}
.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;
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;
}