/* ── CMS-Layout ─────────────────────────────────────── */

html, body {
	height: 100%;
	overflow: hidden;
}

.cms-wrap {
	display: grid;
	grid-template-rows: 42px 1fr;
	grid-template-columns: 260px 1fr 14px;
	height: 100vh;
}

/* ── Topbar ─────────────────────────────────────────── */

.cms-topbar {
	grid-column: 1 / -1;
	display: flex;
	align-items: center;
	background-color: rgb(235, 235, 235);
	border-bottom: 1px solid rgb(195, 195, 195);
	padding: 0 10px;
	gap: 6px;
}

.cms-topbar .btn {
	padding: 4px 10px;
	background-color: rgb(215, 215, 215);
	border: 1px solid rgb(175, 175, 175);
	color: rgb(55, 55, 55);
	cursor: pointer;
	font-size: 12px;
	text-decoration: none;
	white-space: nowrap;
}

.cms-topbar .btn:hover {
	background-color: rgb(195, 195, 195);
}

.cms-topbar .btn-tab {
	padding: 4px 12px;
	background-color: rgb(205, 205, 205);
	border: 1px solid rgb(175, 175, 175);
	color: rgb(75, 75, 75);
	cursor: pointer;
	font-size: 12px;
}

.cms-topbar .btn-tab.aktiv {
	background-color: rgb(95, 145, 225);
	color: rgb(0, 0, 0);
	border-color: rgb(55, 105, 195);
}

.cms-topbar .spacer {
	flex: 1;
}

.cms-topbar .logo {
	height: 28px;
	width: auto;
	display: block;
	flex-shrink: 0;
}

.cms-topbar .abmelden {
	font-size: 12px;
	color: rgb(95, 95, 95);
	text-decoration: none;
	padding: 4px 8px;
}

.cms-topbar .abmelden:hover {
	color: rgb(35, 35, 35);
}

/* ── Seitenbaum (links) ─────────────────────────────── */

.cms-baum {
	background-color: rgb(230, 230, 230);
	border-right: 1px solid rgb(200, 200, 200);
	overflow-y: auto;
	padding: 8px 0;
}

.baum-neuepage {
	display: block;
	margin: 0 8px 10px 8px;
	padding: 5px 10px;
	background-color: rgb(155, 215, 175);
	color: rgb(15, 55, 15);
	font-size: 12px;
	text-decoration: none;
	border: 1px solid rgb(125, 195, 145);
}

.baum-neuepage:hover {
	background-color: rgb(135, 205, 155);
}

.baum-label {
	font-size: 11px;
	color: rgb(135, 135, 135);
	padding: 4px 10px 2px 10px;
	text-transform: uppercase;
	letter-spacing: 1px;
}

/* ── Baum-Knoten ────────────────────────────────────── */

.baum-knoten {
	list-style: none;
	margin: 0;
	padding: 0;
}

.baum-wurzel > li { margin: 0; }

/* ── Toggle +/- ─────────────────────────────────────── */

.baum-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 14px;
	height: 14px;
	flex-shrink: 0;
	font-size: 14px;
	line-height: 1;
	color: rgb(135, 135, 135);
	cursor: pointer;
	margin-right: 4px;
	user-select: none;
}

.baum-toggle:hover { color: rgb(55, 55, 55); }
.baum-toggle-leer  { cursor: default; }

/* ── Sprach-Dots ────────────────────────────────────── */

.sprach-dots {
	display: inline-flex;
	gap: 2px;
	margin-right: 3px;
	flex-shrink: 0;
}

.sprach-dot {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 18px;
	height: 14px;
	padding: 0 3px;
	font-size: 9px;
	font-weight: bold;
	border-radius: 1px;
	cursor: pointer;
	letter-spacing: 0.3px;
	user-select: none;
}

.sprach-dot:hover { outline: 1px solid rgb(35, 35, 35); }

.dot-online   { background-color: rgb(95, 205, 110);  color: rgb(0, 35, 0); }
.dot-modified { background-color: rgb(55, 115, 215); color: rgb(0, 25, 55); }
.dot-offline  { background-color: rgb(205, 75, 75);  color: rgb(45, 0, 0); }
.dot-root     { background-color: rgb(225, 225, 225);   color: transparent; min-width: 18px; }

/* ── Baum-Item ──────────────────────────────────────── */

.baum-item {
	display: flex;
	align-items: center;
	padding: 2px 6px 2px 4px;
	white-space: nowrap;
	overflow: hidden;
}

.baum-item:hover { background-color: rgb(215, 215, 215); }
.baum-item.aktiv { background-color: rgb(135, 165, 225); }

.seiten-name {
	font-size: 12px;
	color: rgb(55, 55, 55);
	overflow: hidden;
	text-overflow: ellipsis;
	cursor: pointer;
}

.seiten-name:hover {
	color: rgb(0, 80, 155);
	text-decoration: underline;
}

.art-root  .seiten-name { color: rgb(0, 80, 155); font-weight: bold; }
.art-gruppe .seiten-name { color: rgb(85, 85, 85); font-style: italic; }

/* ── Verbindungslinien ──────────────────────────────── */

.baum-kinder {
	list-style: none;
	margin: 0;
	padding-left: 20px;
	position: relative;
}

.baum-kinder::before {
	content: '';
	position: absolute;
	left: 10px;
	top: 0;
	bottom: 10px;
	border-left: 1px dotted rgb(180, 180, 180);
}

.baum-kinder > li {
	position: relative;
}

.baum-kinder > li::before {
	content: '';
	position: absolute;
	left: -10px;
	top: 11px;
	width: 10px;
	border-top: 1px dotted rgb(180, 180, 180);
}

/* ── Content-Bereich ────────────────────────────────── */

.cms-content {
	background-color: rgb(220, 220, 220);
	overflow-y: auto;
	padding: 20px 24px;
}

.cms-content h2 {
	font-size: 22px;
	color: rgb(0, 80, 155);
	font-weight: normal;
	margin-bottom: 16px;
}

.cms-content .page-einstellungen {
	font-size: 11px;
	color: rgb(155, 155, 155);
	margin-bottom: 20px;
	border-bottom: 1px solid rgb(200, 200, 200);
	padding-bottom: 10px;
}

/* ── Vorschau-Layout-Wrapper ────────────────────────── */

.vorschau-layout-wrap {
	position: relative;
	overflow: visible;
	/* transform schafft neuen Stacking Context:
	   position:fixed Kindelemente bleiben innerhalb dieses Containers */
	transform: translateZ(0);
}

/* ── Vorschau-Overlay ───────────────────────────────── */

.vorschau-overlay {
	position: relative;
	cursor: pointer;
	border: 2px solid rgb(255, 210, 45);
	background-color: rgba(255, 210, 0, 0.07);
}

.vorschau-overlay:hover {
	background-color: rgba(255, 210, 0, 0.25);
}

.vorschau-overlay-label {
	position: absolute;
	top: 6px;
	right: 8px;
	background-color: rgb(255, 210, 45);
	color: rgb(255, 245, 215);
	width: 24px;
	height: 24px;
	line-height: 24px;
	text-align: center;
	border-radius: 3px;
	font-size: 14px;
	pointer-events: none;
	z-index: 10;
}

/* ── Vorschau Online-Leiste ─────────────────────────── */

.vorschau-online-bar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 8px 14px;
	background-color: rgb(213, 213, 225);
	border-bottom: 1px solid rgb(185, 185, 200);
}

.vorschau-online-info {
	font-size: 13px;
	color: rgb(55, 55, 65);
}

.vorschau-online-info .badge {
	margin-left: 8px;
}

.vorschau-version-info {
	color: rgb(125, 125, 145);
	font-size: 11px;
	margin-left: 8px;
}

.btn-online-stellen {
	background-color: rgb(125, 215, 155);
	color: rgb(0, 0, 0);
	border: none;
	padding: 6px 16px;
	border-radius: 3px;
	font-size: 12px;
	font-weight: bold;
	cursor: pointer;
}

.btn-online-stellen:hover {
	background-color: rgb(100, 205, 135);
}

/* ── Meta-Vorschau ─────────────────────────────────── */

.meta-vorschau-wrap {
	padding: 15px 20px;
}

.meta-vorschau-block {
	margin-bottom: 18px;
}

.meta-vorschau-label {
	font-size: 13px;
	font-weight: bold;
	color: rgb(75, 80, 95);
	margin: 0 0 6px 0;
	border-bottom: 1px solid rgb(190, 190, 205);
	padding-bottom: 4px;
}

.meta-vorschau-wert {
	color: rgb(25, 25, 35);
	font-size: 14px;
	margin: 0;
}

.meta-vorschau-tabelle {
	width: 100%;
	border-collapse: collapse;
	font-size: 12px;
}

.meta-vorschau-tabelle th {
	text-align: left;
	color: rgb(95, 95, 115);
	padding: 5px 8px;
	border-bottom: 1px solid rgb(180, 180, 195);
	font-weight: normal;
}

.meta-vorschau-tabelle td {
	padding: 5px 8px;
	border-bottom: 1px solid rgb(200, 200, 215);
	color: rgb(40, 40, 55);
	word-break: break-word;
}

.meta-vorschau-tabelle td:first-child {
	white-space: nowrap;
}

.meta-vorschau-tabelle tr:hover td {
	background-color: rgb(205, 205, 220);
}

.meta-vorschau-code {
	background-color: rgb(220, 220, 230);
	border: 1px solid rgb(190, 190, 205);
	border-radius: 4px;
	padding: 10px 12px;
	font-size: 11px;
	color: rgb(55, 65, 85);
	overflow-x: auto;
	white-space: pre-wrap;
	word-break: break-word;
	line-height: 1.5;
}

/* ── Multipage-Vorschau ────────────────────────────── */

.mp-vorschau-wrap {
	position: relative;
}

.mp-sektion-overlay {
	margin: 4px 0;
	min-height: 40px;
}

/* ── Meta-Vererbung ────────────────────────────────── */

.meta-vererbung-bar {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 10px 0;
	margin-bottom: 14px;
	border-bottom: 1px solid rgb(190, 190, 205);
}

.meta-vererbung-toggle {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 13px;
	color: rgb(40, 40, 55);
	cursor: pointer;
	font-weight: bold;
}

.meta-vererbung-toggle input[type="checkbox"] {
	width: 16px;
	height: 16px;
	cursor: pointer;
}

.meta-vererbung-hinweis {
	font-size: 11px;
	color: rgb(95, 115, 145);
}

.meta-vererbt {
	background-color: rgb(213, 218, 230);
	border: 1px solid rgb(180, 190, 210);
	border-radius: 4px;
	padding: 10px 12px;
}

.meta-vererbt .meta-vorschau-tabelle td {
	color: rgb(75, 85, 105);
}

.meta-durchgestrichen td {
	color: rgb(135, 140, 155);
}

.meta-durchgestrichen td:nth-child(2) {
	text-decoration: line-through;
}

.meta-ueberschrieben {
	font-size: 10px;
	color: rgb(195, 165, 55);
	white-space: nowrap;
	text-decoration: none;
	display: inline-block;
}

/* ── Drag & Drop ────────────────────────────────────── */

.baum-item[draggable="true"] { cursor: grab; }
.baum-item[draggable="true"]:active { cursor: grabbing; }

.baum-item.dd-dragging {
	opacity: 0.35;
}

.baum-item.dd-vor {
	border-top: 2px solid rgb(0, 70, 155);
}

.baum-item.dd-nach {
	border-bottom: 2px solid rgb(0, 70, 155);
}

.baum-item.dd-in {
	background-color: rgb(140, 170, 230);
	outline: 1px solid rgb(55, 105, 195);
}

/* ── Auswahl-Panel (rechts, ausklappbar) ────────────── */

.cms-auswahl {
	background-color: rgb(210, 210, 225);
	border-left: 1px solid rgb(165, 165, 195);
	display: flex;
	align-items: stretch;
	position: relative;
}

.auswahl-toggle {
	width: 14px;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	color: rgb(105, 105, 145);
	font-size: 9px;
	user-select: none;
	flex-shrink: 0;
}

.auswahl-toggle:hover {
	background-color: rgb(190, 190, 210);
	color: rgb(35, 35, 75);
}

.auswahl-panel {
	position: fixed;
	right: 14px;
	top: 42px;
	bottom: 0;
	width: 0;
	overflow: hidden;
	background-color: rgb(223, 223, 233);
	border-left: 1px solid rgb(175, 175, 200);
	transition: width 0.25s ease;
	display: flex;
	flex-direction: column;
	z-index: 50;
}

.auswahl-panel.offen {
	width: 280px;
}

.auswahl-menu {
	display: flex;
	flex-wrap: wrap;
	gap: 4px;
	padding: 8px;
	border-bottom: 1px solid rgb(183, 183, 205);
	background-color: rgb(217, 217, 230);
	flex-shrink: 0;
	min-width: 280px;
}

.auswahl-menu-btn {
	padding: 3px 8px;
	background-color: rgb(195, 195, 217);
	color: rgb(55, 55, 105);
	border: 1px solid rgb(160, 160, 195);
	cursor: pointer;
	font-size: 10px;
	white-space: nowrap;
}

.auswahl-menu-btn:hover {
	background-color: rgb(175, 175, 203);
	color: rgb(15, 15, 55);
}

.auswahl-menu-btn.aktiv {
	background-color: rgb(120, 155, 225);
	color: rgb(0, 30, 75);
	border-color: rgb(60, 105, 200);
}

.auswahl-inhalt {
	flex: 1;
	overflow-y: auto;
	padding: 8px;
	min-width: 280px;
}

/* ── Auswahl: Bilder ─────────────────────────────────── */

.ausw-pfad-nav {
	font-size: 10px;
	color: rgb(135, 135, 165);
	margin-bottom: 6px;
	display: flex;
	flex-wrap: wrap;
	gap: 3px;
	align-items: center;
	line-height: 1.4;
}

.ausw-pfad-nav span {
	cursor: pointer;
	color: rgb(60, 95, 155);
}

.ausw-pfad-nav span:hover { text-decoration: underline; }

.ausw-bilder-verz {
	display: flex;
	flex-wrap: wrap;
	gap: 4px;
	margin-bottom: 8px;
}

.ausw-verz-btn {
	padding: 2px 7px;
	background-color: rgb(203, 203, 223);
	color: rgb(65, 95, 145);
	border: 1px solid rgb(170, 170, 200);
	cursor: pointer;
	font-size: 10px;
}

.ausw-verz-btn:hover { background-color: rgb(189, 189, 213); }

.ausw-bild-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 5px;
}

.ausw-bild-item {
	cursor: grab;
	border: 1px solid rgb(183, 183, 205);
	background-color: rgb(217, 217, 229);
	text-align: center;
	padding: 4px;
}

.ausw-bild-item:hover {
	border-color: rgb(60, 95, 175);
	background-color: rgb(203, 203, 223);
}

.ausw-bild-item:active { cursor: grabbing; }

.ausw-bild-item img {
	max-width: 100%;
	height: 58px;
	object-fit: cover;
	display: block;
	pointer-events: none;
}

.ausw-bild-item span {
	display: block;
	font-size: 9px;
	color: rgb(140, 140, 165);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	margin-top: 2px;
}

/* ── Auswahl-Dropzone ────────────────────────────────── */

.ausw-dropzone {
	border: 2px dashed rgb(175, 180, 195);
	border-radius: 4px;
	padding: 10px;
	margin: 6px 0;
	text-align: center;
	transition: border-color 0.2s, background-color 0.2s;
}

.ausw-dropzone.dragover {
	border-color: rgb(35, 95, 175);
	background-color: rgb(200, 210, 230);
}

.ausw-dropzone-text {
	font-size: 11px;
	color: rgb(120, 125, 145);
}

.ausw-dropzone-link {
	color: rgb(25, 85, 155);
	cursor: pointer;
	text-decoration: underline;
}

.ausw-dropzone-link:hover {
	color: rgb(15, 65, 125);
}

.ausw-dropzone-status {
	font-size: 10px;
	margin-top: 4px;
	min-height: 14px;
}

.ausw-upload-hinweis {
	font-size: 10px;
	color: rgb(145, 145, 165);
	margin: 6px 0;
	font-style: italic;
}

/* ── Bildeigenschaften ──────────────────────────────── */

.bild-eigen-wrap {
	padding: 15px 20px;
	display: flex;
	gap: 24px;
	flex-wrap: wrap;
}

.bild-eigen-block {
	flex: 1;
	min-width: 250px;
}

.bild-eigen-block h3 {
	font-size: 13px;
	color: rgb(75, 80, 95);
	margin: 0 0 8px 0;
	border-bottom: 1px solid rgb(190, 190, 205);
	padding-bottom: 4px;
}

.bild-eigen-vorschau {
	background-color: rgb(225, 225, 235);
	border: 1px solid rgb(190, 190, 205);
	border-radius: 4px;
	padding: 8px;
	text-align: center;
	margin-bottom: 6px;
}

.bild-eigen-vorschau img {
	max-width: 100%;
	height: auto;
}

.bild-eigen-meta {
	font-size: 11px;
	color: rgb(100, 100, 125);
	margin-bottom: 10px;
}

.bild-eigen-upload {
	margin-top: 8px;
}

.bild-eigen-upload .bilder-file-input {
	font-size: 11px;
	margin-bottom: 4px;
	display: block;
}

.bild-eigen-cb {
	display: flex;
	align-items: center;
	gap: 5px;
	font-size: 11px;
	color: rgb(55, 55, 75);
	margin: 6px 0;
	cursor: pointer;
}

.bild-eigen-cb input[type="checkbox"] {
	width: 14px;
	height: 14px;
}

.bild-eigen-verwendung {
	width: 100%;
	margin-top: 16px;
	padding-top: 12px;
	border-top: 1px solid rgb(190, 190, 205);
}

.bild-eigen-verwendung h3 {
	font-size: 13px;
	color: rgb(75, 80, 95);
	margin: 0 0 6px 0;
}

.bild-verwendung-liste {
	list-style: disc;
	padding: 0 0 0 18px;
	margin: 0;
}

.bild-verwendung-liste li {
	padding: 3px 0;
	font-size: 12px;
}

.bild-verwendung-liste a {
	color: rgb(25, 85, 155);
	text-decoration: none;
}

.bild-verwendung-liste a:hover {
	text-decoration: underline;
}

.bild-verwendung-leer {
	font-size: 11px;
	color: rgb(135, 135, 155);
	margin: 0;
}

.bild-eigen-loeschen {
	width: 100%;
	margin-top: 16px;
	padding-top: 12px;
	border-top: 1px solid rgb(190, 190, 205);
}

.btn-loeschen {
	background-color: rgb(215, 135, 135);
	color: rgb(75, 0, 0);
	border-color: rgb(205, 105, 105);
}

.btn-loeschen:hover {
	background-color: rgb(205, 105, 105);
}

/* ── Auswahl: Downloads ─────────────────────────────── */

.ausw-dl-liste {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.ausw-dl-item {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 5px 6px;
	cursor: grab;
	border-radius: 3px;
}

.ausw-dl-item:hover {
	background-color: rgb(209, 209, 227);
}

.ausw-dl-item:active { cursor: grabbing; }

.ausw-dl-icon {
	width: 28px;
	height: 28px;
	flex-shrink: 0;
	pointer-events: none;
}

.ausw-dl-info {
	overflow: hidden;
	pointer-events: none;
}

.ausw-dl-name {
	display: block;
	font-size: 11px;
	color: rgb(40, 40, 55);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.ausw-dl-meta {
	display: block;
	font-size: 9px;
	color: rgb(140, 140, 165);
}

.ausw-bild-badge {
	display: inline-block;
	background-color: rgb(115, 165, 215);
	color: rgb(0, 30, 75);
	font-size: 8px;
	padding: 1px 4px;
	border-radius: 2px;
	margin-top: 2px;
}

/* ── Auswahl: Links ──────────────────────────────────── */

.ausw-link-item {
	display: flex;
	align-items: baseline;
	gap: 4px;
	padding: 4px 6px;
	cursor: grab;
	border-bottom: 1px solid rgb(199, 199, 217);
}

.ausw-link-item:hover { background-color: rgb(209, 209, 227); }
.ausw-link-item:active { cursor: grabbing; }

.ausw-link-pfad {
	font-size: 9px;
	color: rgb(150, 150, 180);
	flex-shrink: 0;
}

.ausw-link-titel {
	font-size: 11px;
	color: rgb(40, 60, 100);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.ausw-link-item.ebene-1 { padding-left: 14px; }
.ausw-link-item.ebene-2 { padding-left: 24px; }
.ausw-link-item.ebene-3 { padding-left: 34px; }

.ausw-link-domain {
	padding: 6px 6px 4px;
	margin-top: 6px;
	border-bottom: 1px solid rgb(190, 190, 205);
	font-size: 11px;
	color: rgb(55, 55, 75);
}

/* ── Multipage ───────────────────────────────────────── */

.badge-mp {
	background-color: rgb(135, 115, 195);
	color: rgb(20, 0, 55);
	border-color: rgb(105, 75, 175);
}

.mp-liste {
	display: flex;
	flex-direction: column;
	gap: 4px;
	padding: 12px 16px;
}

.mp-sektion {
	display: flex;
	align-items: center;
	gap: 8px;
	background-color: rgb(203, 203, 217);
	border: 1px solid rgb(175, 175, 195);
	border-radius: 4px;
	padding: 6px 10px;
}

.mp-nr {
	width: 22px;
	text-align: center;
	font-size: 11px;
	color: rgb(115, 115, 135);
	flex-shrink: 0;
}

.mp-name {
	flex: 1;
}

.mp-name-input {
	width: 100%;
	background-color: rgb(213, 213, 225);
	border: 1px solid rgb(175, 175, 195);
	border-radius: 3px;
	color: rgb(35, 35, 35);
	padding: 3px 6px;
	font-size: 12px;
}

.mp-name-input:focus {
	border-color: rgb(55, 95, 175);
	outline: none;
}

.mp-layout-badge {
	font-size: 10px;
	color: rgb(95, 95, 115);
	background-color: rgb(213, 213, 225);
	border: 1px solid rgb(180, 180, 200);
	border-radius: 3px;
	padding: 2px 6px;
	white-space: nowrap;
	flex-shrink: 0;
}

.mp-status {
	flex-shrink: 0;
}

.mp-aktionen {
	display: flex;
	gap: 4px;
	flex-shrink: 0;
}

.mp-btn {
	padding: 3px 7px;
	background-color: rgb(190, 190, 205);
	border: 1px solid rgb(160, 160, 180);
	border-radius: 3px;
	color: rgb(40, 40, 55);
	font-size: 11px;
	cursor: pointer;
	white-space: nowrap;
}

.mp-btn:hover {
	background-color: rgb(170, 170, 190);
}

.mp-btn-leer {
	display: inline-block;
	width: 28px;
}

.mp-btn-edit {
	background-color: rgb(125, 165, 225);
	border-color: rgb(75, 125, 205);
}

.mp-btn-edit:hover {
	background-color: rgb(95, 145, 215);
}

.mp-btn-del {
	background-color: rgb(225, 165, 165);
	border-color: rgb(205, 125, 125);
	color: rgb(95, 0, 0);
}

.mp-btn-del:hover {
	background-color: rgb(215, 135, 135);
}

.mp-btn-zurueck {
	padding: 4px 10px;
	background-color: rgb(195, 195, 210);
	border: 1px solid rgb(160, 160, 180);
	border-radius: 3px;
	color: rgb(55, 55, 75);
	font-size: 12px;
	cursor: pointer;
	margin-right: 6px;
}

.mp-btn-zurueck:hover {
	background-color: rgb(175, 175, 195);
}

.mp-neu {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 12px 16px;
	border-top: 1px solid rgb(185, 185, 200);
	margin-top: 4px;
}

.eins-zeile-sektionen .eins-wert {
	display: flex;
	flex-direction: column;
	gap: 0;
	padding: 0;
}

.eins-zeile-sektionen .mp-sektion {
	background-color: rgb(211, 211, 223);
}

/* ── Seitentyp-Icons im Baum ─────────────────────────── */

.pf-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 14px;
	height: 14px;
	font-size: 8px;
	border-radius: 2px;
	flex-shrink: 0;
	margin-right: 4px;
	user-select: none;
}

.pf-icon-1 {
	background-color: rgb(180, 220, 190);
	color: rgb(35, 115, 35);
}

.pf-icon-2 {
	background-color: rgb(155, 182, 227);
	color: rgb(0, 45, 115);
}

.pf-icon-3 {
	background-color: rgb(160, 140, 210);
	color: rgb(30, 0, 90);
}

/* ── Einstellungen-Baum ─────────────────────────────── */

.settings-baum {
	padding: 8px 0;
}

.settings-baum-label {
	font-size: 10px;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: rgb(135, 135, 145);
	padding: 6px 12px 4px;
}

/* Wurzel-Liste (kein Einzug, keine Linien) */
.settings-wurzel {
	list-style: none;
	margin: 0;
	padding: 0;
}

/* Gruppe-Header (Sprachen / Layout) — wirkt wie ein Elternknoten */
.settings-gruppe-header {
	display: flex;
	align-items: center;
	gap: 4px;
	padding: 3px 6px 3px 4px;
	cursor: pointer;
	font-size: 12px;
	font-weight: bold;
	color: rgb(45, 45, 55);
	user-select: none;
	white-space: nowrap;
	overflow: hidden;
}

.settings-gruppe-header:hover {
	background-color: rgb(215, 215, 215);
}

.settings-gruppe-header.aktiv {
	background-color: rgb(135, 165, 225);
	color: rgb(0, 80, 155);
}

/* Toggle +/- vor dem Gruppenname */
.settings-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 14px;
	height: 14px;
	flex-shrink: 0;
	font-size: 14px;
	line-height: 1;
	color: rgb(135, 135, 135);
	cursor: pointer;
	user-select: none;
}

.settings-toggle:hover { color: rgb(55, 55, 55); }

/* Kind-Liste mit Verbindungslinien — genau wie .baum-kinder */
.settings-kinder {
	list-style: none;
	margin: 0;
	padding-left: 20px;
	position: relative;
	display: none;
}

.settings-kinder.offen {
	display: block;
}

.settings-kinder::before {
	content: '';
	position: absolute;
	left: 10px;
	top: 0;
	bottom: 10px;
	border-left: 1px dotted rgb(180, 180, 180);
}

.settings-kinder > li {
	position: relative;
}

.settings-kinder > li::before {
	content: '';
	position: absolute;
	left: -10px;
	top: 11px;
	width: 10px;
	border-top: 1px dotted rgb(180, 180, 180);
}

/* Einzelner Eintrag */
.settings-item {
	display: flex;
	align-items: center;
	gap: 6px;
	padding: 2px 6px 2px 4px;
	cursor: pointer;
	font-size: 12px;
	color: rgb(65, 65, 75);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.settings-item:hover {
	background-color: rgb(215, 215, 215);
}

.settings-item.aktiv {
	background-color: rgb(135, 165, 225);
	color: rgb(0, 35, 75);
}

.settings-badge {
	font-size: 10px;
	font-weight: bold;
	background-color: rgb(125, 165, 215);
	color: rgb(0, 50, 95);
	padding: 1px 5px;
	border-radius: 2px;
	flex-shrink: 0;
}

.settings-badge.inaktiv {
	background-color: rgb(195, 195, 195);
	color: rgb(115, 115, 125);
}

.settings-icon {
	font-size: 9px;
	color: rgb(85, 155, 105);
	flex-shrink: 0;
}

.settings-icon.mp {
	color: rgb(85, 45, 125);
}

/* ── Einstellungen-Formular ─────────────────────────── */

.settings-header {
	padding: 16px 20px 12px;
	border-bottom: 1px solid rgb(190, 190, 200);
	display: flex;
	align-items: baseline;
	gap: 10px;
}

.settings-header h2 {
	font-size: 15px;
	font-weight: bold;
	color: rgb(35, 35, 45);
}

.settings-wrap {
	padding: 16px 20px;
	max-width: 520px;
}

.settings-zeile {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	margin-bottom: 14px;
}

.settings-label {
	width: 130px;
	flex-shrink: 0;
	font-size: 12px;
	color: rgb(90, 90, 105);
	padding-top: 7px;
}

.settings-wert {
	flex: 1;
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	align-items: center;
}

.settings-input {
	width: 100%;
	padding: 6px 8px;
	background-color: rgb(210, 210, 220);
	border: 1px solid rgb(170, 170, 185);
	color: rgb(25, 25, 35);
	font-size: 12px;
}

.settings-input:focus {
	outline: none;
	border-color: rgb(55, 105, 175);
}

.settings-input-sm {
	width: 90px;
}

.settings-textarea {
	width: 100%;
	min-height: 80px;
	resize: vertical;
	font-family: inherit;
	line-height: 1.4;
}

.settings-json {
	font-family: monospace;
	font-size: 12px;
	white-space: pre;
	tab-size: 2;
}

.settings-hinweis {
	display: block;
	color: rgb(125, 125, 145);
	font-size: 11px;
	margin-top: 3px;
}

.settings-select {
	padding: 6px 8px;
	background-color: rgb(210, 210, 220);
	border: 1px solid rgb(170, 170, 185);
	color: rgb(25, 25, 35);
	font-size: 12px;
}

.btn-settings {
	padding: 5px 12px;
	background-color: rgb(95, 145, 215);
	color: rgb(0, 15, 35);
	border: none;
	font-size: 12px;
	cursor: pointer;
}

.btn-settings:hover {
	background-color: rgb(65, 125, 205);
}

.settings-trennlinie {
	border: none;
	border-top: 1px solid rgb(195, 195, 205);
	margin: 20px 0;
}

.settings-neu-titel {
	font-size: 12px;
	font-weight: bold;
	color: rgb(90, 90, 105);
	margin-bottom: 14px;
}

.badge-inaktiv {
	font-size: 10px;
	padding: 2px 6px;
	background-color: rgb(225, 195, 175);
	color: rgb(155, 95, 35);
	vertical-align: middle;
}

/* ── Layout HTML-Editor ─────────────────────────────── */

.layout-html-bereich {
	display: flex;
	gap: 0;
	flex-direction: column;
	border-top: 1px solid rgb(195, 195, 205);
	margin-top: 4px;
}

.layout-html-block {
	display: flex;
	flex-direction: column;
	border-bottom: 1px solid rgb(195, 195, 205);
}

.layout-html-label {
	font-size: 11px;
	font-weight: bold;
	color: rgb(75, 75, 95);
	padding: 8px 20px 6px;
	background-color: rgb(220, 220, 227);
	border-bottom: 1px solid rgb(195, 195, 205);
}

.layout-html-hint {
	font-weight: normal;
	color: rgb(135, 135, 155);
	font-size: 10px;
}

.layout-html-editor {
	width: 100%;
	min-height: 280px;
	padding: 12px 20px;
	background-color: rgb(227, 227, 235);
	color: rgb(35, 55, 35);
	font-family: "Consolas", "Monaco", "Courier New", monospace;
	font-size: 12px;
	line-height: 1.6;
	border: none;
	resize: vertical;
	box-sizing: border-box;
	tab-size: 2;
}

.layout-html-editor:focus {
	outline: none;
	background-color: rgb(223, 223, 233);
	box-shadow: inset 0 0 0 1px rgb(55, 105, 175);
}

.layout-html-footer {
	padding: 12px 20px;
	background-color: rgb(220, 220, 227);
	border-top: 1px solid rgb(195, 195, 205);
}

/* ── Session-Modal ─────────────────────────────────── */

.session-modal-overlay {
	position: fixed;
	inset: 0;
	background-color: rgba(255, 255, 255, 0.75);
	z-index: 9999;
	display: flex;
	align-items: center;
	justify-content: center;
}

.session-modal-box {
	background-color: rgb(205, 205, 215);
	border: 1px solid rgb(155, 155, 175);
	border-radius: 6px;
	padding: 30px 36px;
	width: 320px;
}

.session-modal-box h2 {
	color: rgb(35, 35, 35);
	font-size: 16px;
	margin-bottom: 8px;
}

.session-modal-box p {
	color: rgb(75, 75, 95);
	font-size: 12px;
	margin-bottom: 20px;
}

.session-modal-fehler {
	color: rgb(175, 35, 35);
	font-size: 12px;
	margin-bottom: 12px;
}

.session-modal-box label {
	display: block;
	font-size: 11px;
	color: rgb(75, 75, 95);
	margin-bottom: 4px;
}

.session-modal-box input {
	width: 100%;
	padding: 7px 10px;
	background-color: rgb(220, 220, 230);
	border: 1px solid rgb(165, 165, 185);
	border-radius: 3px;
	color: rgb(35, 35, 35);
	font-size: 13px;
	margin-bottom: 14px;
}

.session-modal-box input[readonly] {
	opacity: 0.6;
}

.session-modal-box button[type="submit"] {
	width: 100%;
	padding: 8px;
	background-color: rgb(55, 115, 195);
	border: none;
	border-radius: 3px;
	color: rgb(0, 0, 0);
	font-size: 13px;
	cursor: pointer;
	margin-top: 4px;
}

.session-modal-box button[type="submit"]:disabled {
	opacity: 0.6;
	cursor: default;
}

/* ── Seiten-Registerleiste ────────────────────────────── */

.cms-register {
	display: flex;
	align-items: flex-end;
	gap: 0;
	padding: 0 0 0 8px;
	margin: -20px -24px 16px -24px;
	background-color: rgb(227, 227, 233);
	border-bottom: 1px solid rgb(190, 190, 200);
	min-height: 32px;
	flex-shrink: 0;
}

.cms-register-tab {
	display: inline-flex;
	align-items: center;
	padding: 6px 14px;
	font-size: 12px;
	color: rgb(100, 100, 115);
	background-color: rgb(217, 217, 225);
	border: 1px solid rgb(190, 190, 200);
	border-bottom: 1px solid rgb(190, 190, 200);
	border-radius: 6px 6px 0 0;
	margin-bottom: -1px;
	cursor: pointer;
	white-space: nowrap;
	transition: background-color 0.15s, color 0.15s;
}

.cms-register-tab:hover {
	background-color: rgb(205, 205, 215);
	color: rgb(50, 50, 65);
}

.cms-register-tab.aktiv {
	background-color: rgb(207, 207, 217);
	color: rgb(25, 25, 35);
	border-bottom-color: rgb(207, 207, 217);
	font-weight: bold;
}

.cms-register-icon {
	margin-right: 5px;
	font-size: 13px;
}

.cms-register-tab .sprach-dot {
	font-size: 9px;
	width: 18px;
	height: 14px;
	line-height: 14px;
	text-align: center;
	border-radius: 2px;
	display: inline-block;
}

.cms-register-tab .dot-online {
	background-color: rgb(175, 225, 185);
	color: rgb(45, 135, 55);
}

.cms-register-tab .dot-modified {
	background-color: rgb(165, 185, 225);
	color: rgb(25, 75, 135);
}

.cms-register-tab .dot-cms {
	background-color: rgb(225, 215, 195);
	color: rgb(155, 125, 55);
}

.cms-register-tab .dot-offline {
	background-color: rgb(225, 195, 195);
	color: rgb(145, 55, 55);
}

/* ── Werkzeuge: Suchen & Ersetzen ────────────────────── */

.se-vorschau {
	margin-top: 14px;
}

.se-zusammenfassung {
	font-size: 12px;
	color: rgb(55, 60, 75);
	padding: 8px 0;
	border-bottom: 1px solid rgb(190, 190, 205);
	margin-bottom: 8px;
}

.se-details {
	max-height: 250px;
	overflow-y: auto;
	margin-bottom: 12px;
}

.se-detail-zeile {
	font-size: 11px;
	color: rgb(85, 90, 105);
	padding: 3px 0;
}

.se-badge {
	display: inline-block;
	font-size: 9px;
	padding: 1px 5px;
	border-radius: 2px;
	background-color: rgb(190, 195, 210);
	color: rgb(85, 95, 125);
	min-width: 60px;
	text-align: center;
}

.se-sprache {
	font-size: 9px;
	color: rgb(110, 120, 145);
}

.se-checkbox {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	margin-right: 14px;
	font-size: 12px;
	color: rgb(65, 70, 85);
	cursor: pointer;
}

.se-ausfuehren {
	padding-top: 8px;
	border-top: 1px solid rgb(190, 190, 205);
}

/* ── Domain-spezifische Einstellungen ────────────────── */

.settings-domain-header {
	font-size: 12px;
	cursor: pointer;
}

.settings-domain-name {
	cursor: pointer;
	text-decoration: underline;
	text-decoration-color: rgb(170, 170, 185);
}

.settings-domain-name:hover {
	color: rgb(45, 45, 55);
	text-decoration-color: rgb(135, 135, 155);
}

.settings-domain-hinweis {
	font-size: 11px;
	font-weight: normal;
	color: rgb(55, 95, 135);
}

.settings-domain-info {
	background-color: rgb(200, 210, 220);
	border: 1px solid rgb(175, 190, 205);
	border-radius: 4px;
	padding: 8px 12px;
	margin-bottom: 14px;
	font-size: 11px;
	color: rgb(55, 85, 115);
	line-height: 1.5;
}

.settings-reset-link {
	display: inline-block;
	margin-left: 6px;
	font-size: 10px;
	color: rgb(155, 105, 75);
	text-decoration: underline;
	cursor: pointer;
}

.settings-reset-link:hover {
	color: rgb(145, 75, 35);
}

/* ── JSON-Listeneditoren (CSS/JS-Dateien) ────────────── */

.json-liste {
	border: 1px solid rgb(190, 190, 200);
	border-radius: 4px;
	background-color: rgb(219, 219, 227);
	padding: 6px;
}

.json-liste-zeile {
	display: flex;
	align-items: center;
	gap: 6px;
	margin-bottom: 4px;
	padding: 4px 6px;
	background-color: rgb(210, 210, 220);
	border-radius: 3px;
}

.json-liste-zeile:hover {
	background-color: rgb(203, 203, 215);
}

.json-input-pfad {
	flex: 1;
	min-width: 0;
	font-size: 12px;
	padding: 4px 8px;
}

.json-input-pfad-breit {
	flex: 2;
}

.json-input-media {
	flex: 1;
	min-width: 0;
	font-size: 11px;
	padding: 4px 8px;
	color: rgb(55, 75, 105);
}

.json-input-media::placeholder {
	color: rgb(145, 155, 175);
}

.btn-json-entfernen {
	background: none;
	border: none;
	color: rgb(175, 75, 75);
	font-size: 16px;
	cursor: pointer;
	padding: 0 4px;
	line-height: 1;
	flex-shrink: 0;
}

.btn-json-entfernen:hover {
	color: rgb(155, 25, 25);
}

.json-sortierung {
	display: flex;
	flex-direction: column;
	flex-shrink: 0;
	gap: 0;
}

.btn-json-sort {
	background: none;
	border: none;
	color: rgb(115, 115, 135);
	font-size: 8px;
	cursor: pointer;
	padding: 0 3px;
	line-height: 1.2;
}

.btn-json-sort:hover {
	color: rgb(55, 55, 75);
}

.json-liste-footer {
	padding: 4px 2px 2px;
}

.btn-settings-sm {
	background-color: rgb(190, 195, 205);
	color: rgb(65, 70, 85);
	border: 1px solid rgb(175, 180, 190);
	border-radius: 3px;
	padding: 3px 10px;
	font-size: 11px;
	cursor: pointer;
}

.btn-settings-sm:hover {
	background-color: rgb(180, 185, 195);
	color: rgb(40, 45, 55);
}

/* ── Benutzer-Tabelle ──────────────────────────────── */

.benutzer-tabelle {
	width: 100%;
	border-collapse: collapse;
	font-size: 13px;
}

.benutzer-tabelle th {
	text-align: left;
	padding: 6px 10px;
	border-bottom: 1px solid rgb(180, 185, 195);
	color: rgb(100, 105, 115);
	font-weight: 500;
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.benutzer-tabelle td {
	padding: 7px 10px;
	border-bottom: 1px solid rgb(197, 200, 210);
	color: rgb(50, 55, 65);
}

.benutzer-tabelle tr:hover td {
	background-color: rgb(203, 207, 217);
}

.benutzer-tabelle td a {
	color: rgb(35, 75, 125);
	text-decoration: none;
	font-size: 12px;
}

.benutzer-tabelle td a:hover {
	text-decoration: underline;
}

.settings-trenner {
	border-top: 1px solid rgb(185, 190, 200);
	margin: 18px 0 14px;
}

/* Color-Picker in System-Settings */
.settings-input-color {
	width: 44px !important;
	min-width: 44px !important;
	height: 28px;
	padding: 1px 2px !important;
	flex: 0 0 auto !important;
	cursor: pointer;
	vertical-align: middle;
}
.settings-input-color:not([data-gesetzt]) {
	opacity: 0.45;
}
.settings-color-reset {
	border: none;
	background: none;
	cursor: pointer;
	font-size: 14px;
	padding: 2px 8px;
	color: inherit;
	opacity: 0.6;
	vertical-align: middle;
}
.settings-color-reset:hover { opacity: 1; }


/* ── Werkzeuge: Update-Dashboard ─────────────────────── */
.update-dashboard { max-width: 960px; }
.update-info-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 12px; margin-bottom: 16px; }
.update-info-item { padding: 10px 12px; background-color: rgb(248, 248, 250); border: 1px solid rgb(225, 225, 235); border-radius: 4px; }
.update-info-label { font-size: 10px; color: rgb(110, 110, 125); text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 4px; }
.update-info-wert { font-size: 13px; color: rgb(35, 35, 45); font-weight: 500; word-break: break-word; }
.update-hinweis { padding: 10px 12px; margin-bottom: 16px; background-color: rgb(255, 248, 225); border-left: 3px solid rgb(230, 170, 50); color: rgb(95, 75, 30); font-size: 12px; border-radius: 3px; }
.update-aktionen { margin-bottom: 14px; }
.update-tabs { display: flex; border-bottom: 2px solid rgb(200, 200, 210); margin: 16px 0 12px; gap: 2px; flex-wrap: wrap; }
.update-tab { padding: 7px 14px; cursor: pointer; border: 1px solid transparent; border-bottom: none; border-radius: 4px 4px 0 0; font-size: 12px; color: rgb(110, 110, 125); margin-bottom: -2px; }
.update-tab:hover { background-color: rgb(240, 240, 245); color: rgb(35, 35, 45); }
.update-tab.aktiv { background-color: rgb(255, 255, 255); border-color: rgb(200, 200, 210); border-bottom-color: rgb(255, 255, 255); color: rgb(35, 35, 45); font-weight: 500; }
.update-tab-content { padding: 4px 0 12px; }
.update-tabelle { width: 100%; border-collapse: collapse; font-size: 12px; }
.update-tabelle th { text-align: left; padding: 7px 10px; border-bottom: 2px solid rgb(200, 200, 210); color: rgb(35, 35, 45); font-weight: 600; }
.update-tabelle td { padding: 7px 10px; border-bottom: 1px solid rgb(225, 225, 235); color: rgb(35, 35, 45); vertical-align: top; }
.update-tabelle tr:hover td { background-color: rgb(248, 248, 250); }
.update-tabelle tr.update-zeile-inaktiv td { opacity: 0.55; }
.update-tabelle code { font-family: monospace; font-size: 11px; background-color: rgb(240, 240, 245); padding: 1px 5px; border-radius: 2px; color: rgb(60, 60, 80); }
.update-pfad { font-family: monospace; font-size: 11px; color: rgb(70, 70, 85); word-break: break-all; }
.update-datum { color: rgb(110, 110, 125); font-size: 11px; white-space: nowrap; }
.update-leer { padding: 18px 12px; color: rgb(110, 110, 125); font-style: italic; font-size: 12px; background-color: rgb(250, 250, 252); border: 1px dashed rgb(215, 215, 225); border-radius: 4px; text-align: center; }
.update-badge-ok, .update-badge-warn, .update-badge-fehler, .update-badge-info { display: inline-block; padding: 2px 8px; border-radius: 3px; font-size: 11px; font-weight: 500; white-space: nowrap; }
.update-badge-ok { background-color: rgb(210, 235, 210); color: rgb(35, 85, 35); }
.update-badge-warn { background-color: rgb(255, 230, 180); color: rgb(120, 75, 20); }
.update-badge-fehler { background-color: rgb(250, 210, 210); color: rgb(130, 40, 40); }
.update-badge-info { background-color: rgb(215, 230, 250); color: rgb(30, 70, 130); }
