.timeline {
    margin-top: 2rem;
    margin-bottom: 2rem;
}

.timeline > .title {
    font-size: 1.5rem;
    margin-top: 2rem;
    margin-bottom: 2rem;
    font-weight: bold;
}

.timeline > .row {
    display: flex;
    gap: 1rem;
}


.timeline > .row > .axis-container > .bullet {
    width: 1rem;
    height: 1rem;
    border-radius: 0.5rem;
    background-color: var(--color-element-contrast-high-primary);
}

.timeline > .row > .axis-container > .line {
    width: 2px;
    height: 100%;
    background-color: var(--color-element-contrast-high-primary);
    margin-left: auto;
    margin-right: auto;
}

.timeline > .row:not(:has(~ .row:not([style*="display: none"]):not([style*="display:none"]))) .axis-container > .line {
    display: none;
}

.timeline > .row > .visit {
    margin-bottom: 2rem;
}

.timeline > .row:last-child > .visit {
    margin-bottom: 0;
}
