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;
}

25
public/assets/css/app.css Normal file
View File

@@ -0,0 +1,25 @@
/* Auth-Guard: bis zum erfolgreichen auth.me nichts anzeigen */
html.auth-pending header,
html.auth-pending main {
display: none !important;
}
:root { color-scheme: light; }
.btn{
display:inline-flex;align-items:center;gap:.5rem;
padding:.35rem .7rem;border-radius:.7rem;border:1px solid #e5e7eb;
background:#fff;font-size:.9rem;cursor:pointer;
}
.btn:hover{background:#f8fafc}
.btn-danger{border-color:#fecaca;color:#b91c1c}
.btn-danger:hover{background:#fef2f2}
.chip{display:inline-flex;align-items:center;gap:.35rem;padding:.15rem .5rem;border-radius:999px;background:#f1f5f9;color:#334155;font-size:.75rem;border:1px solid #e5e7eb}
.chip .dot{width:.5rem;height:.5rem;border-radius:999px;background:#64748b}
dialog::backdrop{background:rgba(15,23,42,.3)}
#toast-root{z-index:2147483647}
.truncate{max-width:22rem;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.hidden{display:none}

View File

@@ -0,0 +1,48 @@
/* assets/css/toast.css */
/* Works whether the root is in <body> or inside a <dialog open> (top layer) */
.toast-root, #toast-root {
position: fixed; /* relative to viewport even inside dialog's top layer */
inset: 0;
pointer-events: none;
z-index: 2147483647;
font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
}
.toast {
pointer-events: auto;
position: fixed;
right: 16px;
top: 16px;
min-width: 240px;
max-width: 420px;
border-radius: 12px;
padding: 12px 14px;
box-shadow: 0 10px 30px rgba(2, 6, 23, .25), 0 2px 8px rgba(2,6,23,.12);
color: #0f172a;
background: #ffffff;
border: 1px solid rgba(148,163,184,.35);
display: flex;
align-items: flex-start;
gap: 10px;
animation: toast-slide-in .18s ease-out;
}
.toast + .toast { margin-top: 12px; }
.toast .icon { font-size: 18px; line-height: 1; margin-top: 2px; }
.toast .content { flex: 1; font-size: 14px; line-height: 1.35; }
.toast .close { appearance: none; border: 0; background: transparent; font-size: 16px; color: #475569; cursor: pointer; padding: 2px 4px; }
/* success (green) by default */
.toast.success { border-color: #86efac; background: #ecfdf5; color: #065f46; }
.toast.success .icon { color: #10b981; }
/* error (red) */
.toast.error { border-color: #fecaca; background: #fff1f2; color: #7f1d1d; }
.toast.error .icon { color: #ef4444; }
@keyframes toast-slide-in {
from { transform: translateY(-6px); opacity: 0; }
to { transform: translateY(0); opacity: 1; }
}