La lista <T> sobrescribe todos los elementos dentro de un bucle foreach al último valor

Estoy tratando de crear una aplicación de Windows en la que hay un cuadro combinado y durante la carga (), estoy completando este cuadro combinado con todas las cadenas de conexión disponibles en mi archivo de configuración de aplicación.

Aquí está la aplicación Fragmento de configuración:

<!-- Adding Multiple Servers in Connection String-->
<connectionStrings>
   <add name="SQLConnect-1"
         connectionString="Data Source=SAHIL; Initial Catalog=RecordComparisonTool; Integrated Security=SSPI"
         providerName="System.Data.SqlCLient"/>

   <add name="SQLConnect-2"
     connectionString="Data Source=SAHIL; Initial Catalog=RecordComparisonTool; User Id=test; Password=12123; Integrated Security=SSPI"
     providerName="System.Data.SqlCLient"/>

   <add name="SQLConnect-3"
     connectionString="Data Source=SAHIL; Initial Catalog=RecordComparisonTool; User Id=test; Password=32315;  Integrated Security=True"
     providerName="System.Data.SqlCLient"/>
 </connectionStrings>

He creado una clase CompareResult en la que intento obtener todos los valores de la aplicación, configurarlos y mostrarlos en el cuadro combinado.

namespace RecordComparisonTool_Win
{
   public class ConnectionString
   {
        public string name { get; set; }
        public string conString { get; set; }
        public string provider { get; set; }
    }

    public class CompareResult
    {

        public List<ConnectionString> GetConnection()
        {
            List<ConnectionString> conStr = new List<ConnectionString>();
            ConnectionString conn = new ConnectionString();

            foreach (ConnectionStringSettings css in ConfigurationManager.ConnectionStrings)
            {
                if (!(css.Name == "LocalSqlServer" || css.Name == "LocalMySqlServer"))
                {
                    conn.name = css.Name;
                    conn.conString = css.ConnectionString;
                    conn.provider = css.ProviderName;

                    conStr.Add(conn);
                }
            }
            return conStr;
        }

    }
}

El problema es que cuando intento vincularlo con el cuadro combinado, muestra tres registros según el archivo app.Config, pero todos los registros tienen el mismo valor que "SQLConnect-3". No puedo encontrar la razón por la cual la Lista se actualizó con "SQLConnect-3" para todos los registros. Por favor, ayuda a corregir el error. Aquí está el fragmento donde estoy vinculando esta lista a ComboBox

protected void LoadConnection()
{
    CompareResult compareResult = new CompareResult();

    List<ConnectionString> connectionString = new List<ConnectionString>();
    connectionString = compareResult.GetConnection();

    cbTokenLeft.DataSource = connectionString;

    cbTokenLeft.DisplayMember = "name";
    cbTokenLeft.ValueMember = "conString";

}

Respuestas a la pregunta(3)

Su respuesta a la pregunta