913 lines
19 KiB
CSS
913 lines
19 KiB
CSS
.studio-canvas-project-bar {
|
|
position: absolute;
|
|
top: 14px;
|
|
right: 14px;
|
|
z-index: 80;
|
|
display: inline-flex;
|
|
align-items: center;
|
|
gap: 10px;
|
|
max-width: calc(100vw - 104px);
|
|
min-height: 44px;
|
|
padding: 6px 6px 6px 14px;
|
|
border: 1px solid var(--border-subtle);
|
|
border-radius: 14px;
|
|
background: var(--bg-panel);
|
|
color: var(--fg-muted);
|
|
box-shadow: var(--shadow-tight);
|
|
}
|
|
|
|
.studio-canvas .react-flow__attribution {
|
|
display: none;
|
|
}
|
|
|
|
.canvas-page .studio-canvas-video-player {
|
|
position: absolute;
|
|
inset: 0;
|
|
overflow: hidden;
|
|
border-radius: inherit;
|
|
background: #050806;
|
|
}
|
|
|
|
.canvas-page .studio-canvas-video-player video {
|
|
display: block;
|
|
width: 100%;
|
|
height: 100%;
|
|
object-fit: cover;
|
|
}
|
|
|
|
.canvas-page .studio-canvas-video-player__shade {
|
|
position: absolute;
|
|
inset: auto 0 0;
|
|
height: 38%;
|
|
background: rgba(0, 0, 0, 0.62);
|
|
pointer-events: none;
|
|
}
|
|
|
|
.canvas-page .studio-canvas-video-player__center,
|
|
.canvas-page .studio-canvas-video-player__button {
|
|
display: inline-grid;
|
|
place-items: center;
|
|
border: 1px solid rgba(255, 255, 255, 0.18);
|
|
background: rgba(0, 0, 0, 0.48);
|
|
color: rgba(255, 255, 255, 0.92);
|
|
cursor: pointer;
|
|
transition:
|
|
background 150ms ease,
|
|
border-color 150ms ease,
|
|
color 150ms ease,
|
|
opacity 150ms ease,
|
|
transform 150ms ease;
|
|
}
|
|
|
|
.canvas-page .studio-canvas-video-player__center {
|
|
position: absolute;
|
|
left: 50%;
|
|
top: 50%;
|
|
z-index: 8;
|
|
width: 46px;
|
|
height: 46px;
|
|
border-radius: 999px;
|
|
font-size: 22px;
|
|
transform: translate(-50%, -50%);
|
|
}
|
|
|
|
.canvas-page .studio-canvas-video-player.is-playing:not(:hover) .studio-canvas-video-player__center {
|
|
opacity: 0;
|
|
pointer-events: none;
|
|
transform: translate(-50%, -50%) scale(0.92);
|
|
}
|
|
|
|
.canvas-page .studio-canvas-video-player__controls {
|
|
position: absolute;
|
|
left: 10px;
|
|
right: 10px;
|
|
bottom: 10px;
|
|
z-index: 9;
|
|
display: grid;
|
|
grid-template-columns: 30px auto minmax(90px, 1fr) 30px;
|
|
align-items: center;
|
|
gap: 8px;
|
|
min-height: 34px;
|
|
padding: 5px 7px;
|
|
border: 1px solid rgba(255, 255, 255, 0.12);
|
|
border-radius: 12px;
|
|
background: rgba(5, 9, 7, 0.58);
|
|
box-shadow: none;
|
|
backdrop-filter: none;
|
|
pointer-events: auto;
|
|
}
|
|
|
|
.canvas-page .studio-canvas-video-player__button {
|
|
width: 28px;
|
|
height: 28px;
|
|
border-radius: 9px;
|
|
font-size: 14px;
|
|
}
|
|
|
|
.canvas-page .studio-canvas-video-player__center:hover,
|
|
.canvas-page .studio-canvas-video-player__button:hover {
|
|
border-color: rgba(var(--accent-rgb), 0.48);
|
|
background: rgba(var(--accent-rgb), 0.18);
|
|
color: #fff;
|
|
transform: translateY(-1px);
|
|
}
|
|
|
|
.canvas-page .studio-canvas-video-player__center:hover {
|
|
transform: translate(-50%, -50%) scale(1.04);
|
|
}
|
|
|
|
.canvas-page .studio-canvas-video-player__time {
|
|
color: rgba(255, 255, 255, 0.86);
|
|
font-size: 11px;
|
|
font-weight: 900;
|
|
line-height: 1;
|
|
white-space: nowrap;
|
|
}
|
|
|
|
.canvas-page .studio-canvas-video-player__seek {
|
|
width: 100%;
|
|
min-width: 0;
|
|
height: 4px;
|
|
accent-color: var(--accent);
|
|
cursor: pointer;
|
|
}
|
|
|
|
.canvas-page .studio-canvas-video-player__seek::-webkit-slider-thumb {
|
|
width: 12px;
|
|
height: 12px;
|
|
border-radius: 999px;
|
|
}
|
|
|
|
.studio-canvas-project-bar__identity {
|
|
display: grid;
|
|
gap: 2px;
|
|
min-width: 0;
|
|
max-width: min(320px, 34vw);
|
|
}
|
|
|
|
.studio-canvas-project-bar__name {
|
|
display: flex;
|
|
align-items: center;
|
|
min-width: 0;
|
|
color: var(--fg-body);
|
|
font-size: 13px;
|
|
font-weight: 1000;
|
|
line-height: 1.2;
|
|
}
|
|
|
|
.studio-canvas-project-bar__name span {
|
|
overflow: hidden;
|
|
text-overflow: ellipsis;
|
|
white-space: nowrap;
|
|
}
|
|
|
|
.studio-canvas-project-bar__name-form {
|
|
display: inline-flex;
|
|
align-items: center;
|
|
gap: 6px;
|
|
min-width: min(260px, 32vw);
|
|
}
|
|
|
|
.studio-canvas-project-bar__name-form input {
|
|
width: min(220px, 28vw);
|
|
height: 30px;
|
|
padding: 0 10px;
|
|
border: 1px solid rgba(var(--accent-rgb), 0.42);
|
|
border-radius: 9px;
|
|
background: var(--bg-inset);
|
|
color: var(--fg-body);
|
|
font-size: 13px;
|
|
font-weight: 900;
|
|
}
|
|
|
|
.studio-canvas-project-bar__name-form button,
|
|
.studio-canvas-project-bar__rename {
|
|
display: inline-grid;
|
|
place-items: center;
|
|
width: 30px;
|
|
min-width: 30px;
|
|
height: 30px;
|
|
border: 1px solid var(--border-subtle);
|
|
border-radius: 9px;
|
|
background: var(--bg-inset);
|
|
color: var(--fg-muted);
|
|
cursor: pointer;
|
|
transition:
|
|
background 160ms ease,
|
|
border-color 160ms ease,
|
|
color 160ms ease,
|
|
transform 160ms ease;
|
|
}
|
|
|
|
.studio-canvas-project-bar__name-form button:hover,
|
|
.studio-canvas-project-bar__rename:hover {
|
|
border-color: rgba(var(--accent-rgb), 0.42);
|
|
background: rgba(var(--accent-rgb), 0.12);
|
|
color: var(--accent);
|
|
transform: translateY(-1px);
|
|
}
|
|
|
|
.studio-canvas-project-bar__status {
|
|
max-width: min(360px, 42vw);
|
|
overflow: hidden;
|
|
font-size: 12px;
|
|
font-weight: 800;
|
|
text-overflow: ellipsis;
|
|
white-space: nowrap;
|
|
}
|
|
|
|
.studio-canvas-project-bar__status.is-success {
|
|
color: var(--accent);
|
|
}
|
|
|
|
.studio-canvas-project-bar__status.is-error {
|
|
color: var(--error);
|
|
}
|
|
|
|
.studio-canvas-project-bar__save {
|
|
display: inline-flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
gap: 7px;
|
|
min-width: 84px;
|
|
min-height: 34px;
|
|
padding: 0 13px;
|
|
border: 1px solid var(--accent);
|
|
border-radius: 11px;
|
|
background: var(--accent);
|
|
color: #061014;
|
|
font-size: 13px;
|
|
font-weight: 900;
|
|
cursor: pointer;
|
|
transition: background 160ms ease, border-color 160ms ease, transform 160ms ease;
|
|
}
|
|
|
|
.studio-canvas-project-bar__save:hover:not(:disabled) {
|
|
border-color: var(--accent-hover, var(--accent));
|
|
background: var(--accent-hover, var(--accent));
|
|
transform: translateY(-1px);
|
|
}
|
|
|
|
.studio-canvas-project-bar__save:disabled {
|
|
cursor: wait;
|
|
opacity: 0.72;
|
|
}
|
|
|
|
.studio-canvas-project-bar__autosave-status {
|
|
display: inline-flex;
|
|
align-items: center;
|
|
font-size: 11px;
|
|
font-weight: 500;
|
|
padding: 0 8px;
|
|
opacity: 0;
|
|
transition: opacity 0.3s ease;
|
|
}
|
|
|
|
.studio-canvas-project-bar__autosave-status--saving {
|
|
opacity: 1;
|
|
color: var(--fg-muted, #888);
|
|
}
|
|
|
|
.studio-canvas-project-bar__autosave-status--saved {
|
|
opacity: 1;
|
|
color: #10b981;
|
|
}
|
|
|
|
.studio-canvas-project-bar__autosave-status--error {
|
|
opacity: 1;
|
|
color: #ef4444;
|
|
}
|
|
|
|
.studio-canvas-project-bar__export,
|
|
.studio-canvas-project-bar__publish {
|
|
display: inline-flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
gap: 7px;
|
|
min-height: 34px;
|
|
padding: 0 12px;
|
|
border-radius: 11px;
|
|
font-size: 13px;
|
|
font-weight: 900;
|
|
cursor: pointer;
|
|
transition:
|
|
background 160ms ease,
|
|
border-color 160ms ease,
|
|
color 160ms ease,
|
|
transform 160ms ease,
|
|
opacity 160ms ease;
|
|
}
|
|
|
|
.studio-canvas-project-bar__export {
|
|
border: 1px solid var(--border-subtle);
|
|
background: var(--bg-inset);
|
|
color: var(--fg-body);
|
|
}
|
|
|
|
.studio-canvas-project-bar__export:hover {
|
|
border-color: rgba(var(--accent-rgb), 0.44);
|
|
background: rgba(var(--accent-rgb), 0.12);
|
|
color: var(--accent);
|
|
transform: translateY(-1px);
|
|
}
|
|
|
|
.studio-canvas-project-bar__publish {
|
|
border: 1px solid #35d27d;
|
|
background: #35d27d;
|
|
color: #06140b;
|
|
}
|
|
|
|
.studio-canvas-project-bar__publish:hover:not(:disabled) {
|
|
border-color: #4ade80;
|
|
background: #4ade80;
|
|
transform: translateY(-1px);
|
|
}
|
|
|
|
.studio-canvas-project-bar__publish:disabled {
|
|
cursor: wait;
|
|
opacity: 0.72;
|
|
}
|
|
|
|
.studio-canvas-project-bar__recent {
|
|
display: inline-flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
gap: 7px;
|
|
min-height: 34px;
|
|
padding: 0 12px;
|
|
border: 1px solid var(--border-subtle);
|
|
border-radius: 11px;
|
|
background: var(--bg-inset);
|
|
color: var(--fg-body);
|
|
font-size: 13px;
|
|
font-weight: 900;
|
|
cursor: pointer;
|
|
transition:
|
|
background 160ms ease,
|
|
border-color 160ms ease,
|
|
color 160ms ease,
|
|
transform 160ms ease;
|
|
}
|
|
|
|
.studio-canvas-project-bar__recent em {
|
|
display: inline-grid;
|
|
place-items: center;
|
|
min-width: 18px;
|
|
height: 18px;
|
|
padding: 0 5px;
|
|
border-radius: 999px;
|
|
background: var(--accent);
|
|
color: #061014;
|
|
font-size: 11px;
|
|
font-style: normal;
|
|
font-weight: 1000;
|
|
}
|
|
|
|
.studio-canvas-project-bar__recent:hover,
|
|
.studio-canvas-project-bar__recent.is-active {
|
|
border-color: rgba(var(--accent-rgb), 0.44);
|
|
background: rgba(var(--accent-rgb), 0.12);
|
|
color: var(--accent);
|
|
transform: translateY(-1px);
|
|
}
|
|
|
|
.studio-canvas-recent-drawer {
|
|
position: absolute;
|
|
top: 72px;
|
|
right: 14px;
|
|
z-index: 82;
|
|
display: grid;
|
|
grid-template-rows: 1fr;
|
|
width: min(360px, calc(100vw - 104px));
|
|
height: min(284px, calc(100vh - 92px));
|
|
min-height: 0;
|
|
overflow: hidden;
|
|
border: 1px solid var(--border-subtle);
|
|
border-radius: 16px;
|
|
background: color-mix(in srgb, var(--bg-panel) 94%, transparent);
|
|
color: var(--fg-body);
|
|
box-shadow: none;
|
|
backdrop-filter: none;
|
|
}
|
|
|
|
.studio-canvas-recent-drawer__list {
|
|
display: grid;
|
|
align-content: start;
|
|
gap: 10px;
|
|
min-height: 0;
|
|
height: 100%;
|
|
padding: 12px;
|
|
overflow-y: auto;
|
|
}
|
|
|
|
.studio-canvas-recent-project {
|
|
display: grid;
|
|
grid-template-columns: 76px 1fr;
|
|
gap: 12px;
|
|
width: 100%;
|
|
min-height: 84px;
|
|
padding: 9px;
|
|
border: 1px solid var(--border-subtle);
|
|
border-radius: 14px;
|
|
background: var(--bg-inset);
|
|
color: var(--fg-body);
|
|
text-align: left;
|
|
cursor: pointer;
|
|
transition:
|
|
background 160ms ease,
|
|
border-color 160ms ease,
|
|
transform 160ms ease;
|
|
}
|
|
|
|
.studio-canvas-recent-project:hover:not(:disabled) {
|
|
border-color: rgba(var(--accent-rgb), 0.46);
|
|
background: rgba(var(--accent-rgb), 0.1);
|
|
transform: translateX(-2px);
|
|
}
|
|
|
|
.studio-canvas-recent-project:disabled {
|
|
cursor: not-allowed;
|
|
opacity: 0.6;
|
|
}
|
|
|
|
.studio-canvas-recent-project img,
|
|
.studio-canvas-recent-project__thumb {
|
|
width: 76px;
|
|
height: 66px;
|
|
overflow: hidden;
|
|
border: 1px solid var(--border-subtle);
|
|
border-radius: 10px;
|
|
background: var(--bg-elevated);
|
|
}
|
|
|
|
.studio-canvas-recent-project img {
|
|
object-fit: cover;
|
|
}
|
|
|
|
.studio-canvas-recent-project__thumb {
|
|
display: grid;
|
|
place-items: center;
|
|
color: var(--accent);
|
|
font-size: 22px;
|
|
}
|
|
|
|
.studio-canvas-recent-project__body {
|
|
display: grid;
|
|
align-content: center;
|
|
gap: 4px;
|
|
min-width: 0;
|
|
}
|
|
|
|
.studio-canvas-recent-project__body strong,
|
|
.studio-canvas-recent-project__body small,
|
|
.studio-canvas-recent-project__body em {
|
|
overflow: hidden;
|
|
text-overflow: ellipsis;
|
|
white-space: nowrap;
|
|
}
|
|
|
|
.studio-canvas-recent-project__body strong {
|
|
color: var(--fg-body);
|
|
font-size: 13px;
|
|
font-weight: 1000;
|
|
}
|
|
|
|
.studio-canvas-recent-project__body small {
|
|
color: var(--fg-muted);
|
|
font-size: 12px;
|
|
font-weight: 800;
|
|
}
|
|
|
|
.studio-canvas-recent-project__body em {
|
|
color: var(--fg-soft);
|
|
font-size: 11px;
|
|
font-style: normal;
|
|
font-weight: 800;
|
|
}
|
|
|
|
.studio-canvas-recent-drawer__empty {
|
|
display: grid;
|
|
justify-items: center;
|
|
gap: 8px;
|
|
padding: 54px 20px;
|
|
color: var(--fg-muted);
|
|
text-align: center;
|
|
}
|
|
|
|
.studio-canvas-recent-drawer__empty .anticon {
|
|
color: var(--accent);
|
|
font-size: 30px;
|
|
}
|
|
|
|
.studio-canvas-recent-drawer__empty strong {
|
|
color: var(--fg-body);
|
|
font-size: 15px;
|
|
}
|
|
|
|
.studio-canvas-recent-drawer__empty span {
|
|
font-size: 12px;
|
|
font-weight: 800;
|
|
}
|
|
|
|
.studio-canvas-recent-drawer__community {
|
|
display: none;
|
|
min-height: 42px;
|
|
margin: 0 12px 12px;
|
|
border: 1px solid rgba(var(--accent-rgb), 0.44);
|
|
border-radius: 12px;
|
|
background: rgba(var(--accent-rgb), 0.12);
|
|
color: var(--accent);
|
|
font-size: 13px;
|
|
font-weight: 1000;
|
|
cursor: pointer;
|
|
}
|
|
|
|
.studio-canvas-recent-drawer__community:hover {
|
|
background: var(--accent);
|
|
color: #061014;
|
|
}
|
|
|
|
.studio-tool-layout--canvas-empty {
|
|
grid-template-rows: minmax(0, 1fr);
|
|
grid-template-areas: "canvas";
|
|
}
|
|
|
|
.studio-canvas.is-empty-projects {
|
|
overflow: hidden;
|
|
}
|
|
|
|
.studio-canvas.is-empty-projects .react-flow__controls {
|
|
display: none;
|
|
}
|
|
|
|
.studio-canvas-empty-projects {
|
|
position: absolute;
|
|
inset: 0;
|
|
z-index: 84;
|
|
display: grid;
|
|
place-content: center;
|
|
justify-items: center;
|
|
gap: 18px;
|
|
padding: 32px;
|
|
color: var(--fg-body);
|
|
text-align: center;
|
|
pointer-events: none;
|
|
}
|
|
|
|
.studio-canvas-empty-projects strong {
|
|
max-width: min(560px, calc(100vw - 180px));
|
|
color: var(--fg-body);
|
|
font-size: clamp(20px, 2vw, 28px);
|
|
font-weight: 1000;
|
|
line-height: 1.35;
|
|
}
|
|
|
|
.studio-canvas-empty-projects__button {
|
|
display: inline-flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
min-width: 132px;
|
|
min-height: 42px;
|
|
padding: 0 22px;
|
|
border: 1px solid var(--accent);
|
|
border-radius: 12px;
|
|
background: var(--accent);
|
|
color: #061014;
|
|
font-size: 14px;
|
|
font-weight: 1000;
|
|
cursor: pointer;
|
|
pointer-events: auto;
|
|
box-shadow: none;
|
|
transition:
|
|
background 160ms ease,
|
|
border-color 160ms ease,
|
|
box-shadow 160ms ease,
|
|
transform 160ms ease;
|
|
}
|
|
|
|
.studio-canvas-empty-projects__button:hover {
|
|
border-color: var(--accent-hover, var(--accent));
|
|
background: var(--accent-hover, var(--accent));
|
|
box-shadow: none;
|
|
transform: translateY(-1px);
|
|
}
|
|
|
|
.studio-canvas-loading-spinner {
|
|
width: 36px;
|
|
height: 36px;
|
|
border: 3px solid rgba(var(--accent-rgb), 0.18);
|
|
border-top-color: var(--accent);
|
|
border-radius: 50%;
|
|
animation: canvas-spin 0.8s linear infinite;
|
|
}
|
|
|
|
@keyframes canvas-spin {
|
|
to { transform: rotate(360deg); }
|
|
}
|
|
|
|
@media (max-width: 640px) {
|
|
.studio-canvas-project-bar {
|
|
right: 10px;
|
|
left: 10px;
|
|
gap: 6px;
|
|
justify-content: space-between;
|
|
}
|
|
|
|
.studio-canvas-project-bar__status {
|
|
max-width: calc(100vw - 140px);
|
|
}
|
|
|
|
.studio-canvas-project-bar__identity {
|
|
max-width: none;
|
|
}
|
|
|
|
.studio-canvas-project-bar__name-form {
|
|
min-width: 0;
|
|
}
|
|
|
|
.studio-canvas-project-bar__name-form input {
|
|
width: min(180px, 42vw);
|
|
}
|
|
|
|
.studio-canvas-project-bar__recent span,
|
|
.studio-canvas-project-bar__export span,
|
|
.studio-canvas-project-bar__publish span {
|
|
display: none;
|
|
}
|
|
|
|
.studio-canvas-project-bar__export,
|
|
.studio-canvas-project-bar__publish,
|
|
.studio-canvas-project-bar__save,
|
|
.studio-canvas-project-bar__recent {
|
|
min-width: 34px;
|
|
padding: 0 9px;
|
|
}
|
|
|
|
.studio-canvas-recent-drawer {
|
|
top: 68px;
|
|
right: 10px;
|
|
left: 10px;
|
|
width: auto;
|
|
}
|
|
|
|
.studio-canvas-empty-projects strong {
|
|
max-width: calc(100vw - 48px);
|
|
font-size: 20px;
|
|
}
|
|
}
|
|
|
|
.studio-canvas-zoom-controls {
|
|
position: absolute;
|
|
bottom: 16px;
|
|
left: 16px;
|
|
z-index: 80;
|
|
display: inline-flex;
|
|
align-items: center;
|
|
gap: 2px;
|
|
padding: 4px;
|
|
border: 1px solid var(--border-subtle);
|
|
border-radius: 12px;
|
|
background: var(--bg-panel);
|
|
pointer-events: auto;
|
|
}
|
|
|
|
.studio-canvas-zoom-controls button {
|
|
display: inline-grid;
|
|
place-items: center;
|
|
min-width: 32px;
|
|
height: 30px;
|
|
padding: 0 8px;
|
|
border: none;
|
|
border-radius: 8px;
|
|
background: transparent;
|
|
color: var(--fg-muted);
|
|
font-size: 14px;
|
|
font-weight: 900;
|
|
cursor: pointer;
|
|
transition: background 140ms ease, color 140ms ease;
|
|
}
|
|
|
|
.studio-canvas-zoom-controls button:hover {
|
|
background: rgba(var(--accent-rgb), 0.12);
|
|
color: var(--accent);
|
|
}
|
|
|
|
.studio-canvas-zoom-controls__pct {
|
|
min-width: 48px !important;
|
|
font-size: 12px !important;
|
|
font-variant-numeric: tabular-nums;
|
|
}
|
|
|
|
.studio-canvas-align-guides {
|
|
position: absolute;
|
|
inset: 0;
|
|
pointer-events: none;
|
|
z-index: 15;
|
|
}
|
|
|
|
.studio-canvas-align-guide {
|
|
position: absolute;
|
|
background: var(--accent);
|
|
opacity: 0.6;
|
|
}
|
|
|
|
.studio-canvas-align-guide--x {
|
|
top: -9999px;
|
|
bottom: -9999px;
|
|
width: 1px;
|
|
}
|
|
|
|
.studio-canvas-align-guide--y {
|
|
left: -9999px;
|
|
right: -9999px;
|
|
height: 1px;
|
|
}
|
|
|
|
/* Tool Modal Overlay */
|
|
.studio-canvas-tool-modal-overlay {
|
|
position: fixed;
|
|
inset: 0;
|
|
z-index: 9000;
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
background: rgba(0, 0, 0, 0.55);
|
|
backdrop-filter: blur(4px);
|
|
}
|
|
|
|
.studio-canvas-tool-modal {
|
|
position: relative;
|
|
width: 90vw;
|
|
max-width: 720px;
|
|
max-height: 80vh;
|
|
overflow-y: auto;
|
|
border-radius: 16px;
|
|
background: var(--bg-panel);
|
|
border: 1px solid var(--border-subtle);
|
|
box-shadow: var(--shadow-heavy, 0 12px 40px rgba(0,0,0,0.4));
|
|
padding: 24px;
|
|
}
|
|
|
|
.studio-canvas-tool-modal__header {
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: space-between;
|
|
margin-bottom: 16px;
|
|
}
|
|
|
|
.studio-canvas-tool-modal__title {
|
|
font-size: 16px;
|
|
font-weight: 600;
|
|
color: var(--fg-default);
|
|
}
|
|
|
|
.studio-canvas-tool-modal__close {
|
|
width: 32px;
|
|
height: 32px;
|
|
border-radius: 8px;
|
|
border: none;
|
|
background: var(--bg-subtle);
|
|
color: var(--fg-muted);
|
|
cursor: pointer;
|
|
font-size: 18px;
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
transition: background 0.15s;
|
|
}
|
|
|
|
.studio-canvas-tool-modal__close:hover {
|
|
background: var(--bg-hover);
|
|
}
|
|
|
|
/* Tool Panel Components */
|
|
.studio-canvas-tool-panel {
|
|
display: flex;
|
|
gap: 20px;
|
|
min-height: 280px;
|
|
}
|
|
|
|
.studio-canvas-tool-panel--inpaint {
|
|
flex-direction: column;
|
|
}
|
|
|
|
.studio-canvas-tool-panel__preview {
|
|
flex: 0 0 260px;
|
|
border-radius: 10px;
|
|
overflow: hidden;
|
|
background: var(--bg-subtle);
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
}
|
|
|
|
.studio-canvas-tool-panel__preview img {
|
|
width: 100%;
|
|
height: 100%;
|
|
object-fit: contain;
|
|
}
|
|
|
|
.studio-canvas-tool-panel__controls {
|
|
flex: 1;
|
|
display: flex;
|
|
flex-direction: column;
|
|
gap: 12px;
|
|
}
|
|
|
|
.studio-canvas-tool-panel__label {
|
|
font-size: 13px;
|
|
font-weight: 500;
|
|
color: var(--fg-muted);
|
|
}
|
|
|
|
.studio-canvas-tool-panel__options {
|
|
display: flex;
|
|
gap: 8px;
|
|
}
|
|
|
|
.studio-canvas-tool-panel__options button {
|
|
padding: 6px 16px;
|
|
border-radius: 8px;
|
|
border: 1px solid var(--border-subtle);
|
|
background: var(--bg-subtle);
|
|
color: var(--fg-default);
|
|
cursor: pointer;
|
|
font-size: 13px;
|
|
transition: all 0.15s;
|
|
}
|
|
|
|
.studio-canvas-tool-panel__options button.is-active {
|
|
background: var(--accent);
|
|
border-color: var(--accent);
|
|
color: #fff;
|
|
}
|
|
|
|
.studio-canvas-tool-panel__textarea {
|
|
width: 100%;
|
|
min-height: 60px;
|
|
padding: 10px;
|
|
border-radius: 8px;
|
|
border: 1px solid var(--border-subtle);
|
|
background: var(--bg-subtle);
|
|
color: var(--fg-default);
|
|
font-size: 13px;
|
|
resize: vertical;
|
|
}
|
|
|
|
.studio-canvas-tool-panel__submit {
|
|
margin-top: auto;
|
|
padding: 10px 20px;
|
|
border-radius: 8px;
|
|
border: none;
|
|
background: var(--accent);
|
|
color: #fff;
|
|
font-size: 14px;
|
|
font-weight: 500;
|
|
cursor: pointer;
|
|
transition: opacity 0.15s;
|
|
}
|
|
|
|
.studio-canvas-tool-panel__submit:disabled {
|
|
opacity: 0.5;
|
|
cursor: not-allowed;
|
|
}
|
|
|
|
.studio-canvas-tool-panel__actions {
|
|
display: flex;
|
|
gap: 10px;
|
|
margin-top: auto;
|
|
}
|
|
|
|
.studio-canvas-tool-panel__reset {
|
|
padding: 10px 16px;
|
|
border-radius: 8px;
|
|
border: 1px solid var(--border-subtle);
|
|
background: var(--bg-subtle);
|
|
color: var(--fg-default);
|
|
font-size: 13px;
|
|
cursor: pointer;
|
|
}
|
|
|
|
.studio-canvas-tool-panel__canvas-wrap {
|
|
position: relative;
|
|
width: 100%;
|
|
max-height: 320px;
|
|
border-radius: 10px;
|
|
overflow: hidden;
|
|
background: var(--bg-subtle);
|
|
}
|
|
|
|
.studio-canvas-tool-panel__canvas-bg {
|
|
width: 100%;
|
|
height: auto;
|
|
display: block;
|
|
}
|
|
|
|
.studio-canvas-tool-panel__canvas {
|
|
position: absolute;
|
|
inset: 0;
|
|
width: 100%;
|
|
height: 100%;
|
|
cursor: crosshair;
|
|
}
|