.visually-hidden {
    clip: rect(0 0 0 0);
    clip-path: inset(100%);
    height: 1px;
    overflow: hidden;
    position: absolute;
    width: 1px;
    white-space: nowrap;
}

.toc-list, .toc-list ol {
    list-style-type: none;
}

.toc-list {
    font-family: Helvetica;
    padding: 0;
}

.toc-list ol {
    padding-inline-start: 2ch;
}

/* Only applies to level 1 entries */
.toc-list > li > a {
    font-weight: bold;
    margin-block-start: 1em;
}

.toc-list li > a {
    text-decoration: none;
    display: grid;
    grid-template-columns: auto max-content;
}

.toc-list li > a > .title {
    position: relative;
    overflow: hidden;
}

.toc-list li > a .leaders::after {
    position: absolute;
    content: "a...................................."
             "....................................."
             "....................................."
             "....................................."
             "....................................."
             "....................................."
             "....................................."
             "....................................."
             "....................................."
             "....................................."
             "....................................."
             "....................................z";
    text-align: right;
    margin-left: .5em;
    margin-right: .5em;
    font-family: consolas;
}

.toc-list li > a > .page {
    font-variant-numeric: tabular-nums;
    text-align: right;
    margin-left: 1ch;
}
