This commit is contained in:
2025-12-04 22:33:05 +01:00
parent 316175e158
commit 9dee06cdd6
145 changed files with 16865 additions and 88 deletions

167
public/assets/css/admin.css Normal file
View File

@@ -0,0 +1,167 @@
/* ============================================================
Admin Theme (SCOPED)
- wirkt NUR unter <body class="page-admin"> bzw. .page-login
- keine globalen Resets (html/body/a/…)
- GrapesJS (gjs-…) wird nicht angetastet
============================================================ */
/* ---- Farb- & UI-Variablen ---- */
body.page-admin,
body.page-login {
--bg: #f7f7fb;
--panel: #ffffff;
--text: #222222;
--muted: #666666;
--border: #e7e7ee;
--accent: #5b7cff;
--accent-600:#3f5ff7;
--danger: #e74c3c;
--ok: #2ecc71;
background: var(--bg);
color: var(--text);
font: 14px/1.45 system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
}
/* ---- Links / Text ---- */
.page-admin a,
.page-login a {
color: inherit;
text-decoration: none;
}
.page-admin .muted,
.page-login .muted { color: var(--muted); }
/* ---- Container ---- */
.page-admin .container { max-width: 1200px; margin: 20px auto; padding: 0 16px; }
/* ============================================================
ADMIN (Dashboard, Listen, Editor-Rahmen)
============================================================ */
/* ---- Topbar ---- */
.page-admin .topbar {
display: flex; align-items: center; justify-content: space-between;
gap: 10px; padding: 10px 16px; background: rgba(255,255,255,.9);
backdrop-filter: saturate(140%) blur(6px);
border-bottom: 1px solid var(--border);
position: sticky; top: 0; z-index: 50;
}
.page-admin .brand { font-size: 16px; margin: 0; font-weight: 600; }
.page-admin .topbar .right { display: flex; gap: 8px; align-items: center; }
/* ---- Buttons (leicht, neutral) ---- */
.page-admin .btn {
display:inline-flex; align-items:center; gap:.5rem;
padding:.38rem .75rem; border-radius:.7rem;
border:1px solid var(--border); background:#fff;
font-size:.9rem; cursor:pointer; transition:.15s background-color, .15s border-color, .15s box-shadow;
}
.page-admin .btn:hover { background:#f8fafc; }
.page-admin .btn-primary { border-color: var(--accent); background: var(--accent); color:#fff; }
.page-admin .btn-primary:hover { background: var(--accent-600); border-color: var(--accent-600); }
.page-admin .btn-danger { border-color:#fecaca; color:#b91c1c; }
.page-admin .btn-danger:hover { background:#fef2f2; }
/* ---- Chips ---- */
.page-admin .chip {
display:inline-flex; align-items:center; gap:.35rem;
padding:.15rem .55rem; border-radius:999px;
background:#f1f5f9; color:#334155; font-size:.75rem; border:1px solid var(--border);
}
.page-admin .chip .dot { width:.5rem; height:.5rem; border-radius:999px; background:#64748b; }
/* ---- Cards & Rows ---- */
.page-admin .card {
background: var(--panel); border:1px solid var(--border);
border-radius: 12px; padding: 16px; margin-bottom: 16px;
}
.page-admin .row {
display:flex; gap:12px; align-items:center; justify-content:space-between; flex-wrap:wrap;
}
.page-admin .row .left,
.page-admin .row .right { display:flex; gap:10px; align-items:center; }
/* ---- Tabs (Header-Tabs) ---- */
.page-admin .tab {
padding:8px 12px; border:1px solid var(--border);
border-radius:999px; background:#fff; cursor:pointer; font-size:.9rem;
}
.page-admin .tab.active { background:var(--accent); border-color:var(--accent); color:#fff; }
/* ---- Tabellen/Listen ---- */
.page-admin .list {
width:100%; border-collapse: separate; border-spacing: 0; background: #fff;
border:1px solid var(--border); border-radius: 12px; overflow: hidden;
}
.page-admin .list thead th {
text-align:left; padding:10px 12px; background:#fafafe; color:#374151; font-weight:600; font-size:.92rem;
border-bottom:1px solid var(--border);
}
.page-admin .list tbody td {
padding:10px 12px; border-bottom:1px solid var(--border); vertical-align: top; font-size:.92rem;
}
.page-admin .list tbody tr:hover td { background:#fafafa; }
.page-admin .empty {
text-align:center; padding:28px; color:var(--muted); font-size:.95rem; background:#fff; border:1px dashed var(--border); border-radius:12px;
}
/* ---- Formulare ---- */
.page-admin input[type="text"],
.page-admin input[type="email"],
.page-admin input[type="number"],
.page-admin input[type="search"],
.page-admin textarea,
.page-admin select {
width:100%; border:1px solid var(--border); border-radius:10px; padding:10px 12px; margin:8px 0; background:#fff;
font: inherit; color: inherit;
}
.page-admin textarea { min-height: 110px; resize: vertical; }
.page-admin label { display:block; margin:12px 0 6px; color:#334155; font-size:.92rem; }
/* ---- Dialoge / Backdrop ---- */
.page-admin dialog::backdrop { background: rgba(15,23,42,.35); }
.page-admin .dialog-head {
display:flex; align-items:center; gap:10px; justify-content:space-between;
padding:10px 14px; background:var(--panel); border-bottom:1px solid var(--border);
}
/* ---- Preview Dialog ---- */
.page-admin .previewDialog { width:min(900px,95vw); border:none; border-radius:12px; padding:0; overflow:hidden; }
.page-admin .previewHead { display:flex; justify-content:space-between; align-items:center; gap:10px; padding:10px 14px; background:var(--panel); border-bottom:1px solid var(--border); }
.page-admin .previewBody { height:min(70vh,700px); }
.page-admin .previewBody iframe { width:100%; height:100%; border:0; background:#fafafa; }
/* ---- Utility ---- */
.page-admin .truncate { max-width:22rem; overflow:hidden; white-space:nowrap; text-overflow:ellipsis; }
.page-admin .hidden { display:none !important; }
.page-admin .muted-12 { font-size:12px; color:var(--muted); }
/* ============================================================
LOGIN (Karte in der Mitte)
============================================================ */
.page-login .loginWrap { display:grid; place-items:center; min-height: 55vh; }
.page-login .loginCard {
width:min(420px,95vw); background: var(--panel); border:1px solid var(--border);
border-radius:16px; box-shadow:0 10px 30px rgba(2,6,23,.06); padding:28px;
}
.page-login h1 { margin:0 0 8px; font-size:20px; }
.page-login p { margin:0 0 18px; color:#475569; }
.page-login label { display:block; margin:12px 0 6px; color:#334155; }
.page-login input[type="email"],
.page-login input[type="text"],
.page-login input[type="password"] {
width:100%; padding:12px; border:1px solid #cbd5e1; border-radius:10px; font-size:15px; background:#fff;
}
.page-login .btn-login {
width:100%; margin-top:16px; padding:12px; border:0; border-radius:12px;
background:#111827; color:#fff; font-weight:600; cursor:pointer;
}
.page-login .mini { margin-top:10px; text-align:center; }
.page-login .hint { font-size:12px; color:var(--muted); }
/* ABSOLUTER UI-FIX: Versteckt die hartnäckige Bibliothek-Kategorie */
.gjs-block-category[data-id="Bibliothek"] {
display: none !important;
}