diff --git a/src/libs/utils/detailswidget.cpp b/src/libs/utils/detailswidget.cpp
index adc0cc2262b2919e28047f29163554ffcdb30872..67b5954aaf304ab716a97c45d63e240a3ff3fa2d 100644
--- a/src/libs/utils/detailswidget.cpp
+++ b/src/libs/utils/detailswidget.cpp
@@ -104,7 +104,7 @@ namespace Utils {
             QWidget(parent),
             d(new DetailsWidgetPrivate(this))
     {
-        d->m_summaryLabel->setTextInteractionFlags(Qt::TextSelectableByMouse);
+        d->m_summaryLabel->setTextInteractionFlags(Qt::TextSelectableByMouse | Qt::LinksAccessibleByMouse);
         d->m_summaryLabel->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Fixed);
         d->m_summaryLabel->setContentsMargins(MARGIN, MARGIN, MARGIN, MARGIN);
 
@@ -128,6 +128,8 @@ namespace Utils {
                 this, SLOT(setExpanded(bool)));
         connect(d->m_summaryCheckBox, SIGNAL(toggled(bool)),
                 this, SIGNAL(checked(bool)));
+        connect(d->m_summaryLabel, SIGNAL(linkActivated(QString)),
+                this, SIGNAL(linkActivated(QString)));
         updateControls();
     }
 
diff --git a/src/libs/utils/detailswidget.h b/src/libs/utils/detailswidget.h
index a34b82b88d0355af2fe07844862b2e71c9760355..7fb01bacfd2c78e1b1150d0ac092ef9ceec58d16 100644
--- a/src/libs/utils/detailswidget.h
+++ b/src/libs/utils/detailswidget.h
@@ -94,6 +94,7 @@ public:
 
 signals:
     void checked(bool);
+    void linkActivated(const QString &link);
 private slots:
     void setExpanded(bool);
 
diff --git a/src/plugins/projectexplorer/environmentwidget.cpp b/src/plugins/projectexplorer/environmentwidget.cpp
index 7f6e597aef003fd6ca6509d65da1780e292b7f1a..ade5dd3d2da60137d7de5fe2735a3ecd7f75084f 100644
--- a/src/plugins/projectexplorer/environmentwidget.cpp
+++ b/src/plugins/projectexplorer/environmentwidget.cpp
@@ -147,6 +147,9 @@ EnvironmentWidget::EnvironmentWidget(QWidget *parent, QWidget *additionalDetails
     connect(d->m_environmentView->selectionModel(), SIGNAL(currentChanged(QModelIndex,QModelIndex)),
             this, SLOT(environmentCurrentIndexChanged(QModelIndex)));
 
+    connect(d->m_detailsContainer, SIGNAL(linkActivated(QString)),
+            this, SLOT(linkActivated(QString)));
+
     connect(d->m_model, SIGNAL(userChangesChanged()), this, SLOT(updateSummaryText()));
 }
 
@@ -199,9 +202,9 @@ void EnvironmentWidget::updateSummaryText()
         if (item.name != Utils::EnvironmentModel::tr("<VARIABLE>")) {
             text.append("<br>");
             if (item.unset)
-                text.append(tr("Unset <b>%1</b>").arg(Qt::escape(item.name)));
+                text.append(tr("Unset <a href=\"%1\"><b>%1</b></a>").arg(Qt::escape(item.name)));
             else
-                text.append(tr("Set <b>%1</b> to <b>%2</b>").arg(Qt::escape(item.name), Qt::escape(item.value)));
+                text.append(tr("Set <a href=\"%1\"><b>%1</b></a> to <b>%2</b>").arg(Qt::escape(item.name), Qt::escape(item.value)));
         }
     }
 
@@ -213,6 +216,13 @@ void EnvironmentWidget::updateSummaryText()
     d->m_detailsContainer->setSummaryText(text);
 }
 
+void EnvironmentWidget::linkActivated(const QString &link)
+{
+    d->m_detailsContainer->setState(Utils::DetailsWidget::Expanded);
+    QModelIndex idx = d->m_model->variableToIndex(link);
+    focusIndex(idx);
+}
+
 void EnvironmentWidget::updateButtons()
 {
     environmentCurrentIndexChanged(d->m_environmentView->currentIndex());
diff --git a/src/plugins/projectexplorer/environmentwidget.h b/src/plugins/projectexplorer/environmentwidget.h
index c8efbed42ca6fe77c8ca704e939e99d0a0e465bc..f00ad5ee17b26fa2edc3ef93a217ce4f8b622c1c 100644
--- a/src/plugins/projectexplorer/environmentwidget.h
+++ b/src/plugins/projectexplorer/environmentwidget.h
@@ -75,6 +75,7 @@ private slots:
     void updateSummaryText();
     void focusIndex(const QModelIndex &index);
     void updateButtons();
+    void linkActivated(const QString &link);
 
 private:
     QScopedPointer<EnvironmentWidgetPrivate> d;