This commit is contained in:
2026-03-25 19:46:14 -03:00
parent 9d5413a522
commit 26f61077b8
13 changed files with 382 additions and 187 deletions

View File

@@ -1,4 +1,6 @@
*, *::before, *::after {
*,
*::before,
*::after {
box-sizing: border-box;
margin: 0;
padding: 0;
@@ -30,7 +32,9 @@
-webkit-font-smoothing: antialiased;
}
html, body, #app {
html,
body,
#app {
height: 100%;
width: 100%;
overflow: hidden;
@@ -144,10 +148,21 @@ html, body, #app {
flex-shrink: 0;
}
.status-done { color: var(--green); }
.status-error { color: var(--red); }
.status-running { color: var(--accent); }
.status-pending { color: var(--text-dim); }
.status-done {
color: var(--green);
}
.status-error {
color: var(--red);
}
.status-running {
color: var(--accent);
}
.status-pending {
color: var(--text-dim);
}
.sidebar-item-title {
overflow: hidden;
@@ -251,10 +266,21 @@ html, body, #app {
text-align: center;
}
.stage-done { color: var(--green); }
.stage-error { color: var(--red); }
.stage-running { color: var(--accent); }
.stage-pending { color: var(--text-dim); }
.stage-done {
color: var(--green);
}
.stage-error {
color: var(--red);
}
.stage-running {
color: var(--accent);
}
.stage-pending {
color: var(--text-dim);
}
.spinner {
display: inline-block;
@@ -262,8 +288,13 @@ html, body, #app {
}
@keyframes spin {
from { transform: rotate(0deg); }
to { transform: rotate(360deg); }
from {
transform: rotate(0deg);
}
to {
transform: rotate(360deg);
}
}
.pipeline-step-label {
@@ -309,10 +340,25 @@ html, body, #app {
flex-shrink: 0;
}
.badge-green { background: rgba(34,197,94,0.15); color: #4ade80; }
.badge-blue { background: rgba(59,130,246,0.15); color: #60a5fa; }
.badge-yellow{ background: rgba(234,179,8,0.15); color: #facc15; }
.badge-red { background: rgba(239,68,68,0.15); color: #f87171; }
.badge-green {
background: rgba(34, 197, 94, 0.15);
color: #4ade80;
}
.badge-blue {
background: rgba(59, 130, 246, 0.15);
color: #60a5fa;
}
.badge-yellow {
background: rgba(234, 179, 8, 0.15);
color: #facc15;
}
.badge-red {
background: rgba(239, 68, 68, 0.15);
color: #f87171;
}
.card-title {
font-size: 16px;
@@ -556,3 +602,124 @@ html, body, #app {
gap: 10px;
padding-top: 4px;
}
/* ── Landing page ───────────────────────────────────────── */
.landing-layout {
display: flex;
height: 100vh;
position: relative;
overflow: hidden;
}
.landing-bg {
position: absolute;
inset: -6px;
/* overflow slightly to hide blur edges */
background: url('/wallpaper.png') center / cover no-repeat;
filter: blur(3px) brightness(0.35);
z-index: 0;
}
.landing-layout .sidebar {
position: relative;
z-index: 1;
background: rgba(26, 29, 39, 0.85);
backdrop-filter: blur(8px);
}
.landing-main {
flex: 1;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 28px;
text-align: center;
position: relative;
z-index: 1;
padding: 40px;
}
.landing-title {
font-size: 5rem;
font-weight: 800;
color: #fff;
letter-spacing: -2px;
line-height: 1;
}
.landing-tagline {
font-size: 1.4rem;
color: rgba(255, 255, 255, 0.6);
font-weight: 400;
}
.btn-gradient {
padding: 18px 52px;
font-size: 1.15rem;
font-weight: 700;
color: #fff;
border: none;
border-radius: 14px;
cursor: pointer;
background: linear-gradient(135deg, #e040fb, #7c4dff, #2979ff, #00b0ff, #e040fb);
background-size: 300% 300%;
animation: gradient-flow 5s ease infinite;
box-shadow: 0 4px 32px rgba(99, 102, 241, 0.4);
transition: transform 0.15s, box-shadow 0.15s;
letter-spacing: 0.02em;
}
.btn-gradient:hover {
transform: translateY(-2px);
box-shadow: 0 8px 40px rgba(99, 102, 241, 0.55);
}
@keyframes gradient-flow {
0% {
background-position: 0% 50%;
}
50% {
background-position: 100% 50%;
}
100% {
background-position: 0% 50%;
}
}
/* ── Recom page ─────────────────────────────────────────── */
.recom-page {
display: flex;
flex-direction: column;
height: 100vh;
overflow: hidden;
}
.recom-nav {
flex-shrink: 0;
padding: 12px 24px;
border-bottom: 1px solid var(--border);
background: var(--bg-surface);
}
.recom-back {
color: var(--text-muted);
text-decoration: none;
font-size: 14px;
font-weight: 500;
transition: color 0.15s;
}
.recom-back:hover {
color: var(--text);
}
.recom-content {
flex: 1;
overflow-y: auto;
padding: 32px;
}