It was added and then removed by accident some time ago. Let us add it again, as it is useful.
        return v.parent
 }
 
+// FirstSection returns the section on level 1 below home, e.g. "/docs".
+// For the home page, this will return itself.
+func (p *Page) FirstSection() *Page {
+       v := p
+       if v.origOnCopy != nil {
+               v = v.origOnCopy
+       }
+
+       if v.parent == nil || v.parent.IsHome() {
+               return v
+       }
+
+       parent := v.parent
+       for {
+               current := parent
+               parent = parent.parent
+               if parent == nil || parent.IsHome() {
+                       return current
+               }
+       }
+
+}
+
 // InSection returns whether the given page is in the current section.
 // Note that this will always return false for pages that are
 // not either regular, home or section pages.
 
                        active, err := home.InSection(home)
                        assert.NoError(err)
                        assert.True(active)
+                       assert.Equal(p, p.FirstSection())
                }},
                {"l1", func(p *Page) {
                        assert.Equal("L1s", p.title)
                        isAncestor, err = p.IsAncestor(l1)
                        assert.NoError(err)
                        assert.False(isAncestor)
+                       assert.Equal(l1, p.FirstSection())
 
                }},
                {"perm a,link", func(p *Page) {