174 lines
7.1 KiB
CSS
174 lines
7.1 KiB
CSS
/* ============================================================
|
|
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;
|
|
}
|
|
|
|
.craft-editor-shell{display:flex;flex-direction:column;height:100%;}
|
|
.craft-editor-toolbar{display:flex;gap:.5rem;padding:.5rem;border-bottom:1px solid #e2e8f0;background:#f8fafc;}
|
|
.craft-editor-canvas{flex:1;min-height:300px;overflow:auto;padding:12px;border:1px solid #e2e8f0;border-radius:8px;background:#fff;}
|
|
.craft-container{min-height:40px;}
|
|
.craft-text:focus{outline:2px solid #38bdf8;outline-offset:2px;}
|