/**
 * Je Travel Affiliation CSS Stylesheet.
 * Conforms to Brand Book v5.0.
 */

:root {
	/* Primary colors */
	--jt-blue: #1CA3DD;
	--jt-blue-hover: #1276A8;
	--jt-blue-pale: #E3F6FD;

	/* Secondary colors */
	--jt-yellow: #F8B400;
	--jt-yellow-pale: #FEF6DC;

	/* Action colors */
	--jt-red: #E63946;
	--jt-red-pale: #FEF0F1;

	/* Premium color */
	--jt-navy: #0B2545;

	/* Neutrals */
	--jt-gray-light: #F5F7FA;
	--jt-gray-dark: #333333;
	--jt-white: #FFFFFF;

	/* Border radius */
	--jt-radius: 6px;
}

/* Typography Overrides inside plugin namespaces */
.jt-affiliate-dashboard,
.jt-affiliate-onboarding,
.jt-admin-wrap {
	font-family: 'Poppins', 'Trebuchet MS', Arial, sans-serif;
	color: var(--jt-gray-dark);
	background-color: var(--jt-gray-light);
	box-sizing: border-box;
}

.jt-affiliate-dashboard h1,
.jt-affiliate-onboarding h1,
.jt-admin-wrap h1,
.jt-admin-h1 {
	font-family: 'Montserrat', 'Trebuchet MS', Arial, sans-serif;
	font-weight: 800;
	font-size: 32px;
	color: var(--jt-navy);
	margin-bottom: 20px;
}

.jt-affiliate-dashboard h2,
.jt-admin-wrap h2 {
	font-family: 'Montserrat', 'Trebuchet MS', Arial, sans-serif;
	font-weight: 600;
	font-size: 24px;
	color: var(--jt-navy);
	margin-top: 30px;
	margin-bottom: 15px;
}

.jt-affiliate-dashboard h3,
.jt-affiliate-onboarding h3,
.jt-admin-wrap h3 {
	font-family: 'Poppins', 'Trebuchet MS', Arial, sans-serif;
	font-weight: 700;
	font-size: 16px;
	color: var(--jt-navy);
	margin-bottom: 10px;
}

/* Buttons */
.jt-btn {
	display: inline-block;
	padding: 12px 24px;
	font-family: 'Poppins', sans-serif;
	font-weight: 700;
	font-size: 14px;
	text-decoration: none;
	border: none;
	border-radius: var(--jt-radius);
	cursor: pointer;
	text-align: center;
	transition: background-color 0.2s ease, transform 0.1s ease;
}

.jt-btn:active {
	transform: scale(0.98);
}

/* Primary: Yellow bg, Navy text. Contrast rule compliant */
.jt-btn-primary {
	background-color: var(--jt-yellow);
	color: var(--jt-navy) !important;
}

.jt-btn-primary:hover {
	background-color: #e0a300;
}

/* Secondary: Blue bg, White text */
.jt-btn-secondary {
	background-color: var(--jt-blue);
	color: var(--jt-white) !important;
}

.jt-btn-secondary:hover {
	background-color: var(--jt-blue-hover);
}

/* Alert Boxes & Messages */
.jt-affiliate-alert,
.jt-affiliate-notice {
	padding: 15px;
	border-radius: var(--jt-radius);
	margin-bottom: 20px;
	font-size: 14px;
}

.jt-affiliate-alert.success,
.jt-affiliate-notice.success {
	background-color: var(--jt-blue-pale);
	color: var(--jt-blue-hover);
	border: 1px solid var(--jt-blue);
}

.jt-affiliate-alert.error,
.jt-affiliate-notice.error {
	background-color: var(--jt-red-pale);
	color: var(--jt-red);
	border: 1px solid var(--jt-red);
}

.jt-affiliate-alert.warning,
.jt-affiliate-notice.warning {
	background-color: var(--jt-yellow-pale);
	color: #c98c00;
	border: 1px solid var(--jt-yellow);
}

/* Onboarding Page styling */
.jt-affiliate-onboarding {
	background: var(--jt-white);
	border-radius: var(--jt-radius);
	padding: 40px;
	text-align: center;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
	max-width: 800px;
	margin: 20px auto;
	position: relative;
	overflow: hidden;
}

.jt-intro-text {
	font-size: 16px;
	line-height: 1.6;
	margin-bottom: 30px;
	color: var(--jt-gray-dark);
}

.jt-benefits-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 20px;
	margin-bottom: 45px;
}

.jt-benefit-card {
	background-color: var(--jt-gray-light);
	border-radius: var(--jt-radius);
	padding: 20px;
	border-top: 4px solid var(--jt-blue);
	transition: transform 0.2s ease;
}

.jt-benefit-card:hover {
	transform: translateY(-5px);
}

/* Active Dashboard Layout */
.jt-affiliate-dashboard {
	background-color: var(--jt-white);
	border-radius: var(--jt-radius);
	padding: 30px;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}

.jt-affiliate-header {
	border-bottom: 2px solid var(--jt-gray-light);
	padding-bottom: 20px;
	margin-bottom: 30px;
}

.jt-welcome-back {
	font-size: 14px;
	color: var(--jt-blue-hover);
	margin-top: 5px;
}

/* Referral Link Box */
.jt-referral-box {
	background-color: var(--jt-blue-pale);
	border-radius: var(--jt-radius);
	padding: 25px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 30px;
	margin-bottom: 35px;
}

.jt-referral-text {
	flex-grow: 1;
}

.jt-referral-text label {
	display: block;
	font-weight: 700;
	margin-bottom: 10px;
	color: var(--jt-navy);
}

.jt-link-input-group {
	display: flex;
	gap: 10px;
}

.jt-link-input-group input {
	flex-grow: 1;
	padding: 12px;
	font-family: 'Poppins', sans-serif;
	font-size: 14px;
	border: 1px solid var(--jt-blue);
	border-radius: var(--jt-radius);
	background-color: var(--jt-white);
	color: var(--jt-navy);
}

.jt-referral-qr {
	background: var(--jt-white);
	padding: 15px;
	border-radius: var(--jt-radius);
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	box-shadow: 0 2px 8px rgba(0,0,0,0.05);
}

#jt-qr-canvas {
	width: 130px;
	height: 130px;
}

.jt-qr-label {
	font-size: 10px;
	color: var(--jt-navy);
	margin-top: 8px;
	font-weight: 700;
}

/* KPI Grid */
.jt-kpis-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 20px;
	margin-bottom: 40px;
}

.jt-kpi-card {
	background-color: var(--jt-white);
	border: 1px solid #e1e8ed;
	border-radius: var(--jt-radius);
	padding: 20px;
	box-shadow: 0 2px 4px rgba(0,0,0,0.02);
	display: flex;
	flex-direction: column;
}

.jt-kpi-card.jt-kpi-clicks { border-left: 4px solid var(--jt-blue); }
.jt-kpi-card.jt-kpi-rate { border-left: 4px solid var(--jt-yellow); }
.jt-kpi-card.jt-kpi-pending { border-left: 4px solid var(--jt-yellow); }
.jt-kpi-card.jt-kpi-validated { border-left: 4px solid var(--jt-blue); }
.jt-kpi-card.jt-kpi-paid { border-left: 4px solid var(--jt-navy); }

/* KPI Admin Custom Styles */
.jt-admin-kpi-grid .jt-kpi-navy { border-top: 4px solid var(--jt-navy); }
.jt-admin-kpi-grid .jt-kpi-blue { border-top: 4px solid var(--jt-blue); }
.jt-admin-kpi-grid .jt-kpi-yellow { border-top: 4px solid var(--jt-yellow); }
.jt-admin-kpi-grid .jt-kpi-blue-pale { border-top: 4px solid var(--jt-blue); }
.jt-admin-kpi-grid .jt-kpi-paid { border-top: 4px solid var(--jt-navy); }

.jt-kpi-card h3 {
	font-size: 12px;
	text-transform: uppercase;
	color: var(--jt-navy);
	margin: 0 0 10px 0;
	letter-spacing: 0.5px;
}

.jt-kpi-value {
	font-family: 'Poppins', sans-serif;
	font-weight: 700;
	font-size: 26px;
	color: var(--jt-navy);
	margin: 0 0 8px 0;
	line-height: 1.1;
}

.jt-kpi-sub {
	font-size: 10px;
	color: var(--jt-gray-dark);
	margin-top: auto;
}

/* Two-column dashboard row */
.jt-dashboard-details-row {
	display: grid;
	grid-template-columns: 2fr 1fr;
	gap: 30px;
}

@media (max-width: 900px) {
	.jt-dashboard-details-row {
		grid-template-columns: 1fr;
	}
	.jt-referral-box {
		flex-direction: column;
		align-items: stretch;
	}
	.jt-referral-qr {
		align-self: center;
	}
}

/* Table styling */
.jt-table-wrapper {
	overflow-x: auto;
	margin-bottom: 20px;
}

.jt-conversions-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 13px;
	text-align: left;
}

.jt-conversions-table th {
	background-color: var(--jt-gray-light);
	color: var(--jt-navy);
	font-weight: 700;
	padding: 12px;
	border-bottom: 2px solid #e1e8ed;
}

.jt-conversions-table td {
	padding: 12px;
	border-bottom: 1px solid #e1e8ed;
}

.jt-conversions-table tbody tr:nth-child(even) {
	background-color: var(--jt-gray-light);
}

/* Badges / Labels */
.jt-status-label,
.jt-affiliate-badge {
	display: inline-block;
	padding: 4px 8px;
	font-size: 11px;
	font-weight: 700;
	border-radius: 4px;
	text-transform: uppercase;
}

/* BuddyBoss Badges */
.jt-affiliate-badge.standard {
	background-color: var(--jt-blue);
	color: var(--jt-white);
}

.jt-affiliate-badge.trained {
	background-color: var(--jt-yellow);
	color: var(--jt-navy);
}

/* Status colors */
.status-pending {
	background-color: var(--jt-yellow-pale);
	color: #b58000;
}

.status-validated {
	background-color: var(--jt-blue-pale);
	color: var(--jt-blue-hover);
}

.status-paid {
	background-color: #e2f8e1;
	color: #1e7e1b;
}

.status-cancelled {
	background-color: var(--jt-red-pale);
	color: var(--jt-red);
}

/* Forms */
.jt-form-group {
	margin-bottom: 20px;
}

.jt-form-group label {
	display: block;
	font-weight: 700;
	font-size: 13px;
	margin-bottom: 8px;
	color: var(--jt-navy);
}

.jt-form-group select,
.jt-form-group textarea {
	width: 100%;
	padding: 10px;
	font-family: 'Poppins', sans-serif;
	font-size: 13px;
	border: 1px solid #e1e8ed;
	border-radius: var(--jt-radius);
	background-color: var(--jt-white);
}

.jt-form-group select:focus,
.jt-form-group textarea:focus {
	border-color: var(--jt-blue);
	outline: none;
}

/* Payout locking box */
.jt-payout-locked {
	background-color: var(--jt-gray-light);
	border: 1px dashed #e1e8ed;
	border-radius: var(--jt-radius);
	padding: 30px;
	text-align: center;
	color: var(--jt-navy);
}

.jt-lock-note {
	font-size: 12px;
	color: var(--jt-gray-dark);
	margin-top: 10px;
	font-style: italic;
}

/* Admin Specific Overrides */
.jt-admin-wrap {
	margin: 20px 20px 0 0;
}

.jt-admin-section-card {
	background-color: var(--jt-white);
	border: 1px solid #e1e8ed;
	border-radius: var(--jt-radius);
	padding: 25px;
	box-shadow: 0 2px 4px rgba(0,0,0,0.02);
	margin-bottom: 30px;
}

.jt-admin-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 20px;
}

@media (max-width: 1100px) {
	.jt-admin-row {
		grid-template-columns: 1fr;
	}
}

.jt-flag-unreviewed {
	background-color: var(--jt-red-pale) !important;
}

.jt-flag-desc {
	font-style: italic;
}

.jt-admin-col-list {
	flex-grow: 1;
	min-width: 0;
}

.jt-admin-col-edit {
	width: 400px;
	flex-shrink: 0;
}

.jt-logs-list {
	list-style: none;
	padding: 0;
	margin: 15px 0 0 0;
	font-size: 11px;
}

.jt-logs-list li {
	padding: 8px;
	border-bottom: 1px solid var(--jt-gray-light);
}

.jt-payout-hide-btn {
	text-decoration: none;
	color: var(--jt-red);
	font-weight: bold;
	font-size: 16px;
	margin-left: 5px;
}

.jt-payout-hide-btn:hover {
	color: darkred;
}

/* Login CTA for non-logged-in users */
.jt-affiliate-login-cta {
	background: var(--jt-white);
	border-radius: var(--jt-radius);
	padding: 50px 30px;
	text-align: center;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05);
	max-width: 650px;
	margin: 40px auto;
	border-top: 4px solid var(--jt-yellow);
}

.jt-cta-icon-wrapper {
	margin-bottom: 25px;
}

.jt-cta-icon {
	width: 70px;
	height: 70px;
	background-color: var(--jt-blue-pale);
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	position: relative;
	margin: 0 auto;
}

.jt-affiliate-login-cta h2 {
	font-family: 'Montserrat', sans-serif;
	font-weight: 800;
	font-size: 26px;
	color: var(--jt-navy);
	margin-bottom: 15px;
	line-height: 1.3;
}

.jt-cta-desc {
	font-family: 'Poppins', sans-serif;
	font-size: 14px;
	line-height: 1.6;
	color: var(--jt-gray-dark);
	max-width: 500px;
	margin: 0 auto 30px auto;
}

.jt-cta-actions {
	display: flex;
	justify-content: center;
	gap: 15px;
	flex-wrap: wrap;
}

.jt-cta-actions .jt-btn {
	min-width: 170px;
}

/* WP Admin panel overrides for list tables */
.jt-admin-wrap .wp-list-table {
	table-layout: auto !important;
	width: 100% !important;
}

.jt-admin-wrap .wp-list-table td,
.jt-admin-wrap .wp-list-table th {
	vertical-align: middle;
	padding: 10px 12px !important;
}

.jt-admin-wrap .jt-actions-wrapper {
	display: flex;
	gap: 6px;
	flex-wrap: wrap;
	align-items: center;
}

.jt-admin-wrap .jt-actions-wrapper .button {
	margin: 0 !important;
	white-space: nowrap;
}

.jt-admin-wrap .wp-list-table th:last-child,
.jt-admin-wrap .wp-list-table td:last-child {
	min-width: 280px;
	width: auto !important;
}

/* Mobile Optimisation for Affiliate Dashboard (Brand Book compliant) */
@media (max-width: 600px) {
	.jt-affiliate-dashboard,
	.jt-affiliate-onboarding,
	.jt-affiliate-login-cta {
		padding: 20px 15px !important;
	}
	.jt-referral-box {
		flex-direction: column !important;
		align-items: stretch !important;
		padding: 15px !important;
		gap: 20px !important;
	}
	.jt-link-input-group {
		flex-direction: column !important;
		gap: 10px !important;
	}
	.jt-link-input-group input {
		width: 100% !important;
	}
	.jt-link-input-group button {
		width: 100% !important;
		margin-top: 5px !important;
	}
	.jt-kpis-grid {
		grid-template-columns: 1fr !important;
		gap: 12px !important;
	}
	.jt-kpi-card {
		padding: 15px !important;
	}
	.jt-kpi-value {
		font-size: 22px !important;
	}
	.jt-dashboard-details-row {
		grid-template-columns: 1fr !important;
		gap: 25px !important;
	}
	.jt-conversions-table th,
	.jt-conversions-table td {
		padding: 8px 6px !important;
		font-size: 11px !important;
	}
	.jt-table-wrapper {
		margin-bottom: 15px !important;
	}
	.jt-cta-actions {
		flex-direction: column !important;
		width: 100% !important;
	}
	.jt-cta-actions .jt-btn {
		width: 100% !important;
	}
}
