/**
 * Secure Site Monitor - Scanner Styles
 *
 * @package SecureSiteMonitor
 * @since   1.0.0
 */

/* ==========================================================================
   CSS Variables
   ========================================================================== */

.wps-scanner-wrapper {
	/* BrandBees design tokens (scoped to scanner only). */
	--primary: #2858A6;
	--primary-hover: #1C4285;
	--primary-light: #EBF1FC;
	--primary-dark: #163572;
	--primary-rgb: 40, 88, 166;
	--accent: #F5A623;
	--accent-hover: #E09515;
	--accent-light: #FEF5E6;
	--accent-rgb: 245, 166, 35;
	--teal: #0EA5A0;
	--teal-light: #E6FAF9;
	--teal-rgb: 14, 165, 160;
	--bg: #ffffff;
	--bg-alt: #F7F9FC;
	--bg-warm: #FFFBF2;
	--bg-dark: #0D1B2A;
	--surface: #ffffff;
	--surface-hover: #F1F4F9;
	--text: #0D1B2A;
	--text-secondary: #4A5568;
	--muted: #8B95A5;
	--border: #E2E8F0;
	--border-strong: #CBD5E1;
	--shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
	--shadow: 0 1px 3px rgba(0, 0, 0, 0.08), 0 1px 2px rgba(0, 0, 0, 0.04);
	--shadow-md: 0 4px 12px rgba(0, 0, 0, 0.08);
	--shadow-lg: 0 12px 24px rgba(0, 0, 0, 0.1);
	--shadow-xl: 0 20px 40px rgba(0, 0, 0, 0.12);
	--shadow-glow: 0 4px 24px rgba(var(--primary-rgb), 0.15);
	--shadow-accent: 0 4px 24px rgba(var(--accent-rgb), 0.2);
	--radius-sm: 6px;
	--radius: 10px;
	--radius-lg: 14px;
	--radius-xl: 20px;
	--radius-2xl: 28px;
	--radius-full: 9999px;
	--ease: cubic-bezier(0.4, 0, 0.2, 1);
	--duration: 0.25s;

	/* Backward-compatible aliases for existing class styles. */
	--wps-primary: var(--primary);
	--wps-primary-hover: var(--primary-hover);
	--wps-success: #22C55E;
	--wps-warning: #F59E0B;
	--wps-danger: #DC2626;
	--wps-info: #0EA5A0;
	--wps-gray-50: #F8FAFC;
	--wps-gray-100: #F1F5F9;
	--wps-gray-200: #E2E8F0;
	--wps-gray-300: #CBD5E1;
	--wps-gray-500: #64748B;
	--wps-gray-700: #334155;
	--wps-gray-900: #0D1B2A;
	--wps-white: #FFFFFF;
	--wps-border-radius: var(--radius);
	--wps-shadow: var(--shadow);
	--wps-shadow-lg: var(--shadow-lg);
}

/* ==========================================================================
   Base Layout
   ========================================================================== */

.wps-scanner-wrapper {
	max-width: 1200px;
	margin: 0 auto;
	padding: 32px 28px;
	font-family: Inter, system-ui, -apple-system, sans-serif;
	font-size: 16px;
	line-height: 1.5;
	color: var(--text);
	background: var(--bg);
	border: 1px solid var(--border);
	border-radius: var(--radius-xl);
	box-shadow: var(--shadow-lg);
}

.wps-scanner-wrapper * {
	box-sizing: border-box;
	font-family: Inter, system-ui, -apple-system, sans-serif;
}

/* Fullscreen template adjustments */
body.wps-fullscreen-template {
	margin: 0;
	min-height: 100vh;
	background: #F7F9FC;
	overflow: hidden;
}

body.wps-fullscreen-template .wps-threatmonitor-page {
	min-height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 24px 16px;
}

body.wps-fullscreen-template.wps-can-scroll {
	overflow-y: auto;
	overflow-x: hidden;
}

body.wps-fullscreen-template.wps-can-scroll .wps-threatmonitor-page {
	align-items: flex-start;
	padding: 40px 16px;
}

body.wps-fullscreen-template .wps-scanner-wrapper {
	max-width: 1200px;
	width: 100%;
	border-radius: 20px;
}

.wps-scanner-brand {
	margin: 0 0 10px 0;
}

.wps-scanner-site-logo {
	display: inline-block;
	max-width: min(360px, 90%);
	max-height: 72px;
	height: auto;
	width: auto;
	object-fit: contain;
}

.wps-scanner-site-logo-link {
	display: inline-block;
	text-decoration: none;
}

/* ==========================================================================
   Quick Scanner Bar Shortcode
   ========================================================================== */

.wps-quick-scan-box {
	background: #ffffff;
	border: 1px solid var(--border);
	border-radius: var(--radius-lg);
	box-shadow: 0 1px 3px rgba(13, 27, 42, 0.06);
	padding: 16px;
	max-width: 860px;
}

.wps-quick-scan-form {
	display: flex;
	align-items: center;
	gap: 10px;
}

.wps-quick-url-input {
	flex: 1;
	min-width: 220px;
	height: 48px;
	padding: 0 16px;
	border: 1px solid var(--border-strong);
	border-radius: 12px;
	background: #ffffff;
	color: var(--text);
	font-family: Inter, system-ui, -apple-system, sans-serif;
	font-size: 16px;
	line-height: 1;
}

.wps-quick-url-input:focus {
	outline: none;
	border-color: var(--primary);
	box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.15);
}

.wps-quick-url-input::placeholder {
	color: var(--text-secondary);
}

.wps-quick-scan-btn,
button.wps-quick-scan-btn {
	height: 48px;
	padding: 0 24px;
	border: 1px solid #f5a623;
	border-radius: 12px;
	background: #f5a623;
	color: #0D1B2A;
	font-family: Inter, system-ui, -apple-system, sans-serif;
	font-size: 16px;
	font-weight: 600;
	line-height: 1;
	cursor: pointer;
	appearance: none;
	-webkit-appearance: none;
	transition: background var(--duration) var(--ease), border-color var(--duration) var(--ease), transform var(--duration) var(--ease);
	box-shadow: 0 4px 14px rgba(245, 166, 35, 0.3);
}

/* Defend quick bar controls from aggressive theme defaults. */
.wps-quick-scan-box .wps-quick-url-input,
.wps-quick-scan-box input.wps-quick-url-input {
	border-radius: 12px !important;
	border-color: var(--border-strong) !important;
	background: #ffffff !important;
	color: var(--text) !important;
	box-shadow: none !important;
}

.wps-quick-scan-box .wps-quick-scan-btn,
.wps-quick-scan-box button.wps-quick-scan-btn {
	border-radius: 12px !important;
	background: #f5a623 !important;
	border-color: #f5a623 !important;
	color: #0D1B2A !important;
}

.wps-quick-scan-btn:hover,
button.wps-quick-scan-btn:hover {
	background: #E09515;
	border-color: #E09515;
}

.wps-quick-scan-btn:active,
button.wps-quick-scan-btn:active {
	transform: translateY(1px);
}

/* ==========================================================================
   Form Section
   ========================================================================== */

.wps-scanner-form-section {
	text-align: center;
	margin-bottom: 30px;
}

.wps-scanner-title {
	font-size: 28px;
	font-weight: 700;
	color: var(--wps-gray-900);
	margin: 0 0 10px 0;
}

.wps-scanner-description {
	font-size: 16px;
	color: var(--wps-gray-500);
	margin: 0 0 25px 0;
}

.wps-scanner-form {
	max-width: 600px;
	margin: 0 auto;
}

.wps-input-group {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
}

.wps-url-input {
	flex: 1;
	min-width: 250px;
	padding: 14px 18px;
	font-size: 16px;
	border: 2px solid var(--wps-gray-300);
	border-radius: var(--wps-border-radius);
	background: var(--surface);
	color: var(--text);
	outline: none;
	transition: border-color 0.2s ease;
}

.wps-url-input:focus {
	border-color: var(--wps-primary);
}

.wps-url-input::placeholder {
	color: #6b7280;
}

.wps-scan-btn {
	padding: 14px 28px;
	font-size: 16px;
	font-weight: 600;
	color: #ffffff;
	background: var(--wps-primary);
	border: none;
	border-radius: var(--wps-border-radius);
	cursor: pointer;
	transition: background 0.2s ease;
	box-shadow: 0 6px 22px rgba(var(--primary-rgb), 0.35);
}

.wps-scan-btn:hover {
	background: var(--wps-primary-hover);
}

.wps-scan-btn:disabled {
	background: var(--wps-gray-300);
	cursor: not-allowed;
	box-shadow: none;
}

.wps-error-message {
	color: var(--wps-danger);
	font-size: 14px;
	margin-top: 10px;
	text-align: left;
}

/* ==========================================================================
   ThreatMonitor-style Results Layout
   ========================================================================== */

.wps-results-section {
	margin-top: 32px;
}

.wps-lead-gate {
	margin-bottom: 18px;
}

.wps-lead-gate-card {
	background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
	border: 1px solid var(--border);
	border-radius: var(--radius-lg);
	padding: 22px;
	box-shadow: var(--shadow);
	text-align: center;
}

.wps-lead-gate-title {
	margin: 0 0 8px 0;
	font-size: 22px;
	font-weight: 700;
	color: var(--text);
}

.wps-lead-gate-subtitle {
	margin: 0 0 12px 0;
	font-size: 14px;
	color: var(--text-secondary);
}

.wps-lead-grade-preview {
	display: flex;
	gap: 12px;
	justify-content: center;
	align-items: stretch;
	margin: 0 0 12px 0;
	flex-wrap: wrap;
}

.wps-lead-grade-box,
.wps-lead-score-box {
	min-width: 170px;
	padding: 12px 16px;
	border: 1px solid var(--border);
	border-radius: 12px;
	background: #ffffff;
	box-shadow: var(--shadow-sm);
	text-align: center;
}

.wps-lead-grade-label,
.wps-lead-score-label {
	display: block;
	font-size: 12px;
	font-weight: 600;
	color: var(--text-secondary);
	margin-bottom: 4px;
	text-transform: uppercase;
	letter-spacing: 0.4px;
}

.wps-lead-grade-letter {
	display: block;
	font-size: 34px;
	line-height: 1;
	font-weight: 800;
	color: var(--primary);
}

.wps-lead-score-value {
	display: block;
	font-size: 28px;
	line-height: 1.1;
	font-weight: 800;
	color: var(--text);
}

.wps-lead-gate-url {
	margin: 0 0 14px 0;
	font-size: 13px;
	color: var(--primary);
	word-break: break-all;
}

.wps-lead-form {
	max-width: 560px;
	margin: 0 auto;
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
	justify-content: center;
}

.wps-lead-email {
	flex: 1;
	min-width: 260px;
	padding: 12px 14px;
	border: 1px solid var(--border-strong);
	border-radius: 12px;
	background: #fff;
	color: var(--text);
	font-size: 15px;
}

.wps-lead-email:focus {
	outline: none;
	border-color: var(--primary);
	box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.15);
}

.wps-unlock-report-btn {
	min-width: 220px;
}

.wps-lead-success {
	margin: 12px 0 0 0;
	color: #15803D;
	font-size: 14px;
	font-weight: 600;
}

.wps-lead-blur-preview {
	margin-top: 14px;
	border-radius: 14px;
	border: 1px solid var(--border);
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.95) 0%, rgba(247, 249, 252, 0.95) 100%);
	padding: 16px;
	box-shadow: var(--shadow-sm);
	position: relative;
	overflow: hidden;
}

.wps-lead-blur-preview::after {
	content: '';
	position: absolute;
	inset: 0;
	backdrop-filter: blur(5px);
	-webkit-backdrop-filter: blur(5px);
	pointer-events: none;
}

.wps-lead-blur-row {
	height: 14px;
	border-radius: 999px;
	background: rgba(var(--primary-rgb), 0.18);
	margin-bottom: 10px;
}

.wps-lead-blur-row-short {
	width: 62%;
}

.wps-lead-blur-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 10px;
}

.wps-lead-blur-card {
	height: 84px;
	border-radius: 10px;
	background: rgba(var(--primary-rgb), 0.12);
	border: 1px solid rgba(var(--primary-rgb), 0.2);
}

.wps-results-header {
	display: flex;
	align-items: stretch;
	justify-content: flex-start;
	margin-bottom: 0;
}

.wps-results-layout {
	display: grid;
	grid-template-columns: minmax(0, 2fr) minmax(0, 1.1fr);
	gap: 24px;
	align-items: flex-start;
}

.wps-results-main {
	display: flex;
	flex-direction: column;
	gap: 15px;
}

.wps-results-side {
	display: flex;
	flex-direction: column;
	gap: 15px;
}

@media (min-width: 960px) {
	.wps-results-side {
		position: sticky;
		top: 0;
	}
}

/* ==========================================================================
   Loading Section
   ========================================================================== */

.wps-loading-section {
	text-align: center;
	padding: 40px 20px;
}

.wps-spinner {
	width: 50px;
	height: 50px;
	border: 4px solid var(--wps-gray-200);
	border-top-color: var(--wps-primary);
	border-radius: 50%;
	margin: 0 auto 20px;
	animation: wps-spin 1s linear infinite;
}

@keyframes wps-spin {
	to {
		transform: rotate(360deg);
	}
}

.wps-loading-text {
	font-size: 18px;
	font-weight: 600;
	color: var(--wps-gray-700);
	margin: 0 0 20px 0;
}

.wps-progress-bar {
	max-width: 400px;
	height: 8px;
	background: var(--wps-gray-200);
	border-radius: 4px;
	margin: 0 auto 10px;
	overflow: hidden;
}

.wps-progress-fill {
	height: 100%;
	background: var(--wps-primary);
	border-radius: 4px;
	transition: width 0.3s ease;
}

.wps-progress-step {
	font-size: 14px;
	color: var(--wps-gray-500);
	margin: 0;
}

/* ==========================================================================
   Grade Badge
   ========================================================================== */

.wps-grade-section {
	width: 100%;
	display: flex;
	flex-direction: column;
	align-items: stretch;
	justify-content: flex-start;
	gap: 14px;
	padding: 20px 24px;
	background: linear-gradient(135deg, #ffffff 0%, rgba(var(--primary-rgb), 0.04) 100%);
	border-radius: var(--wps-border-radius);
	border: 1px solid #F3CBCD;
	box-shadow: var(--shadow);
	position: relative;
	overflow: hidden;
}

.wps-grade-top-row {
	display: flex;
	align-items: flex-start;
	gap: 16px;
}

.wps-grade-bottom-row {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.wps-grade-badge {
	width: 110px;
	height: 110px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	background: radial-gradient(circle at 30% 20%, #3b6fbe 0, #2858A6 55%, #1C4285 100%);
	box-shadow: var(--wps-shadow-lg);
	transform: translateY(-4px);
	border: 4px solid #fff;
	box-shadow: 0 10px 22px rgba(13, 27, 42, 0.15);
	flex-shrink: 0;
}

.wps-grade-letter {
	font-size: 52px;
	font-weight: 700;
	color: #ffffff;
}

/* Grade Colors */
.wps-grade-badge.grade-a {
	background: var(--wps-success);
}

.wps-grade-badge.grade-b {
	background: #22c55e;
}

.wps-grade-badge.grade-c {
	background: var(--wps-warning);
}

.wps-grade-badge.grade-d {
	background: #f97316;
}

.wps-grade-badge.grade-f {
	background: var(--wps-danger);
}

.wps-grade-info {
	text-align: left;
}

.wps-grade-headline {
	margin: 0;
	font-size: 18px;
	font-weight: 700;
	color: var(--text);
	line-height: 1.3;
}

.wps-grade-headline-highlight {
	color: #C0392B;
}

.wps-grade-checkpoints {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.wps-grade-checkpoints li {
	position: relative;
	padding-left: 24px;
	color: var(--text-secondary);
	font-size: 14px;
	line-height: 1.4;
}

.wps-grade-checkpoints li::before {
	content: "✓";
	position: absolute;
	left: 0;
	top: 0;
	width: 16px;
	height: 16px;
	border-radius: 50%;
	background: #22c55e;
	color: #fff;
	font-size: 11px;
	font-weight: 700;
	line-height: 16px;
	text-align: center;
}

.wps-grade-score {
	font-size: 20px;
	font-weight: 700;
	color: var(--wps-gray-900);
	margin: 0;
}

.wps-scanned-url {
	font-size: 16px;
	color: var(--wps-gray-500);
	margin: 0;
	word-break: break-all;
}

.wps-grade-cta-box {
	margin-left: 0;
	max-width: none;
	display: flex;
	flex-direction: column;
	gap: 10px;
	width: 100%;
	align-items: center;
}

.wps-grade-cta-text {
	margin: 0;
	padding: 16px 18px;
	border-radius: 12px;
	border: 1px solid #F6DFAB;
	background: #FFF5DC;
	color: #4B3A12;
	font-size: 17px;
	font-weight: 600;
	width: 100%;
	text-align: center;
}

.wps-grade-cta-text::before {
	content: "➜";
	margin-right: 8px;
	color: #E09515;
}

.wps-grade-cta-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 13px 28px;
	border-radius: 12px;
	background: #f5a623;
	border: 1px solid #f5a623;
	color: #0D1B2A;
	font-size: 16px;
	font-weight: 700;
	text-decoration: none;
	min-width: 320px;
	max-width: 460px;
	width: 100%;
}

.wps-grade-risk-intro {
	margin: 2px 0 0;
	color: #6B7280;
	font-size: 14px;
	font-weight: 600;
}

body.wps-fullscreen-template .wps-grade-section {
	border: 1px solid #F4CFD2;
	background: linear-gradient(180deg, #FFFDFE 0%, #FFFFFF 70%);
}

body.wps-fullscreen-template .wps-grade-badge {
	transform: translateY(-6px);
}

.wps-grade-cta-btn:hover {
	background: #E09515;
	border-color: #E09515;
	color: #0D1B2A;
}

/* ==========================================================================
   Website Screenshot Section
   ========================================================================== */

.wps-screenshot-section {
	margin-bottom: 20px;
}

.wps-screenshot-container {
	position: relative;
	background: var(--wps-gray-100);
	border: 1px solid var(--wps-gray-200);
	border-radius: var(--wps-border-radius);
	overflow: hidden;
	min-height: 200px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.wps-screenshot-loading {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 12px;
	color: var(--wps-gray-500);
	font-size: 14px;
}

.wps-screenshot-spinner {
	width: 30px;
	height: 30px;
	border: 3px solid var(--wps-gray-200);
	border-top-color: var(--wps-primary);
	border-radius: 50%;
	animation: wps-spin 1s linear infinite;
}

.wps-screenshot-image {
	width: 100%;
	height: auto;
	max-height: 400px;
	object-fit: contain;
	display: block;
}

.wps-screenshot-error {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 40px;
	color: var(--wps-gray-500);
	font-size: 14px;
	font-style: italic;
}

/* ==========================================================================
   Result Cards
   ========================================================================== */

.wps-result-card {
	background: var(--surface);
	border: 1px solid var(--border);
	border-radius: var(--wps-border-radius);
	margin-bottom: 15px;
	box-shadow: var(--shadow-sm);
	transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.wps-result-card:hover {
	border-color: rgba(var(--primary-rgb), 0.35);
	box-shadow: var(--shadow-glow);
	transform: translateY(-1px);
}

.wps-card-title {
	font-size: 16px;
	font-weight: 600;
	color: var(--wps-gray-900);
	padding: 15px 20px;
	margin: 0;
	border-bottom: 1px solid var(--border);
	background: var(--bg-alt);
	border-radius: var(--wps-border-radius) var(--wps-border-radius) 0 0;
}

.wps-card-content {
	padding: 15px 20px;
	color: var(--text-secondary);
}

/* ==========================================================================
   Status Icons and Items
   ========================================================================== */

.wps-status-item {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	padding: 8px 0;
	border-bottom: 1px solid var(--wps-gray-100);
}

.wps-status-item:last-child {
	border-bottom: none;
}

.wps-status-icon {
	flex-shrink: 0;
	width: 22px;
	height: 22px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 12px;
	font-weight: 700;
	color: var(--wps-white);
}

.wps-status-icon.status-pass {
	background: var(--wps-success);
}

.wps-status-icon.status-pass::before {
	content: "✓";
}

.wps-status-icon.status-fail {
	background: var(--wps-danger);
}

.wps-status-icon.status-fail::before {
	content: "✗";
}

.wps-status-icon.status-warn {
	background: var(--wps-warning);
}

.wps-status-icon.status-warn::before {
	content: "!";
}

.wps-status-icon.status-info {
	background: var(--wps-info);
}

.wps-status-icon.status-info::before {
	content: "i";
	font-style: italic;
}

.wps-status-text {
	flex: 1;
}

.wps-status-label {
	font-weight: 500;
	color: var(--wps-gray-900);
}

.wps-status-value {
	font-size: 14px;
	color: var(--wps-gray-500);
	margin-top: 2px;
}

/* ==========================================================================
   Headers Table
   ========================================================================== */

.wps-headers-table {
	width: 100%;
	border-collapse: collapse;
}

.wps-headers-table th,
.wps-headers-table td {
	padding: 10px 12px;
	text-align: left;
	border-bottom: 1px solid var(--wps-gray-100);
}

.wps-headers-table th {
	font-weight: 600;
	color: var(--wps-gray-700);
	background: var(--wps-gray-50);
}

.wps-headers-table tr:last-child td {
	border-bottom: none;
}

.wps-header-status {
	width: 30px;
	text-align: center;
}

/* ==========================================================================
   Plugin/Theme List (Legacy)
   ========================================================================== */

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

.wps-component-item {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 10px 0;
	border-bottom: 1px solid var(--wps-gray-100);
}

.wps-component-item:last-child {
	border-bottom: none;
}

.wps-component-name {
	font-weight: 500;
	color: var(--wps-gray-900);
}

.wps-component-version {
	font-size: 13px;
	color: var(--wps-gray-500);
}

.wps-component-outdated {
	font-size: 12px;
	color: var(--wps-danger);
	font-weight: 500;
}

.wps-component-current {
	font-size: 12px;
	color: var(--wps-success);
}

/* ==========================================================================
   Enhanced Plugin/Theme Cards
   ========================================================================== */

.wps-plugins-list {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.wps-plugin-card {
	background: var(--wps-white);
	border: 1px solid var(--wps-gray-200);
	border-radius: 6px;
	padding: 15px;
	transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.wps-plugin-card:hover {
	border-color: var(--wps-primary);
	box-shadow: 0 16px 40px rgba(15, 23, 42, 0.65);
	transform: translateY(-2px);
}

.wps-plugin-card.wps-plugin-current {
	border-left: 3px solid var(--wps-success);
}

.wps-plugin-card.wps-plugin-outdated {
	border-left: 3px solid var(--wps-warning);
	background: #fffbeb;
}

.wps-plugin-card.wps-plugin-vulnerable {
	border-left: 3px solid var(--wps-danger);
	background: #fef2f2;
}

/* Ensure readable text on light plugin cards */
.wps-plugin-card.wps-plugin-outdated,
.wps-plugin-card.wps-plugin-vulnerable {
	color: #111827;
}

.wps-plugin-card.wps-plugin-outdated .wps-plugin-name,
.wps-plugin-card.wps-plugin-vulnerable .wps-plugin-name,
.wps-plugin-card.wps-plugin-outdated .wps-version-label,
.wps-plugin-card.wps-plugin-vulnerable .wps-version-label,
.wps-plugin-card.wps-plugin-outdated .wps-version-value,
.wps-plugin-card.wps-plugin-vulnerable .wps-version-value,
.wps-plugin-card.wps-plugin-outdated .wps-meta-item,
.wps-plugin-card.wps-plugin-vulnerable .wps-meta-item {
	color: #111827;
}

.wps-plugin-header {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 10px;
	flex-wrap: wrap;
}

.wps-plugin-name {
	font-weight: 600;
	font-size: 15px;
	color: var(--wps-gray-900);
}

.wps-vuln-badge,
.wps-outdated-badge {
	padding: 2px 8px;
	font-size: 10px;
	font-weight: 700;
	text-transform: uppercase;
	border-radius: 3px;
	letter-spacing: 0.5px;
}

.wps-vuln-badge {
	background: var(--wps-danger);
	color: var(--wps-white);
}

.wps-outdated-badge {
	background: var(--wps-warning);
	color: var(--wps-white);
}

.wps-plugin-versions {
	display: flex;
	flex-direction: column;
	gap: 6px;
	margin-bottom: 10px;
}

.wps-version-row {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 13px;
}

.wps-version-label {
	color: var(--wps-gray-500);
	min-width: 70px;
}

.wps-version-value {
	font-weight: 500;
	color: var(--wps-gray-700);
}

.wps-version-old {
	color: var(--wps-danger);
	text-decoration: line-through;
	opacity: 0.8;
}

.wps-version-new {
	color: var(--wps-success);
	font-weight: 600;
}

.wps-version-unknown {
	color: var(--wps-gray-400);
	font-style: italic;
}

.wps-plugin-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 15px;
	padding-top: 10px;
	border-top: 1px solid var(--wps-gray-100);
	margin-top: 10px;
}

.wps-meta-item {
	font-size: 12px;
	color: var(--wps-gray-500);
}

/* Vulnerability Details */
.wps-vulnerabilities {
	background: #fef2f2;
	border: 1px solid #fecaca;
	border-radius: 4px;
	padding: 12px;
	margin-top: 10px;
}

.wps-vuln-title {
	font-size: 12px;
	font-weight: 600;
	color: var(--wps-danger);
	margin-bottom: 8px;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.wps-vuln-item {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	padding: 8px 0;
	border-bottom: 1px solid #fecaca;
	font-size: 13px;
}

.wps-vuln-item:last-child {
	border-bottom: none;
	padding-bottom: 0;
}

.wps-vuln-severity {
	padding: 2px 6px;
	font-size: 10px;
	font-weight: 600;
	text-transform: uppercase;
	border-radius: 3px;
}

.wps-severity-critical {
	background: var(--wps-danger);
	color: var(--wps-white);
}

.wps-severity-medium {
	background: #f97316;
	color: var(--wps-white);
}

.wps-severity-low {
	background: var(--wps-warning);
	color: var(--wps-white);
}

.wps-severity-unknown {
	background: var(--wps-gray-300);
	color: var(--wps-gray-700);
}

.wps-vuln-name {
	flex: 1;
	color: var(--wps-gray-700);
	min-width: 150px;
}

.wps-vuln-cvss {
	font-size: 11px;
	font-weight: 600;
	color: var(--wps-gray-500);
}

.wps-vuln-fix {
	width: 100%;
	font-size: 12px;
	color: var(--wps-success);
	font-weight: 500;
}

.wps-vuln-more {
	font-size: 12px;
	color: var(--wps-danger);
	font-style: italic;
	padding-top: 8px;
}

/* ==========================================================================
   Recommendations
   ========================================================================== */

.wps-recommendations {
	border-color: var(--wps-primary);
}

.wps-recommendations .wps-card-title {
	background: var(--primary-light);
	color: var(--primary-dark);
}

.wps-recommendation-item {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 12px 0;
	border-bottom: 1px solid var(--wps-gray-100);
	transition: background 0.18s ease, border-color 0.18s ease, transform 0.18s ease;
}

.wps-recommendation-item:last-child {
	border-bottom: none;
}

.wps-recommendation-item:hover {
	background: var(--surface-hover);
	border-left: 3px solid var(--wps-primary);
	transform: translateY(-1px);
}

.wps-recommendation-priority-icon {
	flex-shrink: 0;
	width: 34px;
	height: 34px;
	text-align: center;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 18px;
	font-weight: 800;
	border-radius: 50%;
}

.wps-priority-critical {
	background: var(--wps-danger);
	color: var(--wps-white);
}

.wps-priority-high {
	background: #f97316;
	color: var(--wps-white);
}

.wps-priority-medium {
	background: #f5a623;
	color: #0D1B2A;
}

.wps-priority-low {
	background: #e2e8f0;
	color: #475569;
}

.wps-recommendation-text {
	flex: 1;
	color: var(--wps-gray-700);
}

/* ==========================================================================
   Summary Stats
   ========================================================================== */

.wps-summary-text {
	font-size: 16px;
	color: var(--wps-gray-700);
	margin: 0 0 20px 0;
	line-height: 1.6;
}

.wps-summary-text strong {
	color: var(--wps-gray-900);
}

.wps-summary-stats {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 15px;
}

.wps-stat-item {
	text-align: center;
	padding: 20px 15px;
	background: var(--wps-gray-50);
	border-radius: var(--wps-border-radius);
	border: 1px solid var(--wps-gray-200);
}

.wps-stat-number {
	font-size: 32px;
	font-weight: 700;
	color: var(--wps-gray-900);
	line-height: 1;
}

.wps-stat-label {
	font-size: 14px;
	font-weight: 600;
	color: var(--wps-gray-700);
	margin-top: 8px;
}

.wps-stat-desc {
	font-size: 12px;
	color: var(--wps-gray-500);
	margin-top: 4px;
}

.wps-stat-number.stat-good {
	color: var(--wps-success);
}

.wps-stat-number.stat-medium {
	color: #f97316;
}

.wps-stat-number.stat-warning {
	color: var(--wps-warning);
}

.wps-stat-number.stat-bad {
	color: var(--wps-danger);
}

.wps-stat-label {
	font-size: 13px;
	color: var(--wps-gray-500);
	margin-top: 5px;
}

/* ==========================================================================
   Error Section
   ========================================================================== */

.wps-error-section {
	text-align: center;
	padding: 40px 20px;
	background: #fef2f2;
	border: 1px solid #fecaca;
	border-radius: var(--wps-border-radius);
}

.wps-error-icon {
	width: 60px;
	height: 60px;
	border-radius: 50%;
	background: var(--wps-danger);
	color: var(--wps-white);
	font-size: 32px;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 15px;
}

.wps-error-text {
	font-size: 16px;
	color: var(--wps-danger);
	margin: 0 0 20px 0;
}

/* ==========================================================================
   Action Buttons Section
   ========================================================================== */

.wps-action-buttons {
	display: flex;
	justify-content: center;
	gap: 15px;
	padding-top: 25px;
	flex-wrap: wrap;
}

.wps-btn {
	padding: 12px 24px;
	font-size: 15px;
	font-weight: 600;
	border: none;
	border-radius: var(--wps-border-radius);
	cursor: pointer;
	transition: all 0.2s ease;
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.wps-btn-secondary {
	background: transparent;
	color: var(--primary);
	border: 1px solid var(--border-strong);
}

.wps-btn-secondary:hover {
	background: var(--primary-light);
	border-color: var(--wps-primary);
}

.wps-btn-icon {
	font-size: 18px;
}

/* Keep scanner buttons consistent when themes (e.g., Hello Elementor)
   apply aggressive global button styles. */
.wps-scanner-wrapper .wps-scan-btn,
.wps-scanner-wrapper button.wps-scan-btn,
.wps-scanner-wrapper .wps-btn,
.wps-scanner-wrapper button.wps-btn {
	appearance: none !important;
	-webkit-appearance: none !important;
	font-family: Inter, system-ui, -apple-system, sans-serif !important;
	font-weight: 600 !important;
	text-transform: none !important;
	letter-spacing: normal !important;
	border-radius: var(--radius) !important;
	text-decoration: none !important;
}

.wps-scanner-wrapper .wps-scan-btn,
.wps-scanner-wrapper button.wps-scan-btn {
	background: var(--primary) !important;
	color: #ffffff !important;
	border: 1px solid var(--primary) !important;
	box-shadow: 0 6px 22px rgba(var(--primary-rgb), 0.35) !important;
}

.wps-scanner-wrapper .wps-scan-btn:hover,
.wps-scanner-wrapper button.wps-scan-btn:hover,
.wps-scanner-wrapper .wps-scan-btn:focus,
.wps-scanner-wrapper button.wps-scan-btn:focus {
	background: var(--primary-hover) !important;
	border-color: var(--primary-hover) !important;
	color: #ffffff !important;
}

.wps-scanner-wrapper .wps-scan-btn:disabled,
.wps-scanner-wrapper button.wps-scan-btn:disabled {
	background: var(--border-strong) !important;
	border-color: var(--border-strong) !important;
	color: #ffffff !important;
	box-shadow: none !important;
}

.wps-scanner-wrapper .wps-btn-secondary,
.wps-scanner-wrapper button.wps-btn-secondary {
	background: var(--primary-light) !important;
	color: var(--primary-dark) !important;
	border: 1px solid rgba(var(--primary-rgb), 0.35) !important;
}

.wps-scanner-wrapper .wps-btn-secondary:hover,
.wps-scanner-wrapper button.wps-btn-secondary:hover,
.wps-scanner-wrapper .wps-btn-secondary:focus,
.wps-scanner-wrapper button.wps-btn-secondary:focus {
	background: #dfe9fb !important;
	border-color: var(--primary) !important;
	color: var(--primary-dark) !important;
}

.wps-scanner-wrapper .wps-inline-cta-btn,
.wps-scanner-wrapper .wps-recommendations-cta-btn {
	text-decoration: none !important;
	font-family: Inter, system-ui, -apple-system, sans-serif !important;
}

.wps-scan-duration {
	font-size: 14px;
	color: var(--wps-gray-500);
	margin-top: 0;
	text-align: left;
}

/* ==========================================================================
   Trust Card + CTA Blocks
   ========================================================================== */

.wps-trust-card .wps-card-content {
	padding: 18px 20px;
}

.wps-trust-header {
	padding: 0 0 14px 0;
	margin: 0 0 14px 0;
	border-bottom: 1px solid var(--border);
}

.wps-trust-heading {
	margin: 0 0 10px 0;
	font-size: 14px;
	font-weight: 700;
	color: var(--text);
}

.wps-trust-rating-row {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 10px;
}

.wps-trust-rating-score {
	font-size: 22px;
	font-weight: 800;
	color: var(--text);
	line-height: 1;
}

.wps-trust-stars {
	font-size: 16px;
	letter-spacing: 1px;
	color: #f5a623;
}

.wps-trust-checkpoints {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.wps-trust-checkpoints li {
	position: relative;
	padding-left: 22px;
	color: var(--text-secondary);
	font-size: 13px;
	font-weight: 600;
}

.wps-trust-checkpoints li::before {
	content: "✓";
	position: absolute;
	left: 0;
	top: 0;
	width: 16px;
	height: 16px;
	border-radius: 4px;
	background: #22c55e;
	color: #fff;
	font-size: 11px;
	line-height: 16px;
	text-align: center;
}

.wps-trust-quote {
	margin: 0 0 16px 0;
	color: var(--text-secondary);
	font-size: 14px;
	line-height: 1.55;
	font-style: italic;
}

.wps-trust-person {
	display: flex;
	align-items: center;
	gap: 12px;
}

.wps-trust-avatar {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: var(--primary);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 18px;
	font-weight: 700;
	text-transform: uppercase;
	flex-shrink: 0;
}

.wps-trust-name {
	font-size: 15px;
	font-weight: 700;
	color: var(--text);
	line-height: 1.1;
}

.wps-trust-role {
	color: var(--text);
	font-size: 12px;
}

.wps-trust-date {
	color: var(--text-secondary);
	font-size: 11px;
}


.wps-inline-cta {
	margin-top: 14px;
	padding-top: 12px;
	border-top: 1px solid var(--border);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	flex-wrap: wrap;
}

.wps-inline-cta-text {
	color: var(--text-secondary);
	font-size: 13px;
}

.wps-inline-cta-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 8px 14px;
	border-radius: 10px;
	background: #f5a623;
	border: 1px solid #f5a623;
	color: #0D1B2A;
	font-size: 13px;
	font-weight: 700;
	text-decoration: none;
}

.wps-inline-cta-btn:hover {
	background: #E09515;
	border-color: #E09515;
	color: #0D1B2A;
}

.wps-recommendations-cta {
	margin-top: 14px;
	padding-top: 12px;
	border-top: 1px solid var(--border);
}

.wps-recommendations-cta-text {
	margin: 0 0 10px 0;
	color: var(--text-secondary);
	font-size: 13px;
}

.wps-recommendations-cta-btn {
	display: inline-flex;
	width: 100%;
	align-items: center;
	justify-content: center;
	padding: 11px 14px;
	border-radius: 12px;
	background: #f5a623;
	border: 1px solid #f5a623;
	color: #0D1B2A;
	font-size: 14px;
	font-weight: 700;
	text-decoration: none;
}

.wps-recommendations-cta-btn:hover {
	background: #E09515;
	border-color: #E09515;
	color: #0D1B2A;
}

/* ==========================================================================
   Empty State
   ========================================================================== */

.wps-empty-state {
	text-align: center;
	padding: 20px;
	color: var(--wps-gray-500);
	font-style: italic;
}

/* ==========================================================================
   Responsive Design
   ========================================================================== */

@media (max-width: 960px) {
	.wps-results-layout {
		grid-template-columns: 1fr;
	}

	.wps-results-side {
		position: static;
	}
}

@media (max-width: 768px) {
	.wps-scanner-wrapper {
		padding: 15px;
	}

	.wps-scanner-title {
		font-size: 24px;
	}

	.wps-scanner-description {
		font-size: 14px;
	}

	.wps-results-header {
		flex-direction: column;
		gap: 15px;
	}
}

@media (max-width: 600px) {
	.wps-scanner-wrapper {
		padding: 12px;
	}

	.wps-scanner-title {
		font-size: 22px;
	}

	.wps-input-group {
		flex-direction: column;
	}

	.wps-url-input,
	.wps-scan-btn {
		width: 100%;
	}

	.wps-quick-scan-form {
		flex-direction: column;
		align-items: stretch;
	}

	.wps-quick-url-input,
	.wps-quick-scan-btn,
	button.wps-quick-scan-btn {
		width: 100%;
	}

	.wps-grade-section {
		flex-direction: column;
		text-align: center;
		padding: 16px;
	}

	.wps-grade-info {
		text-align: center;
	}

	.wps-grade-cta-box {
		margin-left: 0;
		width: 100%;
		max-width: none;
	}

	.wps-grade-headline {
		text-align: center;
	}

	.wps-grade-risk-intro {
		text-align: center;
	}

	.wps-grade-checkpoints {
		text-align: left;
	}

	.wps-grade-top-row {
		flex-direction: column;
		align-items: center;
	}

	.wps-grade-checkpoints li {
		font-size: 14px;
	}

	.wps-grade-cta-btn {
		min-width: 100%;
		width: 100%;
	}

	.wps-grade-badge {
		width: 80px;
		height: 80px;
	}

	.wps-grade-letter {
		font-size: 40px;
	}

	.wps-card-title,
	.wps-card-content {
		padding: 12px 15px;
	}

	.wps-headers-table th,
	.wps-headers-table td {
		padding: 8px;
		font-size: 14px;
	}

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

	.wps-component-item {
		flex-direction: column;
		align-items: flex-start;
		gap: 5px;
	}

	.wps-plugin-card {
		padding: 12px;
	}

	.wps-detection-accordion-header {
		padding: 10px 12px;
	}

	.wps-detection-accordion-content {
		padding: 12px;
	}
}

@media (max-width: 400px) {
	.wps-summary-stats {
		grid-template-columns: 1fr;
	}

	.wps-stat-item {
		padding: 12px;
	}

	.wps-stat-number {
		font-size: 24px;
	}

	.wps-action-buttons {
		flex-direction: column;
	}

	.wps-action-buttons button {
		width: 100%;
	}
}

/* ==========================================================================
   PDF Header/Footer (hidden on screen, visible in print)
   ========================================================================== */

.wps-pdf-header,
.wps-pdf-footer,
.wps-pdf-grade-message,
.wps-pdf-cta {
	display: none;
}

/* ==========================================================================
   Print Styles for PDF Export - Light Theme
   ========================================================================== */

@media print {
	/* Page setup */
	@page {
		margin: 8mm;
		size: A4;
		background: #ffffff !important;
	}

	/* Force colors to print and set white background */
	* {
		-webkit-print-color-adjust: exact !important;
		print-color-adjust: exact !important;
		color-adjust: exact !important;
	}

	/* Body and page background - fix dark blank space */
	html,
	body,
	body.wps-fullscreen-template,
	.wps-threatmonitor-page {
		background: #ffffff !important;
		background-color: #ffffff !important;
		min-height: 100% !important;
	}

	/* Hide everything except scanner */
	body * {
		visibility: hidden;
	}

	.wps-scanner-wrapper,
	.wps-scanner-wrapper * {
		visibility: visible;
	}

	/* Main wrapper - light theme */
	.wps-scanner-wrapper {
		position: absolute;
		left: 0;
		top: 0;
		width: 100%;
		max-width: none;
		padding: 15px;
		margin: 0;
		font-size: 10px;
		font-family: Inter, system-ui, -apple-system, sans-serif;
		background: #ffffff !important;
		color: #111827 !important;
		border-radius: 0 !important;
		box-shadow: none !important;
	}

	/* Hide form and buttons */
	.wps-scanner-form-section,
	.wps-loading-section,
	.wps-error-section,
	.wps-action-buttons,
	.wps-lead-gate,
	.wps-grade-cta-box,
	.wps-trust-card,
	.wps-inline-cta,
	.wps-recommendations-cta {
		display: none !important;
	}

	.wps-results-section {
		display: block !important;
		background: #ffffff !important;
		margin-top: 0 !important;
	}

	/* Single column layout */
	.wps-results-layout {
		display: block !important;
	}

	.wps-results-main,
	.wps-results-side {
		display: block !important;
		width: 100% !important;
		position: static !important;
	}

	/* Grade section */
	.wps-grade-section {
		background: #f8fafc !important;
		border: 1px solid #e2e8f0 !important;
		padding: 12px !important;
		margin-bottom: 10px !important;
		border-radius: 6px !important;
		box-shadow: none !important;
	}

	.wps-grade-badge {
		width: 60px !important;
		height: 60px !important;
	}

	.wps-grade-badge.grade-a { background: #15803d !important; }
	.wps-grade-badge.grade-b { background: #22c55e !important; }
	.wps-grade-badge.grade-c { background: #eab308 !important; }
	.wps-grade-badge.grade-d { background: #f97316 !important; }
	.wps-grade-badge.grade-f { background: #ef4444 !important; }

	.wps-grade-letter {
		font-size: 28px !important;
		color: #fff !important;
	}

	.wps-grade-score {
		color: #111827 !important;
		font-size: 12px !important;
	}

	.wps-scanned-url {
		color: #111827 !important;
		font-size: 10px !important;
	}

	/* Result cards - compact */
	.wps-result-card {
		page-break-inside: auto;
		break-inside: auto;
		margin-bottom: 8px !important;
		box-shadow: none !important;
		border: 1px solid #e2e8f0 !important;
		background: #ffffff !important;
		border-radius: 6px !important;
	}

	.wps-result-card:hover {
		transform: none !important;
		box-shadow: none !important;
	}

	/* Card titles - compact */
	.wps-card-title {
		background: #f1f5f9 !important;
		color: #111827 !important;
		border-bottom: 1px solid #e2e8f0 !important;
		padding: 8px 10px !important;
		font-size: 11px !important;
	}

	/* Card content */
	.wps-card-content {
		padding: 8px 10px !important;
		background: #ffffff !important;
		color: #111827 !important;
	}

	/* Summary stats - 4 column grid */
	.wps-summary-stats {
		display: grid !important;
		grid-template-columns: repeat(4, 1fr) !important;
		gap: 6px !important;
	}

	.wps-stat-item {
		padding: 6px !important;
		background: #f8fafc !important;
		border: 1px solid #e2e8f0 !important;
		border-radius: 4px !important;
	}

	.wps-stat-number {
		font-size: 18px !important;
	}

	.wps-stat-number.stat-bad { color: #dc2626 !important; }
	.wps-stat-number.stat-warning { color: #d97706 !important; }
	.wps-stat-number.stat-medium { color: #ea580c !important; }
	.wps-stat-number.stat-good { color: #16a34a !important; }

	.wps-stat-label {
		color: #111827 !important;
		font-size: 9px !important;
	}

	.wps-stat-desc {
		color: #374151 !important;
	}

	/* Status icons */
	.wps-status-icon {
		width: 14px !important;
		height: 14px !important;
		font-size: 8px !important;
	}

	.wps-status-icon.status-pass { background: #22c55e !important; color: #fff !important; }
	.wps-status-icon.status-fail { background: #ef4444 !important; color: #fff !important; }
	.wps-status-icon.status-warn { background: #eab308 !important; color: #fff !important; }
	.wps-status-icon.status-info { background: #0ea5e9 !important; color: #fff !important; }

	.wps-status-item {
		padding: 4px 0 !important;
		border-bottom: 1px solid #e2e8f0 !important;
	}

	.wps-status-label {
		color: #111827 !important;
		font-size: 10px !important;
	}

	.wps-status-value {
		color: #111827 !important;
		font-size: 9px !important;
	}

	/* Summary text */
	.wps-summary-text {
		color: #111827 !important;
	}

	.wps-summary-text strong {
		color: #111827 !important;
	}

	/* Malware section */
	.wps-malware-status {
		padding: 10px !important;
		border-radius: 6px !important;
	}

	.wps-malware-clean {
		background: #f0fdf4 !important;
		border: 1px solid #86efac !important;
	}

	.wps-malware-infected {
		background: #fef2f2 !important;
		border: 1px solid #fecaca !important;
	}

	.wps-malware-clean .wps-malware-status-icon { color: #16a34a !important; }
	.wps-malware-clean .wps-malware-status-text strong { color: #166534 !important; }
	.wps-malware-clean .wps-malware-status-text p { color: #15803d !important; }
	.wps-malware-infected .wps-malware-status-icon { color: #dc2626 !important; }
	.wps-malware-infected .wps-malware-status-text strong { color: #991b1b !important; }
	.wps-malware-infected .wps-malware-status-text p { color: #b91c1c !important; }

	/* Accordions - show content */
	.wps-detection-accordion-content {
		max-height: none !important;
		padding: 8px !important;
		display: block !important;
		border-top: 1px solid #e2e8f0 !important;
	}

	.wps-accordion-icon {
		display: none !important;
	}

	.wps-detection-accordion-item {
		background: #ffffff !important;
		border: 1px solid #e2e8f0 !important;
		margin-bottom: 6px !important;
	}

	.wps-detection-accordion-item.wps-detection-critical,
	.wps-detection-accordion-item.wps-detection-high {
		border-left: 3px solid #ef4444 !important;
	}

	.wps-detection-accordion-item.wps-detection-medium {
		border-left: 3px solid #f97316 !important;
	}

	.wps-detection-accordion-item.wps-detection-low {
		border-left: 3px solid #0ea5e9 !important;
	}

	.wps-detection-accordion-header {
		padding: 6px 8px !important;
		background: #f8fafc !important;
	}

	.wps-detection-accordion-title strong {
		color: #111827 !important;
	}

	.wps-detection-desc {
		color: #111827 !important;
	}

	.wps-detection-location {
		color: #374151 !important;
	}

	.wps-detection-location code {
		background: #f1f5f9 !important;
		color: #1e40af !important;
	}

	/* Severity badges */
	.wps-severity-badge,
	.wps-detection-severity,
	.wps-vuln-severity,
	.wps-outdated-badge,
	.wps-vuln-badge {
		font-size: 8px !important;
		padding: 2px 5px !important;
	}

	.wps-severity-badge.wps-severity-critical,
	.wps-severity-badge.wps-severity-high,
	.wps-severity-critical,
	.wps-severity-high { background: #ef4444 !important; color: #fff !important; }
	.wps-severity-badge.wps-severity-medium,
	.wps-severity-medium { background: #f97316 !important; color: #fff !important; }
	.wps-severity-badge.wps-severity-low,
	.wps-severity-low { background: #0ea5e9 !important; color: #fff !important; }

	/* Recommendations */
	.wps-recommendations .wps-card-title {
		background: #EBF1FC !important;
		color: #163572 !important;
	}

	.wps-recommendation-item {
		padding: 6px 0 !important;
		border-bottom: 1px solid #e2e8f0 !important;
	}

	.wps-recommendation-item:hover {
		background: transparent !important;
		transform: none !important;
	}

	.wps-recommendation-priority-icon {
		font-size: 7px !important;
		padding: 2px 5px !important;
		min-width: 50px !important;
	}

	.wps-priority-critical { background: #ef4444 !important; color: #fff !important; }
	.wps-priority-high { background: #f97316 !important; color: #fff !important; }
	.wps-priority-medium { background: #eab308 !important; color: #fff !important; }
	.wps-priority-low { background: #0ea5e9 !important; color: #fff !important; }

	.wps-recommendation-text {
		color: #111827 !important;
		font-size: 9px !important;
	}

	/* Code snippets */
	.wps-code-snippet {
		background: #1e293b !important;
		border: 1px solid #334155 !important;
		padding: 5px !important;
	}

	.wps-code-snippet code {
		color: #f87171 !important;
		font-size: 8px !important;
	}

	.wps-detection-fix {
		background: #fffbeb !important;
		border: 1px solid #fcd34d !important;
	}

	.wps-detection-fix strong {
		color: #92400e !important;
	}

	.wps-detection-fix li {
		color: #78350f !important;
	}

	/* Tables */
	.wps-headers-table th,
	.wps-headers-table td {
		padding: 4px 6px !important;
		border-bottom: 1px solid #e2e8f0 !important;
		font-size: 9px !important;
		color: #111827 !important;
	}

	.wps-headers-table th {
		background: #f1f5f9 !important;
		color: #111827 !important;
	}

	/* Plugin cards */
	.wps-plugin-card {
		margin-bottom: 5px !important;
		background: #ffffff !important;
		border: 1px solid #e2e8f0 !important;
		padding: 8px !important;
	}

	.wps-plugin-card.wps-plugin-outdated {
		background: #fffbeb !important;
		border-left: 3px solid #eab308 !important;
	}

	.wps-plugin-card.wps-plugin-vulnerable {
		background: #fef2f2 !important;
		border-left: 3px solid #ef4444 !important;
	}

	.wps-plugin-name {
		color: #111827 !important;
		font-size: 11px !important;
	}

	.wps-version-label {
		color: #374151 !important;
	}

	.wps-version-value {
		color: #111827 !important;
	}

	.wps-version-old {
		color: #dc2626 !important;
	}

	.wps-version-new {
		color: #16a34a !important;
	}

	.wps-meta-item {
		color: #374151 !important;
	}

	/* Screenshot */
	.wps-screenshot-section {
		margin-bottom: 8px;
	}

	.wps-screenshot-loading,
	.wps-screenshot-error {
		display: none !important;
	}

	.wps-screenshot-image {
		max-height: 150px;
	}

	.wps-screenshot-container {
		border: 1px solid #e2e8f0 !important;
		background: #f8fafc !important;
	}

	/* Scan duration */
	.wps-scan-duration {
		text-align: center;
		margin-top: 8px;
		padding-top: 8px;
		border-top: 1px solid #e2e8f0;
		color: #374151 !important;
		font-size: 9px !important;
	}

	/* Empty state */
	.wps-empty-state {
		color: #374151 !important;
	}

	/* Remove pseudo-element header/footer - using real elements now */
	.wps-results-section::before,
	.wps-results-section::after {
		display: none !important;
	}

	/* PDF Header - from settings */
	.wps-pdf-header {
		display: block !important;
		text-align: center;
		margin-bottom: 15px;
	}

	.wps-pdf-logo {
		display: none !important;
		max-width: 200px;
		max-height: 60px;
		margin: 0 auto 12px auto;
	}

	.wps-pdf-logo.has-logo {
		display: block !important;
	}

	.wps-pdf-heading-bar {
		padding: 20px 15px;
		border-radius: 6px;
		background: #2858A6 !important;
		border: 1px solid #1C4285 !important;
	}

	.wps-pdf-heading {
		font-size: 18px;
		font-weight: bold;
		color: #ffffff !important;
		margin: 0;
	}

	/* PDF Grade Messages - only show if has content */
	.wps-pdf-grade-message {
		display: none !important;
		padding: 12px 15px;
		border-radius: 6px;
		margin: 10px 0;
		font-size: 11px;
		line-height: 1.5;
	}

	.wps-pdf-grade-message.has-content {
		display: block !important;
	}

	/* Grade message colors based on grade - light theme */
	.wps-pdf-grade-message.grade-good {
		background: #f0fdf4 !important;
		border: 1px solid #86efac !important;
		color: #166534 !important;
	}

	.wps-pdf-grade-message.grade-warning {
		background: #fffbeb !important;
		border: 1px solid #fcd34d !important;
		color: #92400e !important;
	}

	.wps-pdf-grade-message.grade-danger {
		background: #fef2f2 !important;
		border: 1px solid #fecaca !important;
		color: #991b1b !important;
	}

	/* PDF CTA - only show if has content */
	.wps-pdf-cta {
		display: none !important;
		padding: 15px 20px;
		border-radius: 6px;
		margin: 15px 0;
		font-size: 12px;
		line-height: 1.6;
		background: #EBF1FC !important;
		border: 1px solid #CBD5E1 !important;
		color: #163572 !important;
		text-align: center;
	}

	.wps-pdf-cta.has-content {
		display: block !important;
	}

	/* PDF Footer - from settings */
	.wps-pdf-footer {
		display: block !important;
		text-align: center;
		margin-top: 15px;
		padding-top: 12px;
		border-top: 1px solid #e2e8f0;
	}

	.wps-pdf-footer p {
		font-size: 10px;
		color: #374151 !important;
		margin: 0 0 5px 0;
	}

	.wps-pdf-footer .wps-pdf-brand {
		font-size: 11px;
		color: #4b5563 !important;
		margin-top: 8px;
	}

	/* Malware actions */
	.wps-malware-actions {
		background: #ffffff !important;
		border: 1px solid #fecaca !important;
	}

	.wps-malware-actions strong {
		color: #991b1b !important;
	}

	.wps-malware-actions .wps-action-list li {
		color: #111827 !important;
	}

	/* Vulnerabilities section */
	.wps-vulnerabilities {
		background: #fef2f2 !important;
		border: 1px solid #fecaca !important;
	}

	.wps-vuln-title {
		color: #991b1b !important;
	}

	.wps-vuln-item {
		border-bottom-color: #fecaca !important;
	}

	.wps-vuln-name {
		color: #111827 !important;
	}

	.wps-vuln-cvss {
		color: #374151 !important;
	}

	.wps-vuln-fix {
		color: #16a34a !important;
	}

	.wps-vuln-more {
		color: #dc2626 !important;
	}
}

/* ==========================================================================
   Malware Scan Section
   ========================================================================== */

.wps-malware-blacklist,
.wps-malware-detections,
.wps-malware-recommendations {
	margin-top: 15px;
	padding-top: 15px;
	border-top: 1px solid var(--wps-gray-200);
}

.wps-subsection-title {
	font-size: 14px;
	font-weight: 600;
	color: var(--wps-gray-700);
	margin-bottom: 10px;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.wps-detection-item {
	background: var(--wps-white);
	border-radius: var(--wps-border-radius);
	padding: 15px;
	margin-bottom: 10px;
	border-left: 4px solid var(--wps-gray-300);
	border: 1px solid var(--wps-gray-200);
}

.wps-detection-critical,
.wps-detection-high {
	border-left-color: var(--wps-danger);
	background: var(--wps-white);
}

.wps-detection-medium {
	border-left-color: var(--wps-warning);
	background: var(--wps-white);
}

.wps-detection-low {
	border-left-color: var(--wps-info);
	background: var(--wps-white);
}

.wps-detection-header {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 8px;
}

.wps-detection-type {
	font-weight: 600;
	color: var(--wps-gray-900);
	flex: 1;
}

.wps-detection-severity {
	font-size: 11px;
	font-weight: 600;
	text-transform: uppercase;
	padding: 3px 8px;
	border-radius: 4px;
	color: var(--wps-white);
}

.wps-severity-critical {
	background: var(--wps-danger);
}

.wps-severity-high {
	background: #ef4444;
}

.wps-severity-medium {
	background: var(--wps-warning);
}

.wps-severity-low {
	background: var(--wps-info);
}

.wps-detection-description {
	font-size: 14px;
	color: var(--wps-gray-700);
	margin-bottom: 10px;
}

.wps-detection-removal {
	font-size: 13px;
	background: var(--wps-gray-50);
	padding: 10px;
	border-radius: 4px;
	border: 1px solid var(--wps-gray-200);
}

.wps-detection-removal strong {
	display: block;
	margin-bottom: 5px;
	color: var(--wps-gray-900);
}

.wps-detection-removal ul {
	margin: 0;
	padding-left: 20px;
}

.wps-detection-removal li {
	margin-bottom: 3px;
	color: var(--wps-gray-500);
}

.wps-recommendation-list {
	margin: 0;
	padding-left: 20px;
}

.wps-recommendation-list li {
	margin-bottom: 5px;
	color: var(--wps-gray-700);
}

.wps-malware-scan-time {
	font-size: 12px;
	color: var(--wps-gray-500);
	text-align: right;
	margin-top: 10px;
	margin-bottom: 0;
}

/* Malware Status Banner (Email Template Style) */
.wps-malware-status {
	display: flex;
	align-items: flex-start;
	gap: 15px;
	padding: 20px;
	border-radius: var(--wps-border-radius);
	margin-bottom: 20px;
	background: var(--surface);
	border: 1px solid var(--wps-gray-200);
}

.wps-malware-clean {
	/* keep subtle green accent but on dark surface */
	border-color: rgba(34, 197, 94, 0.6);
}

.wps-malware-infected {
	/* keep subtle red accent but on dark surface */
	border-color: rgba(239, 68, 68, 0.7);
}

.wps-malware-status-icon {
	font-size: 28px;
	line-height: 1;
	flex-shrink: 0;
}

.wps-malware-clean .wps-malware-status-icon {
	color: var(--wps-success);
}

.wps-malware-infected .wps-malware-status-icon {
	color: var(--wps-danger);
}

.wps-malware-status-text strong {
	display: block;
	font-size: 18px;
	margin-bottom: 5px;
}

.wps-malware-clean .wps-malware-status-text strong {
	color: var(--wps-gray-900);
}

.wps-malware-infected .wps-malware-status-text strong {
	color: var(--wps-gray-900);
}

.wps-malware-status-text p {
	margin: 0;
	font-size: 14px;
}

.wps-malware-clean .wps-malware-status-text p {
	color: var(--wps-gray-500);
}

.wps-malware-infected .wps-malware-status-text p {
	color: var(--wps-gray-500);
}

/* Detection List (Email Template Style) */
.wps-malware-detection-list {
	list-style: none;
	margin: 0 0 20px 0;
	padding: 0;
}

.wps-malware-detection-item {
	padding: 15px;
	margin-bottom: 10px;
	background: var(--wps-white); /* dark card, consistent with other sections */
	border-radius: var(--wps-border-radius);
	border: 1px solid var(--wps-gray-200);
	border-left: 4px solid var(--wps-danger);
}

.wps-malware-detection-item .wps-detection-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 8px;
}

.wps-malware-detection-item .wps-detection-header strong {
	font-size: 15px;
	color: var(--wps-gray-900);
}

.wps-severity-badge {
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	padding: 4px 10px;
	border-radius: 4px;
	color: #fff;
}

.wps-severity-badge.wps-severity-high,
.wps-severity-badge.wps-severity-critical {
	background: #dc2626;
}

.wps-severity-badge.wps-severity-medium {
	background: #d97706;
}

.wps-severity-badge.wps-severity-low {
	background: #0891b2;
}

.wps-detection-desc {
	font-size: 14px;
	color: var(--wps-gray-500);
	margin: 0;
	line-height: 1.5;
}

/* Recommended Actions (Email Template Style) */
.wps-malware-actions {
	background: var(--wps-white);
	border: 1px solid var(--wps-gray-200);
	border-left: 4px solid var(--wps-danger);
	border-radius: var(--wps-border-radius);
	padding: 15px 20px;
}

.wps-malware-actions strong {
	display: block;
	font-size: 15px;
	color: var(--wps-gray-900);
	margin-bottom: 10px;
}

.wps-action-list {
	margin: 0;
	padding-left: 20px;
}

.wps-action-list li {
	margin-bottom: 8px;
	color: var(--wps-gray-500);
	font-size: 14px;
	line-height: 1.5;
}

.wps-action-list li:last-child {
	margin-bottom: 0;
}

/* ==========================================================================
   Malware Detection Accordions
   ========================================================================== */

.wps-malware-detections-accordion {
	margin-bottom: 20px;
}

.wps-detection-accordion-item {
	background: var(--wps-white);
	border-radius: var(--wps-border-radius);
	border: 1px solid var(--wps-gray-200);
	margin-bottom: 10px;
	overflow: hidden;
}

.wps-detection-accordion-item.wps-detection-critical,
.wps-detection-accordion-item.wps-detection-high {
	border-left: 4px solid #dc2626;
}

.wps-detection-accordion-item.wps-detection-medium {
	border-left: 4px solid #d97706;
}

.wps-detection-accordion-item.wps-detection-low {
	border-left: 4px solid #0891b2;
}

.wps-detection-accordion-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 15px;
	cursor: pointer;
	background: var(--wps-white);
	transition: background 0.2s ease;
}

.wps-detection-accordion-header:hover {
	background: var(--wps-gray-50);
}

.wps-detection-accordion-title {
	display: flex;
	align-items: center;
	gap: 10px;
}

.wps-accordion-icon {
	font-size: 10px;
	color: var(--wps-gray-500);
	transition: transform 0.2s ease;
}

.wps-detection-accordion-item.wps-accordion-expanded .wps-accordion-icon {
	transform: rotate(180deg);
}

.wps-detection-accordion-content {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.3s ease, padding 0.3s ease;
	padding: 0 15px;
}

.wps-detection-accordion-content.wps-accordion-open {
	max-height: 1000px;
	padding: 15px;
	border-top: 1px solid var(--wps-gray-200);
}

.wps-detection-desc {
	color: var(--wps-gray-500);
	font-size: 14px;
	line-height: 1.5;
	margin: 0 0 15px 0;
}

.wps-detection-location {
	margin-bottom: 15px;
	font-size: 13px;
	color: var(--wps-gray-500);
}

.wps-detection-location code {
	background: var(--wps-gray-200);
	padding: 2px 6px;
	border-radius: 4px;
	font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
	font-size: 12px;
	color: var(--wps-gray-700);
}

.wps-detection-code {
	margin-bottom: 15px;
}

.wps-detection-code strong {
	display: block;
	font-size: 13px;
	margin-bottom: 8px;
	color: var(--wps-gray-900);
}

.wps-code-snippet {
	background: #1e1e1e;
	border-radius: 6px;
	padding: 12px 15px;
	overflow-x: auto;
	margin: 0;
}

.wps-code-snippet code {
	color: #e06c75;
	font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
	font-size: 12px;
	line-height: 1.5;
	white-space: pre-wrap;
	word-break: break-all;
}

.wps-detection-fix {
	background: var(--wps-gray-50);
	border: 1px solid var(--wps-gray-200);
	border-left: 4px solid var(--wps-warning);
	border-radius: var(--wps-border-radius);
	padding: 12px 15px;
}

.wps-detection-fix strong {
	display: block;
	font-size: 13px;
	margin-bottom: 8px;
	color: var(--wps-gray-900);
}

.wps-detection-fix ul {
	margin: 0;
	padding-left: 18px;
}

.wps-detection-fix li {
	font-size: 13px;
	color: var(--wps-gray-500);
	margin-bottom: 5px;
	line-height: 1.5;
}
.wps-malware-actions .wps-action-list li{
	color: var(--wps-gray-500);
}

.wps-detection-fix li:last-child {
	margin-bottom: 0;
}
