2026-05-06 11:00:38 +08:00
|
|
|
.dashboard {
|
2026-05-12 15:39:55 +00:00
|
|
|
min-width: 0;
|
2026-05-06 11:00:38 +08:00
|
|
|
display: grid;
|
|
|
|
|
gap: 16px;
|
2026-05-12 15:39:55 +00:00
|
|
|
padding-bottom: 10px;
|
2026-05-06 11:00:38 +08:00
|
|
|
animation: fadeUp 260ms var(--ease) both;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.kpi-grid {
|
|
|
|
|
display: grid;
|
|
|
|
|
grid-template-columns: repeat(6, minmax(0, 1fr));
|
|
|
|
|
gap: 12px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.kpi-card {
|
|
|
|
|
position: relative;
|
|
|
|
|
padding: 12px 14px 10px;
|
|
|
|
|
display: flex;
|
|
|
|
|
flex-direction: column;
|
|
|
|
|
border-left: 3px solid var(--accent);
|
|
|
|
|
animation: dashboardItemIn 520ms var(--ease) both;
|
|
|
|
|
animation-delay: var(--delay, 0ms);
|
|
|
|
|
transition: box-shadow 200ms ease, transform 200ms ease;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.kpi-card:hover {
|
|
|
|
|
box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
|
|
|
|
|
transform: translateY(-1px);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.kpi-head {
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
gap: 6px;
|
|
|
|
|
margin-bottom: 8px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.kpi-icon {
|
|
|
|
|
width: 26px;
|
|
|
|
|
height: 26px;
|
|
|
|
|
display: grid;
|
|
|
|
|
place-items: center;
|
|
|
|
|
border-radius: 7px;
|
|
|
|
|
background: color-mix(in srgb, var(--accent) 10%, white);
|
|
|
|
|
color: var(--accent);
|
|
|
|
|
font-size: 14px;
|
|
|
|
|
flex: 0 0 auto;
|
|
|
|
|
animation: iconPop 560ms var(--ease) both;
|
|
|
|
|
animation-delay: calc(var(--delay, 0ms) + 100ms);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.kpi-label {
|
|
|
|
|
color: #64748b;
|
|
|
|
|
font-size: 11px;
|
|
|
|
|
font-weight: 500;
|
|
|
|
|
line-height: 1.2;
|
|
|
|
|
white-space: nowrap;
|
|
|
|
|
overflow: hidden;
|
|
|
|
|
text-overflow: ellipsis;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.kpi-value {
|
|
|
|
|
display: block;
|
|
|
|
|
min-height: 22px;
|
|
|
|
|
color: #0f172a;
|
|
|
|
|
font-size: clamp(16px, 1.2vw, 20px);
|
|
|
|
|
line-height: 1;
|
|
|
|
|
font-weight: 800;
|
|
|
|
|
font-variant-numeric: tabular-nums;
|
|
|
|
|
white-space: nowrap;
|
|
|
|
|
margin-bottom: 6px;
|
|
|
|
|
letter-spacing: 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.kpi-trend {
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
gap: 6px;
|
|
|
|
|
padding-top: 6px;
|
|
|
|
|
border-top: 1px solid #f1f5f9;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.kpi-badge {
|
|
|
|
|
display: inline-flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
gap: 2px;
|
|
|
|
|
padding: 1px 6px;
|
|
|
|
|
border-radius: 4px;
|
|
|
|
|
font-size: 11px;
|
|
|
|
|
font-weight: 700;
|
|
|
|
|
line-height: 1.45;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.kpi-badge.up {
|
|
|
|
|
background: rgba(239, 68, 68, 0.08);
|
|
|
|
|
color: #dc2626;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.kpi-badge.down {
|
|
|
|
|
background: rgba(22, 163, 74, 0.08);
|
|
|
|
|
color: #16a34a;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.kpi-badge .mdi {
|
|
|
|
|
font-size: 11px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.kpi-delta {
|
|
|
|
|
color: #94a3b8;
|
|
|
|
|
font-size: 10px;
|
|
|
|
|
white-space: nowrap;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.content-grid {
|
|
|
|
|
display: grid;
|
|
|
|
|
grid-template-columns: repeat(12, minmax(0, 1fr));
|
|
|
|
|
gap: 24px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.dashboard-card {
|
|
|
|
|
padding: 20px;
|
|
|
|
|
transition: box-shadow 200ms ease, transform 200ms ease;
|
|
|
|
|
animation: dashboardItemIn 560ms var(--ease) both;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.top-grid .dashboard-card:nth-child(1) { animation-delay: 80ms; }
|
|
|
|
|
.top-grid .dashboard-card:nth-child(2) { animation-delay: 150ms; }
|
|
|
|
|
.top-grid .dashboard-card:nth-child(3) { animation-delay: 220ms; }
|
|
|
|
|
.bottom-grid .dashboard-card:nth-child(1) { animation-delay: 290ms; }
|
|
|
|
|
.bottom-grid .dashboard-card:nth-child(2) { animation-delay: 360ms; }
|
|
|
|
|
.bottom-grid .dashboard-card:nth-child(3) { animation-delay: 430ms; }
|
|
|
|
|
|
|
|
|
|
.dashboard-card:hover {
|
|
|
|
|
box-shadow: 0 4px 24px rgba(0, 0, 0, 0.06);
|
|
|
|
|
transform: translateY(-1px);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.trend-panel,
|
|
|
|
|
.rank-panel {
|
|
|
|
|
grid-column: span 6;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.donut-panel,
|
|
|
|
|
.bottleneck-panel,
|
|
|
|
|
.budget-panel {
|
|
|
|
|
grid-column: span 3;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.card-head {
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
gap: 16px;
|
|
|
|
|
margin-bottom: 16px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.card-head h3 {
|
|
|
|
|
color: #1e293b;
|
|
|
|
|
font-size: 16px;
|
|
|
|
|
font-weight: 600;
|
|
|
|
|
line-height: 1.35;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.card-head .mdi {
|
|
|
|
|
color: #94a3b8;
|
|
|
|
|
font-size: 12px;
|
|
|
|
|
vertical-align: 1px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.card-select {
|
|
|
|
|
height: 30px;
|
|
|
|
|
min-width: 82px;
|
|
|
|
|
padding: 0 8px;
|
|
|
|
|
border: 1px solid #cbd5e1;
|
|
|
|
|
border-radius: 4px;
|
|
|
|
|
background: #fff;
|
|
|
|
|
color: #334155;
|
|
|
|
|
font-size: 14px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.panel-note {
|
|
|
|
|
margin-top: 8px;
|
|
|
|
|
color: #64748b;
|
|
|
|
|
font-size: 12px;
|
|
|
|
|
text-align: center;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.bottleneck-panel,
|
|
|
|
|
.budget-panel {
|
|
|
|
|
display: flex;
|
|
|
|
|
flex-direction: column;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.bottleneck-panel .text-link,
|
|
|
|
|
.budget-panel .text-link {
|
|
|
|
|
margin-top: auto;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.bottleneck-list {
|
|
|
|
|
flex: 1;
|
|
|
|
|
display: grid;
|
|
|
|
|
gap: 16px;
|
|
|
|
|
align-content: center;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.bottleneck-row {
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
gap: 12px;
|
|
|
|
|
animation: listRowIn 460ms var(--ease) both;
|
|
|
|
|
animation-delay: var(--delay, 0ms);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.reviewer {
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
gap: 12px;
|
|
|
|
|
min-width: 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.reviewer-avatar {
|
|
|
|
|
width: 32px;
|
|
|
|
|
height: 32px;
|
|
|
|
|
display: grid;
|
|
|
|
|
place-items: center;
|
|
|
|
|
border-radius: 999px;
|
|
|
|
|
background: #e2f6ef;
|
|
|
|
|
color: #047857;
|
|
|
|
|
font-size: 13px;
|
|
|
|
|
font-weight: 700;
|
|
|
|
|
flex: 0 0 auto;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.reviewer strong,
|
|
|
|
|
.reviewer-stats strong {
|
|
|
|
|
display: block;
|
|
|
|
|
color: #1e293b;
|
|
|
|
|
font-size: 14px;
|
|
|
|
|
font-weight: 500;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.reviewer span,
|
|
|
|
|
.reviewer-stats span {
|
|
|
|
|
display: block;
|
|
|
|
|
margin-top: 4px;
|
|
|
|
|
color: #64748b;
|
|
|
|
|
font-size: 12px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.reviewer-stats {
|
|
|
|
|
text-align: right;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.status-tag {
|
|
|
|
|
display: inline-flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
padding: 2px 8px;
|
|
|
|
|
border-radius: 4px;
|
|
|
|
|
font-size: 12px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.status-tag.danger {
|
|
|
|
|
background: rgba(239,68,68,.10);
|
|
|
|
|
color: #ef4444;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.status-tag.warning {
|
|
|
|
|
background: rgba(245,158,11,.10);
|
|
|
|
|
color: #f59e0b;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.status-tag.success {
|
|
|
|
|
background: rgba(16,185,129,.10);
|
|
|
|
|
color: #16a34a;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.text-link {
|
|
|
|
|
width: 100%;
|
|
|
|
|
margin-top: 16px;
|
|
|
|
|
display: inline-flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
padding: 16px 0 0;
|
|
|
|
|
border: 0;
|
|
|
|
|
border-top: 1px solid #f1f5f9;
|
|
|
|
|
background: transparent;
|
|
|
|
|
color: #10b981;
|
|
|
|
|
font-size: 14px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@keyframes dashboardItemIn {
|
|
|
|
|
from {
|
|
|
|
|
opacity: 0;
|
|
|
|
|
transform: translateY(12px);
|
|
|
|
|
}
|
|
|
|
|
to {
|
|
|
|
|
opacity: 1;
|
|
|
|
|
transform: translateY(0);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@keyframes listRowIn {
|
|
|
|
|
from {
|
|
|
|
|
opacity: 0;
|
|
|
|
|
transform: translateX(-10px);
|
|
|
|
|
}
|
|
|
|
|
to {
|
|
|
|
|
opacity: 1;
|
|
|
|
|
transform: translateX(0);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@keyframes iconPop {
|
|
|
|
|
0% {
|
|
|
|
|
opacity: 0;
|
|
|
|
|
transform: scale(.82);
|
|
|
|
|
}
|
|
|
|
|
70% {
|
|
|
|
|
opacity: 1;
|
|
|
|
|
transform: scale(1.04);
|
|
|
|
|
}
|
|
|
|
|
100% {
|
|
|
|
|
opacity: 1;
|
|
|
|
|
transform: scale(1);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@media (prefers-reduced-motion: reduce) {
|
|
|
|
|
.kpi-card,
|
|
|
|
|
.dashboard-card,
|
|
|
|
|
.bottleneck-row {
|
|
|
|
|
animation: none;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@media (max-width: 1320px) {
|
|
|
|
|
.kpi-grid {
|
|
|
|
|
grid-template-columns: repeat(3, minmax(0, 1fr));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.trend-panel,
|
|
|
|
|
.rank-panel {
|
|
|
|
|
grid-column: span 12;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.donut-panel,
|
|
|
|
|
.bottleneck-panel,
|
|
|
|
|
.budget-panel {
|
|
|
|
|
grid-column: span 6;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2026-05-12 15:39:55 +00:00
|
|
|
@media (max-width: 1440px) {
|
|
|
|
|
.dashboard {
|
|
|
|
|
gap: 14px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.kpi-grid {
|
|
|
|
|
gap: 10px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.content-grid {
|
|
|
|
|
gap: 18px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.dashboard-card {
|
|
|
|
|
padding: 18px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.card-head {
|
|
|
|
|
margin-bottom: 14px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.card-head h3 {
|
|
|
|
|
font-size: 15px;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2026-05-06 11:00:38 +08:00
|
|
|
@media (max-width: 860px) {
|
|
|
|
|
.kpi-grid,
|
|
|
|
|
.content-grid {
|
|
|
|
|
grid-template-columns: 1fr;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.trend-panel,
|
|
|
|
|
.rank-panel,
|
|
|
|
|
.donut-panel,
|
|
|
|
|
.bottleneck-panel,
|
|
|
|
|
.budget-panel {
|
|
|
|
|
grid-column: span 1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.card-head {
|
|
|
|
|
align-items: flex-start;
|
|
|
|
|
flex-direction: column;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.donut-wrap {
|
|
|
|
|
grid-template-columns: 1fr;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.rank-row {
|
|
|
|
|
grid-template-columns: 24px 64px minmax(0, 1fr);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.rank-value {
|
|
|
|
|
grid-column: 2 / -1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.budget-summary {
|
|
|
|
|
grid-template-columns: 1fr;
|
|
|
|
|
}
|
|
|
|
|
}
|