/**
 * DanubeHandwerk Portal – Kunden-Ansicht.
 *
 * Bewusst helles, sachliches Arbeits-Layout (im Gegensatz zur dunklen
 * Funnel-Landingpage): Das Portal ist ein Werkzeug, keine Werbefläche.
 * Akzentfarben sind mit dem Funnel geteilt (Markenblau #4f9be0).
 */

.dh-portal {
	/* Farbwerte kommen zentral aus dh-brand.css (Fallbacks identisch). */
	--dh-accent: var(--dh-brand-accent, #4f9be0);
	--dh-accent-dark: var(--dh-brand-accent-dark, #2d6faf);
	--dh-accent-soft: rgba(79, 155, 224, 0.12);
	--dh-ink: var(--dh-brand-ink, #1b2836);
	--dh-muted: #64748c;
	--dh-line: #dbe4ee;
	--dh-bg: #ffffff;
	--dh-bg-soft: #f4f7fb;
	--dh-success: #3dae7d;
	--dh-success-soft: rgba(61, 174, 125, 0.14);
	--dh-warn: #b98a2d;
	--dh-warn-soft: rgba(232, 180, 86, 0.2);
	--dh-danger: #c04f4f;
	--dh-danger-soft: rgba(224, 103, 103, 0.14);

	color: var(--dh-ink);
	font-size: var(--dh-fs-base, 16px);
	line-height: 1.6;
	margin: 0 auto;
	max-width: 1080px;
	padding: 1.5rem 0 3rem;
}

/* --- Brand-Kopfzeile --- */

.dh-brandbar {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	justify-content: space-between;
	margin: 0 0 2.25rem;
}

.dh-brandbar--center {
	justify-content: center;
}

.dh-portal *,
.dh-portal *::before,
.dh-portal *::after {
	box-sizing: border-box;
}

/* --- Kopf --- */

.dh-portal-head {
	margin: 0 0 1.75rem;
}

.dh-portal-title {
	font-size: var(--dh-fs-title, 1.7rem);
	font-weight: 700;
	letter-spacing: -0.015em;
	line-height: 1.25;
	margin: 0 0 0.4rem;
}

.dh-portal-sub {
	color: var(--dh-muted);
	margin: 0;
}

/* --- Karten --- */

.dh-card {
	background: var(--dh-bg);
	border: 1px solid var(--dh-line);
	border-radius: var(--dh-radius-lg, 16px);
	padding: 1.75rem 2rem;
}

.dh-card--message {
	margin: 1.5rem 0;
	padding: 2.5rem 2rem;
	text-align: center;
}

.dh-card-title {
	font-size: 1.25rem;
	margin: 0 0 0.5rem;
}

.dh-card-text {
	color: var(--dh-muted);
	margin: 0 0 1rem;
}

.dh-assignment-meta {
	margin: 0 0 1.75rem;
}

.dh-meta-grid {
	display: grid;
	gap: 1.25rem 2.5rem;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	margin: 0;
}

.dh-meta-grid dt {
	color: var(--dh-muted);
	font-size: 0.78rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	margin: 0 0 0.15rem;
	text-transform: uppercase;
}

.dh-meta-grid dd {
	margin: 0;
	white-space: pre-line;
}

/* --- Hinweise --- */

.dh-notice {
	border: 1px solid var(--dh-line);
	border-left-width: 4px;
	border-radius: var(--dh-radius, 10px);
	margin: 0 0 1.75rem;
	padding: 1rem 1.25rem;
}

.dh-notice--success {
	background: var(--dh-success-soft);
	border-left-color: var(--dh-success);
}

.dh-notice--error {
	background: var(--dh-danger-soft);
	border-left-color: var(--dh-danger);
}

.dh-notice--info {
	background: var(--dh-accent-soft);
	border-left-color: var(--dh-accent);
}

/* --- Tabelle --- */

.dh-table-wrap {
	background: var(--dh-bg);
	border: 1px solid var(--dh-line);
	border-radius: var(--dh-radius-lg, 16px);
	margin: 0 0 1.5rem;
	overflow-x: auto;
}

.dh-table {
	border-collapse: collapse;
	margin: 0;
	min-width: 720px;
	width: 100%;
}

.dh-table th,
.dh-table td {
	border-bottom: 1px solid var(--dh-line);
	padding: 1rem 1.25rem;
	text-align: left;
	vertical-align: top;
}

.dh-table thead th {
	background: var(--dh-bg-soft);
	color: var(--dh-muted);
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	white-space: nowrap;
}

.dh-table tbody tr:last-child td {
	border-bottom: 0;
}

.dh-table tbody tr:hover td {
	background: var(--dh-bg-soft);
}

.dh-num {
	text-align: right;
	white-space: nowrap;
}

.dh-table .dh-num {
	text-align: right;
}

.dh-action-col {
	white-space: nowrap;
}

.dh-strong {
	font-weight: 600;
}

.dh-muted {
	color: var(--dh-muted);
}

.dh-small {
	font-size: 0.82rem;
}

/* --- Badges --- */

.dh-badge {
	border-radius: var(--dh-radius-pill, 999px);
	display: inline-block;
	font-size: 0.75rem;
	font-weight: 600;
	margin: 0 0.25rem 0.25rem 0;
	padding: 0.15rem 0.6rem;
	white-space: nowrap;
}

.dh-badge--open {
	background: var(--dh-accent-soft);
	color: var(--dh-accent-dark);
}

.dh-badge--approved {
	background: var(--dh-warn-soft);
	color: var(--dh-warn);
}

.dh-badge--confirmed {
	background: var(--dh-success-soft);
	color: var(--dh-success);
}

.dh-badge--rejected {
	background: var(--dh-danger-soft);
	color: var(--dh-danger);
}

/* --- Buttons --- */

.dh-btn {
	align-items: center;
	border: 1px solid transparent;
	border-radius: var(--dh-radius, 10px);
	cursor: pointer;
	display: inline-flex;
	font-size: var(--dh-fs-btn, 0.95rem);
	font-weight: 600;
	justify-content: center;
	/* Touch-Mindestfläche – auch auf dem Desktop nie "zu klein am Handy". */
	min-height: var(--dh-tap-min, 48px);
	padding: 0.55rem 1.25rem;
	text-decoration: none;
	transition: background-color 0.15s ease, border-color 0.15s ease;
}

.dh-btn--primary {
	background: var(--dh-accent);
	color: #ffffff;
}

.dh-btn--primary:hover,
.dh-btn--primary:focus {
	background: var(--dh-accent-dark);
	color: #ffffff;
}

.dh-btn--ghost {
	background: transparent;
	border-color: var(--dh-line);
	color: var(--dh-ink);
}

.dh-btn--ghost:hover,
.dh-btn--ghost:focus {
	border-color: var(--dh-accent);
	color: var(--dh-accent-dark);
}

/* --- Prüfungs-Formular --- */

.dh-decision {
	border: 0;
	margin: 0;
	min-width: 220px;
	padding: 0;
}

.dh-choice {
	align-items: center;
	cursor: pointer;
	display: inline-flex;
	font-size: 0.85rem;
	gap: 0.3rem;
	margin: 0 0.6rem 0.35rem 0;
}

.dh-choice input {
	accent-color: var(--dh-accent);
	margin: 0;
}

.dh-choice--approve span {
	color: var(--dh-success);
	font-weight: 600;
}

.dh-choice--query span {
	color: var(--dh-danger);
	font-weight: 600;
}

.dh-choice--none span {
	color: var(--dh-muted);
}

.dh-comment {
	border: 1px solid var(--dh-line);
	border-radius: var(--dh-radius, 10px);
	display: block;
	font-size: 0.85rem;
	margin-top: 0.25rem;
	padding: 0.4rem 0.6rem;
	width: 100%;
}

.dh-comment:disabled {
	background: var(--dh-bg-soft);
	opacity: 0.55;
}

.dh-comment.dh-comment--missing {
	border-color: var(--dh-danger);
	box-shadow: 0 0 0 2px var(--dh-danger-soft);
}

.dh-form-foot {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 1.25rem;
	justify-content: space-between;
	margin-top: 1.5rem;
}

.dh-form-foot p {
	flex: 1 1 320px;
	margin: 0;
}

/* --- Signatur (Phase 3) --- */

.dh-sign-card {
	border-left: 4px solid var(--dh-success);
	margin-top: 2rem;
}

.dh-sign-pad {
	margin: 1.5rem 0;
}

.dh-sign-canvas {
	background: #fff;
	border: 2px dashed var(--dh-line);
	border-radius: var(--dh-radius, 10px);
	cursor: crosshair;
	display: block;
	touch-action: none;
	width: 100%;
}

.dh-sign-canvas:focus,
.dh-sign-canvas:hover {
	border-color: var(--dh-accent);
}

.dh-sign-hint {
	margin: 0.35rem 0 0;
	text-align: center;
}

.dh-sign-actions {
	display: inline-flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.dh-btn--confirm {
	background: var(--dh-success);
	color: #ffffff;
}

.dh-btn--confirm:hover:not(:disabled),
.dh-btn--confirm:focus:not(:disabled) {
	background: #2c8763;
	color: #ffffff;
}

.dh-btn:disabled {
	cursor: not-allowed;
	opacity: 0.45;
}

.dh-protocol-link {
	display: flex;
	flex-wrap: wrap;
	gap: 0.6rem;
	margin-top: 1.5rem;
}

/* --- Registrierung --- */

.dh-portal--narrow {
	max-width: 560px;
}

.dh-field {
	margin: 0 0 1.1rem;
}

.dh-field label {
	display: block;
	font-size: 0.88rem;
	font-weight: 600;
	margin: 0 0 0.3rem;
}

.dh-field input,
.dh-field select {
	background: #fff;
	border: 1px solid var(--dh-line);
	border-radius: var(--dh-radius, 10px);
	color: var(--dh-ink);
	font-size: 1rem;
	padding: 0.55rem 0.75rem;
	width: 100%;
}

.dh-field input:focus,
.dh-field select:focus {
	border-color: var(--dh-accent);
	box-shadow: 0 0 0 3px var(--dh-accent-soft);
	outline: none;
}

.dh-field p {
	margin: 0.3rem 0 0;
}

.dh-req {
	color: var(--dh-danger);
}

/* Honeypot: aus dem Viewport, nicht display:none (manche Bots prüfen das). */
.dh-hp {
	left: -9999px;
	margin: 0;
	position: absolute;
	top: -9999px;
}

/* --- Mitarbeiter-Cockpit: Nachtblau-Industrie-Look, Mobile-First ---
 * Baustellen-tauglich: sehr große Bedienflächen, hoher Kontrast
 * (Sonnenlicht), Zahlen groß und fett. Farbwelt = Funnel-Nachtblau. */

.dh-worker {
	max-width: 640px;
}

.dh-worker-week {
	background: #122036;
	border: 1px solid rgba(148, 178, 209, 0.32);
	border-radius: var(--dh-radius-pill, 999px);
	color: #c2cfdd;
	font-size: 0.95rem;
	padding: 0.55rem 1.1rem;
	white-space: nowrap;
}

.dh-worker-week strong {
	color: #ffffff;
	font-size: 1.1rem;
}

.dh-wcard {
	background: linear-gradient(168deg, #122036 0%, #0c1626 55%, #070d17 100%);
	border: 1px solid rgba(148, 178, 209, 0.28);
	border-radius: var(--dh-radius-lg, 16px);
	color: #eef3f9;
	margin: 0 0 1.5rem;
	padding: 1.6rem 1.4rem;
}

.dh-wcard--empty {
	font-size: 1.15rem;
	text-align: center;
}

.dh-wtitle {
	color: #ffffff;
	font-size: 1.3rem;
	font-weight: 700;
	letter-spacing: 0.01em;
	margin: 0 0 1.1rem;
}

.dh-wmuted {
	color: #8fa3b8;
	font-weight: 400;
}

.dh-wmeta {
	display: grid;
	gap: 1rem 1.5rem;
	margin: 0;
}

.dh-wmeta dt {
	color: #8fa3b8;
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	margin: 0 0 0.2rem;
	text-transform: uppercase;
}

.dh-wmeta dd {
	font-size: 1.05rem;
	margin: 0;
	white-space: pre-line;
}

@media (min-width: 480px) {
	.dh-wmeta {
		grid-template-columns: 1fr 1fr;
	}
}

.dh-wlabel {
	color: #8fa3b8;
	display: block;
	font-size: 0.8rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	margin: 1.1rem 0 0.45rem;
	text-transform: uppercase;
}

.dh-winput {
	background: #0e1b2e;
	border: 2px solid rgba(148, 178, 209, 0.4);
	border-radius: var(--dh-radius, 10px);
	color: #ffffff;
	color-scheme: dark;
	font-size: 1.3rem;
	min-height: 58px;
	padding: 0.85rem 1rem;
	width: 100%;
}

.dh-winput:focus {
	border-color: #4f9be0;
	box-shadow: 0 0 0 3px rgba(79, 155, 224, 0.35);
	outline: none;
}

.dh-winput--hours {
	font-size: 1.7rem;
	font-weight: 800;
	text-align: center;
}

.dh-hour-chips {
	display: grid;
	gap: 0.55rem;
	grid-template-columns: repeat(4, 1fr);
	margin: 0 0 0.55rem;
}

.dh-chip {
	background: #182b44;
	border: 2px solid rgba(148, 178, 209, 0.4);
	border-radius: var(--dh-radius, 10px);
	color: #c2cfdd;
	cursor: pointer;
	font-size: 1.15rem;
	font-weight: 700;
	min-height: 56px;
	padding: 0.4rem;
}

.dh-chip.is-active,
.dh-chip:active {
	background: #4f9be0;
	border-color: #7cbcf2;
	color: #ffffff;
}

.dh-wsubmit {
	background: #4f9be0;
	border: 0;
	border-radius: var(--dh-radius-lg, 16px);
	color: #ffffff;
	cursor: pointer;
	font-size: 1.3rem;
	font-weight: 800;
	letter-spacing: 0.03em;
	margin-top: 1.4rem;
	min-height: 72px;
	text-transform: uppercase;
	width: 100%;
}

.dh-wsubmit:hover:not(:disabled),
.dh-wsubmit:focus:not(:disabled) {
	background: #2d6faf;
}

.dh-wsubmit:disabled {
	cursor: wait;
	opacity: 0.6;
}

.dh-wfeedback {
	border-radius: var(--dh-radius, 10px);
	font-size: 1.15rem;
	font-weight: 600;
	margin-top: 1.1rem;
	padding: 1.1rem 1.2rem;
}

.dh-wfeedback--ok {
	background: rgba(61, 174, 125, 0.18);
	border: 2px solid #3dae7d;
	color: #7fe0b4;
}

.dh-wfeedback--err {
	background: rgba(224, 103, 103, 0.16);
	border: 2px solid #e06767;
	color: #ffb3b3;
}

.dh-wlist {
	list-style: none;
	margin: 0;
	padding: 0;
}

.dh-wlist li {
	align-items: center;
	border-bottom: 1px solid rgba(148, 178, 209, 0.18);
	display: flex;
	flex-wrap: wrap;
	gap: 0.6rem;
	justify-content: space-between;
	padding: 0.85rem 0;
}

.dh-wlist-date {
	font-weight: 700;
}

.dh-wlist-hours {
	font-size: 1.15rem;
	font-variant-numeric: tabular-nums;
	font-weight: 800;
}

.dh-wlist-empty {
	color: #8fa3b8;
}

/* Badges auf dunklem Grund: hellere Textfarben für Kontrast. */
.dh-worker .dh-badge--open {
	background: rgba(79, 155, 224, 0.2);
	color: #7cbcf2;
}

.dh-worker .dh-badge--approved {
	background: rgba(232, 180, 86, 0.2);
	color: #ffd48a;
}

.dh-worker .dh-badge--confirmed {
	background: rgba(61, 174, 125, 0.2);
	color: #7fe0b4;
}

.dh-worker .dh-badge--rejected {
	background: rgba(224, 103, 103, 0.22);
	color: #ffb3b3;
}

/* --- Mobil: Tabelle als gestapelte Karten --- */

@media (max-width: 719px) {
	.dh-portal {
		padding: 1rem 0.25rem 2rem;
	}

	.dh-card {
		padding: 1.25rem 1.1rem;
	}

	.dh-brandbar {
		margin-bottom: 1.5rem;
	}

	.dh-table {
		min-width: 0;
	}

	.dh-table thead {
		display: none;
	}

	.dh-table tbody tr {
		border-bottom: 6px solid var(--dh-bg-soft);
		display: block;
		padding: 0.5rem 0;
	}

	.dh-table tbody td {
		border: 0;
		display: block;
		padding: 0.35rem 1rem;
		text-align: left;
	}

	.dh-table tbody td::before {
		color: var(--dh-muted);
		content: attr(data-label);
		display: block;
		font-size: 0.72rem;
		font-weight: 700;
		letter-spacing: 0.05em;
		text-transform: uppercase;
	}

	.dh-num {
		text-align: left;
	}

	.dh-action-col {
		white-space: normal;
	}
}

/* --- Trust-Section (Fußzeile der Portal-Ansichten) --- */

.dh-trust {
	align-items: center;
	border-top: 1px solid var(--dh-line, #dbe4ee);
	color: var(--dh-muted, #64748c);
	display: flex;
	flex-wrap: wrap;
	font-size: 0.82rem;
	gap: 0.5rem 1.5rem;
	justify-content: center;
	margin-top: 3rem;
	padding-top: 1.5rem;
	text-align: center;
}

.dh-trust-item {
	align-items: center;
	display: inline-flex;
	gap: 0.4rem;
	white-space: nowrap;
}

.dh-trust-item svg {
	flex: none;
	height: 14px;
	opacity: 0.7;
	width: 14px;
}

/* Im dunklen Mitarbeiter-Cockpit: helle Variante. */
.dh-worker .dh-trust {
	border-top-color: rgba(148, 178, 209, 0.25);
	color: #8fa3b8;
}

/* --- DANUBE-Logik-Engine (v2.8.0) --- */

.dh-site-form {
	margin: 0 0 1.75rem;
}

.dh-site-form .dh-field textarea {
	background: #fff;
	border: 1px solid var(--dh-line);
	border-radius: var(--dh-radius, 10px);
	color: var(--dh-ink);
	font-size: 1rem;
	padding: 0.55rem 0.75rem;
	width: 100%;
}

.dh-whead {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 0.6rem;
	justify-content: space-between;
	margin: 0 0 1rem;
}

.dh-whead .dh-wtitle {
	margin: 0;
}

.dh-wactions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.6rem;
	margin-top: 1.25rem;
}

.dh-wactions .dh-waction {
	flex: 1 1 200px;
	min-height: 56px;
}

.dh-worker .dh-btn--confirm {
	background: var(--dh-success, #3dae7d);
	color: #ffffff;
}

.dh-worker .dh-btn--confirm:hover:not(:disabled) {
	background: #2c8763;
}

.dh-wdelete {
	background: rgba(224, 103, 103, 0.16);
	border: 2px solid #e06767;
	border-radius: var(--dh-radius, 10px);
	color: #ffb3b3;
	cursor: pointer;
	font-size: 1rem;
	font-weight: 700;
	line-height: 1;
	min-height: 44px;
	min-width: 44px;
	padding: 0.4rem;
}

.dh-wdelete:hover:not(:disabled) {
	background: rgba(224, 103, 103, 0.3);
}

/* Header-Logo-Styles (SVG-Signet) liegen site-weit in dh-brand.css. */
