|
|
* { |
|
|
margin: 0; |
|
|
padding: 0; |
|
|
box-sizing: border-box; |
|
|
} |
|
|
|
|
|
body { |
|
|
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif; |
|
|
background: linear-gradient(135deg, #667eea 0%, #764ba2 100%); |
|
|
min-height: 100vh; |
|
|
color: #333; |
|
|
} |
|
|
|
|
|
.container { |
|
|
max-width: 1400px; |
|
|
margin: 0 auto; |
|
|
padding: 20px; |
|
|
} |
|
|
|
|
|
header { |
|
|
text-align: center; |
|
|
margin-bottom: 30px; |
|
|
color: white; |
|
|
} |
|
|
|
|
|
header h1 { |
|
|
font-size: 2.5rem; |
|
|
margin-bottom: 10px; |
|
|
text-shadow: 2px 2px 4px rgba(0,0,0,0.3); |
|
|
} |
|
|
|
|
|
header p { |
|
|
font-size: 1.1rem; |
|
|
opacity: 0.9; |
|
|
} |
|
|
|
|
|
.controls { |
|
|
background: white; |
|
|
padding: 20px; |
|
|
border-radius: 12px; |
|
|
box-shadow: 0 8px 32px rgba(0,0,0,0.1); |
|
|
margin-bottom: 30px; |
|
|
display: flex; |
|
|
justify-content: space-between; |
|
|
align-items: center; |
|
|
flex-wrap: wrap; |
|
|
gap: 20px; |
|
|
} |
|
|
|
|
|
.run-selector select { |
|
|
padding: 8px 16px; |
|
|
border: 2px solid #e1e5e9; |
|
|
border-radius: 8px; |
|
|
font-size: 14px; |
|
|
background: white; |
|
|
cursor: pointer; |
|
|
transition: border-color 0.3s ease; |
|
|
} |
|
|
|
|
|
.run-selector select:focus { |
|
|
outline: none; |
|
|
border-color: #667eea; |
|
|
} |
|
|
|
|
|
.metric-toggle { |
|
|
display: flex; |
|
|
gap: 20px; |
|
|
flex-wrap: wrap; |
|
|
} |
|
|
|
|
|
.metric-toggle label { |
|
|
display: flex; |
|
|
align-items: center; |
|
|
gap: 8px; |
|
|
cursor: pointer; |
|
|
font-weight: 500; |
|
|
color: #555; |
|
|
} |
|
|
|
|
|
.metric-toggle input[type="checkbox"] { |
|
|
width: 18px; |
|
|
height: 18px; |
|
|
accent-color: #667eea; |
|
|
} |
|
|
|
|
|
.charts-container { |
|
|
display: grid; |
|
|
grid-template-columns: repeat(auto-fit, minmax(600px, 1fr)); |
|
|
gap: 30px; |
|
|
margin-bottom: 30px; |
|
|
} |
|
|
|
|
|
.chart-card { |
|
|
background: white; |
|
|
padding: 25px; |
|
|
border-radius: 12px; |
|
|
box-shadow: 0 8px 32px rgba(0,0,0,0.1); |
|
|
transition: transform 0.3s ease, box-shadow 0.3s ease; |
|
|
} |
|
|
|
|
|
.chart-card:hover { |
|
|
transform: translateY(-5px); |
|
|
box-shadow: 0 12px 40px rgba(0,0,0,0.15); |
|
|
} |
|
|
|
|
|
.chart-card h3 { |
|
|
margin-bottom: 20px; |
|
|
color: #333; |
|
|
font-size: 1.2rem; |
|
|
display: flex; |
|
|
align-items: center; |
|
|
gap: 8px; |
|
|
} |
|
|
|
|
|
.chart-card canvas { |
|
|
max-height: 400px; |
|
|
width: 100% !important; |
|
|
} |
|
|
|
|
|
.run-summary, .config-details { |
|
|
background: white; |
|
|
padding: 25px; |
|
|
border-radius: 12px; |
|
|
box-shadow: 0 8px 32px rgba(0,0,0,0.1); |
|
|
margin-bottom: 30px; |
|
|
} |
|
|
|
|
|
.run-summary h3, .config-details h3 { |
|
|
margin-bottom: 20px; |
|
|
color: #333; |
|
|
font-size: 1.2rem; |
|
|
display: flex; |
|
|
align-items: center; |
|
|
gap: 8px; |
|
|
} |
|
|
|
|
|
.run-grid { |
|
|
display: grid; |
|
|
grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); |
|
|
gap: 20px; |
|
|
} |
|
|
|
|
|
.run-card { |
|
|
background: #f8f9fa; |
|
|
padding: 20px; |
|
|
border-radius: 8px; |
|
|
border-left: 4px solid #667eea; |
|
|
} |
|
|
|
|
|
.run-card h4 { |
|
|
color: #667eea; |
|
|
margin-bottom: 10px; |
|
|
font-size: 1.1rem; |
|
|
} |
|
|
|
|
|
.run-card p { |
|
|
margin-bottom: 8px; |
|
|
color: #666; |
|
|
font-size: 0.9rem; |
|
|
} |
|
|
|
|
|
.run-card .metric { |
|
|
display: flex; |
|
|
justify-content: space-between; |
|
|
margin-bottom: 5px; |
|
|
} |
|
|
|
|
|
.run-card .metric .value { |
|
|
font-weight: 600; |
|
|
color: #333; |
|
|
} |
|
|
|
|
|
.config-grid { |
|
|
display: grid; |
|
|
grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); |
|
|
gap: 15px; |
|
|
} |
|
|
|
|
|
.config-item { |
|
|
background: #f8f9fa; |
|
|
padding: 15px; |
|
|
border-radius: 8px; |
|
|
text-align: center; |
|
|
} |
|
|
|
|
|
.config-item .label { |
|
|
font-size: 0.8rem; |
|
|
color: #666; |
|
|
text-transform: uppercase; |
|
|
letter-spacing: 0.5px; |
|
|
margin-bottom: 5px; |
|
|
} |
|
|
|
|
|
.config-item .value { |
|
|
font-size: 1.2rem; |
|
|
font-weight: 600; |
|
|
color: #333; |
|
|
} |
|
|
|
|
|
@media (max-width: 768px) { |
|
|
.container { |
|
|
padding: 15px; |
|
|
} |
|
|
|
|
|
header h1 { |
|
|
font-size: 2rem; |
|
|
} |
|
|
|
|
|
.controls { |
|
|
flex-direction: column; |
|
|
align-items: stretch; |
|
|
} |
|
|
|
|
|
.charts-container { |
|
|
grid-template-columns: 1fr; |
|
|
} |
|
|
|
|
|
.chart-card { |
|
|
padding: 20px; |
|
|
} |
|
|
|
|
|
.run-grid, .config-grid { |
|
|
grid-template-columns: 1fr; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
.chartjs-tooltip { |
|
|
background: rgba(0,0,0,0.8) !important; |
|
|
color: white !important; |
|
|
border-radius: 8px !important; |
|
|
padding: 10px !important; |
|
|
font-size: 12px !important; |
|
|
} |
|
|
|
|
|
|
|
|
.loading { |
|
|
text-align: center; |
|
|
padding: 40px; |
|
|
color: #666; |
|
|
} |
|
|
|
|
|
.loading::after { |
|
|
content: ''; |
|
|
display: inline-block; |
|
|
width: 20px; |
|
|
height: 20px; |
|
|
border: 3px solid #f3f3f3; |
|
|
border-top: 3px solid #667eea; |
|
|
border-radius: 50%; |
|
|
animation: spin 1s linear infinite; |
|
|
margin-left: 10px; |
|
|
} |
|
|
|
|
|
@keyframes spin { |
|
|
0% { transform: rotate(0deg); } |
|
|
100% { transform: rotate(360deg); } |
|
|
} |
|
|
|