/* =================== Für Mitarbeiter (Adressenversand + Honorare) =================== */

.mit-trigger { margin-right: 0; }

/* Staff area — persistent left sidebar (module switcher) + content */
.staff-area { display: flex; gap: 1.5rem; align-items: flex-start; }
.staff-area[hidden] { display: none; }
.staff-sidebar {
	flex: none; width: 224px;
	position: sticky; top: 84px;
	display: flex; flex-direction: column; gap: 4px;
}
.staff-nav-item {
	display: flex; align-items: center; justify-content: flex-start; gap: 10px;
	width: 100%; height: auto; text-align: left;
	padding: 9px 12px; border-radius: var(--radius-md);
	background: transparent; border: 1px solid transparent; box-shadow: none;
	color: var(--text-muted); font-size: 0.9375rem; font-weight: 500; cursor: pointer;
}
.staff-nav-item[hidden] { display: none; }
.staff-nav-item svg { flex: none; color: var(--text-faint); }
.staff-nav-item:hover { background: var(--accent); color: var(--text-strong); }
.staff-nav-item.active { background: var(--accent); color: var(--text-strong); border-color: var(--card-border); }
.staff-nav-item.active svg { color: var(--gold); }
.staff-content { flex: 1 1 auto; min-width: 0; }
.staff-content .tab-panel { animation: none; }
@media (max-width: 760px) {
	.staff-area { flex-direction: column; gap: 0.75rem; }
	.staff-sidebar { width: 100%; position: static; flex-direction: row; flex-wrap: wrap; }
	.staff-nav-item { width: auto; }
}

.mit-dashboard-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: 16px;
	max-width: 1100px;
}
.mit-module-card {
	background: var(--card-bg);
	border: 1px solid var(--card-border);
	border-radius: var(--radius-xl);
	padding: 22px;
	text-align: left;
	cursor: pointer;
	box-shadow: var(--card-shadow);
	transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
	display: flex; flex-direction: column; gap: 10px;
	color: var(--text-strong);
	font: inherit;
	height: auto;
	align-items: stretch;
	white-space: normal;
}
.mit-module-card:hover { border-color: var(--gold-tint-border); box-shadow: var(--shadow-md); }
.mit-module-card:focus-visible { border-color: var(--ring); box-shadow: 0 0 0 3px var(--ring-soft); }
.mit-module-card[hidden] { display: none; }
.mit-module-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 46px;
	height: 46px;
	border-radius: var(--radius-lg);
	background: var(--gold-tint);
	color: var(--gold-strong);
	margin-bottom: 4px;
	transition: background .15s, color .15s;
}
.mit-module-icon svg { display: block; }
.mit-module-card:hover .mit-module-icon { background: var(--gold); color: #4a3a18; }
.mit-module-title { font-family: var(--font-head); font-size: 1.25rem; font-weight: 600; color: var(--text-strong); }
.mit-module-desc { font-size: 0.875rem; color: var(--text-muted); line-height: 1.5; }

.mit-module-header {
	display: flex; gap: 16px; align-items: center;
	margin-bottom: 28px; flex-wrap: wrap;
}
.mit-module-header h1.page-title { margin: 0; flex: 1; }

/* Small screens: stack title above the tabs, smaller text, more breathing room
   between the header (title + tabs) and the content below it. */
@media (max-width: 900px) {
	.mit-module-header { gap: 12px; margin-bottom: 32px; }
	.mit-module-header h1.page-title { flex: 1 1 100%; font-size: 1.6rem; }
	.mit-subtab { padding: 6px 10px; font-size: 13px; }
	.mit-toolbar input[type="search"], .mit-toolbar select { font-size: 13px; }
	.mit-table-wrap table, #admin-table { font-size: 13px; }
	#admin-table th, #admin-table td { padding-left: 6px; padding-right: 6px; }
}

/* Segmented control sub-tabs (shadcn Tabs look) */
.mit-subtabs {
	display: inline-flex; gap: 2px;
	background: var(--muted);
	border: 1px solid var(--card-border);
	border-radius: var(--radius-lg);
	padding: 3px;
}
.mit-subtab {
	height: auto;
	padding: 6px 14px; background: transparent; border: 1px solid transparent;
	box-shadow: none; cursor: pointer;
	border-radius: var(--radius-md);
	font-size: 14px; font-weight: 500; color: var(--text-muted);
	transition: background .15s, color .15s, box-shadow .15s;
}
.mit-subtab.active {
	color: var(--text-strong);
	background: var(--card-bg);
	box-shadow: var(--shadow-xs);
}
.mit-subtab:hover:not(.active) { color: var(--text-strong); }
.mit-subtab:focus-visible { box-shadow: 0 0 0 3px var(--ring-soft); }
.mit-subpanel { display: none; }
.mit-subpanel.active { display: block; }

.mit-toolbar { display: flex; gap: 12px; margin-bottom: 12px; flex-wrap: wrap; align-items: center; }
.mit-toolbar input[type="search"], .mit-toolbar select {
	height: 2.25rem;
	padding: 8px 12px; font-size: 14px;
	border: 1px solid var(--input-border); border-radius: var(--radius-md);
	box-shadow: var(--shadow-xs);
	background: var(--input-bg); color: var(--text);
	font-family: inherit;
}
.mit-toolbar input[type="search"]:focus, .mit-toolbar select:focus {
	outline: none; border-color: var(--input-focus); box-shadow: 0 0 0 3px var(--input-focus-ring);
}
.mit-toolbar input[type="search"] { flex: 1 1 280px; max-width: 360px; }

.mit-status { color: var(--text-muted); font-size: 0.875rem; margin-bottom: 12px; }
.mit-table-wrap {
	overflow-x: auto;
	border: 1px solid var(--card-border);
	border-radius: var(--radius-lg);
	box-shadow: var(--card-shadow);
}
#mit-table, #mit-hon-table {
	width: 100%; border-collapse: collapse;
	background: var(--card-bg);
}
#mit-table th, #mit-table td,
#mit-hon-table th, #mit-hon-table td {
	text-align: left; padding: 11px 14px;
	border-bottom: 1px solid var(--section-border);
	font-size: 0.875rem; vertical-align: top;
}
#mit-table tbody tr:last-child td, #mit-hon-table tbody tr:last-child td { border-bottom: none; }
#mit-table tbody tr:hover, #mit-hon-table tbody tr:hover { background: color-mix(in srgb, var(--muted) 60%, transparent); }
#mit-table th, #mit-hon-table th {
	background: var(--muted); font-weight: 500;
	color: var(--text-muted); font-size: 0.8125rem;
	text-transform: none; letter-spacing: 0;
}

.badge-Bezahlt, .badge-active { background: rgb(220 252 231); color: rgb(22 101 52); border-color: rgb(187 247 208); }
.badge-Offen, .badge-trial, .badge-future { background: rgb(255 243 214); color: rgb(138 90 0); border-color: rgb(253 230 138); }
.badge-Storniert, .badge-cancelled_from_dunning, .badge-dunning, .badge-inactive { background: rgb(253 232 232); color: rgb(161 48 48); border-color: rgb(254 202 202); }
:root.dark .badge-Bezahlt, :root.dark .badge-active { background: rgb(26 58 42); color: rgb(121 217 164); }
:root.dark .badge-Offen, :root.dark .badge-trial, :root.dark .badge-future { background: rgb(58 46 16); color: rgb(240 195 114); }
:root.dark .badge-Storniert, :root.dark .badge-cancelled_from_dunning, :root.dark .badge-dunning, :root.dark .badge-inactive { background: rgb(58 26 26); color: rgb(242 154 154); }

.mit-hon-totals { display: flex; gap: 16px; flex-wrap: wrap; margin-bottom: 12px; }
.mit-hon-totals .pill {
	background: var(--card-bg); border: 1px solid var(--card-border);
	padding: 12px 16px; border-radius: var(--radius-xl); font-size: 0.875rem;
	box-shadow: var(--card-shadow);
}
.mit-hon-totals .pill strong { display: block; font-size: 1.25rem; color: var(--text-strong); }

.mit-category-filter {
	display: flex; gap: 4px; align-items: center;
	background: var(--card-bg); border: 1px solid var(--card-border);
	border-radius: var(--radius-md); padding: 4px 8px;
	box-shadow: var(--shadow-xs);
}
.mit-category-filter label {
	display: inline-flex; align-items: center; gap: 6px;
	padding: 4px 8px; font-size: 0.875rem; border-radius: var(--radius-sm); cursor: pointer;
}
.mit-category-filter label:hover { background: var(--accent); }
.mit-category-filter.status-filter { flex-wrap: wrap; }
.mit-category-filter.status-filter label { text-transform: capitalize; }

.mit-settings-grid {
	display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: 24px; margin-bottom: 16px; align-items: start; /* don't stretch short blocks to full height */
}
@media (max-width: 720px) { .mit-settings-grid { grid-template-columns: 1fr; } }
.mit-settings-block {
	background: var(--card-bg); padding: 16px;
	border-radius: var(--radius-xl); border: 1px solid var(--card-border);
	box-shadow: var(--card-shadow);
}
.mit-settings-header { display: flex; align-items: center; gap: 8px; margin-bottom: 12px; }

.mit-options { display: flex; flex-direction: column; gap: 6px; }
.mit-options .option {
	display: flex; align-items: center; gap: 10px;
	padding: 6px 8px; border-radius: var(--radius-sm); font-size: 0.875rem; cursor: pointer;
}
.mit-options .option:hover { background: var(--accent); }

.mit-subhead { font-size: 11px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; color: var(--text-muted); margin: 16px 0 8px; }
.mit-subhead:first-of-type { margin-top: 6px; }
/* Export-Produkte rows: Name + Abkürzung + remove. */
.ep-line { display: grid; grid-template-columns: 1fr 90px auto; gap: 8px; align-items: center; }
.ep-line input { height: 2rem; padding: 6px 8px; font-size: 13px; min-width: 0; border: 1px solid var(--input-border); border-radius: var(--radius-md); box-shadow: var(--shadow-xs); background: var(--input-bg); color: var(--text); font-family: inherit; }
.ep-line input[data-ep="code"] { text-align: center; text-transform: uppercase; font-family: var(--font-mono); }
.ep-line input:focus { outline: none; border-color: var(--input-focus); box-shadow: 0 0 0 3px var(--input-focus-ring); }
.mit-product-codes { display: flex; flex-direction: column; gap: 4px; }
.mit-product-codes .product-row {
	display: block;
	padding: 8px 4px; border-bottom: 1px solid var(--section-border);
}
.mit-product-codes .product-head { display: flex; align-items: center; gap: 12px; }
.prod-expand { border: none; background: transparent; cursor: pointer; color: var(--text-muted); font-size: 12px; width: 18px; padding: 0; box-shadow: none; }
.prod-spacer { display: inline-block; width: 22px; flex: 0 0 auto; }
.prod-plans { margin: 8px 0 2px 30px; display: flex; flex-direction: column; gap: 5px; }
.prod-plans[hidden] { display: none; }
.plan-row { display: flex; align-items: center; gap: 8px; font-size: 12px; cursor: pointer; }
.plan-row .plan-name { flex: 1; }
.plan-row input[type="checkbox"] { flex: 0 0 auto; }
.mit-add-product {
	margin-top: 12px; height: 2rem; padding: 6px 8px; font-size: 13px;
	border: 1px solid var(--input-border); border-radius: var(--radius-md);
	background: var(--input-bg); color: var(--text); font-family: inherit;
}
.mit-add-product:disabled { opacity: 0.5; }
/* Interne Verteilung — add-lines list: Produkt + Anzahl + Beschreibung per line. */
.mit-internal-list { display: flex; flex-direction: column; gap: 8px; }
.id-line, .iv-line { display: grid; grid-template-columns: minmax(0,1.3fr) 56px minmax(0,1.4fr) auto; gap: 8px; align-items: center; }
.iv-line { margin: 6px 0; }
.id-line select, .id-line input, .iv-line select, .iv-line input {
	height: 2rem; padding: 6px 8px; font-size: 13px; min-width: 0;
	border: 1px solid var(--input-border); border-radius: var(--radius-md);
	box-shadow: var(--shadow-xs); background: var(--input-bg); color: var(--text); font-family: inherit;
}
.id-line input[type="number"], .iv-line input[type="number"] { text-align: center; font-family: var(--font-mono); }
.id-line select:focus, .id-line input:focus, .iv-line select:focus, .iv-line input:focus { outline: none; border-color: var(--input-focus); box-shadow: 0 0 0 3px var(--input-focus-ring); }
.id-line .icon-btn, .iv-line .icon-btn { border: none; background: transparent; box-shadow: none; cursor: pointer; padding: 2px 6px; color: var(--destructive); font-size: 16px; line-height: 1; }
.iv-footer { margin-top: 8px; display: flex; align-items: center; gap: 12px; font-size: 12px; min-height: 1.2em; }
.iv-footer a { color: var(--accent); }
.iv-saved { color: var(--text-muted); opacity: 0; transition: opacity .2s; }
.iv-saved.show { opacity: 1; }
.pv-internal-headrow { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; }
.pv-reset { font-size: 12px; color: var(--accent); white-space: nowrap; }
.iv-group { margin-top: 12px; }
.iv-group-head { font-style: italic; font-weight: 600; margin-bottom: 4px; }
.iv-remaining { font-weight: 600; margin-top: 4px; }
.pv-kommentar-input {
	width: 100%; height: 2rem; padding: 6px 8px; font-size: 13px; margin-top: 6px;
	border: 1px solid var(--input-border); border-radius: var(--radius-md);
	box-shadow: var(--shadow-xs); background: var(--input-bg); color: var(--text); font-family: inherit;
}
.pv-kommentar-input:focus { outline: none; border-color: var(--input-focus); box-shadow: 0 0 0 3px var(--input-focus-ring); }
.btn-add-line {
	margin-top: 10px; border: 1px dashed var(--input-border); background: transparent; color: var(--text-muted);
	border-radius: var(--radius-md); padding: 6px 10px; font-size: 13px; cursor: pointer;
}
.btn-add-line:hover { background: var(--accent); color: var(--text); }
.mit-product-codes .product-row:last-child { border-bottom: none; }
.mit-product-codes .product-name { flex: 1; display: flex; flex-direction: column; gap: 2px; font-size: 13px; }
.mit-product-codes input[type="text"] {
	width: 80px; height: 2rem; padding: 6px 8px; font-size: 13px;
	font-family: var(--font-mono);
	border: 1px solid var(--input-border); border-radius: var(--radius-md);
	box-shadow: var(--shadow-xs);
	background: var(--input-bg); color: var(--text);
	text-align: center; text-transform: uppercase;
}
.mit-product-codes input[type="text"]:focus { outline: none; border-color: var(--input-focus); box-shadow: 0 0 0 3px var(--input-focus-ring); }
.mit-product-codes select {
	height: 2rem; padding: 6px 8px; font-size: 13px;
	border: 1px solid var(--input-border); border-radius: var(--radius-md);
	box-shadow: var(--shadow-xs);
	background: var(--input-bg); color: var(--text); min-width: 160px;
	font-family: inherit;
}

/* "Sync prüfen" — non-prominent cache verification control */
.check-sync { white-space: nowrap; }
.check-sync-result {
	display: inline-flex; align-items: center; gap: 6px;
	font-size: 0.8125rem; color: var(--text-muted);
}
.check-sync-result .spinner { width: 12px; height: 12px; border-width: 2px; margin: 0; }
.check-sync-result .check-ok { color: var(--text-muted); }
.check-sync-result .check-all { font-size: 0.8125rem; }

/* Login-Admin sync bar + table controls */
.admin-syncbar { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; flex-wrap: wrap; }
.admin-syncbar .spinner { border-color: currentColor; border-right-color: transparent; }
.admin-role {
	height: 2rem; padding: 6px 8px; font-size: 13px;
	border: 1px solid var(--input-border); border-radius: var(--radius-md);
	box-shadow: var(--shadow-xs);
	background: var(--input-bg); color: var(--text); font-family: inherit;
}
.admin-role:focus { outline: none; border-color: var(--input-focus); box-shadow: 0 0 0 3px var(--input-focus-ring); }
#admin-table .admin-mod { width: 16px; height: 16px; accent-color: var(--gold-strong); cursor: pointer; }
#admin-table .admin-mod:disabled { cursor: default; opacity: .5; }
#admin-table td { vertical-align: middle; }
.admin-save { height: 2rem; padding: 0.4rem 0.875rem; font-size: 0.75rem; }
.admin-rowstatus { margin-left: 8px; white-space: nowrap; }

/* Admin sub-tabs reuse the segmented-control look */
.admin-subtabs { display: inline-flex; }
.admin-subtab {
	height: auto;
	padding: 6px 14px; background: transparent; border: 1px solid transparent;
	box-shadow: none; cursor: pointer;
	border-radius: var(--radius-md);
	font-size: 14px; font-weight: 500; color: var(--text-muted);
	transition: background .15s, color .15s, box-shadow .15s;
}
.admin-subtab.active {
	color: var(--text-strong);
	background: var(--card-bg);
	box-shadow: var(--shadow-xs);
}
.admin-subtab:hover:not(.active) { color: var(--text-strong); }
.admin-subtab:focus-visible { box-shadow: 0 0 0 3px var(--ring-soft); }
/* Admin Tools sub-tabs (Import / Bereinigung) — same look as admin sub-tabs */
.tools-subtab {
	height: auto; padding: 6px 14px; background: transparent; border: 1px solid transparent;
	box-shadow: none; cursor: pointer; border-radius: var(--radius-md);
	font-size: 14px; font-weight: 500; color: var(--text-muted);
	transition: background .15s, color .15s, box-shadow .15s;
}
.tools-subtab.active { color: var(--text-strong); background: var(--card-bg); box-shadow: var(--shadow-xs); }
.tools-subtab:hover:not(.active) { color: var(--text-strong); }
.tools-subpanel { display: none; }
.tools-subpanel.active { display: block; }

/* Generic admin tables (subscriptions / products / plans / invoices) */
#subs-table, #prods-table, #plans-table, #inv-table {
	width: 100%; border-collapse: collapse;
	background: var(--card-bg); font-size: 0.875rem;
}
#subs-table th, #prods-table th, #plans-table th, #inv-table th,
#subs-table td, #prods-table td, #plans-table td, #inv-table td {
	text-align: left; padding: 11px 14px;
	border-bottom: 1px solid var(--section-border); vertical-align: middle;
}
#subs-table tbody tr:last-child td, #prods-table tbody tr:last-child td,
#plans-table tbody tr:last-child td, #inv-table tbody tr:last-child td { border-bottom: none; }
#subs-table th, #prods-table th, #plans-table th, #inv-table th {
	background: var(--muted); font-weight: 500;
	color: var(--text-muted); font-size: 0.8125rem;
}
#subs-table tbody tr:hover, #prods-table tbody tr:hover,
#plans-table tbody tr:hover, #inv-table tbody tr:hover { background: color-mix(in srgb, var(--muted) 60%, transparent); }

/* Dialog — shadcn modal */
.mit-dialog {
	position: fixed; inset: 0; background: rgba(0,0,0,.6);
	display: flex; align-items: center; justify-content: center; z-index: 50;
	animation: overlay-in .2s ease both;
}
.mit-dialog[hidden] { display: none; }
.mit-dialog-card {
	background: var(--card-bg); color: var(--text);
	padding: 24px; border-radius: var(--radius-xl);
	border: 1px solid var(--card-border);
	width: min(780px, 96vw); max-height: 92vh; overflow-y: auto;
	box-shadow: var(--shadow-lg);
	animation: dialog-in .2s cubic-bezier(.2,.7,.2,1) both;
}
.mit-dialog-card h2 {
	font-family: var(--font-head); font-size: 1.125rem; font-weight: 600;
	text-transform: none; letter-spacing: 0; color: var(--text-strong); margin: 0 0 12px;
}
.mit-dialog-grid {
	display: grid; grid-template-columns: 1.6fr 1fr; gap: 12px;
}
.mit-issue-grid { grid-template-columns: 1.6fr 1fr 1fr; align-items: end; }
/* Read-only values (Ausgabe / Datum / Seitenanzahl) — shown as plain text, NOT as edit fields. */
.mit-readonly {
	height: 2.25rem; display: flex; align-items: center;
	padding: 8px 2px; font-size: 14px; font-weight: 600;
	border: none; background: transparent; color: var(--text-strong); font-variant-numeric: tabular-nums;
}
.mit-dialog-grid select, .mit-dialog-grid input {
	height: 2.25rem; padding: 8px 10px; font-size: 14px;
	border: 1px solid var(--input-border); border-radius: var(--radius-md);
	box-shadow: var(--shadow-xs);
	background: var(--input-bg); color: var(--text); width: 100%;
	font-family: inherit;
}
.mit-dialog-grid select:focus, .mit-dialog-grid input:focus { outline: none; border-color: var(--input-focus); box-shadow: 0 0 0 3px var(--input-focus-ring); }
.mit-field { display: flex; flex-direction: column; gap: 6px; font-size: 13px; }
.mit-field input { height: 2.25rem; padding: 8px 12px; font-size: 14px; border: 1px solid var(--input-border); border-radius: var(--radius-md); box-shadow: var(--shadow-xs); background: var(--input-bg); color: var(--text); }
.mit-ausgabe-blocks { display: flex; flex-direction: column; gap: 16px; margin-top: 12px; }
.ausgabe-block {
	border: 1px solid var(--card-border); border-radius: var(--radius-lg);
	padding: 12px 14px; background: var(--sub-bg);
}
.ausgabe-block h3 { font-size: 14px; margin: 0 0 8px; color: var(--text-strong); }
.ausgabe-block .field { display: flex; flex-direction: column; gap: 4px; font-size: 13px; margin: 0; }
.ausgabe-block .field > span { color: var(--text-muted); }
.ausgabe-block .row { display: grid; grid-template-columns: 1fr 90px auto; gap: 8px; align-items: center; margin-bottom: 6px; }
.ausgabe-block input[type="text"], .ausgabe-block input[type="number"] {
	height: 2rem; padding: 6px 8px; font-size: 13px; border: 1px solid var(--input-border); border-radius: var(--radius-md);
	box-shadow: var(--shadow-xs);
	background: var(--input-bg); color: var(--text); width: 100%;
}
.ausgabe-block input:focus { outline: none; border-color: var(--input-focus); box-shadow: 0 0 0 3px var(--input-focus-ring); }
.ausgabe-block input[type="number"] { text-align: right; font-variant-numeric: tabular-nums; }
.ausgabe-block .block-grid { display: grid; grid-template-columns: 1fr 90px; gap: 8px; margin-bottom: 8px; }
.ausgabe-block .auto-stat { display: flex; justify-content: space-between; font-size: 13px; padding: 4px 0; color: var(--text-muted); }
.ausgabe-block .icon-btn { height: auto; border: none; background: transparent; box-shadow: none; cursor: pointer; padding: 2px 6px; color: var(--destructive); font-size: 16px; line-height: 1; }
.ausgabe-block .add-line {
	height: auto;
	background: transparent; border: 1px dashed var(--card-border); color: var(--text-muted);
	padding: 4px 10px; font-size: 12px; border-radius: var(--radius-md); margin-top: 4px; cursor: pointer;
	box-shadow: none;
}
.ausgabe-block .add-line:hover { background: var(--accent); color: var(--text); }
/* Export dialog: read-only preview that mirrors the exported PDF. */
#mit-preview { max-width: 620px; }
.pv-title { font-weight: 700; font-size: 15px; margin: 2px 0 14px; }
.pv-block { border: 1px solid var(--card-border); border-radius: var(--radius-lg); padding: 12px 14px; }
.pv-block h3 { margin: 0 0 2px; font-size: 14px; }
.pv-sub { color: var(--text-muted); font-size: 12px; margin-bottom: 8px; }
.pv-row { display: flex; justify-content: space-between; gap: 12px; font-size: 13px; padding: 3px 0; font-variant-numeric: tabular-nums; }
.pv-total { border-top: 1px solid var(--section-border); margin-top: 4px; padding-top: 6px; font-weight: 700; }
.pv-internal { background: var(--muted); }
.pv-internal-note { font-style: italic; color: var(--text-muted); font-size: 12px; }
.pv-internal-head { font-weight: 700; margin: 2px 0 6px; }
.mit-dialog-actions { display: flex; gap: 8px; justify-content: flex-end; margin-top: 16px; }

/* Administrator hinzufügen dialog */
#admin-add-search {
	width: 100%; height: 2.25rem; padding: 8px 12px; margin: 4px 0 12px;
	font-size: 14px; border: 1px solid var(--input-border); border-radius: var(--radius-md);
	box-shadow: var(--shadow-xs); background: var(--input-bg); color: var(--text); font-family: inherit;
}
#admin-add-search:focus { outline: none; border-color: var(--input-focus); box-shadow: 0 0 0 3px var(--input-focus-ring); }
.admin-add-results {
	display: flex; flex-direction: column;
	max-height: 50vh; overflow-y: auto;
	border: 1px solid var(--card-border); border-radius: var(--radius-lg);
}
.admin-add-item {
	display: flex; flex-direction: column; gap: 2px;
	align-items: flex-start; justify-content: center;
	width: 100%; height: auto; text-align: left;
	background: transparent; border: none; border-bottom: 1px solid var(--section-border);
	border-radius: 0; box-shadow: none; padding: 10px 12px; cursor: pointer;
}
.admin-add-item:last-child { border-bottom: none; }
.admin-add-item:hover { background: var(--accent); }
.admin-add-name { font-size: 0.9375rem; color: var(--text-strong); font-weight: 500; }
.admin-add-email { font-size: 0.8125rem; color: var(--text-muted); }
.admin-add-empty { padding: 12px; margin: 0; }

/* All pages/modules share ONE container width for a coherent layout.
   Wide tables scroll horizontally inside .mit-table-wrap rather than
   widening the page, so switching tabs never shifts the body width. */
.mit-dashboard-grid { max-width: none; }

/* Benutzer table: take the full width, everything left-aligned. */
#admin-table { width: 100%; }
#admin-table th, #admin-table td { text-align: left; vertical-align: middle; }
/* "Produkte" restriction — a button (shows the allowed product names) that opens a modal. */
.prod-restrict-btn {
	cursor: pointer; padding: 4px 10px; font-size: 0.8125rem; white-space: normal; text-align: left; max-width: 340px; line-height: 1.3;
	border: 1px solid var(--input-border); border-radius: var(--radius-md); background: var(--input-bg); color: var(--text); box-shadow: none;
}
.prod-restrict-btn:hover:not([disabled]) { border-color: var(--input-focus); }
.prod-restrict-btn[disabled] { opacity: .5; cursor: default; }
.prod-modal-list { margin: 10px 0; max-height: 50vh; overflow-y: auto; display: flex; flex-direction: column; gap: 2px; }
.prod-opt { display: flex; align-items: center; gap: 8px; font-size: 0.875rem; padding: 6px 8px; border-radius: var(--radius-sm); cursor: pointer; }
.prod-opt:hover { background: var(--accent); }

/* ---------- Abonnenten-Views editor ---------- */
.views-list { display: flex; flex-direction: column; gap: 16px; }
.view-card { border: 1px solid var(--border); border-radius: var(--radius); padding: 16px; background: var(--card); }
.view-card-head { display: flex; align-items: center; gap: 10px; margin-bottom: 6px; }
.view-card-head .view-name { flex: 1; font-size: 1rem; font-weight: 600; padding: 6px 8px; }
.view-card-head .view-rowstatus { margin-left: auto; }
.view-subhead { font-size: 0.8125rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--text-muted); margin: 14px 0 6px; }
.view-plans { display: flex; flex-wrap: wrap; gap: 14px; }
.view-plan-group { min-width: 200px; }
.view-plan-prod { font-weight: 600; font-size: 0.8125rem; margin-bottom: 2px; }
.view-tabs { display: flex; flex-direction: column; gap: 10px; }
.view-tab { border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 10px; }
.view-tab-head { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.view-tab-head .view-tab-name { flex: 1; padding: 5px 8px; font-weight: 500; }
.view-tab-crits { display: flex; flex-direction: column; gap: 6px; margin-bottom: 6px; }
.view-crit { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.view-crit select, .view-crit input { padding: 4px 6px; font-size: 0.875rem; }
.view-crit .view-crit-value { flex: 1; min-width: 140px; }
.view-card-actions { margin-top: 12px; display: flex; gap: 8px; }
.view-summary { display: flex; align-items: center; justify-content: space-between; gap: 12px; border: 1px solid var(--border); border-radius: var(--radius); padding: 12px 16px; background: var(--card); }
.view-summary-main { display: flex; flex-direction: column; gap: 2px; }
.view-summary-name { font-weight: 600; }
.view-summary-actions { display: flex; gap: 4px; }
.view-plan-prodhead { display: flex; align-items: center; gap: 8px; padding: 4px 0; }
.view-plan-caret { background: none; border: none; cursor: pointer; color: var(--text-muted); font-size: 0.9rem; width: 18px; padding: 0; }
.view-plan-prodlabel { display: flex; align-items: center; gap: 6px; cursor: pointer; }
.view-plan-plans { padding: 4px 0 8px 26px; display: flex; flex-direction: column; gap: 2px; }
.view-plan-group { border-bottom: 1px solid var(--border); }
.view-plans { display: block; }

/* Websites (SSO) admin panel — uses theme vars so it reads in light AND dark mode */
/* ── SSO website modal — one systematic layout ───────────────────────────────
   Every row: a muted label on top, a full-width control below. Read-only values
   (callback, credentials, endpoints) all share .sso-val-row: value stretches,
   action icons sit inline on the right — never below. Spacing comes from flex
   `gap`, never ad-hoc margins. Title + footer are fixed; only the body scrolls. */
.sso-modal-card { max-width: 760px; width: 94vw; max-height: 90vh; display: flex; flex-direction: column; overflow: hidden; }
.sso-modal-card .sso-form { overflow-y: auto; min-height: 0; padding-right: 6px; }
.sso-modal-card .mit-dialog-actions { border-top: 1px solid var(--card-border); padding-top: 14px; margin-top: 14px; }

.sso-modal-titlebar { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 6px; }
.sso-modal-titlebar .sso-modal-title { margin: 0; }
.sso-copyall { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; border: 1px solid var(--input-border); border-radius: var(--radius-md); background: var(--input-bg); color: var(--text-muted); font: inherit; font-size: 0.8rem; cursor: pointer; white-space: nowrap; }
.sso-copyall:hover { color: var(--text); border-color: var(--ghost-border); }
.sso-copyall svg { width: 15px; height: 15px; }

.sso-form { display: flex; flex-direction: column; gap: 16px; margin: 6px 0 8px; }
.sso-field { display: flex; flex-direction: column; gap: 6px; font-size: 0.875rem; }
.sso-field > span { color: var(--text-muted); font-size: 0.8rem; }
.sso-field > input, .sso-field > textarea, .sso-field > select,
.sso-val-row > input, .sso-val {
	padding: 9px 12px; border: 1px solid var(--input-border); border-radius: var(--radius-sm);
	font: inherit; background: var(--input-bg); color: var(--text); resize: vertical;
}
.sso-field-error { color: var(--destructive); font-size: 0.78rem; line-height: 1.3; min-height: 1.3em; }
.sso-field > input.invalid { border-color: var(--destructive); }
.sso-checks { display: flex; flex-wrap: wrap; gap: 6px 16px; }

/* Read-only value row: stretchy value + inline action icon(s). */
.sso-val-row { display: flex; align-items: center; gap: 8px; }
.sso-val-row > input, .sso-val-row > .sso-val { flex: 1; min-width: 0; }
.sso-val { display: block; font-family: var(--font-mono); font-size: 0.8rem; color: var(--text-muted); word-break: break-all; }
.sso-field > input[readonly], .sso-val-row > input[readonly] { color: var(--text-muted); cursor: default; }

/* Icon-only action button — square, used for copy / edit / reset / regenerate. */
.sso-icon-btn { flex: none; display: inline-flex; align-items: center; justify-content: center; width: 38px; height: 38px; padding: 0; border: 1px solid var(--input-border); border-radius: var(--radius-sm); background: var(--input-bg); color: var(--text-muted); cursor: pointer; }
.sso-icon-btn:hover { color: var(--text); border-color: var(--ghost-border); }
.sso-icon-btn.ok { color: var(--gold-strong); border-color: var(--gold-strong); }

/* Einrichtung group — always visible (no collapsible); separated by a hairline. */
.sso-advanced { display: flex; flex-direction: column; gap: 16px; border-top: 1px solid var(--card-border); padding-top: 16px; margin-top: 2px; }
.sso-modal-instructions { display: flex; flex-direction: column; gap: 16px; }
.sso-modal-instructions > * { margin: 0; }
.sso-fields { display: flex; flex-direction: column; gap: 16px; }

.sso-check-row { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.sso-check-row input { padding: 9px 12px; border: 1px solid var(--input-border); border-radius: var(--radius-sm); font: inherit; background: var(--input-bg); color: var(--text); flex: 1 1 240px; }
.sso-check-result { line-height: 1.6; }
.sso-caveat { padding: 12px 14px; border-left: 3px solid var(--gold-strong); background: var(--gold-tint); border-radius: var(--radius-sm); font-size: 0.82rem; line-height: 1.55; }

/* Tag picker (reusable multi-select with chips + searchable dropdown) */
.tp-chips { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 8px; min-height: 4px; }
.tp-empty { color: var(--text-muted); font-size: 0.8rem; }
.tp-chip { display: inline-flex; align-items: center; gap: 6px; background: var(--ghost-hover-bg); color: var(--text); border: 1px solid var(--card-border); border-radius: 999px; padding: 3px 6px 3px 11px; font-size: 0.82rem; }
.tp-chip-x { border: none; background: none; cursor: pointer; color: var(--text-muted); font-size: 1rem; line-height: 1; padding: 0 2px; border-radius: 999px; }
.tp-chip-x:hover { color: var(--destructive); }
.tp-add-wrap { display: block; }
.tp-add { padding: 6px 12px; border: 1px dashed var(--input-border); border-radius: var(--radius-sm); background: var(--card-bg); color: var(--text); cursor: pointer; font: inherit; font-size: 0.85rem; }
.tp-add:hover { border-style: solid; }
/* In-flow (not absolute) so it can never be clipped by a scrolling modal/panel. */
.tp-pop { margin-top: 6px; width: 100%; max-width: 460px; background: var(--card-bg); border: 1px solid var(--card-border); border-radius: var(--radius); box-shadow: var(--shadow-md, 0 4px 16px rgba(0,0,0,.18)); padding: 8px; box-sizing: border-box; }
.tp-search { width: 100%; box-sizing: border-box; padding: 7px 10px; border: 1px solid var(--input-border); border-radius: var(--radius-sm); font: inherit; background: var(--input-bg); color: var(--text); margin-bottom: 6px; }
.tp-list { max-height: 260px; overflow: auto; }
.tp-group { font-size: 0.72rem; text-transform: uppercase; letter-spacing: .04em; color: var(--text-muted); padding: 8px 6px 3px; }
.tp-opt { display: block; width: 100%; text-align: left; border: none; background: none; cursor: pointer; padding: 7px 8px; border-radius: var(--radius-sm); font: inherit; font-size: 0.85rem; color: var(--text); }
.tp-opt:hover { background: var(--ghost-hover-bg); }
.tp-hint { color: var(--text-muted); font-size: 0.78rem; }
.tp-none { color: var(--text-muted); font-size: 0.82rem; padding: 8px; }

/* Druckauftrag → E-Mails settings */
.mit-email-actions { margin-top: 10px; display: flex; gap: 10px; align-items: center; }
.mit-field-row { display: flex; align-items: center; gap: 10px; margin: 6px 0; }
.mit-field-row > span { font-size: 0.875rem; }
textarea#mit-email-recipients { width: 100%; resize: vertical; font-family: inherit; padding: 6px 8px; }

/* Import Script module */
.imp-step { margin: 12px 0; display: flex; align-items: center; gap: 12px; }
.imp-upload {
	display: inline-flex; align-items: center; gap: 8px;
	padding: 0.55rem 1rem;
	border-radius: var(--radius-md);
	border: 1px solid var(--card-border);
	background: var(--card-bg);
	color: var(--text-strong);
	font-size: 0.9375rem; font-weight: 600;
	cursor: pointer;
	transition: background .15s, border-color .15s, box-shadow .15s;
}
.imp-upload:hover { border-color: var(--ring); background: var(--toggle-hover-bg); }
.imp-upload:focus-within { border-color: var(--ring); box-shadow: 0 0 0 3px var(--ring-soft); }
.imp-upload svg { flex: 0 0 auto; opacity: 0.8; }
.imp-actions { margin: 14px 0; display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.imp-opt { display: flex; align-items: center; gap: 6px; font-size: 0.875rem; }
.imp-req { color: var(--destructive); }
.imp-warn { color: #b07b00; font-size: 0.8125rem; }
#imp-mapping-table select.imp-map { padding: 4px 6px; min-width: 180px; }
.imp-badge { display: inline-block; padding: 2px 8px; border-radius: 999px; font-size: 0.78rem; font-weight: 600; }
.imp-badge.imp-ok { background: #e8f4e8; color: #1e6b32; }
.imp-badge.imp-skip { background: #eee; color: #555; }
.imp-badge.imp-new { background: #e6eefb; color: #2a3f9c; }
.imp-badge.imp-warn { background: #fdf0d5; color: #8a5a00; }
.imp-badge.imp-err { background: #fde8e8; color: #a13030; }
.danger-action { background: var(--destructive, #b8336a); }
/* Step-1 correspondence cell with a per-row Zoho-customer picker */
.imp-corr { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.imp-row-commit, .imp-pick-customer, .imp-pick-plan { padding: 3px 12px; font-size: 0.8rem; }

/* 4-step wizard: progress menu */
.imp-steps { display: flex; gap: 6px; margin: 18px 0; flex-wrap: wrap; }
.imp-stepbtn { display: flex; align-items: center; gap: 8px; padding: 8px 16px; border-radius: 999px; background: var(--card); border: 1px solid var(--border); color: var(--text-muted); font-size: 0.9rem; cursor: pointer; }
.imp-stepbtn .imp-stepno { display: inline-flex; align-items: center; justify-content: center; width: 22px; height: 22px; border-radius: 999px; background: var(--border); color: var(--text); font-size: 0.78rem; font-weight: 700; }
.imp-stepbtn.active { border-color: var(--link-color); color: var(--text); font-weight: 600; }
.imp-stepbtn.active .imp-stepno { background: var(--link-color); color: #fff; }
.imp-nav-actions { display: flex; justify-content: space-between; gap: 12px; margin-top: 18px; }
.imp-nav-actions .imp-next { margin-left: auto; }

/* Import + cleanup tables — full width, same look as the other staff tables */
#imp-cust-table, #imp-sub-table, #imp-plans-table, #cleanup-table {
	width: 100%; border-collapse: collapse; background: var(--card-bg);
}
#imp-cust-table th, #imp-cust-table td,
#imp-sub-table th, #imp-sub-table td,
#imp-plans-table th, #imp-plans-table td,
#cleanup-table th, #cleanup-table td {
	text-align: left; padding: 11px 14px;
	border-bottom: 1px solid var(--section-border);
	font-size: 0.875rem; vertical-align: middle;
}
#imp-cust-table th, #imp-sub-table th, #imp-plans-table th, #cleanup-table th {
	background: var(--muted); font-weight: 500; color: var(--text-muted); font-size: 0.8125rem;
}
#imp-cust-table tbody tr:last-child td, #imp-sub-table tbody tr:last-child td, #imp-plans-table tbody tr:last-child td, #cleanup-table tbody tr:last-child td { border-bottom: none; }
#imp-cust-table tbody tr:hover, #imp-sub-table tbody tr:hover, #imp-plans-table tbody tr:hover, #cleanup-table tbody tr:hover { background: color-mix(in srgb, var(--muted) 60%, transparent); }
.imp-corr { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; justify-content: space-between; }
.imp-corr .imp-pick-customer { margin-left: auto; }

/* Search-picker modal list */
.imp-picker-list { margin: 10px 0; max-height: 56vh; overflow-y: auto; display: flex; flex-direction: column; gap: 2px; }
.imp-picker-item { text-align: left; background: transparent; border: none; border-radius: var(--radius-sm); padding: 8px 10px; cursor: pointer; font-size: 0.875rem; color: var(--text); }
.imp-picker-item:hover { background: var(--accent); }
#imp-picker-search { width: 100%; padding: 8px 10px; }
/* mapping: example navigator + matched grids (horizontal) + not-recognized list */
.imp-example-nav { display: flex; align-items: center; gap: 8px; margin: 6px 0 12px; font-size: 0.85rem; }
.imp-example-nav button { padding: 1px 10px; line-height: 1.4; font-size: 1rem; }
.imp-example-nav button:disabled { opacity: 0.4; cursor: default; }
.imp-group-head { font-size: 0.95rem; margin: 16px 0 6px; }
.imp-fgrid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 4px 28px; }
.imp-frow { display: grid; grid-template-columns: minmax(110px, max-content) auto minmax(120px, 1fr) minmax(0, 1.1fr); align-items: center; gap: 8px; padding: 3px 6px; border-radius: 6px; font-size: 0.85rem; }
.imp-frow:hover { background: rgba(127,127,127,0.06); }
.imp-frow-req { background: rgba(176,123,0,0.10); }
.imp-flabel { white-space: nowrap; font-weight: 500; }
.imp-arrow { color: var(--text-muted); }
.imp-frow select.imp-map { padding: 3px 6px; width: 100%; min-width: 0; font-size: 0.82rem; }
.imp-fsample { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.imp-mok { color: #1e9e4a; font-weight: 700; }
.imp-mdash { color: var(--text-muted); }
@media (max-width: 1100px) { .imp-fgrid { grid-template-columns: 1fr; } }

/* ---------- "Für Mitarbeiter" empty state (staff with no modules) ---------- */
.mit-empty {
	margin: 8px 4px;
	padding: 18px 20px;
	border: 1px dashed var(--gold-tint-border);
	border-radius: var(--radius-xl);
	background: var(--gold-tint);
	color: var(--text-muted, inherit);
	max-width: 640px;
}

/* ---------- Login-Admin sub-panels (Benutzer / Abonnements / Produkte / Pläne / Rechnungen) ---------- */
.admin-subpanel { display: none; }
.admin-subpanel.active { display: block; }
/* invoice / status badge colours reusing the existing palette */
.badge-paid { background: rgb(220 252 231); color: rgb(22 101 52); border-color: rgb(187 247 208); }
.badge-overdue { background: rgb(254 226 226); color: rgb(153 27 27); border-color: rgb(254 202 202); }
html.dark .badge-paid { background: rgba(22,101,52,.25); color: rgb(187 247 208); border-color: rgba(22,101,52,.5); }
html.dark .badge-overdue { background: rgba(153,27,27,.25); color: rgb(254 202 202); border-color: rgba(153,27,27,.5); }

/* Section headings inside the combined "Produkte & Pläne" sub-panel */
.admin-section-title {
	font-family: var(--font-head);
	font-size: 1.05rem; font-weight: 600; margin: 22px 4px 10px;
	color: var(--text-strong);
}
.admin-subpanel > .admin-section-title:first-child { margin-top: 4px; }


/* Öffentliche Module (Login-Admin → Module) */
.pubmods-list { display: flex; flex-direction: column; gap: 4px; max-width: 28rem; }

/* Mitglieder-Abgleich (Admin Tools → Mitglieder-Abgleich) — flat matching table */
#recon-table { width: 100%; border-collapse: collapse; background: var(--card-bg); font-size: 0.875rem; }
#recon-table th, #recon-table td {
	text-align: left; padding: 8px 12px; vertical-align: middle;
	border-bottom: 1px solid var(--section-border);   /* one full horizontal line per row */
}
#recon-table th { background: var(--muted); font-weight: 500; color: var(--text-muted); font-size: 0.8125rem; padding: 11px 12px; }
#recon-table tbody tr:last-child td { border-bottom: none; }
#recon-table td.recon-check, #recon-table th.recon-check { width: 28px; padding-right: 0; }
#recon-table .recon-pick { margin: 0; }
#recon-table td.recon-member-cell { width: 32%; }
.recon-member-head { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
#recon-table td.recon-cand { max-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
#recon-table td.recon-cand strong { margin-right: 6px; }
#recon-table td.recon-cand .muted { margin-right: 6px; }
#recon-table td.recon-tier { white-space: nowrap; width: 1%; }
#recon-table td.recon-actions { white-space: nowrap; width: 1%; text-align: right; }
#recon-table td.recon-actions .recon-icon-btn { margin-right: 6px; }
.recon-icon-btn {
	display: inline-flex; align-items: center; justify-content: center;
	width: 28px; height: 28px; padding: 0; border: 1px solid var(--section-border);
	border-radius: var(--radius-md); background: none; color: inherit; cursor: pointer;
}
.recon-icon-btn:hover { background: rgba(127,127,127,.12); }
.recon-create-open { font-size: 0.8125rem; padding: 3px 10px; }
/* modals */
.recon-picker-bar { display: flex; gap: 8px; margin-top: 8px; }
.recon-picker-bar input { flex: 1 1 auto; }
.recon-search-hit { display: flex; align-items: baseline; gap: 8px; width: 100%; text-align: left; background: none; border: 0; padding: 6px 8px; border-radius: var(--radius-sm, 4px); cursor: pointer; color: inherit; white-space: nowrap; overflow: hidden; }
.recon-search-hit:hover { background: rgba(127,127,127,.12); }
.recon-search-hit > * { overflow: hidden; text-overflow: ellipsis; }
.recon-tier-sure { background: rgb(220 252 231); color: rgb(22 101 52); border-color: rgb(187 247 208); }
.recon-tier-maybe { background: rgb(254 243 199); color: rgb(146 64 14); border-color: rgb(253 230 138); }
html.dark .recon-tier-sure { background: rgba(22,101,52,.25); color: rgb(187 247 208); border-color: rgba(22,101,52,.5); }
html.dark .recon-tier-maybe { background: rgba(146,64,14,.25); color: rgb(253 230 138); border-color: rgba(146,64,14,.5); }
