.toc{
    position:fixed;
    top:50%;
    right:10px;
    transform:translateY(-50%);
    z-index:1000;
    width:min(320px,18vw);
    max-height:70vh;
    background:var(--panel2);
    border:1px solid var(--border);
    border-right:none;
    border-radius:12px 0 0 12px;
    overflow:hidden;
    box-shadow:0 8px 24px rgba(0,0,0,.12);
}

.toc__title{
    padding:10px 12px;
    font-weight:900;
    border-bottom:1px solid var(--border);
    background:var(--panel);
}

.toc__list{
    display:flex;
    flex-direction:column;
    gap:4px;
    padding:8px;
    overflow:auto;
    max-height:calc(70vh - 44px);
}

.toc__a{
    display:block;
    text-decoration:none;
    color:var(--text);
    padding:8px 10px;
    border-radius:10px;
    border:1px solid transparent;
    font-weight:700;
    line-height:1.15;
}

.toc__a:hover{
    background:var(--panel);
    border-color:var(--border2);
    color:var(--accent);
}

.toc__a--sys{color:var(--muted)}
.toc__a--l3{padding-left:18px}
.toc__a--l4{padding-left:26px}

@media (max-width:1100px){
    .toc{display:none}
}
