697 lines
14 KiB
CSS
697 lines
14 KiB
CSS
/* Unified studio layout — shared by Digital Human, Character Mix, and similar workspace pages. */
|
|
.studio-tool-layout {
|
|
display: grid;
|
|
grid-template-rows: 46px minmax(0, 1fr) 36px;
|
|
grid-template-columns: minmax(260px, 300px) minmax(0, 1fr) minmax(238px, 280px);
|
|
grid-template-areas:
|
|
"toolstrip toolstrip toolstrip"
|
|
"left canvas right"
|
|
"status status status";
|
|
width: 100%;
|
|
height: 100%;
|
|
min-height: 0;
|
|
overflow: hidden;
|
|
background: var(--bg-base);
|
|
}
|
|
|
|
.studio-tool-layout--no-left {
|
|
grid-template-columns: minmax(0, 1fr) minmax(238px, 280px);
|
|
grid-template-areas:
|
|
"toolstrip toolstrip"
|
|
"canvas right"
|
|
"status status";
|
|
}
|
|
|
|
.studio-tool-layout--no-right {
|
|
grid-template-columns: minmax(260px, 300px) minmax(0, 1fr);
|
|
grid-template-areas:
|
|
"toolstrip toolstrip"
|
|
"left canvas"
|
|
"status status";
|
|
}
|
|
|
|
.studio-tool-layout--no-left.studio-tool-layout--no-right {
|
|
grid-template-columns: minmax(0, 1fr);
|
|
grid-template-areas:
|
|
"toolstrip"
|
|
"canvas"
|
|
"status";
|
|
}
|
|
|
|
.studio-tool-layout--no-top {
|
|
grid-template-rows: minmax(0, 1fr) 36px;
|
|
grid-template-areas:
|
|
"left canvas right"
|
|
"status status status";
|
|
}
|
|
|
|
.studio-tool-layout--no-top.studio-tool-layout--no-left {
|
|
grid-template-areas:
|
|
"canvas right"
|
|
"status status";
|
|
}
|
|
|
|
.studio-tool-layout--no-top.studio-tool-layout--no-right {
|
|
grid-template-areas:
|
|
"left canvas"
|
|
"status status";
|
|
}
|
|
|
|
.studio-tool-layout--no-top.studio-tool-layout--no-left.studio-tool-layout--no-right {
|
|
grid-template-areas:
|
|
"canvas"
|
|
"status";
|
|
}
|
|
|
|
.studio-toolstrip {
|
|
grid-area: toolstrip;
|
|
display: flex;
|
|
align-items: center;
|
|
min-width: 0;
|
|
gap: 12px;
|
|
padding: 0 16px;
|
|
border-bottom: 1px solid var(--border-weak);
|
|
background:
|
|
linear-gradient(90deg, rgba(var(--accent-rgb), 0.14), transparent 48%),
|
|
var(--bg-panel);
|
|
}
|
|
|
|
.studio-toolstrip__left {
|
|
display: flex;
|
|
align-items: center;
|
|
min-width: 0;
|
|
gap: 12px;
|
|
}
|
|
|
|
.studio-toolstrip__breadcrumb {
|
|
color: var(--fg-body);
|
|
font-size: 14px;
|
|
font-weight: 750;
|
|
white-space: nowrap;
|
|
}
|
|
|
|
.studio-toolstrip__divider {
|
|
width: 1px;
|
|
height: 18px;
|
|
background: var(--border-subtle);
|
|
}
|
|
|
|
.studio-segmented {
|
|
display: flex;
|
|
align-items: center;
|
|
gap: 4px;
|
|
padding: 3px;
|
|
border: 1px solid var(--border-weak);
|
|
border-radius: var(--radius-xs);
|
|
background: var(--bg-inset);
|
|
}
|
|
|
|
.studio-segmented__btn {
|
|
display: inline-flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
min-height: 28px;
|
|
padding: 0 12px;
|
|
border: 1px solid transparent;
|
|
border-radius: 6px;
|
|
background: transparent;
|
|
color: var(--fg-muted);
|
|
font: inherit;
|
|
font-size: 12px;
|
|
font-weight: 700;
|
|
cursor: pointer;
|
|
transition: background 140ms ease, color 140ms ease, border-color 140ms ease;
|
|
}
|
|
|
|
.studio-segmented__btn:hover {
|
|
background: var(--bg-hover);
|
|
color: var(--fg-body);
|
|
}
|
|
|
|
.studio-segmented__btn.is-active {
|
|
border-color: rgba(var(--accent-rgb), 0.38);
|
|
background: rgba(var(--accent-rgb), 0.13);
|
|
color: var(--accent);
|
|
}
|
|
|
|
/* Panels */
|
|
.studio-panel {
|
|
grid-area: left;
|
|
display: grid;
|
|
align-content: start;
|
|
min-width: 0;
|
|
min-height: 0;
|
|
gap: 0;
|
|
overflow-y: auto;
|
|
padding: 14px;
|
|
border-right: 1px solid var(--border-weak);
|
|
background: var(--bg-panel);
|
|
scrollbar-color: rgba(var(--accent-rgb), 0.34) transparent;
|
|
}
|
|
|
|
.studio-panel--right {
|
|
grid-area: right;
|
|
border-right: 0;
|
|
border-left: 1px solid var(--border-weak);
|
|
}
|
|
|
|
.studio-panel__section {
|
|
display: grid;
|
|
gap: 10px;
|
|
padding: 14px 0;
|
|
border-bottom: 1px solid var(--border-weak);
|
|
}
|
|
|
|
.studio-panel__section:first-child {
|
|
padding-top: 0;
|
|
}
|
|
|
|
.studio-panel__section:last-child {
|
|
border-bottom: 0;
|
|
}
|
|
|
|
.studio-panel__section-head {
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: space-between;
|
|
min-width: 0;
|
|
gap: 10px;
|
|
}
|
|
|
|
.studio-panel__section-title {
|
|
color: var(--fg-body);
|
|
font-size: 13px;
|
|
font-weight: 750;
|
|
}
|
|
|
|
.studio-panel__section-chip {
|
|
display: inline-flex;
|
|
align-items: center;
|
|
min-height: 22px;
|
|
padding: 0 8px;
|
|
border-radius: 999px;
|
|
font-size: 11px;
|
|
font-weight: 700;
|
|
}
|
|
|
|
.studio-panel__section-chip--waiting {
|
|
background: var(--bg-inset);
|
|
color: var(--fg-muted);
|
|
}
|
|
|
|
.studio-panel__section-chip--ready {
|
|
background: rgba(var(--accent-rgb), 0.13);
|
|
color: var(--accent);
|
|
}
|
|
|
|
/* Upload slots */
|
|
.studio-upload-slot--empty,
|
|
.studio-upload-slot--filled {
|
|
display: grid;
|
|
grid-template-columns: auto minmax(0, 1fr);
|
|
align-items: center;
|
|
gap: 14px;
|
|
min-height: 100px;
|
|
padding: 16px;
|
|
border: 1px dashed rgba(var(--accent-rgb), 0.36);
|
|
border-radius: var(--radius-sm);
|
|
background:
|
|
linear-gradient(180deg, rgba(var(--accent-rgb), 0.06), transparent),
|
|
var(--bg-inset);
|
|
cursor: pointer;
|
|
transition: border-color 140ms ease, background 140ms ease;
|
|
}
|
|
|
|
.studio-upload-slot--empty:hover,
|
|
.studio-upload-slot--filled:hover {
|
|
border-color: rgba(var(--accent-rgb), 0.56);
|
|
background: var(--bg-hover);
|
|
}
|
|
|
|
.studio-upload-slot--filled {
|
|
border-style: solid;
|
|
border-color: rgba(var(--accent-rgb), 0.28);
|
|
}
|
|
|
|
.studio-upload-slot--empty input[type="file"],
|
|
.studio-upload-slot--filled input[type="file"] {
|
|
display: none;
|
|
}
|
|
|
|
.studio-upload-slot--empty__icon {
|
|
display: grid;
|
|
place-items: center;
|
|
width: 56px;
|
|
height: 56px;
|
|
border-radius: var(--radius-xs);
|
|
background: rgba(var(--accent-rgb), 0.13);
|
|
color: var(--accent);
|
|
font-size: 24px;
|
|
}
|
|
|
|
.studio-upload-slot--filled__thumb {
|
|
width: 72px;
|
|
height: 72px;
|
|
border-radius: var(--radius-xs);
|
|
object-fit: cover;
|
|
border: 1px solid var(--border-subtle);
|
|
}
|
|
|
|
.studio-upload-slot--filled__info {
|
|
display: grid;
|
|
gap: 3px;
|
|
min-width: 0;
|
|
}
|
|
|
|
.studio-upload-slot--filled__info strong {
|
|
color: var(--fg-body);
|
|
font-size: 13px;
|
|
font-weight: 700;
|
|
overflow: hidden;
|
|
text-overflow: ellipsis;
|
|
white-space: nowrap;
|
|
}
|
|
|
|
.studio-upload-slot--filled__info small {
|
|
color: var(--fg-muted);
|
|
font-size: 11px;
|
|
}
|
|
|
|
/* Canvas */
|
|
.studio-canvas {
|
|
grid-area: canvas;
|
|
position: relative;
|
|
display: grid;
|
|
place-items: center;
|
|
min-width: 0;
|
|
min-height: 0;
|
|
overflow: auto;
|
|
padding: 18px;
|
|
background:
|
|
radial-gradient(circle, rgba(var(--accent-rgb), 0.12) 1px, transparent 1.4px),
|
|
var(--bg-inset);
|
|
background-size: 22px 22px;
|
|
}
|
|
|
|
.studio-canvas-ghost {
|
|
display: grid;
|
|
justify-items: center;
|
|
gap: 10px;
|
|
padding: 32px;
|
|
text-align: center;
|
|
border-radius: 12px;
|
|
cursor: pointer;
|
|
transition: background 0.18s ease, outline 0.18s ease, transform 0.18s ease;
|
|
}
|
|
|
|
.studio-canvas-ghost:hover {
|
|
background: rgba(var(--accent-rgb), 0.05);
|
|
outline: 1px dashed rgba(var(--accent-rgb), 0.25);
|
|
}
|
|
|
|
.studio-canvas-ghost:focus-visible {
|
|
outline: 2px solid var(--accent);
|
|
outline-offset: 2px;
|
|
}
|
|
|
|
.studio-canvas-ghost.is-dragging {
|
|
background: rgba(var(--accent-rgb), 0.1);
|
|
outline: 2px dashed var(--accent);
|
|
transform: scale(1.02);
|
|
}
|
|
|
|
.studio-canvas-ghost__icon {
|
|
display: grid;
|
|
place-items: center;
|
|
width: 56px;
|
|
height: 56px;
|
|
border-radius: var(--radius-sm);
|
|
background: rgba(var(--accent-rgb), 0.22);
|
|
color: var(--accent);
|
|
font-size: 26px;
|
|
box-shadow: 0 0 20px rgba(var(--accent-rgb), 0.08);
|
|
}
|
|
|
|
.studio-canvas-ghost__title {
|
|
color: var(--fg-body);
|
|
font-size: 15px;
|
|
font-weight: 700;
|
|
}
|
|
|
|
.studio-canvas-ghost__hint {
|
|
max-width: 320px;
|
|
color: var(--fg-muted);
|
|
font-size: 12px;
|
|
line-height: 1.5;
|
|
}
|
|
|
|
.studio-canvas-image {
|
|
display: grid;
|
|
place-items: center;
|
|
}
|
|
|
|
.studio-canvas-image img {
|
|
display: block;
|
|
max-width: 100%;
|
|
max-height: 68vh;
|
|
border: 1px solid var(--border-subtle);
|
|
border-radius: var(--radius-sm);
|
|
object-fit: contain;
|
|
}
|
|
|
|
.studio-canvas-video {
|
|
position: relative;
|
|
display: grid;
|
|
place-items: center;
|
|
width: 100%;
|
|
}
|
|
|
|
.studio-canvas-video video {
|
|
display: block;
|
|
max-width: 100%;
|
|
max-height: 68vh;
|
|
border: 1px solid var(--border-subtle);
|
|
border-radius: var(--radius-sm);
|
|
}
|
|
|
|
.studio-result-caption {
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
gap: 8px;
|
|
margin-top: 10px;
|
|
color: var(--fg-muted);
|
|
font-size: 12px;
|
|
}
|
|
|
|
.studio-result-caption strong {
|
|
color: var(--accent);
|
|
font-weight: 750;
|
|
}
|
|
|
|
.studio-result-actions {
|
|
display: grid;
|
|
grid-template-columns: repeat(2, minmax(0, 1fr));
|
|
gap: 8px;
|
|
margin-top: 8px;
|
|
}
|
|
|
|
.studio-result-actions button {
|
|
display: inline-flex;
|
|
min-width: 0;
|
|
min-height: 48px;
|
|
align-items: center;
|
|
justify-content: center;
|
|
gap: 8px;
|
|
border: 1px solid var(--border-subtle);
|
|
border-radius: var(--radius-xs);
|
|
background: var(--bg-inset);
|
|
color: var(--fg-body);
|
|
font: inherit;
|
|
font-size: 14px;
|
|
font-weight: 750;
|
|
cursor: pointer;
|
|
transition: border-color 140ms ease, background 140ms ease, color 140ms ease;
|
|
}
|
|
|
|
.studio-result-actions button:hover:not(:disabled) {
|
|
border-color: rgba(var(--accent-rgb), 0.42);
|
|
background: rgba(var(--accent-rgb), 0.11);
|
|
color: var(--accent);
|
|
}
|
|
|
|
.studio-result-actions button:disabled {
|
|
cursor: not-allowed;
|
|
opacity: 0.56;
|
|
}
|
|
|
|
.studio-canvas-pip {
|
|
position: absolute;
|
|
bottom: 14px;
|
|
right: 14px;
|
|
width: 96px;
|
|
height: 96px;
|
|
overflow: hidden;
|
|
border: 2px solid rgba(var(--accent-rgb), 0.42);
|
|
border-radius: var(--radius-xs);
|
|
box-shadow: 0 4px 16px rgba(0, 0, 0, 0.4);
|
|
}
|
|
|
|
.studio-canvas-pip img {
|
|
width: 100%;
|
|
height: 100%;
|
|
object-fit: cover;
|
|
}
|
|
|
|
/* Controls: toggles, generate button, audio preview */
|
|
.studio-toggle-row {
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: space-between;
|
|
min-width: 0;
|
|
gap: 12px;
|
|
padding: 10px 0;
|
|
}
|
|
|
|
.studio-toggle-row__copy {
|
|
display: grid;
|
|
gap: 2px;
|
|
min-width: 0;
|
|
}
|
|
|
|
.studio-toggle-row__title {
|
|
color: var(--fg-body);
|
|
font-size: 13px;
|
|
font-weight: 700;
|
|
}
|
|
|
|
.studio-toggle-row__desc {
|
|
color: var(--fg-muted);
|
|
font-size: 11px;
|
|
}
|
|
|
|
.studio-toggle {
|
|
position: relative;
|
|
flex: 0 0 auto;
|
|
width: 40px;
|
|
height: 22px;
|
|
border: 1px solid var(--border-subtle);
|
|
border-radius: 999px;
|
|
background: var(--bg-inset);
|
|
cursor: pointer;
|
|
transition: background 140ms ease, border-color 140ms ease;
|
|
}
|
|
|
|
.studio-toggle__thumb {
|
|
position: absolute;
|
|
top: 3px;
|
|
left: 3px;
|
|
width: 14px;
|
|
height: 14px;
|
|
border-radius: 50%;
|
|
background: var(--fg-muted);
|
|
transition: transform 140ms ease, background 140ms ease;
|
|
}
|
|
|
|
.studio-toggle.is-on {
|
|
border-color: rgba(var(--accent-rgb), 0.42);
|
|
background: rgba(var(--accent-rgb), 0.13);
|
|
}
|
|
|
|
.studio-toggle.is-on .studio-toggle__thumb {
|
|
background: var(--accent);
|
|
transform: translateX(18px);
|
|
}
|
|
|
|
.studio-generate-btn {
|
|
display: inline-flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
gap: 8px;
|
|
width: 100%;
|
|
min-height: 40px;
|
|
margin-top: 8px;
|
|
border: 1px solid var(--accent);
|
|
border-radius: var(--radius-xs);
|
|
background: var(--accent);
|
|
color: #061014;
|
|
font: inherit;
|
|
font-size: 13px;
|
|
font-weight: 750;
|
|
cursor: pointer;
|
|
transition: opacity 140ms ease, transform 140ms ease;
|
|
}
|
|
|
|
.studio-generate-btn:hover {
|
|
opacity: 0.88;
|
|
transform: translateY(-1px);
|
|
}
|
|
|
|
.studio-generate-btn:disabled {
|
|
cursor: not-allowed;
|
|
opacity: 0.48;
|
|
}
|
|
|
|
.studio-audio-preview {
|
|
width: 100%;
|
|
height: 36px;
|
|
margin-top: 8px;
|
|
border-radius: var(--radius-xs);
|
|
}
|
|
|
|
/* Debug panel */
|
|
.studio-debug-panel__clear {
|
|
border: 1px solid var(--border-subtle);
|
|
border-radius: 999px;
|
|
background: var(--bg-inset);
|
|
color: var(--fg-muted);
|
|
font: inherit;
|
|
font-size: 11px;
|
|
font-weight: 700;
|
|
padding: 3px 8px;
|
|
cursor: pointer;
|
|
}
|
|
|
|
.studio-debug-panel__clear:hover {
|
|
color: var(--fg-body);
|
|
border-color: rgba(var(--accent-rgb), 0.36);
|
|
}
|
|
|
|
.studio-debug-panel__list {
|
|
display: grid;
|
|
gap: 8px;
|
|
max-height: 280px;
|
|
overflow-y: auto;
|
|
padding-right: 2px;
|
|
}
|
|
|
|
.studio-debug-panel__item {
|
|
display: grid;
|
|
gap: 5px;
|
|
padding: 9px 10px;
|
|
border: 1px solid var(--border-subtle);
|
|
border-left: 3px solid rgba(var(--accent-rgb), 0.42);
|
|
border-radius: var(--radius-xs);
|
|
background: var(--bg-inset);
|
|
}
|
|
|
|
.studio-debug-panel__item--success {
|
|
border-left-color: var(--accent);
|
|
}
|
|
|
|
.studio-debug-panel__item--error {
|
|
border-left-color: #ff5c7a;
|
|
}
|
|
|
|
.studio-debug-panel__item-head {
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: space-between;
|
|
min-width: 0;
|
|
gap: 8px;
|
|
}
|
|
|
|
.studio-debug-panel__item-head strong {
|
|
color: var(--fg-body);
|
|
font-size: 12px;
|
|
font-weight: 750;
|
|
overflow: hidden;
|
|
text-overflow: ellipsis;
|
|
white-space: nowrap;
|
|
}
|
|
|
|
.studio-debug-panel__item-head span,
|
|
.studio-debug-panel__empty {
|
|
color: var(--fg-muted);
|
|
font-size: 11px;
|
|
}
|
|
|
|
.studio-debug-panel__item p {
|
|
margin: 0;
|
|
color: var(--fg-muted);
|
|
font-size: 11px;
|
|
line-height: 1.45;
|
|
word-break: break-all;
|
|
}
|
|
|
|
/* Status bar */
|
|
.studio-status-bar {
|
|
grid-area: status;
|
|
display: flex;
|
|
align-items: center;
|
|
min-width: 0;
|
|
gap: 10px;
|
|
padding: 0 16px;
|
|
border-top: 1px solid var(--border-weak);
|
|
background: var(--bg-panel);
|
|
}
|
|
|
|
.studio-status-bar__badge {
|
|
display: inline-flex;
|
|
align-items: center;
|
|
min-height: 22px;
|
|
padding: 0 8px;
|
|
border-radius: 999px;
|
|
font-size: 11px;
|
|
font-weight: 750;
|
|
}
|
|
|
|
.studio-status-bar__badge--idle {
|
|
background: var(--bg-inset);
|
|
color: var(--fg-muted);
|
|
}
|
|
|
|
.studio-status-bar__badge--running {
|
|
background: rgba(var(--accent-rgb), 0.13);
|
|
color: var(--accent);
|
|
}
|
|
|
|
.studio-status-bar__text {
|
|
color: var(--fg-muted);
|
|
font-size: 12px;
|
|
overflow: hidden;
|
|
text-overflow: ellipsis;
|
|
white-space: nowrap;
|
|
}
|
|
|
|
.studio-status-bar__meta {
|
|
margin-left: auto;
|
|
color: var(--accent);
|
|
font-size: 12px;
|
|
font-weight: 700;
|
|
white-space: nowrap;
|
|
}
|
|
|
|
/* Responsive */
|
|
@media (max-width: 1080px) {
|
|
.studio-tool-layout {
|
|
grid-template-columns: minmax(220px, 280px) minmax(0, 1fr);
|
|
grid-template-areas:
|
|
"toolstrip toolstrip"
|
|
"left canvas"
|
|
"status status";
|
|
}
|
|
|
|
.studio-panel--right {
|
|
display: none;
|
|
}
|
|
}
|
|
|
|
@media (max-width: 720px) {
|
|
.studio-tool-layout {
|
|
grid-template-columns: minmax(0, 1fr);
|
|
grid-template-rows: 46px auto minmax(260px, 1fr) 36px;
|
|
grid-template-areas:
|
|
"toolstrip"
|
|
"left"
|
|
"canvas"
|
|
"status";
|
|
}
|
|
|
|
.studio-panel {
|
|
border-right: 0;
|
|
border-bottom: 1px solid var(--border-weak);
|
|
max-height: 320px;
|
|
}
|
|
}
|