Files
NianAIGC/app/globals.css
2026-05-29 15:54:13 +08:00

2738 lines
43 KiB
CSS

:root {
color-scheme: light;
--bg: #f6f7f4;
--panel: #ffffff;
--panel-muted: #f0f3ef;
--ink: #18201d;
--muted: #61706b;
--line: #dce3dd;
--green: #167a5b;
--green-dark: #0f5d46;
--coral: #c85d4a;
--amber: #a26f15;
--blue: #316f9d;
--shadow: 0 16px 40px rgba(31, 43, 37, 0.08);
}
* {
box-sizing: border-box;
}
html,
body {
overflow-x: clip;
}
body {
margin: 0;
background: var(--bg);
color: var(--ink);
font-family: Arial, "PingFang SC", "Microsoft YaHei", sans-serif;
letter-spacing: 0;
}
a {
color: inherit;
text-decoration: none;
}
button,
input,
textarea,
select {
font: inherit;
}
button {
cursor: pointer;
}
.app-shell {
min-height: 100vh;
display: block;
}
.topbar {
min-height: 70px;
display: grid;
grid-template-columns: minmax(150px, 1fr) auto minmax(150px, 1fr);
align-items: center;
gap: 18px;
padding: 12px 28px;
background: rgba(246, 247, 244, 0.94);
border-bottom: 1px solid var(--line);
backdrop-filter: blur(12px);
position: sticky;
top: 0;
z-index: 20;
}
.brand {
display: flex;
align-items: center;
gap: 10px;
justify-self: start;
min-width: 0;
}
.brand-mark {
width: auto;
height: 30px;
display: flex;
align-items: center;
flex: 0 0 auto;
}
.brand-logo-img {
display: block;
width: 104px;
max-height: 30px;
height: auto;
object-fit: contain;
}
.brand-title {
font-weight: 800;
font-size: 17px;
}
.brand-subtitle {
color: var(--muted);
font-size: 12px;
margin-top: 3px;
}
.nav {
display: flex;
align-items: center;
gap: 6px;
}
.top-nav {
justify-self: center;
padding: 4px;
border: 1px solid var(--line);
border-radius: 999px;
background: #edf2ee;
}
.nav-link {
display: inline-flex;
align-items: center;
justify-content: center;
gap: 7px;
min-height: 34px;
padding: 0 13px;
border-radius: 999px;
color: var(--muted);
font-size: 13px;
font-weight: 800;
white-space: nowrap;
}
.nav-link:hover,
.nav-link.active {
background: #ffffff;
color: var(--ink);
box-shadow: 0 1px 5px rgba(31, 43, 37, 0.08);
}
.nav-link svg {
width: 15px;
height: 15px;
}
.main {
min-width: 0;
width: min(1240px, calc(100vw - 32px));
margin: 0 auto;
padding: 18px 0 32px;
}
.page-head {
display: flex;
align-items: flex-end;
justify-content: space-between;
gap: 18px;
margin-bottom: 24px;
}
.eyebrow {
color: var(--green);
font-size: 12px;
font-weight: 800;
text-transform: uppercase;
}
h1,
h2,
h3,
p {
margin-top: 0;
}
h1 {
margin-bottom: 8px;
font-size: 34px;
line-height: 1.15;
}
h2 {
font-size: 22px;
margin-bottom: 14px;
}
h3 {
font-size: 16px;
margin-bottom: 8px;
}
.muted {
color: var(--muted);
}
.grid {
display: grid;
gap: 16px;
}
.grid.cols-2 {
grid-template-columns: repeat(2, minmax(0, 1fr));
}
.grid.cols-3 {
grid-template-columns: repeat(3, minmax(0, 1fr));
}
.grid.cols-4 {
grid-template-columns: repeat(4, minmax(0, 1fr));
}
.panel,
.card {
background: var(--panel);
border: 1px solid var(--line);
border-radius: 8px;
box-shadow: var(--shadow);
}
.panel {
padding: 20px;
}
.card {
overflow: hidden;
}
.card-body {
padding: 16px;
}
.metric {
display: grid;
gap: 10px;
}
.metric-value {
font-size: 28px;
font-weight: 800;
}
.toolbar {
display: flex;
align-items: center;
flex-wrap: wrap;
gap: 10px;
}
.button,
.icon-button {
border: 1px solid var(--line);
background: #ffffff;
color: var(--ink);
border-radius: 8px;
min-height: 40px;
display: inline-flex;
align-items: center;
justify-content: center;
gap: 8px;
padding: 0 14px;
font-weight: 700;
white-space: nowrap;
}
.button.primary {
background: var(--green);
border-color: var(--green);
color: #ffffff;
}
.button.danger {
color: #8d2f21;
border-color: #e6b8ae;
}
.icon-button {
width: 40px;
padding: 0;
}
.button:disabled,
.icon-button:disabled {
cursor: not-allowed;
opacity: 0.55;
}
.spin {
animation: spin 1s linear infinite;
}
@keyframes spin {
to {
transform: rotate(360deg);
}
}
.field {
display: grid;
gap: 7px;
margin-bottom: 14px;
}
.field label {
font-weight: 700;
font-size: 13px;
}
.field input,
.field textarea,
.field select {
width: 100%;
border: 1px solid var(--line);
background: #ffffff;
color: var(--ink);
border-radius: 8px;
min-height: 42px;
padding: 10px 12px;
}
.field textarea {
resize: vertical;
min-height: 108px;
}
.segmented {
display: flex;
gap: 4px;
padding: 4px;
background: var(--panel-muted);
border-radius: 8px;
border: 1px solid var(--line);
}
.segmented button {
flex: 1;
border: 0;
border-radius: 6px;
min-height: 38px;
background: transparent;
font-weight: 700;
color: var(--muted);
}
.segmented button.active {
background: #ffffff;
color: var(--ink);
box-shadow: 0 1px 5px rgba(31, 43, 37, 0.08);
}
.asset-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(min(100%, 280px), 1fr));
gap: 14px;
}
.asset-thumb {
width: 100%;
aspect-ratio: 4 / 3;
background: var(--panel-muted);
object-fit: cover;
display: block;
}
.asset-placeholder {
width: 100%;
aspect-ratio: 4 / 3;
display: grid;
place-items: center;
background: var(--panel-muted);
color: var(--muted);
}
.status {
display: inline-flex;
align-items: center;
border-radius: 999px;
padding: 4px 9px;
background: #edf3f0;
color: var(--green-dark);
font-size: 12px;
font-weight: 800;
}
.status.failed,
.status.expired,
.status.cancelled {
background: #fae9e5;
color: #8d2f21;
}
.status.running,
.status.queued {
background: #f6eddc;
color: #7c530d;
}
.callout {
padding: 14px 16px;
background: #f7faf7;
border: 1px solid var(--line);
border-radius: 8px;
color: var(--ink);
}
.callout[role="alert"],
.asset-error {
background: #fff4f1;
border-color: #e6b8ae;
color: #8d2f21;
}
.create-studio {
display: grid;
gap: 16px;
align-items: start;
max-width: 980px;
margin-inline: auto;
}
.create-studio.enhance-studio {
max-width: 1240px;
}
.create-mode-bar {
display: flex;
align-items: center;
justify-content: space-between;
gap: 12px;
}
.mode-switch {
width: min(560px, 100%);
}
.mode-switch button {
display: inline-flex;
align-items: center;
justify-content: center;
gap: 7px;
}
.create-actions {
margin-left: auto;
}
.prompt-label-row {
display: flex;
align-items: center;
justify-content: space-between;
gap: 10px;
}
.prompt-upload-button input {
display: none;
}
.prompt-upload-button:hover {
border-color: #b8c7c1;
background: #f7faf7;
}
.prompt-field textarea {
min-height: 260px;
line-height: 1.6;
color: var(--ink);
}
.prompt-field textarea::placeholder {
color: #9aa8a1;
}
.prompt-editor-wrap {
position: relative;
}
.prompt-editor-wrap textarea {
position: relative;
z-index: 2;
background: transparent;
}
.prompt-token-layer {
position: absolute;
inset: 0;
z-index: 1;
overflow: hidden;
border: 1px solid transparent;
border-radius: 8px;
color: transparent;
font: inherit;
line-height: 1.6;
padding: 10px 12px;
pointer-events: none;
white-space: pre-wrap;
word-break: break-word;
}
.prompt-token-card {
display: inline;
border-radius: 5px;
background: rgba(57, 217, 119, 0.34);
box-decoration-break: clone;
-webkit-box-decoration-break: clone;
box-shadow: 0 0 0 3px rgba(57, 217, 119, 0.34);
}
.prompt-token-card.unbound {
background: rgba(255, 183, 38, 0.42);
box-shadow: 0 0 0 3px rgba(255, 183, 38, 0.42);
}
.mention-popover {
position: absolute;
left: 10px;
right: 10px;
bottom: 10px;
z-index: 10;
display: grid;
gap: 4px;
max-height: 220px;
overflow: auto;
padding: 6px;
border: 1px solid var(--line);
border-radius: 8px;
background: #ffffff;
box-shadow: 0 12px 28px rgba(31, 43, 37, 0.14);
}
.mention-option {
min-height: 34px;
border: 0;
border-radius: 6px;
background: transparent;
display: grid;
grid-template-columns: 28px auto minmax(0, 1fr) auto;
align-items: center;
gap: 8px;
padding: 0 8px;
text-align: left;
font-size: 13px;
}
.mention-option.active,
.mention-option:hover {
background: #f0f3ef;
}
.mention-kind {
color: var(--muted);
font-size: 12px;
}
.upload-icon-button {
border: 1px solid var(--line);
background: #ffffff;
color: var(--ink);
border-radius: 8px;
min-width: 108px;
height: 38px;
padding: 0 10px;
display: inline-flex;
align-items: center;
justify-content: center;
gap: 6px;
font-size: 13px;
font-weight: 800;
white-space: nowrap;
cursor: pointer;
}
.upload-icon-button input {
display: none;
}
.upload-icon-button:hover,
.material-card:hover {
border-color: #b8c7c1;
background: #f7faf7;
}
.material-card.referenced {
border-color: #b7d6c8;
background: #f2faf6;
}
.material-card.missing {
border-color: var(--line);
background: #ffffff;
}
.material-board {
min-height: 42px;
display: grid;
grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
gap: 8px;
}
.prompt-material-board {
grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
margin-top: 10px;
}
.material-card {
position: relative;
min-width: 0;
border: 1px solid var(--line);
border-radius: 8px;
background: #ffffff;
color: var(--ink);
overflow: hidden;
}
.material-card-main {
width: 100%;
min-height: 68px;
border: 0;
background: transparent;
color: inherit;
padding: 8px 34px 8px 8px;
display: flex;
align-items: center;
gap: 10px;
text-align: left;
}
.prompt-material-board .material-card-main {
min-height: 58px;
}
.material-card-copy {
min-width: 0;
display: grid;
gap: 5px;
}
.material-card-head {
display: flex;
align-items: center;
gap: 7px;
min-width: 0;
}
.material-state {
display: inline-flex;
align-items: center;
min-height: 21px;
padding: 0 7px;
border-radius: 999px;
background: #edf3f0;
color: var(--muted);
font-size: 11px;
font-weight: 800;
white-space: nowrap;
}
.material-card.referenced .material-state {
background: #dff2e8;
color: var(--green-dark);
}
.material-remove {
position: absolute;
top: 6px;
right: 6px;
width: 24px;
height: 24px;
border: 0;
border-radius: 6px;
background: rgba(255, 255, 255, 0.86);
color: var(--muted);
display: grid;
place-items: center;
padding: 0;
}
.material-remove:hover {
background: #fae9e5;
color: #8d2f21;
}
.material-preview {
width: 26px;
height: 26px;
border: 1px solid var(--line);
border-radius: 6px;
background: var(--panel-muted);
display: inline-grid;
place-items: center;
overflow: hidden;
color: var(--muted);
flex: 0 0 auto;
}
.material-preview.tiny {
width: 24px;
height: 24px;
}
.material-preview.large {
width: 50px;
height: 50px;
}
.prompt-material-board .material-preview.large {
width: 42px;
height: 42px;
}
.material-preview img,
.material-preview video {
width: 100%;
height: 100%;
display: block;
object-fit: cover;
}
.chip-token {
color: var(--green-dark);
white-space: nowrap;
}
.chip-name {
min-width: 0;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
.compact-hint {
font-size: 13px;
line-height: 1.5;
}
.mini-button {
min-height: 32px;
padding: 0 10px;
font-size: 12px;
}
.inline-settings {
display: grid;
gap: 10px;
align-items: end;
}
.inline-settings {
grid-template-columns: repeat(3, minmax(0, 1fr));
margin-bottom: 12px;
}
.inline-field {
margin-bottom: 0;
}
.range-field input {
padding-inline: 0;
}
.toggle-line {
min-height: 42px;
display: inline-flex;
align-items: center;
gap: 8px;
padding: 0 12px;
border: 1px solid var(--line);
border-radius: 8px;
background: #ffffff;
font-weight: 800;
}
.studio-messages {
display: grid;
gap: 8px;
margin-top: 12px;
}
.success-callout {
background: #eef8f2;
border-color: #b7d6c8;
color: var(--green-dark);
}
.pagination {
display: flex;
align-items: center;
justify-content: center;
gap: 8px;
margin-top: 12px;
}
.pager-meta {
min-width: 58px;
color: var(--muted);
font-size: 13px;
font-weight: 800;
text-align: center;
}
.compact-job .card-body {
display: flex;
align-items: center;
justify-content: space-between;
gap: 12px;
}
.compact-job h3 {
max-width: 42ch;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
.asset-manager-toolbar {
display: flex;
align-items: center;
justify-content: space-between;
gap: 14px;
margin-bottom: 16px;
}
.asset-view-switch {
width: min(240px, 100%);
}
.asset-error {
margin-bottom: 14px;
}
.asset-history-grid {
align-items: stretch;
}
.asset-history-card {
display: grid;
grid-template-columns: minmax(112px, 34%) minmax(0, 1fr);
min-height: 0;
min-width: 0;
}
.asset-preview-button {
width: 100%;
height: 140px;
display: block;
border: 0;
padding: 0;
overflow: hidden;
background: transparent;
color: inherit;
cursor: zoom-in;
text-align: left;
}
.asset-history-card .asset-thumb,
.asset-history-card .asset-placeholder {
width: 100%;
height: 100%;
aspect-ratio: auto;
object-fit: cover;
}
.asset-history-body {
min-width: 0;
display: grid;
grid-template-rows: auto auto 1fr;
gap: 8px;
padding: 12px;
}
.asset-history-body p {
margin-bottom: 0;
}
.asset-card-title {
min-width: 0;
width: 100%;
justify-content: space-between;
flex-wrap: nowrap;
}
.asset-card-title h3 {
flex: 1 1 auto;
min-width: 0;
max-width: 100%;
margin-bottom: 0;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
.asset-card-title .status {
flex: 0 0 auto;
}
.asset-card-actions {
align-self: end;
justify-content: flex-start;
align-items: center;
gap: 6px;
min-height: 32px;
margin-top: 4px;
}
.asset-card-actions .compact-hint {
display: none;
}
.asset-card-actions .mini-button {
min-height: 30px;
padding: 0 8px;
}
.asset-kind-placeholder {
gap: 8px;
color: var(--muted);
}
.task-history-list {
gap: 10px;
}
.job-summary {
min-width: 0;
}
.job-summary p {
margin-bottom: 4px;
}
.job-actions {
flex: 0 0 auto;
justify-content: flex-end;
}
.job-detail-panel {
display: grid;
gap: 14px;
padding: 0 16px 16px;
border-top: 1px solid var(--line);
}
.job-detail-grid {
display: grid;
grid-template-columns: repeat(3, minmax(0, 1fr));
gap: 10px;
margin: 0;
padding-top: 14px;
}
.job-detail-grid div {
min-width: 0;
display: grid;
gap: 4px;
}
.job-detail-grid dt {
color: var(--muted);
font-size: 12px;
font-weight: 700;
}
.job-detail-grid dd {
min-width: 0;
margin: 0;
overflow-wrap: anywhere;
font-size: 13px;
}
.job-prompt-detail {
display: grid;
gap: 5px;
padding: 10px 12px;
border: 1px solid var(--line);
border-radius: 8px;
background: #fbfcfa;
}
.job-prompt-detail p {
margin: 0;
color: var(--ink);
font-size: 13px;
line-height: 1.55;
white-space: pre-wrap;
}
.asset-preview-backdrop {
position: fixed;
inset: 0;
z-index: 50;
display: grid;
place-items: center;
padding: 16px;
background: rgba(24, 32, 29, 0.45);
}
.asset-preview-dialog {
width: min(920px, calc(100vw - 32px));
max-height: calc(100dvh - 32px);
display: grid;
grid-template-rows: auto minmax(0, auto);
overflow: hidden;
border: 1px solid var(--line);
border-radius: 8px;
background: var(--panel);
box-shadow: 0 24px 70px rgba(24, 32, 29, 0.22);
}
.asset-preview-head {
display: flex;
align-items: center;
justify-content: space-between;
gap: 16px;
padding: 12px 14px;
border-bottom: 1px solid var(--line);
}
.asset-preview-head > div {
min-width: 0;
display: grid;
gap: 2px;
}
.asset-preview-actions {
flex: 0 0 auto;
display: flex !important;
align-items: center;
gap: 8px;
}
.asset-preview-head strong,
.asset-preview-head span {
min-width: 0;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
.asset-preview-media {
min-height: 0;
max-height: calc(100dvh - 118px);
display: grid;
place-items: center;
overflow: hidden;
padding: 12px;
background: #f8faf7;
}
.asset-preview-media img,
.asset-preview-media video {
width: auto;
height: auto;
max-width: 100%;
max-height: calc(100dvh - 150px);
border-radius: 6px;
object-fit: contain;
background: #ffffff;
}
.asset-preview-media audio {
width: min(520px, 100%);
}
.settings-panel {
display: grid;
gap: 14px;
}
.settings-actions {
display: flex;
align-items: center;
justify-content: space-between;
gap: 14px;
}
.settings-tabs {
width: min(420px, 100%);
}
.settings-actions h2,
.settings-group h2 {
margin-bottom: 4px;
}
.settings-group {
display: grid;
gap: 14px;
}
.settings-field-grid {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 12px;
}
.settings-field {
margin-bottom: 0;
}
.settings-field > span {
display: flex;
align-items: center;
justify-content: space-between;
gap: 8px;
font-weight: 800;
font-size: 13px;
}
.settings-field em {
color: var(--muted);
font-size: 11px;
font-style: normal;
}
.settings-field small {
color: var(--muted);
font-size: 11px;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
.settings-capability-list {
display: grid;
gap: 10px;
}
.settings-service-strip {
display: grid;
grid-template-columns: repeat(4, minmax(0, 1fr));
gap: 8px;
}
.settings-service-badge {
min-width: 0;
border: 1px solid var(--line);
border-radius: 8px;
background: #f8faf8;
padding: 10px 12px;
display: grid;
gap: 4px;
}
.settings-service-badge.ready {
border-color: #b7d6c8;
background: #f2faf6;
}
.settings-service-badge span {
color: var(--muted);
font-size: 12px;
}
.settings-service-badge strong {
font-size: 15px;
}
.settings-engine-table {
border: 1px solid var(--line);
border-radius: 8px;
overflow: hidden;
background: #ffffff;
}
.settings-engine-row {
display: grid;
grid-template-columns: minmax(150px, 1.15fr) minmax(180px, 0.95fr) minmax(120px, 0.7fr) minmax(160px, 1.2fr);
align-items: center;
gap: 12px;
padding: 12px;
border-top: 1px solid var(--line);
}
.settings-engine-row:first-child {
border-top: 0;
}
.settings-engine-head {
color: var(--muted);
background: #f7f9f7;
font-size: 12px;
font-weight: 800;
}
.settings-engine-name {
min-width: 0;
display: grid;
gap: 3px;
}
.settings-engine-name strong,
.settings-engine-value {
font-size: 14px;
}
.settings-engine-name small,
.settings-engine-key small {
color: var(--muted);
font-size: 11px;
overflow-wrap: anywhere;
}
.settings-engine-control {
width: 100%;
}
.settings-loading {
display: inline-flex;
align-items: center;
gap: 8px;
}
.image-upload-button {
flex: 0 0 auto;
}
.editor-picker-panel {
border: 1px solid var(--line);
border-radius: 8px;
background: #fbfcfa;
padding: 10px;
margin-bottom: 14px;
}
.editor-picker-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(132px, 1fr));
gap: 10px;
margin-bottom: 14px;
max-height: 330px;
overflow: auto;
padding: 2px;
}
.editor-thumb-option {
min-width: 0;
border: 1px solid var(--line);
border-radius: 8px;
background: #ffffff;
color: var(--ink);
overflow: hidden;
padding: 0;
text-align: left;
}
.editor-thumb-option.selected {
border-color: var(--green);
box-shadow: 0 0 0 2px rgba(22, 122, 91, 0.14);
}
.editor-thumb-option img {
width: 100%;
aspect-ratio: 1 / 1;
object-fit: cover;
display: block;
background: var(--panel-muted);
}
.editor-thumb-info {
min-width: 0;
display: grid;
gap: 3px;
padding: 8px;
}
.editor-thumb-info strong,
.editor-thumb-info span {
min-width: 0;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
.editor-thumb-info strong {
font-size: 12px;
}
.editor-thumb-info span {
color: var(--muted);
font-size: 11px;
}
.editor-empty {
grid-column: 1 / -1;
}
.selected-asset-line {
display: flex;
align-items: center;
gap: 10px;
border: 1px solid var(--line);
border-radius: 8px;
background: #fbfcfa;
padding: 8px;
margin-bottom: 14px;
}
.editor-selection-summary {
flex-wrap: wrap;
}
.editor-selection-summary div {
flex: 1 1 180px;
}
.selected-asset-line img {
width: 44px;
height: 44px;
border-radius: 6px;
object-fit: cover;
background: var(--panel-muted);
}
.selected-asset-placeholder {
width: 44px;
height: 44px;
border-radius: 6px;
display: grid;
place-items: center;
background: var(--panel-muted);
color: var(--muted);
flex: 0 0 auto;
}
.selected-asset-line div {
min-width: 0;
display: grid;
gap: 3px;
}
.selected-asset-line strong,
.selected-asset-line span {
min-width: 0;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
.editor-canvas-wrap {
position: relative;
width: 100%;
max-width: 760px;
border: 1px solid var(--line);
border-radius: 8px;
overflow: hidden;
background: #ffffff;
}
.editor-canvas-wrap img,
.editor-canvas-wrap canvas {
display: block;
width: 100%;
height: auto;
}
.editor-canvas-wrap canvas {
position: absolute;
inset: 0;
cursor: crosshair;
filter: drop-shadow(0 0 1px rgba(0, 0, 0, 0.5));
opacity: 0.82;
touch-action: none;
}
@media (max-width: 920px) {
.topbar {
grid-template-columns: 1fr;
justify-items: center;
gap: 10px;
padding: 12px 16px;
}
.brand {
justify-self: center;
}
.top-nav {
width: min(100%, 560px);
justify-content: center;
}
.nav-link {
justify-content: center;
font-size: 13px;
}
.main {
width: min(980px, calc(100% - 32px));
padding: 16px 0 28px;
}
.grid.cols-2,
.grid.cols-3,
.grid.cols-4,
.settings-service-strip,
.settings-engine-row,
.settings-field-grid {
grid-template-columns: 1fr;
}
.create-studio,
.inline-settings {
grid-template-columns: 1fr;
}
.create-mode-bar {
align-items: stretch;
flex-direction: column;
}
.settings-actions {
align-items: stretch;
flex-direction: column;
}
.settings-tabs,
.settings-actions .toolbar,
.settings-actions .button {
width: 100%;
}
.settings-engine-head {
display: none;
}
.mode-switch,
.create-actions {
width: 100%;
}
.create-actions .button {
flex: 1;
}
}
@media (max-width: 560px) {
h1 {
font-size: 28px;
}
.topbar {
padding: 10px 12px;
}
.brand-title {
font-size: 15px;
}
.brand-subtitle {
display: none;
}
.page-head {
align-items: flex-start;
flex-direction: column;
}
.top-nav {
justify-content: center;
overflow: hidden;
}
.nav-link {
flex: 0 0 auto;
gap: 0;
padding: 0 10px;
}
.nav-link svg {
display: none;
}
.main {
width: calc(100% - 24px);
padding-top: 12px;
}
.asset-history-card {
grid-template-columns: 104px minmax(0, 1fr);
min-height: 0;
}
.asset-preview-button {
height: 140px;
}
.prompt-field textarea {
min-height: 220px;
}
.upload-icon-button {
min-width: 108px;
}
.material-board {
grid-template-columns: 1fr;
}
.compact-job .card-body {
align-items: flex-start;
flex-direction: column;
}
.job-actions {
width: 100%;
justify-content: flex-start;
}
.job-detail-grid {
grid-template-columns: 1fr;
}
.asset-manager-toolbar,
.editor-selection-summary {
align-items: stretch;
flex-direction: column;
}
.editor-selection-summary div {
flex: 0 1 auto;
width: 100%;
}
.editor-selection-summary > img,
.editor-selection-summary .selected-asset-placeholder {
align-self: flex-start;
}
}
/* UI/UX Pro Max pass: professional creator workspace tokens and interaction layer. */
:root {
color-scheme: light;
--bg: #f4f7f8;
--surface: #ffffff;
--surface-raised: #ffffff;
--surface-subtle: #eef4f4;
--panel: var(--surface);
--panel-muted: var(--surface-subtle);
--ink: #111827;
--muted: #5d6b78;
--muted-strong: #334155;
--line: #d7e0e4;
--line-strong: #b9c8cf;
--green: #0f766e;
--green-dark: #0b5f59;
--coral: #c24137;
--amber: #a16207;
--blue: #2563eb;
--indigo: #4f46e5;
--success: #0f766e;
--warning: #a16207;
--danger: #b42318;
--focus: #2563eb;
--shadow: 0 14px 34px rgba(15, 23, 42, 0.08);
--shadow-soft: 0 1px 2px rgba(15, 23, 42, 0.08), 0 10px 28px rgba(15, 23, 42, 0.06);
--shadow-strong: 0 24px 70px rgba(15, 23, 42, 0.22);
--radius: 8px;
--radius-sm: 6px;
--tap: 44px;
--ease-out: cubic-bezier(0.16, 1, 0.3, 1);
--ease-in: cubic-bezier(0.7, 0, 0.84, 0);
--duration-fast: 150ms;
--duration: 220ms;
}
html {
min-width: 320px;
scroll-behavior: smooth;
}
body {
min-width: 320px;
background:
linear-gradient(180deg, rgba(232, 241, 243, 0.74), rgba(244, 247, 248, 0) 340px),
var(--bg);
color: var(--ink);
font-family: Inter, Arial, "PingFang SC", "Microsoft YaHei", sans-serif;
line-height: 1.5;
text-rendering: optimizeLegibility;
}
button,
input,
textarea,
select {
min-width: 0;
}
button,
a,
input,
textarea,
select {
touch-action: manipulation;
}
button,
.button,
.icon-button,
.nav-link,
.asset-preview-button,
.material-card-main,
.editor-thumb-option {
transition:
background-color var(--duration-fast) var(--ease-out),
border-color var(--duration-fast) var(--ease-out),
color var(--duration-fast) var(--ease-out),
box-shadow var(--duration-fast) var(--ease-out),
transform var(--duration-fast) var(--ease-out);
}
button:hover:not(:disabled),
.button:hover:not(:disabled),
.icon-button:hover:not(:disabled),
.nav-link:hover,
.asset-preview-button:hover,
.material-card:hover,
.editor-thumb-option:hover {
transform: translateY(-1px);
}
button:active:not(:disabled),
.button:active:not(:disabled),
.icon-button:active:not(:disabled),
.nav-link:active {
transform: translateY(0) scale(0.99);
}
:focus-visible {
outline: 3px solid rgba(37, 99, 235, 0.28);
outline-offset: 3px;
}
.skip-link {
position: fixed;
left: 14px;
top: 10px;
z-index: 100;
min-height: var(--tap);
display: inline-flex;
align-items: center;
border: 1px solid var(--line-strong);
border-radius: var(--radius);
background: var(--surface);
color: var(--ink);
padding: 0 14px;
box-shadow: var(--shadow-soft);
font-weight: 800;
transform: translateY(-72px);
}
.skip-link:focus {
transform: translateY(0);
}
.app-shell {
min-height: 100dvh;
}
.topbar {
min-height: 76px;
grid-template-columns: minmax(220px, 1fr) auto minmax(220px, 1fr);
padding: 14px 28px;
background: rgba(249, 251, 251, 0.88);
border-bottom-color: rgba(185, 200, 207, 0.7);
box-shadow: 0 1px 0 rgba(255, 255, 255, 0.65) inset;
backdrop-filter: blur(18px) saturate(1.15);
}
.brand {
border-radius: var(--radius);
padding: 4px 6px 4px 4px;
}
.brand:hover {
background: rgba(255, 255, 255, 0.62);
}
.brand-mark {
border: 0;
background: transparent;
color: inherit;
box-shadow: none;
}
.brand-title {
font-size: 16px;
letter-spacing: 0;
}
.brand-subtitle {
color: var(--muted);
}
.top-nav {
min-height: 48px;
background: #e8eef1;
box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.78);
}
.nav-link {
min-height: var(--tap);
padding: 0 15px;
color: var(--muted-strong);
}
.nav-link:hover,
.nav-link.active {
background: var(--surface-raised);
color: var(--ink);
box-shadow: var(--shadow-soft);
}
.nav-link.active {
border: 1px solid rgba(185, 200, 207, 0.82);
}
.main {
width: min(1280px, calc(100vw - 32px));
padding: 24px 0 40px;
}
.workspace-head {
display: grid;
grid-template-columns: minmax(0, 1fr) auto;
align-items: end;
gap: 18px;
margin-bottom: 18px;
}
.workspace-kicker,
.eyebrow {
color: var(--green-dark);
font-size: 12px;
font-weight: 900;
letter-spacing: 0.04em;
text-transform: uppercase;
}
.workspace-title {
margin: 5px 0 6px;
font-size: clamp(28px, 4vw, 42px);
line-height: 1.12;
}
.workspace-copy {
max-width: 72ch;
margin: 0;
color: var(--muted);
font-size: 15px;
}
.workspace-meta {
display: flex;
align-items: center;
flex-wrap: wrap;
justify-content: flex-end;
gap: 8px;
}
.meta-pill {
min-height: 34px;
display: inline-flex;
align-items: center;
gap: 7px;
border: 1px solid var(--line);
border-radius: 999px;
background: rgba(255, 255, 255, 0.76);
color: var(--muted-strong);
padding: 0 11px;
font-size: 12px;
font-weight: 800;
box-shadow: 0 1px 0 rgba(255, 255, 255, 0.72) inset;
}
.panel,
.card {
border-color: rgba(215, 224, 228, 0.96);
border-radius: var(--radius);
box-shadow: var(--shadow-soft);
}
.panel {
padding: 22px;
}
.panel-head {
display: flex;
align-items: flex-start;
justify-content: space-between;
gap: 14px;
margin-bottom: 16px;
}
.panel-head h2,
.panel-head h3,
.panel-head p {
margin-bottom: 0;
}
.card {
background: var(--surface);
}
.button,
.icon-button,
.upload-icon-button {
min-height: var(--tap);
border-color: var(--line);
border-radius: var(--radius);
background: var(--surface);
color: var(--ink);
box-shadow: 0 1px 0 rgba(255, 255, 255, 0.75) inset;
}
.button:hover:not(:disabled),
.icon-button:hover:not(:disabled),
.upload-icon-button:hover {
border-color: var(--line-strong);
background: #f8fbfb;
box-shadow: var(--shadow-soft);
}
.button.primary {
border-color: var(--green);
background: var(--green);
color: #ffffff;
box-shadow: 0 10px 22px rgba(15, 118, 110, 0.2);
}
.button.primary:hover:not(:disabled) {
border-color: var(--green-dark);
background: var(--green-dark);
}
.button.danger {
color: var(--danger);
border-color: #efc7c1;
background: #fff9f8;
}
.button.danger:hover:not(:disabled) {
background: #fff1ee;
}
.icon-button {
width: var(--tap);
height: var(--tap);
}
.mini-button {
min-height: var(--tap);
}
.field {
gap: 8px;
}
.field label,
.prompt-label-row label,
.settings-field > span {
color: var(--muted-strong);
font-weight: 850;
}
.field input,
.field textarea,
.field select,
.settings-engine-control {
min-height: var(--tap);
border-color: var(--line);
border-radius: var(--radius);
background: #fbfdfd;
transition:
border-color var(--duration-fast) var(--ease-out),
box-shadow var(--duration-fast) var(--ease-out),
background-color var(--duration-fast) var(--ease-out);
}
.field input:focus,
.field textarea:focus,
.field select:focus,
.settings-engine-control:focus {
border-color: rgba(37, 99, 235, 0.7);
background: #ffffff;
box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.12);
outline: 0;
}
.segmented {
min-height: 48px;
border-color: rgba(185, 200, 207, 0.82);
border-radius: var(--radius);
background: #e8eef1;
}
.segmented button {
min-height: var(--tap);
color: var(--muted-strong);
}
.segmented button.active {
background: #ffffff;
color: var(--ink);
box-shadow: var(--shadow-soft);
}
.status {
min-height: 25px;
background: #e8f5f1;
color: var(--green-dark);
}
.status.failed,
.status.expired,
.status.cancelled {
background: #fff0ed;
color: var(--danger);
}
.status.running,
.status.queued {
background: #fff6dc;
color: var(--warning);
}
.callout {
border-color: var(--line);
background: #f8fbfb;
}
.callout[role="alert"],
.asset-error {
border-color: #efc7c1;
background: #fff5f3;
color: var(--danger);
}
.success-callout {
border-color: #b9dccc;
background: #eefaf4;
color: var(--green-dark);
}
.create-studio {
max-width: 1060px;
}
.create-studio.enhance-studio {
max-width: 1280px;
}
.create-mode-bar {
position: sticky;
top: 92px;
z-index: 12;
padding: 10px;
border: 1px solid rgba(215, 224, 228, 0.82);
border-radius: var(--radius);
background: rgba(249, 251, 251, 0.86);
box-shadow: var(--shadow-soft);
backdrop-filter: blur(16px) saturate(1.08);
}
.mode-switch {
width: min(680px, 100%);
min-width: 0;
}
.prompt-field textarea {
min-height: 300px;
background: transparent;
font-size: 15px;
}
.prompt-editor-wrap {
border: 1px solid var(--line);
border-radius: var(--radius);
background: #fbfdfd;
box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.82);
transition:
border-color var(--duration-fast) var(--ease-out),
box-shadow var(--duration-fast) var(--ease-out);
}
.prompt-editor-wrap:focus-within {
border-color: rgba(37, 99, 235, 0.7);
box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.12);
}
.prompt-editor-wrap textarea {
border: 0;
box-shadow: none;
}
.prompt-token-layer {
border: 0;
}
.prompt-token-card {
background: rgba(45, 212, 191, 0.28);
box-shadow: 0 0 0 3px rgba(45, 212, 191, 0.28);
}
.prompt-token-card.unbound {
background: rgba(251, 191, 36, 0.34);
box-shadow: 0 0 0 3px rgba(251, 191, 36, 0.34);
}
.mention-popover {
border-color: var(--line-strong);
box-shadow: var(--shadow-strong);
}
.mention-option {
min-height: 40px;
}
.mention-option.active,
.mention-option:hover {
background: #eef4f4;
}
.material-board {
gap: 10px;
}
.material-card {
border-color: var(--line);
box-shadow: 0 1px 0 rgba(255, 255, 255, 0.74) inset;
}
.material-card:hover {
border-color: var(--line-strong);
box-shadow: var(--shadow-soft);
}
.material-remove {
width: 40px;
height: 40px;
}
.material-card.referenced {
border-color: #a8d9cf;
background: #f1fbf8;
}
.material-preview {
border-color: var(--line);
background: #e9f0f2;
}
.inline-settings {
grid-template-columns: minmax(160px, 0.7fr) minmax(220px, 1fr) minmax(120px, 0.45fr);
align-items: end;
margin-top: 16px;
margin-bottom: 0;
padding-top: 16px;
border-top: 1px solid var(--line);
}
.toggle-line {
min-height: var(--tap);
background: #fbfdfd;
}
.asset-manager-toolbar,
.settings-actions {
padding: 10px;
border: 1px solid rgba(215, 224, 228, 0.82);
border-radius: var(--radius);
background: #f8fbfb;
}
.asset-history-card {
border-color: rgba(215, 224, 228, 0.96);
}
.asset-preview-button {
background: #e9f0f2;
}
.asset-preview-button:hover {
filter: saturate(1.04);
}
.asset-history-body {
gap: 10px;
}
.asset-card-meta {
overflow-wrap: anywhere;
}
.asset-card-actions .mini-button {
min-width: var(--tap);
min-height: var(--tap);
padding: 0 10px;
}
.compact-job {
overflow: hidden;
}
.compact-job .card-body {
min-height: 84px;
}
.job-detail-panel {
background: #fbfdfd;
}
.job-detail-grid {
grid-template-columns: repeat(4, minmax(0, 1fr));
}
.asset-preview-backdrop {
background: rgba(15, 23, 42, 0.52);
backdrop-filter: blur(8px);
}
.asset-preview-dialog {
border-color: rgba(215, 224, 228, 0.9);
border-radius: var(--radius);
box-shadow: var(--shadow-strong);
}
.asset-preview-head {
background: #fbfdfd;
}
.asset-preview-media {
background: #eef4f4;
}
.settings-panel {
gap: 16px;
}
.settings-service-badge {
background: #f8fbfb;
}
.settings-service-badge.ready {
border-color: #a8d9cf;
background: #f1fbf8;
}
.settings-engine-table {
border-color: var(--line);
}
.settings-engine-row {
grid-template-columns: minmax(150px, 1.1fr) minmax(180px, 0.95fr) minmax(110px, 0.6fr) minmax(160px, 1fr);
}
.settings-engine-row:not(.settings-engine-head):hover {
background: #fbfdfd;
}
.editor-picker-panel,
.selected-asset-line,
.job-prompt-detail {
border-color: var(--line);
background: #f8fbfb;
}
.editor-thumb-option {
border-color: var(--line);
}
.editor-thumb-option.selected {
border-color: var(--green);
box-shadow: 0 0 0 3px rgba(15, 118, 110, 0.16);
}
.editor-canvas-wrap {
border-color: var(--line);
background: #ffffff;
box-shadow: var(--shadow-soft);
}
.pagination .icon-button {
width: var(--tap);
height: var(--tap);
min-height: var(--tap);
}
@media (prefers-reduced-motion: reduce) {
*,
*::before,
*::after {
scroll-behavior: auto !important;
transition-duration: 0.01ms !important;
animation-duration: 0.01ms !important;
animation-iteration-count: 1 !important;
}
}
@media (max-width: 920px) {
.topbar {
grid-template-columns: 1fr;
min-height: auto;
}
.workspace-head {
grid-template-columns: 1fr;
}
.workspace-meta {
justify-content: flex-start;
}
.create-mode-bar {
position: static;
}
.inline-settings {
grid-template-columns: 1fr;
}
.job-detail-grid {
grid-template-columns: repeat(2, minmax(0, 1fr));
}
.settings-engine-row {
display: grid;
grid-template-columns: 1fr;
gap: 8px;
padding: 14px;
}
.settings-engine-row:not(.settings-engine-head) {
border-top: 1px solid var(--line);
}
}
@media (max-width: 560px) {
body {
background: var(--bg);
}
.main {
width: calc(100% - 24px);
padding-bottom: 28px;
}
.workspace-title {
font-size: 28px;
}
.workspace-copy {
font-size: 14px;
}
.panel {
padding: 16px;
}
.top-nav {
width: 100%;
overflow-x: auto;
justify-content: flex-start;
scrollbar-width: none;
}
.top-nav::-webkit-scrollbar {
display: none;
}
.nav-link {
min-width: 88px;
gap: 7px;
padding: 0 12px;
}
.nav-link svg {
display: block;
}
.create-mode-bar,
.asset-manager-toolbar,
.settings-actions {
padding: 8px;
}
.segmented {
max-width: 100%;
min-width: 0;
overflow-x: auto;
scrollbar-width: none;
}
.segmented::-webkit-scrollbar {
display: none;
}
.segmented button {
min-width: max-content;
padding: 0 12px;
}
.create-mode-bar,
.mode-switch {
min-width: 0;
max-width: 100%;
overflow: hidden;
}
.mode-switch.segmented {
overflow-x: auto;
}
.prompt-field textarea {
min-height: 240px;
}
.asset-history-card {
grid-template-columns: 1fr;
}
.asset-preview-button {
height: auto;
aspect-ratio: 4 / 3;
}
.job-detail-grid {
grid-template-columns: 1fr;
}
.settings-service-strip {
grid-template-columns: 1fr;
}
}
/* Compact header pass: keep the shell shorter and avoid horizontal scrollers below it. */
.topbar {
min-height: 64px;
padding-block: 9px;
}
.brand-mark {
width: auto;
height: 28px;
}
.brand-title {
font-size: 15px;
}
.top-nav {
min-height: 42px;
}
.nav-link {
min-height: 38px;
}
@media (max-width: 920px) {
.topbar {
grid-template-columns: auto minmax(0, 1fr);
justify-items: stretch;
gap: 12px;
padding: 8px 16px;
}
.brand {
justify-self: start;
}
.top-nav {
justify-self: end;
width: min(320px, 100%);
min-width: 0;
justify-content: flex-end;
overflow: visible;
}
}
@media (max-width: 560px) {
.topbar {
grid-template-columns: auto minmax(0, 1fr);
padding: 7px 10px;
gap: 8px;
}
.brand {
gap: 8px;
padding: 2px;
}
.brand-mark {
width: auto;
height: 24px;
}
.brand-logo-img {
width: 86px;
max-height: 24px;
}
.brand-title {
display: none;
}
.top-nav {
width: min(214px, 100%);
min-height: 38px;
padding: 3px;
overflow: visible;
}
.nav-link {
flex: 1 1 0;
min-width: 0;
min-height: 34px;
gap: 4px;
padding: 0 6px;
font-size: 12px;
}
.nav-link svg {
width: 14px;
height: 14px;
}
.segmented,
.mode-switch.segmented {
overflow: visible;
}
.mode-switch.segmented {
display: grid;
grid-template-columns: repeat(4, minmax(0, 1fr));
}
.mode-switch.segmented button {
min-width: 0;
min-height: 38px;
gap: 3px;
padding: 0 4px;
font-size: 12px;
}
.mode-switch.segmented button svg {
width: 13px;
height: 13px;
}
.asset-view-switch,
.settings-tabs {
display: grid;
}
.asset-view-switch {
grid-template-columns: repeat(2, minmax(0, 1fr));
}
.settings-tabs {
grid-template-columns: repeat(6, minmax(0, 1fr));
}
.asset-view-switch button,
.settings-tabs button {
min-width: 0;
min-height: 38px;
padding: 0 4px;
font-size: 12px;
}
}
@media (max-width: 560px) {
.workspace-head {
gap: 10px;
margin-bottom: 12px;
}
.workspace-title {
margin-bottom: 4px;
}
.workspace-copy {
line-height: 1.45;
}
.create-mode-bar {
gap: 8px;
display: grid;
grid-template-columns: minmax(0, 1fr) var(--tap);
align-items: center;
}
.create-actions .button {
width: var(--tap);
min-height: var(--tap);
padding: 0;
}
.create-submit-label,
.mode-switch.segmented button svg {
display: none;
}
.prompt-field textarea {
min-height: 180px;
}
.inline-settings {
gap: 8px;
margin-top: 12px;
padding-top: 12px;
}
.field {
margin-bottom: 10px;
}
}
.topbar-account {
justify-self: end;
display: inline-flex;
align-items: center;
gap: 8px;
min-width: 0;
}
.account-chip {
min-height: 38px;
max-width: 190px;
display: inline-flex;
align-items: center;
gap: 7px;
padding: 0 11px;
border: 1px solid var(--line);
border-radius: 999px;
background: rgba(255, 255, 255, 0.72);
color: var(--muted-strong);
font-size: 13px;
font-weight: 800;
white-space: nowrap;
}
.account-chip span {
min-width: 0;
overflow: hidden;
text-overflow: ellipsis;
}
.account-chip svg,
.logout-button svg,
.login-link svg {
width: 16px;
height: 16px;
flex: 0 0 auto;
}
.logout-button {
width: 38px;
min-height: 38px;
padding: 0;
border-radius: 999px;
}
.auth-shell {
min-height: 100dvh;
background:
linear-gradient(90deg, rgba(220, 227, 221, 0.55) 1px, transparent 1px),
linear-gradient(180deg, rgba(220, 227, 221, 0.45) 1px, transparent 1px),
var(--bg);
background-size: 44px 44px;
}
.auth-main {
width: 100%;
min-height: 100dvh;
padding: 0;
}
.auth-page {
min-height: 100dvh;
width: min(1120px, 100%);
margin: 0 auto;
display: grid;
grid-template-columns: minmax(280px, 0.9fr) minmax(340px, 440px);
align-items: center;
gap: clamp(28px, 6vw, 72px);
padding: clamp(36px, 8vw, 76px) 24px;
}
.auth-brand-panel {
display: grid;
justify-items: start;
gap: 16px;
}
.auth-brand-logo {
display: block;
width: min(292px, 76vw);
height: auto;
object-fit: contain;
}
.auth-brand-panel h1 {
margin: 0;
max-width: 9em;
font-size: clamp(36px, 5vw, 58px);
line-height: 1.05;
font-weight: 900;
color: var(--ink);
}
.auth-panel {
width: 100%;
display: grid;
justify-items: stretch;
gap: 18px;
padding: 28px;
}
.auth-panel h2 {
margin: 0;
font-size: 24px;
line-height: 1.2;
}
.auth-password-form {
width: 100%;
display: grid;
gap: 14px;
}
.auth-password-form .field {
margin-bottom: 0;
}
.auth-captcha-row {
display: grid;
grid-template-columns: minmax(0, 1fr) 118px;
gap: 8px;
align-items: center;
}
.auth-captcha-button {
height: 44px;
border: 1px solid var(--line);
border-radius: 8px;
background: #ffffff;
display: inline-flex;
align-items: center;
justify-content: center;
padding: 0;
overflow: hidden;
}
.auth-captcha-button img {
width: 100%;
height: 100%;
display: block;
object-fit: cover;
}
.auth-submit,
.auth-submit.button {
width: 100%;
min-height: 46px;
}
@media (max-width: 920px) {
.topbar {
grid-template-columns: auto minmax(0, 1fr) auto;
}
.top-nav {
justify-self: center;
}
.account-chip {
max-width: 150px;
}
}
@media (max-width: 700px) {
.topbar-account {
grid-column: 1 / -1;
justify-self: stretch;
justify-content: flex-end;
}
.account-chip {
max-width: min(260px, calc(100vw - 92px));
}
.auth-page {
grid-template-columns: 1fr;
align-content: center;
gap: 24px;
padding: 34px 14px;
}
.auth-brand-panel {
justify-items: center;
text-align: center;
gap: 10px;
}
.auth-brand-panel h1 {
font-size: 34px;
}
.auth-panel {
padding: 20px;
}
}
@media (max-width: 560px) {
.topbar {
grid-template-columns: auto minmax(0, 1fr);
}
.topbar-account {
padding-top: 0;
}
.account-chip {
min-height: 34px;
max-width: calc(100vw - 78px);
padding: 0 9px;
font-size: 12px;
}
.logout-button {
width: 34px;
min-height: 34px;
}
.auth-captcha-row {
grid-template-columns: minmax(0, 1fr) 104px;
}
}