diff --git a/css/app.css b/css/app.css index 9dd5ede..61fbc58 100644 --- a/css/app.css +++ b/css/app.css @@ -630,21 +630,25 @@ select:focus { border-color: var(--accent); } /* ── HISTORY TIMELINE ── */ .tl-item { - padding: 12px 0; + display: flex; + align-items: center; + justify-content: space-between; + gap: 24px; + padding: 9px 0; border-bottom: 1px solid var(--border); } .tl-item:last-child { border-bottom: none; } -.tl-time { display: block; color: var(--text3); font-size: 11px; margin-bottom: 5px; } -.tl-desc { display: flex; align-items: baseline; gap: 16px; font-size: 13px; } -.tl-label { color: var(--text2); min-width: 130px; } -.tl-change { display: flex; align-items: baseline; gap: 8px; } -.tl-old { color: var(--text3); text-decoration: line-through; } -.tl-arrow { color: var(--text3); } +.tl-event { display: flex; align-items: center; gap: 7px; font-size: 13px; min-width: 0; } +.tl-label { color: var(--text2); } +.tl-sep { color: var(--text3); user-select: none; } +.tl-old { color: var(--text3); text-decoration: line-through; font-size: 12px; } +.tl-arrow { color: var(--text3); font-size: 11px; } .tl-new { color: var(--text); font-weight: 500; } +.tl-time { color: var(--text3); font-size: 11px; white-space: nowrap; flex-shrink: 0; } .tl-deployed { color: var(--accent); } .tl-testing { color: var(--amber); } .tl-degraded { color: var(--red); } -.tl-created .tl-label { color: var(--accent); font-weight: 500; } +.tl-created .tl-event { color: var(--accent); font-weight: 500; } .tl-empty { color: var(--text3); font-size: 12px; padding: 8px 0; } /* ── SETTINGS MODAL ── */ diff --git a/js/ui.js b/js/ui.js index d3fb403..672ba3f 100644 --- a/js/ui.js +++ b/js/ui.js @@ -193,21 +193,23 @@ async function renderDetailPage(vmid) { ? history.map(e => { if (e.field === 'created') return `