22-05-2026 Optimierung der User und Admin Panels
Some checks failed
linter / quality (push) Has been cancelled
tests / ci (push) Has been cancelled

This commit is contained in:
Kevin Adametz 2026-05-22 11:18:59 +02:00
parent d2ba22c0cf
commit e8c47b7553
73 changed files with 10282 additions and 1546 deletions

View file

@ -665,6 +665,450 @@
max-width: 440px;
}
/* ============================================================
* SEG-TOGGLE (Karten- vs. Listenansicht)
* ============================================================ */
.seg-toggle {
display: inline-flex;
background: var(--color-bg-card);
border: 1px solid var(--color-hub-soft-2);
border-radius: 4px;
padding: 2px;
gap: 0;
}
.seg-toggle button {
display: inline-flex;
align-items: center;
gap: 6px;
padding: 5px 11px;
font-size: 12px;
font-weight: 600;
color: var(--color-ink-3);
border-radius: 3px;
transition: background 0.12s, color 0.12s;
cursor: pointer;
}
.seg-toggle button:hover {
color: var(--color-hub);
}
.seg-toggle button.is-active {
background: var(--color-hub);
color: #fff;
}
.seg-toggle button svg {
opacity: 0.7;
}
.seg-toggle button.is-active svg {
opacity: 1;
}
/* ============================================================
* FIRM-CARD Firmen-Karte im Card-Grid
* ============================================================ */
.firm-card {
background: var(--color-bg-card);
border: 1px solid var(--color-bg-rule);
border-radius: 6px;
padding: 18px;
transition: border-color 0.15s;
display: flex;
flex-direction: column;
gap: 14px;
min-height: 266px;
}
.firm-card:hover {
border-color: var(--color-hub-line);
}
.firm-card.is-self {
border-color: var(--color-bg-rule);
box-shadow: none;
}
.firm-card .logo {
width: 56px;
height: 56px;
border-radius: 6px;
display: flex;
align-items: center;
justify-content: center;
font-family: var(--font-mono);
font-weight: 700;
font-size: 18px;
letter-spacing: -0.5px;
flex-shrink: 0;
overflow: hidden;
}
.firm-card .logo img {
width: 100%;
height: 100%;
object-fit: cover;
}
.firm-card .name {
font-size: 16px;
font-weight: 700;
letter-spacing: -0.3px;
color: var(--color-ink);
line-height: 1.2;
margin: 0;
}
.firm-card .meta-line {
font-size: 11.5px;
color: var(--color-ink-3);
margin-top: 3px;
line-height: 1.4;
}
.firm-card .kpis {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 0;
border-top: 1px solid var(--color-bg-rule-2);
padding-top: 11px;
margin-top: auto;
}
.firm-card .kpi {
display: flex;
flex-direction: column;
gap: 2px;
padding: 0 4px;
border-right: 1px solid var(--color-bg-rule-2);
}
.firm-card .kpi:last-child {
border-right: 0;
}
.firm-card .kpi .k {
font-family: var(--font-mono);
font-size: 15.5px;
font-weight: 600;
color: var(--color-ink);
font-variant-numeric: tabular-nums;
line-height: 1.1;
letter-spacing: -0.3px;
}
.firm-card .kpi .l {
font-size: 10px;
font-weight: 700;
letter-spacing: 0.14em;
text-transform: uppercase;
color: var(--color-ink-4);
}
/* ============================================================
* ROLE-PILL Rolle innerhalb einer Firma
* ============================================================ */
.role-pill {
display: inline-flex;
align-items: center;
gap: 5px;
padding: 2px 8px 2px 7px;
background: var(--color-bg-elev);
border: 1px dashed var(--color-hub-soft-2);
border-radius: 99px;
font-size: 10.5px;
color: var(--color-ink-3);
font-weight: 600;
letter-spacing: 0.04em;
}
.role-pill::before {
content: "";
width: 5px;
height: 5px;
border-radius: 99px;
background: var(--color-accent-warm);
}
.role-pill.admin {
color: var(--color-hub);
}
.role-pill.admin::before {
background: var(--color-hub);
}
/* ============================================================
* MINI-LOGO Kleines Logo in Listen-Zeilen
* ============================================================ */
.mini-logo {
width: 30px;
height: 30px;
border-radius: 4px;
display: inline-flex;
align-items: center;
justify-content: center;
font-family: var(--font-mono);
font-size: 11px;
font-weight: 700;
letter-spacing: -0.3px;
flex-shrink: 0;
overflow: hidden;
}
.mini-logo img {
width: 100%;
height: 100%;
object-fit: cover;
}
/* ============================================================
* LOGO-COLOR-TOKENS Deterministische Avatar-Varianten
* ============================================================ */
.lg-brew {
background: linear-gradient(135deg, #3a4d2f 0%, #1f2e1a 100%);
color: var(--color-accent-soft);
}
.lg-mv {
background: linear-gradient(
135deg,
var(--color-hub) 0%,
var(--color-hub-2) 100%
);
color: #fff;
}
.lg-soft {
background: var(--color-accent-soft);
color: var(--color-accent-deep);
border: 1px solid
color-mix(in oklab, var(--color-accent-warm), transparent 50%);
}
.lg-warm {
background: linear-gradient(
135deg,
var(--color-accent-warm) 0%,
var(--color-accent-deep) 100%
);
color: #fff;
}
.lg-blank {
background: repeating-linear-gradient(
135deg,
var(--color-bg-elev) 0 6px,
var(--color-bg-rule-2) 6px 12px
);
color: var(--color-ink-4);
border: 1px dashed var(--color-hub-soft-2);
}
/* ============================================================
* CARD-ACTION Aktion-Button auf einer Karte
* ============================================================ */
.card-action {
display: inline-flex;
align-items: center;
gap: 6px;
padding: 6px 12px;
border: 1px solid var(--color-hub-soft-2);
background: var(--color-bg-card);
color: var(--color-hub);
border-radius: 4px;
font-size: 12px;
font-weight: 600;
transition: border-color 0.12s, background 0.12s;
white-space: nowrap;
}
.card-action:hover {
border-color: var(--color-hub);
background: var(--color-bg);
}
.card-action.primary {
background: var(--color-hub);
color: #fff;
border-color: var(--color-hub);
}
.card-action.primary:hover {
background: var(--color-hub-2);
}
/* ============================================================
* MENU-TRIGGER 3-Dots Menu-Knopf
* ============================================================ */
.menu-trigger {
display: inline-flex;
align-items: center;
justify-content: center;
width: 30px;
height: 30px;
border-radius: 4px;
border: 1px solid transparent;
color: var(--color-ink-3);
background: transparent;
transition: background 0.12s, border-color 0.12s, color 0.12s;
cursor: pointer;
}
.menu-trigger:hover {
background: var(--color-bg);
border-color: var(--color-hub-soft-2);
color: var(--color-hub);
}
/* ============================================================
* PAGE-BTN Pagination-Buttons
* ============================================================ */
.page-btn {
display: inline-flex;
align-items: center;
justify-content: center;
min-width: 30px;
height: 30px;
padding: 0 9px;
border-radius: 4px;
border: 1px solid var(--color-hub-soft-2);
background: var(--color-bg-card);
font-size: 12px;
font-weight: 600;
color: var(--color-ink-2);
font-family: var(--font-mono);
font-variant-numeric: tabular-nums;
transition: border-color 0.12s, background 0.12s, color 0.12s;
}
.page-btn:hover {
border-color: var(--color-hub);
color: var(--color-hub);
}
.page-btn.is-current {
background: var(--color-hub);
border-color: var(--color-hub);
color: #fff;
}
.page-btn.is-disabled {
color: var(--color-ink-4);
border-color: var(--color-bg-rule-2);
background: var(--color-bg-elev);
cursor: default;
}
.page-btn.is-disabled:hover {
color: var(--color-ink-4);
border-color: var(--color-bg-rule-2);
}
/* ============================================================
* TABLE.LIST Hub-styled Datentabelle (für reine HTML-Tabellen)
* ============================================================ */
table.list {
width: 100%;
border-collapse: separate;
border-spacing: 0;
font-size: 13px;
}
table.list thead th {
text-align: left;
font-weight: 700;
font-size: 10px;
letter-spacing: 0.18em;
text-transform: uppercase;
color: var(--color-ink-3);
padding: 11px 14px;
background: var(--color-bg-elev);
border-bottom: 1px solid var(--color-bg-rule);
white-space: nowrap;
}
table.list thead th:first-child {
padding-left: 18px;
}
table.list thead th:last-child {
padding-right: 18px;
}
table.list tbody td {
padding: 14px;
border-bottom: 1px solid var(--color-bg-rule-2);
vertical-align: middle;
}
table.list tbody td:first-child {
padding-left: 18px;
}
table.list tbody td:last-child {
padding-right: 18px;
}
table.list tbody tr:last-child td {
border-bottom: 0;
}
table.list tbody tr {
transition: background 0.1s;
}
table.list tbody tr:hover {
background: var(--color-bg-elev);
}
.row-title {
font-weight: 600;
color: var(--color-ink);
font-size: 13.5px;
line-height: 1.35;
letter-spacing: -0.1px;
display: inline-flex;
align-items: center;
gap: 9px;
}
.row-title:hover {
color: var(--color-hub);
}
.row-sub {
font-size: 11.5px;
color: var(--color-ink-3);
margin-top: 3px;
line-height: 1.4;
}
.row-num {
font-family: var(--font-mono);
font-variant-numeric: tabular-nums;
font-size: 13px;
color: var(--color-ink);
font-weight: 600;
}
.row-num .sub {
font-family: var(--font-sans, "Inter Tight", sans-serif);
font-weight: 400;
font-size: 11px;
color: var(--color-ink-4);
margin-left: 4px;
letter-spacing: 0.02em;
}
/* ============================================================
* ADD-TILE "Neue Firma anlegen" Karte im Card-Grid
* ============================================================ */
.add-tile {
border: 1.5px dashed var(--color-hub-soft-2);
background: var(--color-bg-elev);
border-radius: 6px;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
text-align: center;
padding: 24px;
min-height: 266px;
transition: border-color 0.15s, background 0.15s, color 0.15s;
cursor: pointer;
color: var(--color-ink-2);
}
.add-tile:hover {
border-color: var(--color-hub);
border-style: solid;
background: var(--color-bg-card);
color: var(--color-hub);
}
.add-tile .ico {
width: 48px;
height: 48px;
border-radius: 6px;
background: var(--color-hub-soft);
color: var(--color-hub);
display: flex;
align-items: center;
justify-content: center;
margin-bottom: 14px;
}
.add-tile:hover .ico {
background: var(--color-hub);
color: #fff;
}
.add-tile .lbl {
font-size: 14px;
font-weight: 600;
}
.add-tile .sub {
font-size: 11.5px;
color: var(--color-ink-3);
margin-top: 6px;
line-height: 1.5;
max-width: 200px;
}
}
/* ============================================================