@import url('https://fonts.bunny.net/css?family=newsreader:400,500,600,700|inter:400,500,600|space-grotesk:500,700|ibm-plex-mono:400,500'); :root { --serif: 'Newsreader', Georgia, serif; --sans: 'Inter', system-ui, -apple-system, sans-serif; --display: 'Space Grotesk', 'Inter', sans-serif; --mono: 'IBM Plex Mono', ui-monospace, monospace; --bg: hsl(35 14% 96%); --panel: #fffdf9; --panel-2: hsl(35 14% 93%); --line: hsl(35 14% 86%); --text: hsl(25 18% 12%); --muted: hsl(25 8% 42%); --accent: #b54a2c; --accent-soft: #d97a5a; --dark: #191919; --dark-text: #f0f0f0; --dark-muted: #a9a9a9; --ok: #5d7d4b; --amber: #b8902f; --radius: 11px; --pill: 22px; --shadow: 0 10px 34px -22px rgba(40,20,10,.5); } * { box-sizing: border-box; } html, body, #root { height: 100%; } body { margin: 0; font-family: var(--sans); font-size: 14.5px; color: var(--text); background: var(--bg); } button, input, select, textarea { font-family: inherit; font-size: inherit; color: var(--text); } .muted { color: var(--muted); } .center { display: grid; place-items: center; height: 100%; } /* ── Login ── */ .login { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); padding: 36px 32px; width: 320px; display: flex; flex-direction: column; gap: 12px; box-shadow: var(--shadow); } .login-brand { font-family: var(--display); font-weight: 700; letter-spacing: .14em; font-size: 20px; } .login-sub { font-family: var(--serif); font-style: italic; color: var(--muted); margin-bottom: 10px; } .err { color: var(--accent); margin: 4px 0 0; font-size: 13px; } /* ── Inputs / Buttons (Pill) ── */ input, select, textarea { background: var(--panel); border: 1px solid var(--line); border-radius: 9px; padding: 9px 11px; width: 100%; } /* Einheitliche, kompakte Höhe für einzeilige Felder (Dropdowns = Textfelder) */ .fields input, .fields select { height: 32px; padding: 0 10px; font-size: 14px; } .fields label.big input { height: 46px; padding: 0 13px; font-size: 21px; } .login input, .profile-card input, .userform input { height: 36px; } input:focus, select:focus, textarea:focus { outline: none; border-color: var(--accent-soft); box-shadow: 0 0 0 3px rgba(181,74,44,.12); } button { background: var(--panel); border: 1px solid var(--line); border-radius: var(--pill); padding: 8px 16px; cursor: pointer; font-weight: 500; transition: .12s; white-space: nowrap; } button:hover { border-color: var(--accent-soft); } button:disabled { opacity: .5; cursor: default; } button.primary { background: var(--accent); border-color: var(--accent); color: #fff; } button.primary:hover { background: #a23f23; } button.ghost { background: transparent; border-color: transparent; color: var(--dark-muted); } button.ghost:hover { color: #fff; border-color: var(--dark-muted); } /* ── Topbar (schwarz wie Site-Masthead) ── */ .app { display: flex; flex-direction: column; height: 100%; } .topbar { display: flex; align-items: center; gap: 12px; padding: 0 18px; height: 54px; background: var(--dark); color: var(--dark-text); flex: none; } .topbar .logo { font-family: var(--display); font-weight: 700; letter-spacing: .14em; } .topbar .logo-sub { font-family: var(--serif); font-style: italic; color: var(--dark-muted); font-size: 13px; } .topbar .spacer { flex: 1; } .topbar .who { color: var(--dark-muted); font-size: 13px; } .nav { display: flex; gap: 4px; margin-left: 16px; } .nav button { background: transparent; border: none; color: var(--dark-muted); padding: 6px 15px; border-radius: var(--pill); } .nav button:hover { color: #fff; } .nav button.active { background: rgba(255,255,255,.12); color: #fff; } .body { display: flex; flex: 1; min-height: 0; } /* ── Sidebar ── */ aside { width: 290px; flex: none; border-right: 1px solid var(--line); background: var(--panel-2); padding: 14px; overflow: auto; } .new { width: 100%; margin-bottom: 12px; background: var(--accent); border-color: var(--accent); color: #fff; font-weight: 600; } .new:hover { background: #a23f23; } .search { display: flex; align-items: center; gap: 7px; background: var(--panel); border: 1px solid var(--line); border-radius: var(--pill); padding: 0 13px; margin-bottom: 16px; } .search span { color: var(--muted); font-size: 17px; } .search input { border: none; background: transparent; padding: 9px 0; } .search input:focus { box-shadow: none; } .group { margin-bottom: 18px; } .group-title { display: flex; align-items: center; gap: 7px; font-family: var(--display); font-size: 11px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--muted); margin: 0 6px 8px; } .group-title span { background: var(--line); color: var(--muted); border-radius: 20px; padding: 1px 7px; font-size: 10px; letter-spacing: 0; } .list { list-style: none; margin: 0; padding: 0; } .list li { display: flex; align-items: center; gap: 10px; padding: 9px; border-radius: 10px; cursor: pointer; } .list li:hover { background: var(--panel); } .list li.active { background: var(--panel); box-shadow: inset 3px 0 0 var(--accent), var(--shadow); } .list .dot { width: 10px; height: 10px; border-radius: 50%; flex: none; border: 1px solid rgba(0,0,0,.12); } .list .t { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 1px; } .list .t-title { font-family: var(--serif); font-size: 15.5px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } .list .t-meta { font-size: 11px; color: var(--muted); } .draft-tag { font-size: 10px; color: var(--amber); border: 1px solid var(--amber); border-radius: 20px; padding: 1px 7px; flex: none; } main { flex: 1; min-width: 0; } .empty { display: grid; place-items: center; height: 100%; color: var(--muted); font-family: var(--serif); font-style: italic; padding: 24px; text-align: center; } .empty.small { font-size: 14px; } /* ── Editor ── */ .editor { display: flex; height: 100%; } .editor-main { flex: 1; min-width: 0; display: flex; flex-direction: column; } .editor-head { display: flex; align-items: center; gap: 9px; padding: 11px 22px; border-bottom: 1px solid var(--line); background: var(--panel); flex: none; } .editor-head .crumb { font-family: var(--mono); font-size: 12px; color: var(--muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } .editor-head .spacer { flex: 1; } .editor-head .toggle { background: transparent; border-color: transparent; color: var(--muted); } .editor-head .toggle:hover { color: var(--text); border-color: var(--line); } .status { font-size: 11px; border-radius: var(--pill); padding: 3px 11px; font-weight: 600; } .status.draft { color: var(--amber); background: rgba(184,144,47,.12); } .status.live { color: var(--ok); background: rgba(93,125,75,.14); } /* Metadaten kompakt oben, Schreibfeld groß darunter */ .fields { flex: 1; min-height: 0; padding: 16px 22px; overflow: auto; display: flex; flex-direction: column; gap: 10px; } .row { display: flex; gap: 12px; align-items: flex-end; } .meta { display: flex; flex-wrap: wrap; gap: 9px 12px; align-items: flex-end; } label { display: flex; flex-direction: column; gap: 3px; font-size: 11.5px; color: var(--muted); flex: 1; } .meta label { flex: 0 0 auto; } .meta label.sm { width: 160px; } .meta label.xs { width: 100px; } .meta label:not(.sm):not(.xs):not(.check) { flex: 1; min-width: 140px; } label.check { flex-direction: row; align-items: center; gap: 7px; white-space: nowrap; padding-bottom: 7px; } label.check input { width: auto; height: auto; } label.big input { font-family: var(--serif); font-weight: 600; } .colorpick { display: flex; align-items: center; gap: 8px; } .colorpick .swatch { width: 32px; height: 32px; border-radius: 7px; border: 1px solid rgba(0,0,0,.15); flex: none; } .colorpick select { flex: 1; } /* Cover-Upload */ .cover-row { display: flex; align-items: center; gap: 8px; } .cover-row input { flex: 1; } .cover-row button { height: 32px; flex: none; padding: 0 14px; } .cover-thumb { width: 32px; height: 32px; border-radius: 7px; border: 1px solid var(--line); background: center/cover no-repeat; flex: none; } /* Autor:innen-Verwaltung */ .userform { display: flex; gap: 8px; } .userform input { flex: 1; } .userlist { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 8px; } .userlist li { display: flex; align-items: center; gap: 10px; padding: 8px 12px; border: 1px solid var(--line); border-radius: 10px; } .userlist .t { flex: 1; display: flex; align-items: center; gap: 9px; font-family: var(--serif); } .userlist button { padding: 5px 12px; font-size: 13px; } .userlist .status { padding: 2px 9px; } /* WYSIWYG-Editor füllt den meisten Platz */ .rich { flex: 1; min-height: 460px; display: flex; flex-direction: column; } .rich-host { flex: 1; min-height: 0; } .rich .toastui-editor-defaultUI { height: 100%; border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow); font-family: var(--sans); } .toastui-editor-contents { font-family: var(--serif); font-size: 16px; } .toastui-editor-defaultUI-toolbar { background: var(--panel-2); } .toastui-editor-toolbar { border-top-left-radius: var(--radius); border-top-right-radius: var(--radius); } /* ── Ziehbarer Trenner + Vorschau ── */ .splitter { width: 7px; flex: none; cursor: col-resize; background: var(--line); } .splitter:hover { background: var(--accent-soft); } .preview { flex: none; background: #fff; } .preview iframe { width: 100%; height: 100%; border: 0; } /* ── Profil ── */ .profile { width: 100%; overflow: auto; display: flex; justify-content: center; padding: 44px 20px; } .profile-card { width: 100%; max-width: 560px; height: max-content; background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow); padding: 28px 30px; display: flex; flex-direction: column; gap: 16px; } .profile-card h2 { font-family: var(--serif); margin: 0 0 4px; font-weight: 600; } .avatar-row { display: flex; align-items: center; gap: 18px; } .avatar { width: 92px; height: 92px; border-radius: 50%; background: var(--panel-2) center/cover no-repeat; border: 1px solid var(--line); display: grid; place-items: center; font-size: 34px; flex: none; } .who-mail { font-size: 12px; margin: 9px 0 0; } .profile-card textarea { font-family: var(--serif); font-size: 15px; line-height: 1.6; resize: vertical; } .profile-card .actions { display: flex; } .profile-card.wide { max-width: 760px; } .role-select { width: auto; height: 32px; padding: 4px 10px; font-size: 13px; } /* ── Foren-Verwaltung ── */ .forumlist { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 8px; } .forumlist li { display: flex; align-items: center; gap: 10px; padding: 7px 12px; border: 1px solid var(--line); border-radius: 10px; } .forumlist li.is-library { background: var(--panel-2); } .forumlist .fsort { width: 2.2em; text-align: center; color: var(--muted); font-size: 12px; flex: none; } .forumlist .fname { flex: 1; height: 32px; } .forumlist .fcolor { width: 34px; height: 32px; padding: 2px; flex: none; } .forumlist .fslug { color: var(--muted); font-size: 12px; font-family: var(--mono, monospace); flex: none; } .forumlist button { padding: 5px 12px; font-size: 13px; } /* ── Moderation (zweispaltig) ── */ .moderation { width: 100%; overflow: auto; display: grid; grid-template-columns: 1fr 1fr; gap: 20px; padding: 30px 24px; align-content: start; } .mod-col h2 { font-family: var(--serif); font-weight: 600; margin: 0 0 12px; } .modlist { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; } .modlist li { padding: 10px 13px; border: 1px solid var(--line); border-radius: 11px; background: var(--panel); } .modlist li.gone { opacity: .5; } .mod-head { font-size: 13.5px; } .mod-head .status { margin-left: 6px; padding: 1px 8px; background: rgba(184,144,47,.14); color: var(--amber); } .mod-body { font-family: var(--serif); font-size: 14.5px; margin: 6px 0; color: var(--text); } .mod-actions { display: flex; align-items: center; gap: 12px; font-size: 13px; } .mod-actions a { color: var(--muted); } .mod-actions button { padding: 4px 11px; font-size: 12.5px; } /* ── Übersicht / Dashboard ── */ .overview { width: 100%; overflow: auto; padding: 30px 28px; } .overview h2 { font-family: var(--serif); font-weight: 600; margin: 0 0 18px; } .stat-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 12px; } .stat-card { display: flex; flex-direction: column; align-items: flex-start; gap: 2px; text-align: left; background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); padding: 16px 18px; box-shadow: var(--shadow); } .stat-card:not(:disabled):hover { border-color: var(--accent-soft); transform: translateY(-1px); } .stat-card:disabled { opacity: 1; cursor: default; } .stat-value { font-family: var(--display); font-weight: 700; font-size: 30px; line-height: 1; color: var(--accent); } .stat-label { font-family: var(--serif); font-size: 15px; margin-top: 6px; } .stat-hint { font-size: 11.5px; color: var(--muted); min-height: 1em; } .overview-actions { margin-top: 30px; } .overview-actions h3 { font-family: var(--display); font-size: 12px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--muted); margin: 0 0 10px; } .quick { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; } .quick-link { display: inline-flex; align-items: center; padding: 8px 16px; border: 1px solid var(--line); border-radius: var(--pill); text-decoration: none; color: var(--muted); } .quick-link:hover { border-color: var(--accent-soft); color: var(--text); } /* ── Nutzerliste (aufgewertet) ── */ .count-pill { font-family: var(--sans); font-size: 12px; font-weight: 500; color: var(--muted); background: var(--panel-2); border-radius: 20px; padding: 2px 9px; vertical-align: middle; margin-left: 6px; } .userfilter { margin: 4px 0 2px; height: 34px; } .userlist .uavatar { width: 30px; height: 30px; border-radius: 50%; display: grid; place-items: center; font-weight: 600; font-size: 13px; flex: none; } .userlist .ucol { flex-direction: column; align-items: flex-start; gap: 1px; min-width: 0; } .uemail { font-family: var(--serif); font-size: 14.5px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 100%; } .uemail .you { color: var(--accent); font-family: var(--sans); font-size: 12px; } .umeta { font-size: 11.5px; color: var(--muted); } .rolebadge { font-size: 11px; border-radius: var(--pill); padding: 3px 10px; font-weight: 600; flex: none; } .rolebadge.admin { color: var(--accent); background: rgba(181,74,44,.12); } .pwinline { display: flex; align-items: center; gap: 5px; flex: none; } .pwinline input { width: 150px; height: 30px; } .pwinline button { padding: 4px 10px; font-size: 12.5px; } /* ── Toast ── */ .toast { position: fixed; bottom: 20px; right: 20px; padding: 11px 18px; border-radius: 11px; color: #fff; cursor: pointer; box-shadow: 0 10px 30px -12px rgba(0,0,0,.4); font-size: 13.5px; max-width: 380px; z-index: 50; } .toast.ok { background: var(--ok); } .toast.err { background: var(--accent); }