diff --git a/alfa-client/apps/admin-e2e/src/components/buildinfo/buildinfo.e2e.component.ts b/alfa-client/apps/admin-e2e/src/components/buildinfo/buildinfo.e2e.component.ts
index 5bede900428396575e45c322fe1357c7ac9d3a3a..e6521431d3c69f85ff9dfc9aa060605a0f38e349 100644
--- a/alfa-client/apps/admin-e2e/src/components/buildinfo/buildinfo.e2e.component.ts
+++ b/alfa-client/apps/admin-e2e/src/components/buildinfo/buildinfo.e2e.component.ts
@@ -1,9 +1,9 @@
 export class BuildInfoE2EComponent {
-  private readonly locatorVersion: string = 'build-version';
+  private readonly locatorBuildInfo: string = 'build-info';
   private readonly locatorBuildTime: string = 'build-time';
 
-  public getVersion() {
-    return cy.getTestElement(this.locatorVersion);
+  public getBuildInfo() {
+    return cy.getTestElement(this.locatorBuildInfo);
   }
 
   public getBuildTime() {
diff --git a/alfa-client/apps/admin-e2e/src/e2e/app/buildinfo.cy.ts b/alfa-client/apps/admin-e2e/src/e2e/app/buildinfo.cy.ts
index 9ba459c3402f408b6a1813da97d3a16d1df224a6..18e94c6e8ac38641fb5555c55e5ae4f17b0e33a7 100644
--- a/alfa-client/apps/admin-e2e/src/e2e/app/buildinfo.cy.ts
+++ b/alfa-client/apps/admin-e2e/src/e2e/app/buildinfo.cy.ts
@@ -14,8 +14,8 @@ describe('Buildinfo', () => {
   });
 
   describe('get buildinfo', () => {
-    it('should show version', () => {
-      exist(buildInfo.getVersion());
+    it('should show build info', () => {
+      exist(buildInfo.getBuildInfo());
       header.getCurrentUserProfile().logout();
     });
   });
diff --git a/alfa-client/apps/admin/project.json b/alfa-client/apps/admin/project.json
index e113da51b11ba0f7afa5d2a0e194ba9aea7a1e82..a823b06f67d3c4bea4fa758699ea1583d1a00c68 100644
--- a/alfa-client/apps/admin/project.json
+++ b/alfa-client/apps/admin/project.json
@@ -8,24 +8,22 @@
   "targets": {
     "build": {
       "executor": "@angular-devkit/build-angular:browser",
-      "outputs": [
-        "{options.outputPath}"
-      ],
+      "outputs": ["{options.outputPath}"],
       "options": {
         "outputPath": "dist/apps/admin",
         "index": "apps/admin/src/index.html",
         "main": "apps/admin/src/main.ts",
-        "polyfills": [
-          "zone.js"
-        ],
+        "polyfills": ["zone.js"],
         "tsConfig": "apps/admin/tsconfig.app.json",
         "assets": [
-          "apps/admin/src/favicon.ico",
-          "apps/admin/src/assets"
-        ],
-        "styles": [
-          "apps/admin/src/styles.scss"
+          "apps/admin/src/assets",
+          {
+            "input": "apps/admin/src/favicon",
+            "glob": "**/*",
+            "output": ""
+          }
         ],
+        "styles": ["apps/admin/src/styles.scss"],
         "scripts": [],
         "stylePreprocessorOptions": {
           "includePaths": [
@@ -87,15 +85,11 @@
     },
     "lint": {
       "executor": "@nx/eslint:lint",
-      "outputs": [
-        "{options.outputFile}"
-      ]
+      "outputs": ["{options.outputFile}"]
     },
     "test": {
       "executor": "@nx/jest:jest",
-      "outputs": [
-        "{workspaceRoot}/coverage/{projectRoot}"
-      ],
+      "outputs": ["{workspaceRoot}/coverage/{projectRoot}"],
       "options": {
         "jestConfig": "apps/admin/jest.config.ts"
       }
@@ -108,22 +102,16 @@
     },
     "container": {
       "executor": "@nx-tools/nx-container:build",
-      "dependsOn": [
-        "build"
-      ],
+      "dependsOn": ["build"],
       "options": {
         "engine": "docker",
         "push": false,
         "metadata": {
-          "images": [
-            "docker.ozg-sh.de/admin-client"
-          ],
+          "images": ["docker.ozg-sh.de/admin-client"],
           "load": true,
-          "tags": [
-            "build-latest"
-          ]
+          "tags": ["build-latest"]
         }
       }
     }
   }
-}
\ No newline at end of file
+}
diff --git a/alfa-client/apps/admin/src/app/app.component.html b/alfa-client/apps/admin/src/app/app.component.html
index f2b6f351107b9ad56a829832c750d7b9f6956033..8fef349aa6bea31dfb841c6a07597871affb55cc 100644
--- a/alfa-client/apps/admin/src/app/app.component.html
+++ b/alfa-client/apps/admin/src/app/app.component.html
@@ -37,6 +37,6 @@
         <unavailable-page></unavailable-page>
       </ng-template>
     </main>
+    <alfa-build-info *ngIf="apiRoot" [apiRoot]="apiRoot" data-test-id="build-info" />
   </div>
-  <footer data-test-id="build-version">Version: {{ apiRoot.version }}</footer>
 </ng-container>
diff --git a/alfa-client/apps/admin/src/app/app.component.spec.ts b/alfa-client/apps/admin/src/app/app.component.spec.ts
index fbf5f0baf5ba16a4c33e3140833521efb6e7a367..818658ddd7ad7ec20ab2e1e48086d50628123f3e 100644
--- a/alfa-client/apps/admin/src/app/app.component.spec.ts
+++ b/alfa-client/apps/admin/src/app/app.component.spec.ts
@@ -1,9 +1,6 @@
 import { ApiRootLinkRel, ApiRootResource, ApiRootService } from '@alfa-client/api-root-shared';
-import {
-  HasLinkPipe,
-  createEmptyStateResource,
-  createStateResource,
-} from '@alfa-client/tech-shared';
+import { BuildInfoComponent } from '@alfa-client/common-lib';
+import { HasLinkPipe, createEmptyStateResource, createStateResource } from '@alfa-client/tech-shared';
 import {
   Mock,
   dispatchEventFromFixture,
@@ -36,7 +33,7 @@ describe('AppComponent', () => {
   let fixture: ComponentFixture<AppComponent>;
 
   const adminHeaderSelector: string = getDataTestIdOf('admin-header');
-  const buildVersionSelector: string = getDataTestIdOf('build-version');
+  const buildInfoSelector: string = getDataTestIdOf('build-info');
   const userProfileButtonSelector: string = getDataTestIdOf('user-profile-button');
   const navigationSelector: string = getDataTestIdOf('navigation');
   const logoLink: string = getDataTestIdOf('logo-link');
@@ -62,6 +59,7 @@ describe('AppComponent', () => {
         MockComponent(UnavailablePageComponent),
         MockComponent(NavbarComponent),
         MockComponent(NavItemComponent),
+        MockComponent(BuildInfoComponent),
         HasLinkPipe,
         MockDirective(RouterOutlet),
       ],
@@ -160,9 +158,7 @@ describe('AppComponent', () => {
   describe('navigation', () => {
     beforeEach(() => {});
     it('should show links if configuration link exists', () => {
-      component.apiRootStateResource$ = of(
-        createStateResource(createApiRootResource([ApiRootLinkRel.CONFIGURATION])),
-      );
+      component.apiRootStateResource$ = of(createStateResource(createApiRootResource([ApiRootLinkRel.CONFIGURATION])));
       fixture.detectChanges();
 
       const navbarElement: HTMLElement = getElementFromFixture(fixture, navigationSelector);
@@ -181,17 +177,15 @@ describe('AppComponent', () => {
   });
 
   describe('build version', () => {
-    const apiResource: ApiRootResource = createApiRootResource();
-
-    beforeEach(() => {
-      component.apiRootStateResource$ = of(createStateResource(apiResource));
+    it('should not be rendered if api root not loaded', () => {
+      notExistsAsHtmlElement(fixture, buildInfoSelector);
     });
 
     it('should show after apiRoot loaded', () => {
+      component.apiRootStateResource$ = of(createStateResource(createApiRootResource()));
       fixture.detectChanges();
 
-      const buildVersionElement = getElementFromFixture(fixture, buildVersionSelector);
-      expect(buildVersionElement.textContent.trim()).toEqual(`Version: ${apiResource.version}`);
+      existsAsHtmlElement(fixture, buildInfoSelector);
     });
   });
 
@@ -199,9 +193,7 @@ describe('AppComponent', () => {
     beforeEach(() => {});
 
     it('should exist if configuration resource available', () => {
-      component.apiRootStateResource$ = of(
-        createStateResource(createApiRootResource([ApiRootLinkRel.CONFIGURATION])),
-      );
+      component.apiRootStateResource$ = of(createStateResource(createApiRootResource([ApiRootLinkRel.CONFIGURATION])));
 
       fixture.detectChanges();
 
diff --git a/alfa-client/apps/admin/src/app/app.module.ts b/alfa-client/apps/admin/src/app/app.module.ts
index 01643aecf53c02179b296544043e2dd10f3fca65..05eb114fe4b711dbcf2f993a4f7cddf41e0d2d11 100644
--- a/alfa-client/apps/admin/src/app/app.module.ts
+++ b/alfa-client/apps/admin/src/app/app.module.ts
@@ -1,9 +1,11 @@
 import { AdminSettingsModule } from '@admin-client/admin-settings';
 import { ApiRootModule } from '@alfa-client/api-root-shared';
+import { BuildInfoComponent } from '@alfa-client/common-lib';
 import { EnvironmentModule } from '@alfa-client/environment-shared';
 import { TechSharedModule } from '@alfa-client/tech-shared';
-import { CommonModule } from '@angular/common';
+import { CommonModule, registerLocaleData } from '@angular/common';
 import { HTTP_INTERCEPTORS, provideHttpClient, withInterceptorsFromDi } from '@angular/common/http';
+import localeDe from '@angular/common/locales/de';
 import { NgModule } from '@angular/core';
 import { FormsModule, ReactiveFormsModule } from '@angular/forms';
 import { BrowserModule } from '@angular/platform-browser';
@@ -36,6 +38,8 @@ import { UserRolesPageComponent } from '../pages/users-roles/user-roles-page/use
 import { AppComponent } from './app.component';
 import { appRoutes } from './app.routes';
 
+registerLocaleData(localeDe);
+
 @NgModule({
   declarations: [
     AppComponent,
@@ -75,6 +79,7 @@ import { appRoutes } from './app.routes';
       },
     }),
     TechSharedModule,
+    BuildInfoComponent,
   ],
   providers: [
     {
diff --git a/alfa-client/apps/admin/src/favicon/apple-touch-icon.png b/alfa-client/apps/admin/src/favicon/apple-touch-icon.png
new file mode 100644
index 0000000000000000000000000000000000000000..d1e03d655a5aa8d259aacdf45f1fcf28a09251be
Binary files /dev/null and b/alfa-client/apps/admin/src/favicon/apple-touch-icon.png differ
diff --git a/alfa-client/apps/admin/src/favicon/favicon.svg b/alfa-client/apps/admin/src/favicon/favicon.svg
new file mode 100644
index 0000000000000000000000000000000000000000..f610ada33f00495a5ce2e6e6f8f1936de57dec4c
--- /dev/null
+++ b/alfa-client/apps/admin/src/favicon/favicon.svg
@@ -0,0 +1,82 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<svg id="Ebene_1" data-name="Ebene 1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 0 250.45 291.68">
+  <defs>
+    <style>
+      .cls-1 {
+        clip-path: url(#clippath-4);
+      }
+
+      .cls-2 {
+        fill: none;
+      }
+
+      .cls-3 {
+        clip-path: url(#clippath-1);
+      }
+
+      .cls-4 {
+        clip-path: url(#clippath-5);
+      }
+
+      .cls-5 {
+        clip-path: url(#clippath-3);
+      }
+
+      .cls-6 {
+        fill: url(#Unbenannter_Verlauf_11);
+      }
+
+      .cls-7 {
+        clip-path: url(#clippath-2);
+      }
+
+      .cls-8 {
+        clip-path: url(#clippath);
+      }
+
+      .cls-9 {
+        fill: #003064;
+      }
+    </style>
+    <linearGradient id="Unbenannter_Verlauf_11" data-name="Unbenannter Verlauf 11" x1="149.23" y1="174.09" x2="250.45" y2="174.09" gradientUnits="userSpaceOnUse">
+      <stop offset="0" stop-color="#003064"/>
+      <stop offset="1" stop-color="#d4004b"/>
+    </linearGradient>
+    <clipPath id="clippath">
+      <path class="cls-2" d="M182.48,248.08c0,21.25-17.11,38.59-38.15,38.59s-36.9-15.93-38.04-36.14c0-31.09-21.39-57.24-50.08-64.28,12.79-4.17,22.94-14.36,27.02-27.3,6.96,29.06,32.78,50.65,63.36,50.65,20.1,1.15,35.88,18.03,35.88,38.48Z"/>
+    </clipPath>
+    <clipPath id="clippath-1">
+      <rect class="cls-2" x="51.21" y="153.95" width="136.27" height="137.73"/>
+    </clipPath>
+    <clipPath id="clippath-2">
+      <rect class="cls-2" x="51.21" y="153.95" width="136.27" height="137.73"/>
+    </clipPath>
+    <clipPath id="clippath-3">
+      <path class="cls-2" d="M182.48,43.59c0,20.45-15.75,37.33-35.73,38.48-35.43,0-64.42,28.83-65.33,64.51-.04.61-.04,1.19-.04,1.8-1.1,19.72-17.03,35.26-36.56,36.1h-.15c-.49.04-1.02.04-1.51.04-2.08,0-4.12-.15-6.13-.54-.61-.11-1.21-.23-1.82-.34-1.78-.34-3.48-.84-5.15-1.45-2.12-.8-4.13-1.76-6.06-2.91-.61-.34-1.17-.69-1.7-1.07-.15-.08-.3-.19-.45-.31-.76-.5-1.48-1.03-2.16-1.57-.11-.08-.23-.15-.34-.31-.87-.69-1.7-1.42-2.5-2.18-.49-.5-.98-1-1.48-1.53-1.67-1.72-3.1-3.6-4.35-5.63-.3-.5-.61-1.03-.91-1.53-.91-1.53-1.7-3.18-2.35-4.86-.68-1.68-1.25-3.45-1.67-5.25-.15-.61-.3-1.19-.38-1.8-.11-.61-.23-1.23-.3-1.84-.19-1.23-.3-2.49-.38-3.75-.04-.57-.04-1.15-.04-1.72,0-.8.04-1.57.08-2.34.08-1.11.19-2.22.34-3.33.11-.88.27-1.76.45-2.64.04-.08.04-.15.08-.19.15-.88.38-1.76.64-2.6.15-.54.34-1.11.53-1.65.19-.57.42-1.19.64-1.76.38-.96.8-1.91,1.25-2.83.34-.73.72-1.42,1.1-2.07.64-1.15,1.36-2.26,2.12-3.33.61-.88,1.25-1.72,1.93-2.53.04-.04.08-.08.11-.11.42-.5.83-.96,1.29-1.42.34-.38.68-.73,1.02-1.07.53-.54,1.06-1.03,1.63-1.49.49-.46.98-.88,1.51-1.26,1.21-1,2.5-1.88,3.82-2.68.83-.5,1.67-.96,2.54-1.38.49-.31,1.02-.54,1.55-.77.38-.19.76-.34,1.17-.5.38-.19.79-.34,1.21-.46,3.33-1.26,6.89-2.03,10.6-2.22h.49c1.14,0,2.27-.04,3.37-.11h.11c34.37-2.07,61.69-30.9,61.69-65.89,1.13-20.33,17.83-36.3,38.04-36.3s38.15,17.34,38.15,38.59Z"/>
+    </clipPath>
+    <clipPath id="clippath-4">
+      <rect class="cls-2" y="0" width="187.48" height="189.53"/>
+    </clipPath>
+    <clipPath id="clippath-5">
+      <rect class="cls-2" y="0" width="187.48" height="189.53"/>
+    </clipPath>
+  </defs>
+  <g>
+    <path class="cls-9" d="M207.42,137.73h-67.63c-8.36,0-15.14-6.86-15.14-15.31s6.78-15.31,15.14-15.31h67.63c8.36,0,15.14,6.86,15.14,15.31s-6.78,15.31-15.14,15.31Z"/>
+    <path class="cls-6" d="M235.31,189.41h-70.94c-8.36,0-15.14-6.86-15.14-15.31s6.78-15.31,15.14-15.31h70.94c8.36,0,15.14,6.86,15.14,15.31s-6.78,15.31-15.14,15.31Z"/>
+  </g>
+  <g class="cls-8">
+    <g class="cls-3">
+      <g class="cls-7">
+        <image width="285" height="288" transform="translate(50.88 153.49) scale(.48)" xlink:href=""/>
+      </g>
+    </g>
+  </g>
+  <g class="cls-5">
+    <g class="cls-1">
+      <g class="cls-4">
+        <image width="391" height="396" transform="translate(0 -.11) scale(.48)" xlink:href=""/>
+      </g>
+    </g>
+  </g>
+</svg>
\ No newline at end of file
diff --git a/alfa-client/apps/admin/src/favicon/logo192.png b/alfa-client/apps/admin/src/favicon/logo192.png
new file mode 100644
index 0000000000000000000000000000000000000000..058c5bb8a8fc79b10adea359c97563030c09bc91
Binary files /dev/null and b/alfa-client/apps/admin/src/favicon/logo192.png differ
diff --git a/alfa-client/apps/admin/src/favicon/logo512.png b/alfa-client/apps/admin/src/favicon/logo512.png
new file mode 100644
index 0000000000000000000000000000000000000000..86e8c57ac21fd004a424962e4d46bf13bfcfcdef
Binary files /dev/null and b/alfa-client/apps/admin/src/favicon/logo512.png differ
diff --git a/alfa-client/apps/admin/src/favicon/manifest.json b/alfa-client/apps/admin/src/favicon/manifest.json
new file mode 100644
index 0000000000000000000000000000000000000000..ab5afa131edbb266f434c9ce991db50fc685633b
--- /dev/null
+++ b/alfa-client/apps/admin/src/favicon/manifest.json
@@ -0,0 +1,24 @@
+{
+  "name": "Alfa Administration",
+  "short_name": "Administration Client",
+  "icons": [
+    {
+      "src": "favicon.svg",
+      "sizes": "64x64 32x32 24x24 16x16",
+      "type": "image/x-icon"
+    },
+    {
+      "src": "logo192.png",
+      "type": "image/png",
+      "sizes": "192x192"
+    },
+    {
+      "src": "logo512.png",
+      "type": "image/png",
+      "sizes": "512x512"
+    }
+  ],
+  "theme_color": "#ffffff",
+  "background_color": "#ffffff",
+  "display": "standalone"
+}
diff --git a/alfa-client/apps/admin/src/index.html b/alfa-client/apps/admin/src/index.html
index e9b77e77d1493dd0f7e67f051941b5c48fff1b33..667d6ae9fdd9724394c4018d6c6526ee13e177c1 100644
--- a/alfa-client/apps/admin/src/index.html
+++ b/alfa-client/apps/admin/src/index.html
@@ -5,11 +5,11 @@
     <title>admin</title>
     <base href="/" />
     <meta name="viewport" content="width=device-width, initial-scale=1" />
-    <link rel="icon" type="image/x-icon" href="favicon.ico" />
+    <link rel="icon" href="/favicon.svg" type="image/svg+xml" />
+    <link rel="apple-touch-icon" href="/apple-touch-icon.png" />
+    <link rel="manifest" href="/manifest.json" />
   </head>
-  <body
-    class="flex max-h-full min-h-full overflow-hidden bg-white text-black dark:bg-slate-900 dark:text-slate-100"
-  >
+  <body class="flex max-h-full min-h-full overflow-hidden bg-white text-black dark:bg-slate-900 dark:text-slate-100">
     <app-root class="flex w-full flex-col"></app-root>
   </body>
 </html>
diff --git a/alfa-client/apps/alfa/src/app/app.component.html b/alfa-client/apps/alfa/src/app/app.component.html
index 089e9de91f369cb64da483eb2a4316543084ae53..b10af37299a6874ab18519ed496e0366d18cb0bc 100644
--- a/alfa-client/apps/alfa/src/app/app.component.html
+++ b/alfa-client/apps/alfa/src/app/app.component.html
@@ -31,11 +31,7 @@
       <div class="mat-app-background relative grow"><router-outlet></router-outlet></div>
 
       <section class="mat-app-background right-nav">
-        <alfa-build-info
-          *ngIf="apiRoot.resource"
-          [apiRoot]="apiRoot.resource"
-          data-test-id="build-info"
-        ></alfa-build-info>
+        <alfa-build-info *ngIf="apiRoot.resource" [apiRoot]="apiRoot.resource" data-test-id="build-info"></alfa-build-info>
       </section>
     </div>
   </ozgcloud-spinner>
diff --git a/alfa-client/apps/alfa/src/app/app.component.spec.ts b/alfa-client/apps/alfa/src/app/app.component.spec.ts
index 0ca6382a2e0987cdbc277b9d388a891049849563..f20f5bc5f23bd56572d7b5d78c8117f5f83341e6 100644
--- a/alfa-client/apps/alfa/src/app/app.component.spec.ts
+++ b/alfa-client/apps/alfa/src/app/app.component.spec.ts
@@ -22,6 +22,7 @@
  * unter der Lizenz sind dem Lizenztext zu entnehmen.
  */
 import { ApiRootFacade } from '@alfa-client/api-root-shared';
+import { BuildInfoComponent } from '@alfa-client/common-lib';
 import { ENVIRONMENT_CONFIG } from '@alfa-client/environment-shared';
 import { NavigationService } from '@alfa-client/navigation-shared';
 import { createEmptyStateResource, createStateResource } from '@alfa-client/tech-shared';
@@ -30,20 +31,18 @@ import { IconService, SpinnerComponent } from '@alfa-client/ui';
 import { registerLocaleData } from '@angular/common';
 import localeDe from '@angular/common/locales/de';
 import { ComponentFixture, TestBed } from '@angular/core/testing';
+import { Params } from '@angular/router';
 import { RouterTestingModule } from '@angular/router/testing';
 import { AuthConfig, OAuthEvent, OAuthService } from 'angular-oauth2-oidc';
 import { createApiRootResource } from 'libs/api-root-shared/test/api-root';
-import { BuildInfoComponent } from 'libs/navigation/src/lib/build-info/build-info.component';
 import { HeaderContainerComponent } from 'libs/navigation/src/lib/header-container/header-container.component';
 import { getDataTestIdOf } from 'libs/tech-shared/test/data-test';
 import { setWindowLocationUrl } from 'libs/tech-shared/test/window';
+import * as VorgangNavigationUtil from 'libs/vorgang-shared/src/lib/vorgang-navigation.util';
 import { MockComponent } from 'ng-mocks';
 import { of } from 'rxjs';
 import { AppComponent } from './app.component';
 
-import { Params } from '@angular/router';
-import * as VorgangNavigationUtil from 'libs/vorgang-shared/src/lib/vorgang-navigation.util';
-
 registerLocaleData(localeDe);
 
 describe('AppComponent', () => {
diff --git a/alfa-client/apps/alfa/src/app/app.module.ts b/alfa-client/apps/alfa/src/app/app.module.ts
index f7138d442ac5f3c8ff30f3864c4f2943bd5a4c9e..d9adaece899487f8d6d584d8ea20ff641578c7e9 100644
--- a/alfa-client/apps/alfa/src/app/app.module.ts
+++ b/alfa-client/apps/alfa/src/app/app.module.ts
@@ -23,6 +23,7 @@
  */
 import { ApiRootModule } from '@alfa-client/api-root-shared';
 import { AppSharedModule } from '@alfa-client/app-shared';
+import { BuildInfoComponent } from '@alfa-client/common-lib';
 import { EnvironmentModule } from '@alfa-client/environment-shared';
 import { HintSharedModule } from '@alfa-client/hint-shared';
 import { NavigationModule } from '@alfa-client/navigation';
@@ -75,6 +76,7 @@ const routes: Routes = [
     }),
     ApiRootModule,
     NavigationModule,
+    BuildInfoComponent,
     AppSharedModule,
     StoreModule.forRoot(
       {},
diff --git a/alfa-client/libs/common-lib/.eslintrc.json b/alfa-client/libs/common-lib/.eslintrc.json
new file mode 100644
index 0000000000000000000000000000000000000000..6685b2e35bbf3f0d58387f6617c9bd749c0c55f2
--- /dev/null
+++ b/alfa-client/libs/common-lib/.eslintrc.json
@@ -0,0 +1,45 @@
+{
+  "extends": ["../../.eslintrc.json"],
+  "ignorePatterns": ["!**/*"],
+  "overrides": [
+    {
+      "files": ["*.ts"],
+      "extends": ["plugin:@nx/angular", "plugin:@angular-eslint/template/process-inline-templates"],
+      "rules": {
+        "@angular-eslint/directive-selector": [
+          "error",
+          {
+            "type": "attribute",
+            "prefix": "lib",
+            "style": "camelCase"
+          }
+        ],
+        "@angular-eslint/component-selector": [
+          "error",
+          {
+            "type": "element",
+            "prefix": "lib",
+            "style": "kebab-case"
+          }
+        ]
+      }
+    },
+    {
+      "files": ["*.html"],
+      "extends": ["plugin:@nx/angular-template"],
+      "rules": {}
+    },
+    {
+      "files": ["*.json"],
+      "parser": "jsonc-eslint-parser",
+      "rules": {
+        "@nx/dependency-checks": [
+          "error",
+          {
+            "ignoredFiles": ["{projectRoot}/eslint.config.{js,cjs,mjs}"]
+          }
+        ]
+      }
+    }
+  ]
+}
diff --git a/alfa-client/libs/common-lib/README.md b/alfa-client/libs/common-lib/README.md
new file mode 100644
index 0000000000000000000000000000000000000000..f56ea72f2a6f3e405f04f090fb7d2670a8913dcf
--- /dev/null
+++ b/alfa-client/libs/common-lib/README.md
@@ -0,0 +1,7 @@
+# common-lib
+
+This library was generated with [Nx](https://nx.dev).
+
+## Running unit tests
+
+Run `nx test common-lib` to execute the unit tests.
diff --git a/alfa-client/libs/common-lib/jest.config.ts b/alfa-client/libs/common-lib/jest.config.ts
new file mode 100644
index 0000000000000000000000000000000000000000..5126e9a7275f05132fe089f9560dd29e561a732e
--- /dev/null
+++ b/alfa-client/libs/common-lib/jest.config.ts
@@ -0,0 +1,21 @@
+export default {
+  displayName: 'common-lib',
+  preset: '../../jest.preset.js',
+  setupFilesAfterEnv: ['<rootDir>/src/test-setup.ts'],
+  coverageDirectory: '../../coverage/libs/common-lib',
+  transform: {
+    '^.+\\.(ts|mjs|js|html)$': [
+      'jest-preset-angular',
+      {
+        tsconfig: '<rootDir>/tsconfig.spec.json',
+        stringifyContentPathRegex: '\\.(html|svg)$',
+      },
+    ],
+  },
+  transformIgnorePatterns: ['node_modules/(?!.*\\.mjs$)'],
+  snapshotSerializers: [
+    'jest-preset-angular/build/serializers/no-ng-attributes',
+    'jest-preset-angular/build/serializers/ng-snapshot',
+    'jest-preset-angular/build/serializers/html-comment',
+  ],
+};
diff --git a/alfa-client/libs/common-lib/project.json b/alfa-client/libs/common-lib/project.json
new file mode 100644
index 0000000000000000000000000000000000000000..8a477e97d512ef3eac6cfe8ff272ed0754b5991c
--- /dev/null
+++ b/alfa-client/libs/common-lib/project.json
@@ -0,0 +1,20 @@
+{
+  "name": "common-lib",
+  "$schema": "../../node_modules/nx/schemas/project-schema.json",
+  "sourceRoot": "libs/common-lib/src",
+  "prefix": "lib",
+  "projectType": "library",
+  "tags": [],
+  "targets": {
+    "test": {
+      "executor": "@nx/jest:jest",
+      "outputs": ["{workspaceRoot}/coverage/{projectRoot}"],
+      "options": {
+        "jestConfig": "libs/common-lib/jest.config.ts"
+      }
+    },
+    "lint": {
+      "executor": "@nx/eslint:lint"
+    }
+  }
+}
diff --git a/alfa-client/libs/common-lib/src/index.ts b/alfa-client/libs/common-lib/src/index.ts
new file mode 100644
index 0000000000000000000000000000000000000000..f8f49f20b7993383fbce5faf8a3db0b1524766a0
--- /dev/null
+++ b/alfa-client/libs/common-lib/src/index.ts
@@ -0,0 +1 @@
+export * from './lib/build-info/build-info.component';
diff --git a/alfa-client/libs/navigation/src/lib/build-info/build-info.component.html b/alfa-client/libs/common-lib/src/lib/build-info/build-info.component.html
similarity index 95%
rename from alfa-client/libs/navigation/src/lib/build-info/build-info.component.html
rename to alfa-client/libs/common-lib/src/lib/build-info/build-info.component.html
index 41cce668006927fdd81db4f1c49e8eaca49358cd..097debe503d2855dd2fed9cd631badf65e9f1836 100644
--- a/alfa-client/libs/navigation/src/lib/build-info/build-info.component.html
+++ b/alfa-client/libs/common-lib/src/lib/build-info/build-info.component.html
@@ -30,6 +30,4 @@
     <span data-test-id="build-time">{{ buildTime }}</span>
   </ng-container>
 </p>
-<p *ngIf="isNotProduction" data-test-id="not-production-text" class="test-environment text-error">
-  Achtung Testumgebung
-</p>
+<p *ngIf="isNotProduction" data-test-id="not-production-text" class="test-environment">Achtung Testumgebung</p>
diff --git a/alfa-client/libs/navigation/src/lib/build-info/build-info.component.scss b/alfa-client/libs/common-lib/src/lib/build-info/build-info.component.scss
similarity index 98%
rename from alfa-client/libs/navigation/src/lib/build-info/build-info.component.scss
rename to alfa-client/libs/common-lib/src/lib/build-info/build-info.component.scss
index 73f433970c0765f31b0f88b78a30fad26513afdb..1d3adee3ebaa45eb315e04c8fca52fd70950e855 100644
--- a/alfa-client/libs/navigation/src/lib/build-info/build-info.component.scss
+++ b/alfa-client/libs/common-lib/src/lib/build-info/build-info.component.scss
@@ -61,4 +61,5 @@ p {
   margin-right: $navigation-height + $header-height;
   letter-spacing: 0.42em;
   text-transform: uppercase;
+  color: theme('colors.error');
 }
diff --git a/alfa-client/libs/navigation/src/lib/build-info/build-info.component.spec.ts b/alfa-client/libs/common-lib/src/lib/build-info/build-info.component.spec.ts
similarity index 97%
rename from alfa-client/libs/navigation/src/lib/build-info/build-info.component.spec.ts
rename to alfa-client/libs/common-lib/src/lib/build-info/build-info.component.spec.ts
index 663ad95f94a684c5b02cae60201ed823b66e4eab..ee6c655e9b27be5f653ac86eb2fbafbcb57400de 100644
--- a/alfa-client/libs/navigation/src/lib/build-info/build-info.component.spec.ts
+++ b/alfa-client/libs/common-lib/src/lib/build-info/build-info.component.spec.ts
@@ -21,10 +21,10 @@
  * Die sprachspezifischen Genehmigungen und Beschränkungen
  * unter der Lizenz sind dem Lizenztext zu entnehmen.
  */
+import { FormatDateWithTimePipe } from '@alfa-client/tech-shared';
 import { registerLocaleData } from '@angular/common';
 import localeDe from '@angular/common/locales/de';
 import { ComponentFixture, TestBed } from '@angular/core/testing';
-import { FormatDateWithTimePipe } from '@alfa-client/tech-shared';
 import { createApiRootResource } from 'libs/api-root-shared/test/api-root';
 import { BuildInfoComponent } from './build-info.component';
 
@@ -47,7 +47,8 @@ describe('BuildInfoComponent', () => {
 
   beforeEach(async () => {
     await TestBed.configureTestingModule({
-      declarations: [BuildInfoComponent, FormatDateWithTimePipe],
+      imports: [BuildInfoComponent],
+      declarations: [FormatDateWithTimePipe],
     }).compileComponents();
   });
 
diff --git a/alfa-client/libs/navigation/src/lib/build-info/build-info.component.ts b/alfa-client/libs/common-lib/src/lib/build-info/build-info.component.ts
similarity index 94%
rename from alfa-client/libs/navigation/src/lib/build-info/build-info.component.ts
rename to alfa-client/libs/common-lib/src/lib/build-info/build-info.component.ts
index be8f576c3288bfb1818b1976030e5f0894a10d8d..8d7182c2f837679916ebc9b91ee0dc7ed382ca63 100644
--- a/alfa-client/libs/navigation/src/lib/build-info/build-info.component.ts
+++ b/alfa-client/libs/common-lib/src/lib/build-info/build-info.component.ts
@@ -21,13 +21,16 @@
  * Die sprachspezifischen Genehmigungen und Beschränkungen
  * unter der Lizenz sind dem Lizenztext zu entnehmen.
  */
-import { Component, Input } from '@angular/core';
 import { ApiRootResource } from '@alfa-client/api-root-shared';
+import { Component, Input } from '@angular/core';
 
 import * as DateUtil from '@alfa-client/tech-shared';
+import { CommonModule } from '@angular/common';
 
 @Component({
   selector: 'alfa-build-info',
+  imports: [CommonModule],
+  standalone: true,
   templateUrl: './build-info.component.html',
   styleUrls: ['./build-info.component.scss'],
 })
diff --git a/alfa-client/libs/common-lib/src/test-setup.ts b/alfa-client/libs/common-lib/src/test-setup.ts
new file mode 100644
index 0000000000000000000000000000000000000000..f7fad5e59f9d4e62a097bbea63040551de396175
--- /dev/null
+++ b/alfa-client/libs/common-lib/src/test-setup.ts
@@ -0,0 +1,11 @@
+import 'jest-preset-angular/setup-jest';
+
+import { getTestBed } from '@angular/core/testing';
+import { BrowserDynamicTestingModule, platformBrowserDynamicTesting } from '@angular/platform-browser-dynamic/testing';
+
+getTestBed().resetTestEnvironment();
+getTestBed().initTestEnvironment(BrowserDynamicTestingModule, platformBrowserDynamicTesting(), {
+  teardown: { destroyAfterEach: false },
+  errorOnUnknownProperties: true,
+  errorOnUnknownElements: true,
+});
diff --git a/alfa-client/libs/common-lib/tailwind.config.js b/alfa-client/libs/common-lib/tailwind.config.js
new file mode 100644
index 0000000000000000000000000000000000000000..d9b5f51f460d135ef0a5398164cf2a820caaa020
--- /dev/null
+++ b/alfa-client/libs/common-lib/tailwind.config.js
@@ -0,0 +1,14 @@
+const { createGlobPatternsForDependencies } = require('@nx/angular/tailwind');
+const { join } = require('path');
+
+const sharedTailwindConfig = require('../../libs/design-system/src/lib/tailwind-preset/tailwind.config.js');
+
+/** @type {import('tailwindcss').Config} */
+module.exports = {
+  presets: [sharedTailwindConfig],
+  content: [join(__dirname, 'src/**/!(*.stories|*.spec).{ts,html}'), ...createGlobPatternsForDependencies(__dirname)],
+  theme: {
+    extend: {},
+  },
+  plugins: [],
+};
diff --git a/alfa-client/libs/common-lib/tsconfig.json b/alfa-client/libs/common-lib/tsconfig.json
new file mode 100644
index 0000000000000000000000000000000000000000..7cc6baf2f58ed5ccfba098131996f579979e9f18
--- /dev/null
+++ b/alfa-client/libs/common-lib/tsconfig.json
@@ -0,0 +1,16 @@
+{
+  "extends": "../../tsconfig.base.json",
+  "files": [],
+  "include": [],
+  "references": [
+    {
+      "path": "./tsconfig.lib.json"
+    },
+    {
+      "path": "./tsconfig.spec.json"
+    }
+  ],
+  "compilerOptions": {
+    "target": "es2022"
+  }
+}
diff --git a/alfa-client/libs/common-lib/tsconfig.lib.json b/alfa-client/libs/common-lib/tsconfig.lib.json
new file mode 100644
index 0000000000000000000000000000000000000000..4cab05d46338c6e9d4dfe6512fd7eb7f60340d3d
--- /dev/null
+++ b/alfa-client/libs/common-lib/tsconfig.lib.json
@@ -0,0 +1,12 @@
+{
+  "extends": "./tsconfig.json",
+  "compilerOptions": {
+    "outDir": "../../dist/out-tsc",
+    "declaration": true,
+    "declarationMap": true,
+    "inlineSources": true,
+    "types": []
+  },
+  "exclude": ["src/**/*.spec.ts", "src/test-setup.ts", "jest.config.ts", "src/**/*.test.ts"],
+  "include": ["src/**/*.ts"]
+}
diff --git a/alfa-client/libs/common-lib/tsconfig.lib.prod.json b/alfa-client/libs/common-lib/tsconfig.lib.prod.json
new file mode 100644
index 0000000000000000000000000000000000000000..61b523783f299f511f27248a42f86e5f9c29512f
--- /dev/null
+++ b/alfa-client/libs/common-lib/tsconfig.lib.prod.json
@@ -0,0 +1,7 @@
+{
+  "extends": "./tsconfig.lib.json",
+  "compilerOptions": {
+    "declarationMap": false
+  },
+  "angularCompilerOptions": {}
+}
diff --git a/alfa-client/libs/common-lib/tsconfig.spec.json b/alfa-client/libs/common-lib/tsconfig.spec.json
new file mode 100644
index 0000000000000000000000000000000000000000..7870b7c011681fb77d6114001f44d3eeca69975b
--- /dev/null
+++ b/alfa-client/libs/common-lib/tsconfig.spec.json
@@ -0,0 +1,11 @@
+{
+  "extends": "./tsconfig.json",
+  "compilerOptions": {
+    "outDir": "../../dist/out-tsc",
+    "module": "commonjs",
+    "target": "es2016",
+    "types": ["jest", "node"]
+  },
+  "files": ["src/test-setup.ts"],
+  "include": ["jest.config.ts", "src/**/*.test.ts", "src/**/*.spec.ts", "src/**/*.d.ts"]
+}
diff --git a/alfa-client/libs/navigation/src/lib/navigation.module.ts b/alfa-client/libs/navigation/src/lib/navigation.module.ts
index 0a98c2c4232b12ea4f7e1004d30f8828bdd0769f..1622cf215a88c546c52288e1ffdda3c1d28075b2 100644
--- a/alfa-client/libs/navigation/src/lib/navigation.module.ts
+++ b/alfa-client/libs/navigation/src/lib/navigation.module.ts
@@ -21,26 +21,20 @@
  * Die sprachspezifischen Genehmigungen und Beschränkungen
  * unter der Lizenz sind dem Lizenztext zu entnehmen.
  */
-import { CommonModule } from '@angular/common';
-import { NgModule } from '@angular/core';
-import { RouterModule } from '@angular/router';
 import { UiModule } from '@alfa-client/ui';
 import { UserAssistanceModule } from '@alfa-client/user-assistance';
 import { UserProfileModule } from '@alfa-client/user-profile';
 import { UserSettingsModule } from '@alfa-client/user-settings';
 import { VorgangSharedUiModule } from '@alfa-client/vorgang-shared-ui';
-import { BuildInfoComponent } from './build-info/build-info.component';
+import { CommonModule } from '@angular/common';
+import { NgModule } from '@angular/core';
+import { RouterModule } from '@angular/router';
 import { HeaderContainerComponent } from './header-container/header-container.component';
 import { HeaderLogoComponent } from './header-container/header/header-logo/header-logo.component';
 import { HeaderComponent } from './header-container/header/header.component';
 
 @NgModule({
-  declarations: [
-    BuildInfoComponent,
-    HeaderComponent,
-    HeaderContainerComponent,
-    HeaderLogoComponent,
-  ],
+  declarations: [HeaderComponent, HeaderContainerComponent, HeaderLogoComponent],
   imports: [
     CommonModule,
     UiModule,
@@ -50,6 +44,6 @@ import { HeaderComponent } from './header-container/header/header.component';
     UserSettingsModule,
     UserAssistanceModule,
   ],
-  exports: [BuildInfoComponent, HeaderContainerComponent],
+  exports: [HeaderContainerComponent],
 })
 export class NavigationModule {}
diff --git a/alfa-client/tsconfig.base.json b/alfa-client/tsconfig.base.json
index 074d37046bc7c1d420bba5c631c72ec945d9b276..1123019a134bc3716bf6280a1115b72261f6a2db 100644
--- a/alfa-client/tsconfig.base.json
+++ b/alfa-client/tsconfig.base.json
@@ -61,7 +61,8 @@
       "@alfa-client/zustaendige-stelle-shared": ["libs/zustaendige-stelle-shared/src/index.ts"],
       "@ods/component": ["libs/design-component/src/index.ts"],
       "@ods/system": ["libs/design-system/src/index.ts"],
-      "authentication": ["libs/authentication/src/index.ts"]
+      "authentication": ["libs/authentication/src/index.ts"],
+      "@alfa-client/common-lib": ["libs/common-lib/src/index.ts"]
     }
   },
   "exclude": ["node_modules", "tmp"]