mirror of
https://github.com/cliffe/BreakEscape.git
synced 2026-02-21 11:18:08 +00:00
221 lines
3.5 KiB
CSS
221 lines
3.5 KiB
CSS
/* Objectives Panel - Top Right HUD
|
|
* Pixel-art aesthetic: sharp corners, 2px borders
|
|
*/
|
|
|
|
.objectives-panel {
|
|
position: fixed;
|
|
top: 20px;
|
|
left: 20px;
|
|
width: 280px;
|
|
max-height: 60vh;
|
|
background: rgba(0, 0, 0, 0.85);
|
|
border: 2px solid #444;
|
|
font-family: 'VT323', monospace;
|
|
z-index: 1500;
|
|
overflow: hidden;
|
|
transition: max-height 0.3s ease;
|
|
}
|
|
|
|
.objectives-panel.collapsed {
|
|
max-height: 40px;
|
|
}
|
|
|
|
.objectives-panel.collapsed .objectives-content {
|
|
display: none;
|
|
}
|
|
|
|
.objectives-header {
|
|
display: flex;
|
|
justify-content: space-between;
|
|
align-items: center;
|
|
padding: 8px 12px;
|
|
background: rgba(40, 40, 60, 0.9);
|
|
border-bottom: 2px solid #444;
|
|
cursor: pointer;
|
|
user-select: none;
|
|
}
|
|
|
|
.objectives-header:hover {
|
|
background: rgba(50, 50, 70, 0.9);
|
|
}
|
|
|
|
.objectives-title {
|
|
color: #fff;
|
|
font-size: 18px;
|
|
font-weight: bold;
|
|
}
|
|
|
|
.objectives-controls {
|
|
display: flex;
|
|
gap: 4px;
|
|
}
|
|
|
|
.objectives-toggle {
|
|
background: none;
|
|
border: none;
|
|
color: #aaa;
|
|
font-size: 14px;
|
|
cursor: pointer;
|
|
padding: 4px 8px;
|
|
font-family: inherit;
|
|
}
|
|
|
|
.objectives-toggle:hover {
|
|
color: #fff;
|
|
}
|
|
|
|
.objectives-content {
|
|
max-height: calc(60vh - 40px);
|
|
overflow-y: auto;
|
|
padding: 8px;
|
|
}
|
|
|
|
.objectives-content::-webkit-scrollbar {
|
|
width: 6px;
|
|
}
|
|
|
|
.objectives-content::-webkit-scrollbar-track {
|
|
background: rgba(0, 0, 0, 0.3);
|
|
}
|
|
|
|
.objectives-content::-webkit-scrollbar-thumb {
|
|
background: rgba(255, 255, 255, 0.2);
|
|
}
|
|
|
|
.objectives-content::-webkit-scrollbar-thumb:hover {
|
|
background: rgba(255, 255, 255, 0.3);
|
|
}
|
|
|
|
/* Aim Styling */
|
|
.objective-aim {
|
|
margin-bottom: 12px;
|
|
}
|
|
|
|
.objective-aim:last-child {
|
|
margin-bottom: 0;
|
|
}
|
|
|
|
.aim-header {
|
|
display: flex;
|
|
align-items: center;
|
|
gap: 8px;
|
|
padding: 6px 0;
|
|
color: #ffcc00;
|
|
font-size: 16px;
|
|
}
|
|
|
|
.aim-completed .aim-header {
|
|
color: #4ade80;
|
|
opacity: 0.7;
|
|
}
|
|
.aim-completed .aim-title {
|
|
text-decoration: line-through;
|
|
}
|
|
|
|
.aim-icon {
|
|
font-size: 12px;
|
|
flex-shrink: 0;
|
|
}
|
|
|
|
.aim-title {
|
|
line-height: 1.2;
|
|
}
|
|
|
|
.aim-tasks {
|
|
padding-left: 20px;
|
|
border-left: 2px solid #333;
|
|
margin-left: 6px;
|
|
}
|
|
|
|
/* Task Styling */
|
|
.objective-task {
|
|
display: flex;
|
|
align-items: flex-start;
|
|
gap: 8px;
|
|
padding: 4px 0;
|
|
color: #ccc;
|
|
font-size: 14px;
|
|
}
|
|
|
|
.task-completed {
|
|
color: #4ade80;
|
|
opacity: 0.6;
|
|
}
|
|
.task-completed .task-title {
|
|
text-decoration: line-through;
|
|
}
|
|
|
|
.task-icon {
|
|
font-size: 10px;
|
|
color: #888;
|
|
flex-shrink: 0;
|
|
margin-top: 2px;
|
|
}
|
|
|
|
.task-completed .task-icon {
|
|
color: #4ade80;
|
|
}
|
|
|
|
.task-title {
|
|
line-height: 1.3;
|
|
}
|
|
|
|
.task-progress {
|
|
color: #888;
|
|
font-size: 12px;
|
|
}
|
|
|
|
.no-objectives {
|
|
color: #666;
|
|
text-align: center;
|
|
padding: 20px;
|
|
font-style: italic;
|
|
}
|
|
|
|
/* Animation for new objectives */
|
|
@keyframes objective-pulse {
|
|
0% { background-color: rgba(255, 204, 0, 0.3); }
|
|
100% { background-color: transparent; }
|
|
}
|
|
|
|
@keyframes task-complete-flash {
|
|
0% { background-color: rgba(74, 222, 128, 0.4); }
|
|
100% { background-color: transparent; }
|
|
}
|
|
|
|
.objective-aim.new-objective {
|
|
animation: objective-pulse 1s ease-out;
|
|
}
|
|
|
|
.objective-task.new-task {
|
|
animation: task-complete-flash 0.8s ease-out;
|
|
}
|
|
|
|
/* Responsive adjustments */
|
|
@media (max-width: 768px) {
|
|
.objectives-panel {
|
|
width: 240px;
|
|
right: 10px;
|
|
top: 10px;
|
|
max-height: 50vh;
|
|
}
|
|
|
|
.objectives-title {
|
|
font-size: 16px;
|
|
}
|
|
|
|
.aim-header {
|
|
font-size: 14px;
|
|
}
|
|
|
|
.objective-task {
|
|
font-size: 12px;
|
|
}
|
|
}
|
|
|
|
/* Hide panel during certain game states */
|
|
.objectives-panel.hidden,
|
|
.minigame-active .objectives-panel {
|
|
display: none !important;
|
|
}
|