19-05-2026 Rebrand Pressekonto, Hub-Flux UI und Legacy-Media-Migration

Umbenennung presseportale → pressekonto in Domains, Themes und Dokumentation.
Design-Tokens, Portal-Shell, Customer-Dashboard, Auth- und Admin-PM-Views.
Artisan-Befehl migrate:legacy-media mit Tests und Hub-Flux-Entwicklungsdocs.

Co-authored-by: Cursor <cursoragent@cursor.com>
This commit is contained in:
Kevin Adametz 2026-05-19 16:36:13 +00:00
parent 092ee0e918
commit 0a3e52d603
112 changed files with 8464 additions and 1649 deletions

View file

@ -1,6 +1,23 @@
@import "tailwindcss";
@import "../../vendor/livewire/flux/dist/flux.css";
/**
* Hub × FluxUI Phase 1: Portal-Shell auf Hub-Design.
*
* Tokens leben in shared/design-tokens.css (Single Source of Truth aus Phase 0).
* Hier:
* 1. Tokens importieren
* 2. Zinc-Skala auf Hub-Buchpapier-Familie mappen (für FluxUI-Komponenten,
* die ihre Skala-Defaults aus Zinc beziehen)
* 3. FluxUI-Akzent (--color-accent) auf Hub-Blau umstellen
* 4. FluxUI-Komponenten via [data-flux-*]-Selektoren ans Hub-Design angleichen
* (Sidebar, Navlist-Active, Primary-Buttons, Cards)
*
* Dokumentation: dev/frontend/hub-flux/02-PHASE-1-PORTAL-SHELL.md
*/
@import "./shared/design-tokens.css";
@import "./shared/hub-components.css";
@source '../views';
@source '../../vendor/laravel/framework/src/Illuminate/Pagination/resources/views/*.blade.php';
@source '../../vendor/livewire/flux-pro/stubs/**/*.blade.php';
@ -9,34 +26,46 @@
@custom-variant dark (&:where(.dark, .dark *));
@theme {
--font-sans: "Instrument Sans", ui-sans-serif, system-ui, sans-serif,
/* Font: Inter Tight statt Instrument Sans
(Token --font-sans aus design-tokens.css wird hier nochmal explizit
gesetzt, weil FluxUI zuvor seinen eigenen Wert setzen würde) */
--font-sans:
"Inter Tight", Inter, ui-sans-serif, system-ui, sans-serif,
"Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol",
"Noto Color Emoji";
--color-zinc-50: var(--color-neutral-50);
--color-zinc-100: var(--color-neutral-100);
--color-zinc-200: var(--color-neutral-200);
--color-zinc-300: var(--color-neutral-300);
--color-zinc-400: var(--color-neutral-400);
--color-zinc-500: var(--color-neutral-500);
--color-zinc-600: var(--color-neutral-600);
--color-zinc-700: var(--color-neutral-700);
--color-zinc-800: var(--color-neutral-800);
--color-zinc-900: var(--color-neutral-900);
--color-zinc-950: var(--color-neutral-950);
/* FluxUI-Akzent (für Buttons, Focus-Rings, Active-States) auf Hub-Blau.
Vorher: #3ea3dc (Starter-Kit-Türkis). */
--color-accent: var(--color-hub);
--color-accent-content: var(--color-hub);
--color-accent-foreground: #ffffff;
--color-accent: #3ea3dc;
--color-accent-content: #3ea3dc;
--color-accent-foreground: var(--color-white);
/* Zinc-Skala auf warmes Buchpapier mappen.
FluxUI nutzt Zinc als neutrale Skala für Sidebars, Borders, Text.
Wir bridgen die ganze Skala, damit der Look automatisch auf Hub-Stil
umschwenkt ohne dass wir hunderte FluxUI-Klassen einzeln umbiegen
müssen. */
--color-zinc-50: #fbfaf6;
--color-zinc-100: #f6f4ef;
--color-zinc-200: #e2ddd0;
--color-zinc-300: #cfc8b5;
--color-zinc-400: #8a918d;
--color-zinc-500: #5a6360;
--color-zinc-600: #3a413d;
--color-zinc-700: #1a1f1c;
--color-zinc-800: #243152;
--color-zinc-900: #1a2540;
--color-zinc-950: #0f1729;
}
@layer theme {
.dark {
--color-accent: #3ea3dc;
--color-accent-content: #5bb8e6;
--color-accent-foreground: var(--color-white);
}
}
/* Phase 5: Dark-Mode-Mapping liegt jetzt vollständig in
shared/design-tokens.css (`.dark { }`). FluxUI Appearance-Switcher
setzt `class="dark"` auf <html>, alle `--color-*`-Vars schalten
automatisch um inklusive `--color-accent`, weil das oben im @theme
per `var(--color-hub)`-Verweis dynamisch ist.
Der Notfall-Hack aus Phase 1 (`.dark { --color-accent: var(--color-hub) }`)
ist damit gegenstandslos und entfernt. */
@layer base {
*,
@ -48,6 +77,10 @@
}
}
/* ============================================================
* FluxUI Form-Felder Layout vom Starter-Kit übernommen
* Input-Focus wird weiter unten im Kontrast-Tuning auf Hub-Blau gesetzt.
* ============================================================ */
[data-flux-field]:not(ui-radio, ui-checkbox) {
@apply grid gap-2;
}
@ -56,12 +89,165 @@
@apply !mb-0 !leading-tight;
}
/* ============================================================
* Phase 1 Hub-Style-Overrides für FluxUI-Komponenten
* ============================================================
*
* Strategie: minimal-invasive Overrides via [data-flux-*]-Attribute und
* der Tailwind-Klassen, die FluxUI auf seinen Komponenten setzt. Wir
* ändern KEINE Vendor-Dateien, sondern legen unsere Styles mit höherer
* Spezifität darüber.
*
* Wichtig: FluxUI nutzt für variant-spezifisches Styling KEINE
* `data-variant`-Attribute, sondern direkt Tailwind-Klassen wie
* `bg-[var(--color-accent)]` (für variant="primary"). Wir greifen
* deshalb über diese Klassen-Selektoren.
*
* Bei FluxUI-Updates können sich diese Klassen ändern Selektoren bewusst
* konservativ, gut kommentiert. Visueller Smoke-Test pro Release-Bump.
* ============================================================ */
/* Sidebar — warmes Buchpapier statt Zinc-Grau, klare Trennlinie */
[data-flux-sidebar] {
background: var(--color-bg-elev);
border-color: var(--color-bg-rule);
}
/* Sidebar-Section-Headings Mockup-Konvention:
10 px, fett, gesperrt, anthrazit */
[data-flux-navlist] [data-flux-navlist-group-heading],
[data-flux-navlist] [data-flux-group-heading] {
font-size: 10px;
font-weight: 700;
letter-spacing: 0.18em;
text-transform: uppercase;
color: var(--color-ink-4);
padding-bottom: 6px;
}
/* Navlist-Item — Hub-Stil: kompakter, mit Active-Strip links */
[data-flux-navlist-item] {
font-size: 13px;
font-weight: 500;
color: var(--color-ink-2);
border-radius: var(--radius-sm);
transition:
background 0.12s,
color 0.12s;
}
[data-flux-navlist-item]:hover {
background: var(--color-bg);
color: var(--color-hub);
}
[data-flux-navlist-item][data-current="true"],
[data-flux-navlist-item][aria-current="page"],
[data-flux-navlist-item].active {
background: var(--color-hub-soft);
color: var(--color-hub);
font-weight: 600;
position: relative;
}
[data-flux-navlist-item][data-current="true"]::before,
[data-flux-navlist-item][aria-current="page"]::before,
[data-flux-navlist-item].active::before {
content: "";
position: absolute;
left: -1px;
top: 6px;
bottom: 6px;
width: 2px;
background: var(--color-hub);
border-radius: 0 2px 2px 0;
}
/* ============================================================
* FluxUI Buttons Hub-Stil
* ============================================================
* FluxUI rendert `<flux:button variant="primary">` als
* class=" bg-[var(--color-accent)]
* hover:bg-[color-mix(in_oklab,_var(--color-accent),_transparent_10%)]
* shadow-[inset_0px_1px_--theme(--color-white/.2)] "
*
* `--color-accent` haben wir auf `var(--color-hub)` (#1A2540) gesetzt
* Default-Background passt schon. ABER:
*
* 1. Der Hover ("10 % transparent") wirkt auf hellem Buchpapier
* hellblau wir wollen statt dessen Hub-2 (#243152, dunkler) wie
* auf der Hub-Landing (`hover:bg-hub-2`).
* 2. FluxUI's Default-Shadow (1 px Weiß-Inset) braucht auf dem warmen
* Hintergrund mehr Kontrast für klare Button-Kanten.
*
* Wir greifen über `data-flux-button` (Attribut auf dem gerenderten
* <button>) plus dem Tailwind-Klassen-Selektor mit escapten Brackets.
* !important ist nötig, weil FluxUI's Tailwind-Hover normal höhere
* Spezifität hätte (escapter Klassenname). */
/* Primary-Button-Hover: dunkler statt heller. */
[data-flux-button].hover\:bg-\[color-mix\(in_oklab\,_var\(--color-accent\)\,_transparent_10\%\)\]:hover {
background-color: var(--color-hub-2) !important;
}
/* Primary-Button: kräftigerer Shadow für klare Button-Kanten auf hellem Bg.
Schatten-Farbton hängt vom Mode ab: Light = warmer Hub-Blau-Alpha,
Dark = neutraler Schwarz-Alpha (sonst wirkt der hub-blaue Schatten
auf dunklem Card-BG zu sichtbar). */
[data-flux-button].bg-\[var\(--color-accent\)\] {
box-shadow:
inset 0 1px 0 rgba(255, 255, 255, 0.18),
0 1px 2px rgba(26, 37, 64, 0.25),
0 2px 6px -2px rgba(26, 37, 64, 0.18);
border-color: var(--color-hub-2);
}
[data-flux-button].bg-\[var\(--color-accent\)\]:hover {
box-shadow:
inset 0 1px 0 rgba(255, 255, 255, 0.15),
0 2px 4px rgba(26, 37, 64, 0.35),
0 3px 10px -2px rgba(26, 37, 64, 0.25);
}
.dark [data-flux-button].bg-\[var\(--color-accent\)\] {
box-shadow:
inset 0 1px 0 rgba(255, 255, 255, 0.12),
0 1px 2px rgba(0, 0, 0, 0.5),
0 2px 6px -2px rgba(0, 0, 0, 0.4);
border-color: var(--color-hub);
}
.dark [data-flux-button].bg-\[var\(--color-accent\)\]:hover {
box-shadow:
inset 0 1px 0 rgba(255, 255, 255, 0.1),
0 2px 4px rgba(0, 0, 0, 0.6),
0 3px 10px -2px rgba(0, 0, 0, 0.5);
}
/* Cards — Buchpapier statt Zinc */
[data-flux-card] {
background: var(--color-bg-card);
border-color: var(--color-bg-rule);
}
/* Headings & Heading-Defaults — Hub-Ink-Farbe */
[data-flux-heading] {
color: var(--color-ink);
}
/* ============================================================
* Kontrast-Tuning für Inputs, Borders, Trennlinien
* ============================================================
* Unser Zinc Buchpapier-Mapping macht `border-zinc-200` zu `#e2ddd0`
* (warmes Rule). Auf hellem Buchpapier sind Inputs/Cards damit korrekt
* vom Bg trennend, aber für Fokus-States braucht's klar Hub-Blau. */
/* Input-Focus: Hub-Blau-Ring statt blassen Default */
input:focus[data-flux-control],
textarea:focus[data-flux-control],
select:focus[data-flux-control] {
@apply outline-hidden ring-2 ring-accent ring-offset-2 ring-offset-accent-foreground;
@apply ring-2 ring-offset-1;
--tw-ring-color: var(--color-hub);
--tw-ring-offset-color: var(--color-bg-elev);
border-color: var(--color-hub) !important;
}
/* \[:where(&)\]:size-4 {
@apply size-4;
} */