/**
 * Tenant Dashboard - paquse Data Insights CI Design
 *
 * Unified design matching Power BI reports
 * Based on paquse Corporate Identity: Navy #0F172A + Pink #DD183B
 *
 * @package Paquse Custom Theme
 * @since 1.2.0
 */

/* =================================================================
   CSS VARIABLES - Matching paquse Data Insights Design System
   ================================================================= */

:root {
	/* Brand Colors */
	--paquse-pink: #DD183B;
	--paquse-navy: #0F172A;
	--paquse-navy-light: #1E293B;

	/* Background Colors */
	--dashboard-bg: #F8F9FA;
	--dashboard-card-bg: #FFFFFF;
	--dashboard-border: #E2E8F0;
	--dashboard-text: #1E293B;
	--dashboard-text-light: #64748B;
	--dashboard-hover: #F1F5F9;

	/* Shadows (matching Data Insights) */
	--box-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
	--box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
	--box-shadow-hover: 0 4px 12px rgba(0, 0, 0, 0.10);
	--box-shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.12);

	/* Spacing */
	--spacing-xs: 0.5rem;
	--spacing-sm: 1rem;
	--spacing-md: 1.5rem;
	--spacing-lg: 2rem;
	--spacing-xl: 3rem;

	/* Border Radius (matching Data Insights) */
	--border-radius-sm: 4px;
	--border-radius: 8px;
	--border-radius-lg: 12px;

	/* Tenant Branding (fallbacks) */
	--tenant-primary: var(--paquse-navy);
	--tenant-secondary: var(--paquse-pink);
}

/* =================================================================
   DASHBOARD CONTAINER
   ================================================================= */

.tenant-dashboard {
	background: var(--dashboard-bg);
	min-height: calc(100vh - 80px);
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

.tenant-dashboard .site-main {
	padding: 0;
	max-width: 1600px;
	margin: 0 auto;
}

/* =================================================================
   DASHBOARD HEADER - With paquse Branding
   ================================================================= */

.dashboard-header {
	background: var(--dashboard-card-bg);
	padding: var(--spacing-lg) var(--spacing-xl);
	border-bottom: 3px solid var(--paquse-pink);
	margin-bottom: var(--spacing-xl);
	box-shadow: var(--box-shadow);
	position: relative;
}

/* paquse Logo - added via PHP template */
.paquse-brand-logo {
	height: 50px;
	width: auto;
	margin-right: var(--spacing-md);
}

.header-container {
	max-width: 1600px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--spacing-lg);
	flex-wrap: wrap;
}

.header-branding {
	display: flex;
	align-items: center;
	gap: var(--spacing-md);
	flex: 1;
}

.tenant-logo {
	max-width: 120px;
	max-height: 60px;
	width: auto;
	height: auto;
	object-fit: contain;
}

.header-text {
	flex: 1;
}

.dashboard-title {
	font-size: 1.75rem;
	font-weight: 700;
	margin: 0 0 var(--spacing-xs) 0;
	color: var(--tenant-primary, var(--paquse-navy));
	display: flex;
	align-items: baseline;
	gap: var(--spacing-sm);
}

/* Dashboard Version Badge (optional) */
.dashboard-title::after {
	content: '';
	font-size: 0.875rem;
	font-weight: 400;
	color: var(--dashboard-text-light);
	background: var(--dashboard-hover);
	padding: 0.25rem 0.75rem;
	border-radius: var(--border-radius);
}

.dashboard-subtitle {
	font-size: 1rem;
	color: var(--dashboard-text-light);
	margin: 0;
	line-height: 1.5;
}

.header-actions {
	display: flex;
	gap: var(--spacing-sm);
}

/* =================================================================
   BUTTONS - Matching Data Insights Style
   ================================================================= */

.btn {
	display: inline-flex;
	align-items: center;
	gap: var(--spacing-xs);
	padding: 0.75rem 1.5rem;
	font-size: 1rem;
	font-weight: 600;
	text-decoration: none;
	border-radius: var(--border-radius);
	transition: all 0.2s ease;
	border: none;
	cursor: pointer;
	box-shadow: var(--box-shadow-sm);
}

.btn-primary {
	background: var(--paquse-pink);
	color: white;
}

.btn-primary:hover {
	background: var(--paquse-navy);
	transform: translateY(-1px);
	box-shadow: var(--box-shadow);
	color: white;
}

.btn-secondary {
	background: var(--tenant-secondary, var(--paquse-pink));
	color: white;
}

.btn-secondary:hover {
	background: var(--paquse-navy);
	transform: translateY(-1px);
	box-shadow: var(--box-shadow);
	color: white;
}

/* =================================================================
   DASHBOARD STATS - KPI Cards
   ================================================================= */

.dashboard-stats {
	padding: 0 var(--spacing-xl) var(--spacing-xl);
}

.stats-container {
	max-width: 1600px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: var(--spacing-lg);
}

.stat-card {
	background: var(--dashboard-card-bg);
	padding: var(--spacing-lg);
	border-radius: var(--border-radius-lg);
	box-shadow: var(--box-shadow);
	border-left: 4px solid var(--paquse-pink);
	transition: all 0.3s ease;
	text-align: center;
}

.stat-card:hover {
	transform: translateY(-2px);
	box-shadow: var(--box-shadow-lg);
}

.stat-icon {
	font-size: 2.5rem;
	margin-bottom: var(--spacing-xs);
}

.stat-value {
	font-size: 2rem;
	font-weight: 700;
	color: var(--tenant-primary, var(--paquse-navy));
	margin-bottom: var(--spacing-xs);
}

.stat-label {
	font-size: 0.875rem;
	color: var(--dashboard-text-light);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	font-weight: 600;
}

/* =================================================================
   PRODUCTS SECTION
   ================================================================= */

.dashboard-products {
	padding: var(--spacing-xl);
	background: var(--dashboard-bg);
}

.products-container {
	max-width: 1600px;
	margin: 0 auto;
}

.section-title {
	font-size: 1.75rem;
	font-weight: 700;
	margin-bottom: var(--spacing-xl);
	color: var(--dashboard-text);
}

.products-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: var(--spacing-xl);
}

.dashboard-products {
	overflow-x: hidden;
}

.product-card {
	background: var(--dashboard-card-bg);
	padding: var(--spacing-lg);
	border-radius: var(--border-radius-lg);
	box-shadow: var(--box-shadow);
	transition: all 0.3s ease;
	border: 1px solid var(--dashboard-border);
}

.product-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--box-shadow-lg);
	border-color: var(--paquse-pink);
}

/* Product Header */
.product-header {
	display: flex;
	align-items: center;
	gap: var(--spacing-md);
	margin-bottom: var(--spacing-md);
	padding-bottom: var(--spacing-md);
	border-bottom: 2px solid var(--dashboard-border);
}

.product-icon-badge {
	font-size: 48px;
	width: 48px;
	height: 48px;
	flex-shrink: 0;
	color: var(--paquse-pink);
}

.product-name {
	font-size: 1.5rem;
	font-weight: 700;
	margin: 0;
	color: var(--dashboard-text);
	flex: 1;
}

.product-description {
	font-size: 1rem;
	line-height: 1.6;
	color: var(--dashboard-text-light);
	margin-bottom: var(--spacing-md);
}

/* Product Metadata (Plan Info & Price) */
.product-meta {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding-top: var(--spacing-md);
	padding-bottom: var(--spacing-md);
	border-top: 1px solid var(--dashboard-border);
	margin-bottom: 0;
	gap: var(--spacing-md);
	flex-wrap: wrap;
}

.plan-info {
	font-size: 0.95rem;
	color: var(--dashboard-text-light);
	flex: 1;
}

.plan-price {
	font-size: 1.125rem;
	font-weight: 700;
	white-space: nowrap;
	color: var(--paquse-pink);
}

/* =================================================================
   DATA INSIGHTS APPS GRID
   ================================================================= */

.product-apps {
	margin-top: var(--spacing-md);
	padding-top: var(--spacing-md);
	border-top: 2px solid var(--dashboard-border);
}

.product-apps h4 {
	font-size: 1rem;
	font-weight: 600;
	margin-bottom: var(--spacing-md);
	color: var(--dashboard-text);
	text-transform: uppercase;
	letter-spacing: 0.025em;
}

.apps-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
	gap: 0.75rem;
}

.app-item {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: var(--spacing-md);
	background: var(--dashboard-hover);
	border-radius: var(--border-radius);
	text-decoration: none;
	transition: all 0.2s ease;
	border: 1px solid transparent;
	text-align: center;
	min-height: 100px;
}

.app-item:hover {
	background: white;
	border-color: var(--paquse-pink);
	transform: translateY(-2px);
	box-shadow: var(--box-shadow);
	text-decoration: none;
}

.app-item .dashicons {
	font-size: 32px;
	width: 32px;
	height: 32px;
	margin-bottom: var(--spacing-xs);
	color: var(--paquse-pink);
}

.app-item span:not(.dashicons) {
	font-size: 0.85rem;
	font-weight: 600;
	color: var(--dashboard-text);
	line-height: 1.3;
}

.app-item:hover span:not(.dashicons) {
	color: var(--paquse-pink);
}

.no-apps-message {
	padding: var(--spacing-md);
	background: var(--dashboard-hover);
	border-radius: var(--border-radius);
	text-align: center;
	font-size: 0.9rem;
	color: var(--dashboard-text-light);
}

/* =================================================================
   NO PRODUCTS MESSAGE
   ================================================================= */

.no-products {
	color: var(--dashboard-text-light);
	font-style: italic;
	text-align: center;
	padding: var(--spacing-xl);
	background: var(--dashboard-card-bg);
	border-radius: var(--border-radius-lg);
	box-shadow: var(--box-shadow);
}

/* =================================================================
   TENANT DETAILS SECTION
   ================================================================= */

.dashboard-tenant-info {
	padding: var(--spacing-xl);
	background: var(--dashboard-card-bg);
	border-top: 1px solid var(--dashboard-border);
	box-shadow: var(--box-shadow);
}

.tenant-info-container {
	max-width: 1600px;
	margin: 0 auto;
}

.tenant-details {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: var(--spacing-lg);
	padding: var(--spacing-md);
	background: var(--dashboard-hover);
	border-radius: var(--border-radius-lg);
}

.detail-item {
	padding: var(--spacing-sm);
	line-height: 1.6;
}

.detail-item strong {
	display: block;
	margin-bottom: var(--spacing-xs);
	color: var(--dashboard-text);
	font-weight: 600;
	font-size: 0.875rem;
	text-transform: uppercase;
	letter-spacing: 0.025em;
}

.detail-item a {
	color: var(--paquse-pink);
	text-decoration: none;
	font-weight: 500;
}

.detail-item a:hover {
	color: var(--paquse-navy);
	text-decoration: underline;
}

/* =================================================================
   RESPONSIVE DESIGN
   ================================================================= */

@media (max-width: 1024px) {

	.dashboard-header,
	.dashboard-stats,
	.dashboard-products,
	.dashboard-tenant-info {
		padding-left: var(--spacing-lg);
		padding-right: var(--spacing-lg);
	}

	.products-grid {
		grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	}
}

@media (max-width: 768px) {
	.header-container {
		flex-direction: column;
		align-items: flex-start;
	}

	.header-branding {
		flex-direction: column;
		align-items: flex-start;
	}

	.dashboard-title {
		font-size: 1.25rem;
	}

	.header-actions {
		width: 100%;
	}

	.header-actions .btn {
		flex: 1;
		justify-content: center;
	}

	.stats-container {
		grid-template-columns: 1fr;
	}

	.products-grid {
		grid-template-columns: 1fr;
	}

	.section-title {
		font-size: 1.5rem;
	}

	.tenant-details {
		grid-template-columns: 1fr;
	}

	.apps-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.product-meta {
		flex-direction: column;
		align-items: flex-start;
	}

	.plan-price {
		align-self: flex-start;
	}
}

@media (max-width: 480px) {

	.dashboard-header,
	.dashboard-stats,
	.dashboard-products,
	.dashboard-tenant-info {
		padding-left: var(--spacing-sm);
		padding-right: var(--spacing-sm);
	}

	.dashboard-title {
		font-size: 1.125rem;
	}

	.tenant-logo {
		max-width: 100px;
		max-height: 50px;
	}

	.product-name {
		font-size: 1.25rem;
	}

	.apps-grid {
		grid-template-columns: 1fr;
	}

	.product-header {
		flex-direction: column;
		align-items: flex-start;
		gap: var(--spacing-sm);
	}

	.product-icon-badge {
		font-size: 40px;
		width: 40px;
		height: 40px;
	}
}

/* =================================================================
   ANIMATIONS - Matching Data Insights
   ================================================================= */

@keyframes fadeInUp {
	from {
		opacity: 0;
		transform: translateY(20px);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.dashboard-header,
.stat-card,
.product-card,
.dashboard-tenant-info {
	animation: fadeInUp 0.5s ease-out;
}

.dashboard-header {
	animation-delay: 0.1s;
}

.stat-card:nth-child(1) {
	animation-delay: 0.2s;
}

.stat-card:nth-child(2) {
	animation-delay: 0.3s;
}

.stat-card:nth-child(3) {
	animation-delay: 0.4s;
}

.product-card:nth-child(1) {
	animation-delay: 0.2s;
}

.product-card:nth-child(2) {
	animation-delay: 0.3s;
}

/* =================================================================
   TOUCH DEVICE OVERRIDES (M-T-06)
   Hover-Effekte auf Touch-Geräten deaktivieren — verhindert
   Tap-Aufflackern bei TouchEnd-Events
   ================================================================= */

@media (hover: none) and (pointer: coarse) {
	.product-card:hover,
	.stat-card:hover,
	.app-item:hover,
	.btn:hover,
	.btn-primary:hover,
	.btn-secondary:hover {
		transform: none;
		box-shadow: var(--box-shadow);
	}

	.product-card:hover {
		border-color: var(--dashboard-border);
	}

	.app-item:hover {
		background: var(--dashboard-hover);
		border-color: transparent;
	}
}

/* =================================================================
   HEADER BREAKPOINT-LÜCKE 481–767px SCHLIESSEN (M-T-11)
   Zwischen max-width: 768px und max-width: 480px wurde Header-Padding
   nicht reduziert — große Lücke auf typischen Smartphone-Breiten.
   ================================================================= */

@media (max-width: 768px) {
	.dashboard-header {
		padding: var(--spacing-md) var(--spacing-lg) !important;
	}
}

/* =================================================================
   SMARTPHONE DASHBOARD — Touch-Geräte kompakt (M-T-13)
   Dashboard-Header und Stats auf schmalen Phones verdichten.
   ================================================================= */

@media (hover: none) and (pointer: coarse) {

    /* ── Header: einzeilig mit Icon + Titel nebeneinander ─────── */
    .dashboard-header {
        padding: 12px 16px !important;
        margin-bottom: 12px !important;
    }

    .header-container {
        flex-direction: row !important;
        align-items: center !important;
        gap: 12px !important;
        flex-wrap: nowrap !important;
    }

    .header-branding {
        flex-direction: row !important;
        align-items: center !important;
        gap: 10px !important;
        flex: 1 !important;
        min-width: 0 !important;
    }

    /* Externes paquse-Logo (fulllogo) auf Mobile ausblenden —
       die Marke ist durch die Nav-Bar bereits erkennbar */
    .paquse-brand-logo {
        display: none !important;
    }

    /* Tenant-Logo klein halten */
    .tenant-logo {
        max-width: 36px !important;
        max-height: 36px !important;
        flex-shrink: 0 !important;
    }

    .tenant-logo-placeholder {
        font-size: 32px !important;
        width: 32px !important;
        height: 32px !important;
        flex-shrink: 0 !important;
    }

    .header-text {
        min-width: 0 !important;
    }

    .dashboard-title {
        font-size: 1rem !important;
        margin: 0 !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        display: block !important;   /* kein ::after Badge auf Mobile */
    }

    .dashboard-title::after {
        display: none !important;
    }

    /* Subtitle auf Mobile ausblenden — spart ~40px */
    .dashboard-subtitle {
        display: none !important;
    }

    /* Action-Buttons: kompakt in einer Zeile */
    .header-actions {
        width: auto !important;
        flex-shrink: 0 !important;
    }

    .header-actions .btn {
        flex: unset !important;
        padding: 8px 12px !important;
        font-size: 0.8rem !important;
    }

    /* ── Stats: 2-spaltig auf schmalen Phones ─────────────────── */
    .stats-container {
        grid-template-columns: 1fr 1fr !important;
        gap: 10px !important;
    }

    .stat-card {
        padding: 14px 12px !important;
    }

    .stat-icon {
        font-size: 1.5rem !important;
        margin-bottom: 4px !important;
    }

    .stat-value {
        font-size: 1.4rem !important;
        margin-bottom: 2px !important;
    }

    .stat-label {
        font-size: 0.7rem !important;
    }

    /* Breadcrumb auf Mobile kompakter */
    .pdi-breadcrumb[style*="margin"] {
        margin: 8px 16px 0 !important;
    }
}

/* =================================================================
   APP-ITEM MIN-HEIGHT AUF MOBILE REDUZIEREN (M-T-12)
   Reduziert Scroll-Aufwand auf kleinen Screens — Apps-Grid-Kacheln
   müssen auf Mobile nicht so viel Platz einnehmen.
   ================================================================= */

@media (max-width: 768px) {
	.app-item {
		min-height: 72px;
		padding: var(--spacing-xs) var(--spacing-sm);
	}

	.app-item .dashicons {
		font-size: 24px;
		width: 24px;
		height: 24px;
	}
}

.product-card:nth-child(3) {
	animation-delay: 0.4s;
}

/* =================================================================
   ACCESSIBILITY
   ================================================================= */

.btn:focus-visible,
.app-item:focus-visible,
.detail-item a:focus-visible {
	outline: 2px solid var(--paquse-pink);
	outline-offset: 2px;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {

	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
	}
}

/* =================================================================
   LEGACY SUPPORT (deprecated styles)
   ================================================================= */

.product-icon {
	width: 64px;
	height: 64px;
	margin-bottom: var(--spacing-md);
	color: var(--tenant-primary, var(--paquse-navy));
}

.product-icon svg {
	width: 100%;
	height: 100%;
}

.product-title {
	font-size: 1.5rem;
	font-weight: 700;
	margin-bottom: var(--spacing-sm);
	color: var(--tenant-primary, var(--dashboard-text));
}

.product-reports h4 {
	font-size: 1rem;
	font-weight: 600;
	margin-bottom: var(--spacing-xs);
	color: var(--dashboard-text);
}

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

.report-list li {
	padding: var(--spacing-xs) 0;
	border-bottom: 1px solid var(--dashboard-border);
}

.report-list li:last-child {
	border-bottom: none;
}

.report-list a {
	color: var(--paquse-pink);
	text-decoration: none;
	font-weight: 500;
	transition: color 0.3s ease;
}

.report-list a:hover {
	color: var(--paquse-navy);
	text-decoration: underline;
}

.no-reports {
	color: var(--dashboard-text-light);
	font-style: italic;
	text-align: center;
	padding: var(--spacing-lg);
}

/* =================================================================
   PDI DATA INSIGHTS — Compact Card Trigger
   ================================================================= */

/* Card section: separator */
.product-pdi.product-pdi--compact {
	margin-top: var(--spacing-md);
	padding-top: var(--spacing-md);
	border-top: 2px solid var(--dashboard-border);
}

/* Full-width trigger button */
.pdi-panel-trigger {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	padding: 12px 14px;
	background: var(--dashboard-hover);
	border: 1px solid var(--dashboard-border);
	border-radius: var(--border-radius);
	cursor: pointer;
	font-family: inherit;
	text-align: left;
	transition: background 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}

.pdi-panel-trigger:hover {
	background: #fff;
	border-color: var(--paquse-pink);
	box-shadow: 0 2px 8px rgba(221,24,59,.08);
}

.pdi-panel-trigger-left {
	display: flex;
	align-items: center;
	gap: 10px;
}

.pdi-panel-trigger-icon {
	font-size: 1.1rem;
	flex-shrink: 0;
}

.pdi-panel-trigger-info {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.pdi-panel-trigger-label {
	font-size: 0.7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--dashboard-text);
}

.pdi-panel-trigger-sub {
	font-size: 0.75rem;
	color: var(--dashboard-text-light);
	font-weight: 400;
}

.pdi-panel-trigger-sub.status-ok      { color: #166534; }
.pdi-panel-trigger-sub.status-warning { color: #92400e; }
.pdi-panel-trigger-sub.status-error   { color: #991b1b; }

.pdi-panel-trigger-arrow {
	font-size: 1.25rem;
	color: var(--dashboard-text-light);
	transition: transform 0.2s ease, color 0.15s ease;
	line-height: 1;
}

.pdi-panel-trigger:hover .pdi-panel-trigger-arrow {
	transform: translateX(3px);
	color: var(--paquse-pink);
}

/* =================================================================
   PDI BUTTONS & SHARED ELEMENTS
   ================================================================= */

/* Refresh button */
.pdi-btn {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	padding: 8px 18px;
	border-radius: var(--border-radius-sm);
	font-size: 0.85rem;
	font-weight: 600;
	cursor: pointer;
	border: 1px solid var(--paquse-pink);
	background: var(--paquse-pink);
	color: #fff;
	transition: background 0.2s ease, border-color 0.2s ease;
	line-height: 1.5;
	white-space: nowrap;
	flex-shrink: 0;
	font-family: inherit;
}

.pdi-btn:hover:not(:disabled) {
	background: #b8102e;
	border-color: #b8102e;
}

.pdi-btn:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}

/* Report toggle link-button */
.pdi-link-btn {
	background: none;
	border: none;
	padding: 0;
	font-size: 0.82rem;
	color: var(--paquse-pink);
	cursor: pointer;
	font-weight: 500;
	text-decoration: underline;
	text-underline-offset: 2px;
	font-family: inherit;
}

.pdi-link-btn:hover { color: #b8102e; }

.product-pdi-report-toggle {
	display: flex;
	align-items: center;
	gap: 16px;
	flex-wrap: wrap;
	margin-bottom: 16px;
}

/* Status shared */
.pdi-status-row    { margin-bottom: 4px; }

.pdi-status-inline {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 0.85rem;
	font-weight: 600;
	flex-wrap: wrap;
}

.pdi-status-icon   { font-style: normal; }

.pdi-status-refresh {
	color: var(--dashboard-text-light);
	font-weight: 400;
	font-size: 0.78rem;
}

.pdi-status--ok      { color: #166534; }
.pdi-status--warning { color: #92400e; }
.pdi-status--error   { color: #991b1b; }

.pdi-status-help {
	display: inline;
	background: none;
	border: none;
	padding: 0;
	margin: 0;
	font-size: 0.75rem;
	color: var(--dashboard-text-light);
	text-decoration: underline;
	text-underline-offset: 2px;
	cursor: pointer;
	font-family: inherit;
}

.pdi-status-help:hover { color: var(--dashboard-text); }

.pdi-status-row--schedule {
	margin-top: 4px;
}

.pdi-schedule-rel {
	font-weight: 400;
	color: var(--dashboard-text-light);
}

.pdi-schedule-expr {
	margin-left: 6px;
	font-family: monospace;
	font-size: 0.72rem;
	color: var(--dashboard-text-light);
	opacity: 0.7;
}

/* =================================================================
   DATA INTEGRATION PAGE (page-data-integration.php)
   ================================================================= */

/* Page Header */
.di-page-header {
	background: var(--paquse-navy);
	padding: 20px var(--spacing-xl) 24px;
	border-bottom: 3px solid var(--paquse-pink);
}

.di-page-header-inner {
	max-width: 900px;
	margin: 0 auto;
}

/* FIX-14: Breadcrumb-Navigation auf der Data-Integration-Seite */
.di-breadcrumb {
	display: flex;
	align-items: center;
	gap: 4px;
	margin-bottom: 12px;
	font-size: 0.78rem;
	font-weight: 600;
}

.di-breadcrumb-link {
	color: rgba(255,255,255,.55);
	text-decoration: none;
	transition: color 0.15s;
}

.di-breadcrumb-link:hover { color: rgba(255,255,255,.9); }

.di-breadcrumb-sep {
	color: rgba(255,255,255,.3);
}

.di-breadcrumb-current {
	color: rgba(255,255,255,.9);
}

.di-back-link {
	display: inline-block;
	font-size: 0.78rem;
	font-weight: 600;
	color: rgba(255,255,255,.55);
	text-decoration: none;
	margin-bottom: 12px;
	transition: color 0.15s;
}

.di-back-link:hover { color: rgba(255,255,255,.9); }

.di-page-title-row {
	display: flex;
	align-items: flex-start;
	gap: 14px;
}

.di-page-icon {
	font-size: 1.75rem;
	flex-shrink: 0;
	margin-top: 2px;
}

.di-page-title {
	margin: 0 0 4px;
	font-size: 1.5rem;
	font-weight: 700;
	color: #fff;
	line-height: 1.2;
}

.di-page-subtitle {
	margin: 0;
	font-size: 0.82rem;
	color: rgba(255,255,255,.5);
}

.di-page-actions {
	margin-left: auto;
	flex-shrink: 0;
	align-self: center;
}

/* Page Body */
.di-page-body {
	background: var(--dashboard-bg);
	min-height: calc(100vh - 140px);
	padding: var(--spacing-lg) var(--spacing-xl) var(--spacing-xl);
}

.di-page-body-inner {
	max-width: 900px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	gap: var(--spacing-md);
}

/* Generic card */
.di-card {
	background: var(--dashboard-card-bg);
	border: 1px solid var(--dashboard-border);
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-md) var(--spacing-lg);
	box-shadow: var(--box-shadow-sm);
}

/* Status card: coloured left border */
.di-card--status {
	border-left: 4px solid var(--dashboard-border);
}

.di-card--status:has(.pdi-status--ok)      { border-left-color: #16a34a; }
.di-card--status:has(.pdi-status--warning) { border-left-color: #d97706; }
.di-card--status:has(.pdi-status--error)   { border-left-color: #dc2626; }

/* History card */
.di-card--history { padding-bottom: var(--spacing-lg); }

.di-section-title {
	font-size: 0.7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--dashboard-text-light);
	margin: 0 0 14px;
}

/* Refresh banner */
.di-refresh-banner {
	min-height: 0;
	transition: min-height 0.2s;
}

/* Report controls row */
.di-report-controls {
	display: flex;
	align-items: center;
	gap: 16px;
	flex-wrap: wrap;
}

/* Not-configured notice */
.di-not-configured {
	background: var(--dashboard-card-bg);
	border: 1px solid var(--dashboard-border);
	border-radius: var(--border-radius-lg);
	padding: var(--spacing-xl);
	text-align: center;
	color: var(--dashboard-text-light);
}

@media (max-width: 768px) {
	.di-page-header {
		padding: 16px var(--spacing-lg) 20px;
	}

	.di-page-body {
		padding: var(--spacing-md) var(--spacing-lg) var(--spacing-lg);
	}

	.di-page-title { font-size: 1.25rem; }

	/* FIX-13: Button bleibt sichtbar, bricht auf eigene Zeile unterhalb des Titels */
	.di-page-title-row { flex-wrap: wrap; }
	.di-page-actions { margin-left: 0; margin-top: 10px; width: 100%; }
}

/* Help modal */
.pdi-help-modal {
	position: fixed;
	inset: 0;
	z-index: 99999;
	display: flex;
	align-items: center;
	justify-content: center;
}

.pdi-help-modal-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.35);
}

.pdi-help-modal-box {
	position: relative;
	z-index: 1;
	background: var(--dashboard-bg, #fff);
	border: 1px solid var(--dashboard-border);
	border-radius: 12px;
	padding: 28px 32px 24px;
	max-width: 440px;
	width: calc(100% - 48px);
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.14);
}

.pdi-help-modal-close {
	position: absolute;
	top: 14px;
	right: 16px;
	background: none;
	border: none;
	font-size: 1rem;
	color: var(--dashboard-text-light);
	cursor: pointer;
	padding: 4px;
	line-height: 1;
}

.pdi-help-modal-close:hover {
	color: var(--dashboard-text);
}

.pdi-help-modal-title {
	margin: 0 0 14px;
	font-size: 0.95rem;
	font-weight: 700;
	color: var(--dashboard-text);
}

.pdi-help-modal-body {
	margin: 0 0 18px;
	font-size: 0.82rem;
	color: var(--dashboard-text);
	line-height: 1.65;
}

.pdi-help-modal-support {
	font-size: 0.82rem;
	font-weight: 600;
	color: var(--paquse-pink, #e91e8c);
	text-decoration: none;
}

.pdi-help-modal-support:hover {
	text-decoration: underline;
}

/* ==========================================================================
   KPI Metrics
   ========================================================================== */

#pdi-kpis {
	margin-bottom: 16px;
}

/* Three metric cards in a row */
.pdi-metrics {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 8px;
	margin-bottom: 16px;
}

.pdi-metric {
	display: flex;
	flex-direction: column;
	gap: 2px;
	padding: 12px 14px;
	background: var(--dashboard-hover);
	border-radius: 10px;
	border: 1px solid var(--dashboard-border);
	position: relative;
	overflow: hidden;
}

/* Coloured top accent per period */
.pdi-metric::before {
	content: '';
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 3px;
	border-radius: 10px 10px 0 0;
}

.pdi-metric--today::before { background: var(--paquse-pink); }
.pdi-metric--month::before { background: var(--paquse-navy); }
.pdi-metric--ytd::before   { background: #7C3AED; }

.pdi-metric-label {
	font-size: 0.7rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--dashboard-text-light);
}

/* Primary value = Euro revenue (cursor hints at hover tooltip) */
.pdi-metric-value {
	font-size: 1.55rem;
	font-weight: 800;
	color: var(--paquse-navy);
	line-height: 1.1;
	letter-spacing: -0.02em;
	cursor: default;
}

/* Secondary line = transaction count "632 sales tx" */
.pdi-metric-unit {
	font-size: 0.75rem;
	color: var(--dashboard-text-light);
	margin-top: 1px;
}

.pdi-metric-rev {
	font-size: 0.78rem;
	color: var(--dashboard-text-light);
	margin-top: 4px;
	font-weight: 500;
}

.pdi-metric-trend {
	margin-top: 2px;
}

/* Channel breakdown bars (inside KPI block) */
.pdi-channels {
	display: flex;
	flex-direction: column;
	gap: 6px;
	margin-bottom: 8px;
}

.pdi-channel-row {
	display: grid;
	grid-template-columns: 8px 1fr auto;
	align-items: center;
	gap: 8px;
	font-size: 0.78rem;
}

.pdi-channel-dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	flex-shrink: 0;
}

.pdi-channel-name {
	color: var(--dashboard-text-light);
	white-space: nowrap;
}

.pdi-channel-bar-wrap {
	display: block;
	height: 4px;
	background: var(--dashboard-border);
	border-radius: 99px;
	overflow: hidden;
	grid-column: 1 / -1;
	margin-top: -2px;
}

/* Re-layout channel row properly */
.pdi-channel-row {
	display: flex;
	align-items: center;
	gap: 7px;
}

.pdi-channel-bar-wrap {
	flex: 1;
	height: 4px;
	background: var(--dashboard-border);
	border-radius: 99px;
	overflow: hidden;
}

.pdi-channel-bar {
	display: block;
	height: 100%;
	border-radius: 99px;
	opacity: 0.75;
}

.pdi-channel-val {
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--dashboard-text);
	white-space: nowrap;
}

.pdi-kpi-footer {
	font-size: 0.72rem;
	color: var(--dashboard-text-light);
	margin-top: 4px;
	text-align: right;
	opacity: 0.75;
}

/* Trend badges */
.pdi-trend-up {
	display: inline-flex;
	align-items: center;
	gap: 2px;
	color: #16a34a;
	font-weight: 700;
	font-size: 0.72rem;
	background: #f0fdf4;
	border-radius: 999px;
	padding: 2px 8px;
}

.pdi-trend-down {
	display: inline-flex;
	align-items: center;
	gap: 2px;
	color: #dc2626;
	font-weight: 700;
	font-size: 0.72rem;
	background: #fef2f2;
	border-radius: 999px;
	padding: 2px 8px;
}

/* Refresh feedback badges */
.pdi-badge {
	display: inline-block;
	padding: 2px 10px;
	border-radius: 999px;
	font-size: 0.75rem;
	font-weight: 600;
	white-space: nowrap;
}

.pdi-badge--success {
	background: #dcfce7;
	color: #166534;
}

.pdi-badge--running {
	background: #dbeafe;
	color: #1e40af;
}

.pdi-badge--error {
	background: #fee2e2;
	color: #991b1b;
	white-space: normal;
}

.pdi-error-detail {
	display: block;
	font-size: 0.7rem;
	font-weight: 400;
	opacity: 0.85;
	margin-top: 2px;
	word-break: break-word;
}

/* Job detail panel (SuperAdmin only) */
.pdi-job-detail {
	margin-top: 8px;
	background: var(--dashboard-hover);
	border: 1px solid var(--dashboard-border);
	border-radius: 8px;
	padding: 10px 12px;
	font-size: 0.75rem;
	text-align: left;
}

.pdi-job-detail-header {
	font-size: 0.68rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--dashboard-text-light);
	margin-bottom: 8px;
}

.pdi-step {
	display: flex;
	align-items: baseline;
	gap: 7px;
	padding: 3px 0;
	color: var(--dashboard-text-light);
	border-top: 1px solid var(--dashboard-border);
	flex-wrap: wrap;
}

.pdi-step:first-of-type {
	border-top: none;
}

.pdi-step-icon {
	font-size: 0.65rem;
	font-weight: 800;
	width: 12px;
	flex-shrink: 0;
}

.pdi-step--ok   { color: #166534; }
.pdi-step--ok .pdi-step-icon { color: #16a34a; }

.pdi-step--fail { color: var(--dashboard-text); }
.pdi-step--fail .pdi-step-icon { color: #dc2626; }

.pdi-step-error {
	display: block;
	width: 100%;
	padding-left: 19px;
	color: #991b1b;
	font-size: 0.7rem;
	font-family: ui-monospace, monospace;
	word-break: break-all;
	margin-top: 2px;
}

/* FIX-19: Skip-Grund (z.B. "previous wave failed") im Step-Detail */
.pdi-step-reason {
	display: block;
	width: 100%;
	padding-left: 19px;
	color: var(--dashboard-text-light);
	font-size: 0.7rem;
	font-style: italic;
	margin-top: 2px;
}

/* ==========================================================================
   Report (collapsible)
   ========================================================================== */

#pdi-report {
	margin-top: var(--spacing-sm);
	padding-top: var(--spacing-sm);
	border-top: 1px solid var(--dashboard-border);
}

.pdi-report-header {
	display: flex;
	align-items: baseline;
	gap: 8px;
	margin-bottom: 16px;
}

.pdi-report-eyebrow {
	font-size: 0.65rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--paquse-pink);
}

.pdi-report-date {
	font-size: 0.82rem;
	color: var(--dashboard-text-light);
}

.pdi-report-section {
	margin-bottom: 20px;
}

.pdi-section-label {
	font-size: 0.65rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--dashboard-text-light);
	margin: 0 0 10px;
}

/* Monthly trend — horizontal bar chart */
.pdi-trend-chart {
	display: flex;
	flex-direction: column;
	gap: 5px;
}

.pdi-trend-row {
	display: grid;
	grid-template-columns: 60px 1fr 52px 72px;
	align-items: center;
	gap: 8px;
	font-size: 0.75rem;
}

.pdi-trend-month {
	color: var(--dashboard-text-light);
	white-space: nowrap;
	font-size: 0.72rem;
}

.pdi-trend-row--current .pdi-trend-month {
	color: var(--dashboard-text);
	font-weight: 600;
}

.pdi-trend-bar-wrap {
	height: 6px;
	background: var(--dashboard-border);
	border-radius: 99px;
	overflow: hidden;
}

.pdi-trend-bar {
	display: block;
	height: 100%;
	background: var(--paquse-navy);
	border-radius: 99px;
	opacity: 0.35;
	transition: width 0.4s ease;
}

.pdi-trend-bar--current {
	background: var(--paquse-pink);
	opacity: 1;
}

/* "2.399 tx" — transaction count, secondary */
.pdi-trend-sales {
	text-align: right;
	color: var(--dashboard-text-light);
	font-size: 0.7rem;
	font-variant-numeric: tabular-nums;
	white-space: nowrap;
}

.pdi-trend-row--current .pdi-trend-sales {
	color: var(--dashboard-text);
}

/* Euro revenue — primary value, right-aligned */
.pdi-trend-revenue {
	text-align: right;
	color: var(--dashboard-text);
	font-size: 0.75rem;
	font-weight: 600;
	white-space: nowrap;
	cursor: default;
}

.pdi-trend-row--current .pdi-trend-revenue {
	color: var(--paquse-navy);
}

/* Channels — report version */
.pdi-channels-report {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.pdi-ch-row {
	display: grid;
	grid-template-columns: 8px auto 1fr auto auto auto;
	align-items: center;
	gap: 8px;
	font-size: 0.78rem;
}

.pdi-ch-name {
	color: var(--dashboard-text);
	font-weight: 500;
	white-space: nowrap;
}

.pdi-ch-bar-wrap {
	height: 20px;
	border-radius: 4px;
	overflow: hidden;
	background: var(--dashboard-hover);
}

.pdi-ch-bar {
	display: block;
	height: 100%;
	border-radius: 4px;
	transition: width 0.5s ease;
}

.pdi-ch-total {
	font-weight: 700;
	color: var(--paquse-navy);
	white-space: nowrap;
	font-variant-numeric: tabular-nums;
	text-align: right;
}

.pdi-ch-rev {
	color: var(--dashboard-text-light);
	font-size: 0.72rem;
	white-space: nowrap;
	text-align: right;
}

.pdi-ch-today {
	font-size: 0.68rem;
	color: #16a34a;
	font-weight: 600;
	white-space: nowrap;
	background: #f0fdf4;
	border-radius: 999px;
	padding: 1px 7px;
}

.pdi-empty {
	font-size: 0.78rem;
	color: var(--dashboard-text-light);
	font-style: italic;
	margin: 0;
}

/* Loading spinner */
@keyframes pdi-spin {
	to {
		transform: rotate(360deg);
	}
}

.pdi-loading {
	display: flex;
	align-items: center;
	gap: 6px;
	padding: 4px 0;
}

.pdi-spinner {
	display: inline-block;
	width: 14px;
	height: 14px;
	border: 2px solid var(--dashboard-border);
	border-top-color: var(--paquse-pink);
	border-radius: 50%;
	animation: pdi-spin 0.7s linear infinite;
	flex-shrink: 0;
}

/* ==========================================================================
   Job History / Statistics (SuperAdmin)
   ========================================================================== */

.pdi-stats-details {
	margin-top: 16px;
	border-top: 1px solid var(--dashboard-border);
	padding-top: 12px;
}

.pdi-stats-summary-toggle {
	font-size: 0.78rem;
	font-weight: 600;
	color: var(--dashboard-text-light);
	cursor: pointer;
	user-select: none;
	list-style: none;
	display: flex;
	align-items: center;
	gap: 6px;
}

.pdi-stats-summary-toggle::-webkit-details-marker {
	display: none;
}

.pdi-stats-details[open] .pdi-stats-summary-toggle {
	color: var(--dashboard-text);
	margin-bottom: 12px;
}

.pdi-stats-summary {
	display: flex;
	gap: 16px;
	flex-wrap: wrap;
	font-size: 0.75rem;
	color: var(--dashboard-text-light);
	margin-bottom: 10px;
}

.pdi-stats-summary strong {
	color: var(--dashboard-text);
}

.pdi-stats-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.73rem;
}

.pdi-stats-table th {
	text-align: left;
	padding: 4px 6px;
	font-size: 0.65rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--dashboard-text-light);
	border-bottom: 1px solid var(--dashboard-border);
}

.pdi-stats-table td {
	padding: 5px 6px;
	color: var(--dashboard-text);
	border-bottom: 1px solid var(--dashboard-hover);
	vertical-align: middle;
}

.pdi-stats-table tr:last-child td {
	border-bottom: none;
}

/* Status badge inside the history table */
.pdi-step-badge {
	display: inline-block;
	padding: 1px 8px;
	border-radius: 999px;
	font-size: 0.68rem;
	font-weight: 700;
	text-transform: lowercase;
}

.pdi-step-badge.pdi-step--ok {
	background: #dcfce7;
	color: #166534;
}

.pdi-step-badge.pdi-step--fail {
	background: #fee2e2;
	color: #991b1b;
}

.pdi-step-badge.pdi-step--skip {
	background: #fef9c3;
	color: #854d0e;
}

/* ==========================================================================
   Job History — Filter Bar + Expandable Rows (v2.2)
   ========================================================================== */

/* Filter panel: subtle card, always above the table */
.pdi-history-filters {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-end;
	gap: 8px;
	padding: 10px 12px;
	background: var(--dashboard-hover);
	border: 1px solid var(--dashboard-border);
	border-radius: var(--border-radius);
	margin-bottom: 12px;
}

/* Label + input stacked group */
.pdi-filter-group {
	display: flex;
	flex-direction: column;
	gap: 3px;
}

.pdi-filter-label {
	font-size: 0.62rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.07em;
	color: var(--dashboard-text-light);
}

.pdi-history-filters input[type="date"],
.pdi-history-filters select {
	font-size: 0.78rem;
	padding: 5px 8px;
	border: 1px solid var(--dashboard-border);
	border-radius: 6px;
	background: #fff;
	color: var(--dashboard-text);
	height: 32px;
	font-family: inherit;
	transition: border-color 0.15s ease;
}

.pdi-history-filters input[type="date"]:focus,
.pdi-history-filters select:focus {
	outline: none;
	border-color: var(--paquse-pink);
	box-shadow: 0 0 0 2px rgba(221,24,59,.1);
}

.pdi-history-filters select {
	padding-right: 24px;
	cursor: pointer;
	min-width: 100px; /* FIX-20: Verhindert dass Select-Elemente auf schmalen Viewports als Punkte erscheinen */
}

/* Action buttons aligned to bottom of filter row */
.pdi-filter-actions {
	display: flex;
	gap: 6px;
	align-items: flex-end;
	padding-bottom: 1px; /* visual baseline align */
}

.pdi-btn-sm {
	font-size: 0.75rem;
	font-weight: 600;
	padding: 0 14px;
	height: 32px;
	border-radius: 6px;
	border: 1px solid var(--paquse-navy);
	background: var(--paquse-navy);
	color: #fff;
	cursor: pointer;
	white-space: nowrap;
	font-family: inherit;
	transition: background 0.15s ease, opacity 0.15s ease;
}

.pdi-btn-sm:hover {
	background: var(--paquse-navy-light);
	border-color: var(--paquse-navy-light);
}

.pdi-btn-ghost {
	background: #fff;
	color: var(--dashboard-text-light);
	border-color: var(--dashboard-border);
}

.pdi-btn-ghost:hover {
	background: var(--dashboard-bg);
	color: var(--dashboard-text);
	border-color: #b0bec5;
}

/* Details expand button */
.pdi-btn-link {
	background: none;
	border: 1px solid var(--dashboard-border);
	padding: 2px 8px;
	border-radius: 4px;
	font-size: 0.7rem;
	font-weight: 600;
	color: var(--dashboard-text-light);
	cursor: pointer;
	white-space: nowrap;
	font-family: inherit;
	transition: background 0.15s ease, color 0.15s ease;
}

.pdi-btn-link:hover {
	background: var(--dashboard-hover);
	color: var(--dashboard-text);
	border-color: #b0bec5;
}

/* Stats summary pills */
.pdi-job-stats-bar {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 12px;
	flex-wrap: wrap;
}

.pdi-job-stats-pill {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-size: 0.72rem;
	color: var(--dashboard-text-light);
	background: var(--dashboard-hover);
	border: 1px solid var(--dashboard-border);
	border-radius: 999px;
	padding: 3px 10px;
}

.pdi-job-stats-pill strong {
	color: var(--dashboard-text);
	font-weight: 700;
}

.pdi-job-stats-pill--success strong { color: #166534; }
.pdi-job-stats-pill--avg    strong { color: var(--paquse-navy); }

/* Trigger badges */
.pdi-trigger-badge {
	display: inline-flex;
	align-items: center;
	gap: 3px;
	padding: 2px 8px;
	border-radius: 999px;
	font-size: 0.67rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	white-space: nowrap;
}

.pdi-trigger--cron {
	background: #eff6ff;
	color: #1d4ed8;
	border: 1px solid #bfdbfe;
}

.pdi-trigger--manual {
	background: #f5f3ff;
	color: #6d28d9;
	border: 1px solid #ddd6fe;
}


/* History table */
.pdi-history-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.78rem;
}

.pdi-history-table thead th {
	font-size: 0.62rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.07em;
	color: var(--dashboard-text-light);
	padding: 6px 8px;
	border-bottom: 2px solid var(--dashboard-border);
	text-align: left;
	white-space: nowrap;
}

.pdi-history-table tbody td {
	padding: 8px 8px;
	color: var(--dashboard-text);
	border-bottom: 1px solid var(--dashboard-hover);
	vertical-align: middle;
}

.pdi-history-table tbody tr.pdi-job-row:last-of-type td {
	border-bottom: none;
}

.pdi-history-table tbody tr.pdi-job-row {
	transition: background 0.1s ease;
}

.pdi-history-table tbody tr.pdi-job-row:hover {
	background: var(--dashboard-hover);
}

/* Started column — compact, two-line */
.pdi-job-started {
	display: flex;
	flex-direction: column;
	gap: 1px;
}

.pdi-job-started-date {
	font-weight: 600;
	color: var(--dashboard-text);
	font-size: 0.78rem;
}

.pdi-job-started-time {
	font-size: 0.68rem;
	color: var(--dashboard-text-light);
}

/* Duration + steps: monospace feel */
.pdi-job-dur {
	font-variant-numeric: tabular-nums;
	color: var(--dashboard-text-light);
	font-size: 0.75rem;
}

.pdi-job-steps {
	font-size: 0.75rem;
	color: var(--dashboard-text-light);
}

/* Last column: align Details button right */
.pdi-history-table th:last-child,
.pdi-history-table td:last-child {
	text-align: right;
}

/* Expandable detail row */
.pdi-job-detail-row > td {
	padding: 0 !important;
}

.pdi-job-detail-cell {
	background: #fafbfc;
	border-bottom: 1px solid var(--dashboard-border);
}

.pdi-job-detail-body {
	padding: 12px 16px;
	border-top: 1px dashed var(--dashboard-border);
}

/* =================================================================
   SUPER ADMIN — Tenant Cards
   ================================================================= */

/* Remove bottom gap in header (no description text in tenant cards) */
.sa-tenant-card .product-header {
	margin-bottom: 0;
	padding-bottom: var(--spacing-md);
}

/* Logo: constrained, no inline margin */
.sa-tenant-logo {
	height: 44px;
	max-width: 100px;
	width: auto;
	object-fit: contain;
	flex-shrink: 0;
}

/* Meta row: Slug · Users · Reports — always single line */
.sa-tenant-meta {
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
	padding: 10px 0;
	border-top: 1px solid var(--dashboard-border);
	border-bottom: 1px solid var(--dashboard-border);
	margin-bottom: var(--spacing-md);
}

.sa-tenant-meta-item {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	font-size: 0.78rem;
	color: var(--dashboard-text);
}

.sa-tenant-meta-label {
	font-size: 0.68rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--dashboard-text-light);
}

.sa-tenant-meta-sep {
	color: var(--dashboard-border);
	font-size: 0.9rem;
	line-height: 1;
}

.sa-tenant-slug {
	background: var(--dashboard-hover);
	border: 1px solid var(--dashboard-border);
	padding: 1px 6px;
	border-radius: 4px;
	font-size: 0.72rem;
	font-family: ui-monospace, "SF Mono", monospace;
	color: var(--dashboard-text);
}

/* CTA Button — always paquse navy, no tenant color */
.sa-tenant-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: 100%;
	padding: 10px 16px;
	background: var(--paquse-navy);
	color: #fff;
	border-radius: var(--border-radius);
	text-decoration: none;
	font-size: 0.875rem;
	font-weight: 600;
	transition: background 0.2s ease, transform 0.15s ease;
	box-shadow: 0 2px 6px rgba(15,23,42,.15);
}

.sa-tenant-btn:hover {
	background: var(--paquse-pink);
	color: #fff;
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(221,24,59,.2);
	text-decoration: none;
}

.sa-tenant-btn .dashicons {
	font-size: 16px;
	width: 16px;
	height: 16px;
	color: rgba(255,255,255,.8);
}
/* =================================================================
   MOBILE NAV — #paquse-mobile-nav (M-T-01)
   Only visible on touch devices ≤782px (matches WP Admin Bar breakpoint)
   ================================================================= */

#paquse-mobile-nav {
    display: none;
}

@media screen and (max-width: 782px) and (hover: none) and (pointer: coarse) {

    /* Hide WordPress Admin Bar on touch — replaced by mobile nav */
    #wpadminbar {
        display: none !important;
    }

    html.admin-bar {
        margin-top: 0 !important;
    }

    /* Show our nav */
    #paquse-mobile-nav {
        display: block;
    }

    /* ---- Top Bar ---- */
    .pmn-bar {
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        height: 52px;
        background: var(--dashboard-navy, #0F172A);
        display: flex;
        align-items: center;
        padding: 0 16px;
        z-index: 99998;
        gap: 12px;
    }

    .pmn-logo {
        text-decoration: none;
        display: flex;
        align-items: center;
    }

    /* paquse-icon.png — ersetzt "p"-Buchstabe auf rotem Grund */
    .pmn-logo-img {
        width: 32px;
        height: 32px;
        display: block;
        object-fit: contain;
        border-radius: 6px;
    }

    .pmn-spacer {
        flex: 1;
    }

    .pmn-avatar {
        width: 36px;
        height: 36px;
        border-radius: 50%;
        background: var(--dashboard-accent, #DD183B);
        color: #fff;
        font-family: 'Lexend', sans-serif;
        font-weight: 700;
        font-size: 13px;
        border: none;
        cursor: pointer;
        display: flex;
        align-items: center;
        justify-content: center;
        -webkit-tap-highlight-color: transparent;
    }

    /* Offset page content below fixed bar */
    body.admin-bar,
    body {
        padding-top: 52px !important;
        margin-top: 0 !important;
    }

    /* ---- Drawer ---- */
    #pmn-drawer {
        position: fixed;
        top: 0;
        right: 0;
        width: min(320px, 85vw);
        height: 100dvh;
        background: #fff;
        z-index: 100000;
        overflow-y: auto;
        display: flex;
        flex-direction: column;
        transform: translateX(100%);
        transition: transform 0.28s cubic-bezier(0.4, 0, 0.2, 1);
        box-shadow: -4px 0 24px rgba(15, 23, 42, 0.18);
    }

    #pmn-drawer:not([hidden]) {
        transform: translateX(0);
    }

    #pmn-drawer[hidden] {
        /* override display:none from [hidden] so transition still runs */
        display: flex !important;
        transform: translateX(100%);
        pointer-events: none;
    }

    .pmn-drawer-header {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        padding: 20px 16px 16px;
        border-bottom: 1px solid var(--dashboard-border, #E2E8F0);
    }

    .pmn-user-info {
        display: flex;
        align-items: center;
        gap: 12px;
    }

    .pmn-user-avatar {
        width: 44px;
        height: 44px;
        border-radius: 50%;
        background: var(--dashboard-navy, #0F172A);
        color: #fff;
        font-family: 'Lexend', sans-serif;
        font-weight: 700;
        font-size: 16px;
        display: flex;
        align-items: center;
        justify-content: center;
        flex-shrink: 0;
    }

    .pmn-user-name {
        font-family: 'Lexend', sans-serif;
        font-weight: 600;
        font-size: 15px;
        color: var(--dashboard-navy, #0F172A);
        line-height: 1.3;
    }

    .pmn-user-email {
        font-size: 12px;
        color: var(--dashboard-muted, #64748B);
        margin-top: 2px;
    }

    .pmn-close {
        background: none;
        border: none;
        font-size: 18px;
        color: var(--dashboard-muted, #64748B);
        cursor: pointer;
        padding: 4px 8px;
        border-radius: 6px;
        -webkit-tap-highlight-color: transparent;
    }

    /* ---- Menu Items ---- */
    .pmn-menu {
        list-style: none;
        margin: 0;
        padding: 8px 0;
        flex: 1;
    }

    .pmn-menu li {
        margin: 0;
        padding: 0;
    }

    .pmn-menu-item {
        display: flex;
        align-items: center;
        gap: 14px;
        padding: 14px 20px;
        font-family: 'DM Sans', sans-serif;
        font-size: 15px;
        color: var(--dashboard-navy, #0F172A);
        text-decoration: none;
        border-radius: 0;
        min-height: 52px;
        transition: background 0.15s ease;
    }

    .pmn-menu-item:active {
        background: var(--dashboard-bg, #F8FAFC);
    }

    .pmn-menu-item .dashicons {
        font-size: 20px;
        width: 20px;
        height: 20px;
        color: var(--dashboard-muted, #64748B);
        flex-shrink: 0;
    }

    .pmn-menu-separator {
        height: 1px;
        background: var(--dashboard-border, #E2E8F0);
        margin: 8px 20px;
    }

    .pmn-menu-logout {
        color: var(--dashboard-accent, #DD183B);
    }

    .pmn-menu-logout .dashicons {
        color: var(--dashboard-accent, #DD183B);
    }

    /* ---- Overlay ---- */
    #pmn-overlay {
        display: none;
        position: fixed;
        inset: 0;
        background: rgba(15, 23, 42, 0.45);
        z-index: 99999;
    }

    #pmn-overlay.pmn-overlay--visible {
        display: block;
    }

    /* Prevent body scroll when drawer is open */
    body.pmn-drawer-open {
        overflow: hidden;
    }
}
