/*
 * WP AI SEO — License & Setup Wizard Styles
 * Extends Sierra Design System from admin.css
 * --------------------------------------------------------- */

/* === CSS Variables (inherit from admin.css if loaded, fallback otherwise) === */
:root {
	--waiseo-primary: #146EF5;
	--waiseo-primary-hover: #0D5FD9;
	--waiseo-primary-light: rgba(20, 110, 245, .08);
	--waiseo-purple: #7C3AED;
	--waiseo-purple-light: rgba(124, 58, 237, .08);
	--waiseo-gold: #F59E0B;
	--waiseo-gold-light: rgba(245, 158, 11, .08);
	--waiseo-green: #22C55E;
	--waiseo-green-light: rgba(34, 197, 94, .1);
	--waiseo-red: #EF4444;
	--waiseo-red-light: rgba(239, 68, 68, .1);
	--waiseo-text: #1D1F20;
	--waiseo-text-secondary: rgba(30, 30, 36, .7);
	--waiseo-text-muted: rgba(30, 30, 36, .45);
	--waiseo-surface: #FFFFFF;
	--waiseo-bg: #F0F0F0;
	--waiseo-border: #E5E7EB;
	--waiseo-radius: 10px;
	--waiseo-radius-lg: 16px;
	--waiseo-radius-xl: 20px;
	--waiseo-shadow: 0 1px 3px rgba(0, 0, 0, .04), 0 1px 2px rgba(0, 0, 0, .03);
	--waiseo-shadow-md: 0 4px 16px rgba(0, 0, 0, .06);
	--waiseo-shadow-lg: 0 12px 40px rgba(0, 0, 0, .1);
	--waiseo-shadow-xl: 0 20px 60px rgba(0, 0, 0, .12);
	--waiseo-font: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	--waiseo-transition: .2s cubic-bezier(.4, 0, .2, 1);
	--waiseo-transition-slow: .35s cubic-bezier(.4, 0, .2, 1);
}

/* ============================================================
   WIZARD — Full-Page Layout
   ============================================================ */

.waiseo-wizard-body {
	margin: 0;
	padding: 0;
	background: var(--waiseo-bg);
	font-family: var(--waiseo-font);
	color: var(--waiseo-text);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	min-height: 100vh;
}

.waiseo-wizard-body *,
.waiseo-wizard-body *::before,
.waiseo-wizard-body *::after {
	box-sizing: border-box;
}

.waiseo-wizard-wrapper {
	max-width: 700px;
	margin: 0 auto;
	padding: 36px 28px 64px;
}

/* --- Header --- */
.waiseo-wizard-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0 0 24px;
	margin-bottom: 28px;
	border-bottom: 1px solid var(--waiseo-border);
}

.waiseo-wizard-logo {
	display: flex;
	align-items: center;
	gap: 10px;
}

.waiseo-wizard-brand {
	font-size: 18px;
	font-weight: 800;
	color: var(--waiseo-text);
	letter-spacing: -.3px;
}

.waiseo-wizard-exit {
	font-size: 28px;
	color: var(--waiseo-text-muted);
	text-decoration: none;
	line-height: 1;
	transition: color var(--waiseo-transition);
}

.waiseo-wizard-exit:hover {
	color: var(--waiseo-red);
}

/* --- Progress Steps --- */
.waiseo-wizard-steps {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0;
	margin-bottom: 32px;
}

.waiseo-step {
	display: flex;
	align-items: center;
	gap: 8px;
	opacity: 0.4;
	transition: opacity var(--waiseo-transition);
}

.waiseo-step.active {
	opacity: 1;
}

.waiseo-step.completed {
	opacity: 0.7;
}

.waiseo-step-number {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 34px;
	height: 34px;
	border-radius: 50%;
	background: var(--waiseo-border);
	color: var(--waiseo-text-secondary);
	font-weight: 700;
	font-size: 14px;
	transition: all var(--waiseo-transition);
}

.waiseo-step.active .waiseo-step-number {
	background: var(--waiseo-primary);
	color: #fff;
	box-shadow: 0 2px 8px rgba(20, 110, 245, .3);
}

.waiseo-step.completed .waiseo-step-number {
	background: var(--waiseo-green);
	color: #fff;
}

.waiseo-step-label {
	font-size: 14px;
	font-weight: 600;
	color: var(--waiseo-text-secondary);
}

.waiseo-step.active .waiseo-step-label {
	color: var(--waiseo-text);
}

.waiseo-step-connector {
	width: 48px;
	height: 2px;
	background: var(--waiseo-border);
	margin: 0 12px;
	flex-shrink: 0;
}

/* --- Card --- */
.waiseo-card {
	background: var(--waiseo-surface);
	border-radius: var(--waiseo-radius-xl);
	padding: 44px;
	box-shadow: var(--waiseo-shadow-md);
	border: 1px solid var(--waiseo-border);
	transition: box-shadow var(--waiseo-transition-slow);
}

.waiseo-card:hover {
	box-shadow: var(--waiseo-shadow-lg);
}

.waiseo-card-centered {
	text-align: center;
}

.waiseo-card-centered h2 {
	font-size: 24px;
	font-weight: 800;
	margin: 16px 0 8px;
	color: var(--waiseo-text);
	letter-spacing: -.4px;
}

.waiseo-card-desc {
	font-size: 15px;
	color: var(--waiseo-text-secondary);
	line-height: 1.6;
	margin: 0 0 24px;
	max-width: 500px;
	margin-left: auto;
	margin-right: auto;
}

.waiseo-card-icon {
	margin-bottom: 8px;
}

/* --- Buttons --- */
.waiseo-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 11px 22px;
	border-radius: var(--waiseo-radius);
	font-family: var(--waiseo-font);
	font-size: 14px;
	font-weight: 600;
	border: none;
	cursor: pointer;
	transition: all var(--waiseo-transition);
	text-decoration: none;
	line-height: 1.4;
}

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

.waiseo-btn-primary {
	background: var(--waiseo-primary);
	color: #fff;
}

.waiseo-btn-primary:hover:not(:disabled) {
	background: var(--waiseo-primary-hover);
	box-shadow: 0 4px 14px rgba(20, 110, 245, .3);
	transform: translateY(-1px);
}

.waiseo-btn-secondary {
	background: var(--waiseo-surface);
	color: var(--waiseo-text);
	border: 1px solid var(--waiseo-border);
}

.waiseo-btn-secondary:hover:not(:disabled) {
	background: var(--waiseo-bg);
	border-color: var(--waiseo-text-muted);
	transform: translateY(-1px);
}

.waiseo-btn-large {
	padding: 14px 34px;
	font-size: 16px;
	border-radius: 12px;
	font-weight: 700;
}

.waiseo-btn-small {
	padding: 6px 14px;
	font-size: 13px;
}

.waiseo-btn-danger {
	background: var(--waiseo-red-light);
	color: var(--waiseo-red);
	border: 1px solid rgba(239, 68, 68, .2);
}

.waiseo-btn-danger:hover:not(:disabled) {
	background: var(--waiseo-red);
	color: #fff;
}

.waiseo-link-subtle {
	color: var(--waiseo-text-muted);
	font-size: 14px;
	text-decoration: none;
	transition: color var(--waiseo-transition);
}

.waiseo-link-subtle:hover {
	color: var(--waiseo-primary);
}

/* --- Inputs --- */
.waiseo-input-group {
	display: flex;
	align-items: center;
	background: var(--waiseo-surface);
	border: 1.5px solid var(--waiseo-border);
	border-radius: 100px;
	padding: 6px;
	margin-bottom: 24px;
	transition: box-shadow var(--waiseo-transition), border-color var(--waiseo-transition);
}

.waiseo-input-group:focus-within {
	border-color: var(--waiseo-primary);
	box-shadow: 0 0 0 3px var(--waiseo-primary-light);
}

.waiseo-input-group .waiseo-input,
.waiseo-input-group .waiseo-input-large,
.waiseo-input-group .waiseo-provider-key {
	flex: 1;
	border: none !important;
	background: transparent !important;
	padding: 10px 18px;
	margin: 0;
	box-shadow: none !important;
	outline: none !important;
}

.waiseo-input-group .waiseo-btn {
	border-radius: 100px;
	padding: 12px 28px;
	margin: 0;
	white-space: nowrap;
}

.waiseo-input-large {
	width: 100%;
	padding: 14px 18px;
	border: 2px solid var(--waiseo-border);
	border-radius: 12px;
	font-family: var(--waiseo-font);
	font-size: 15px;
	color: var(--waiseo-text);
	background: var(--waiseo-surface);
	transition: border-color var(--waiseo-transition), box-shadow var(--waiseo-transition);
	outline: none;
}

.waiseo-input-large:focus {
	border-color: var(--waiseo-primary);
	box-shadow: 0 0 0 4px var(--waiseo-primary-light);
}

.waiseo-input-large::placeholder {
	color: var(--waiseo-text-muted);
}

/* --- Form Actions --- */
.waiseo-form-actions {
	margin-bottom: 16px;
}

/* --- Result Box --- */
.waiseo-result-box {
	padding: 12px 16px;
	border-radius: var(--waiseo-radius);
	font-size: 14px;
	margin-top: 12px;
	text-align: left;
}

.waiseo-result-box.waiseo-result-success {
	background: var(--waiseo-green-light);
	color: #166534;
	border: 1px solid rgba(34, 197, 94, .2);
}

.waiseo-result-box.waiseo-result-error {
	background: var(--waiseo-red-light);
	color: #991B1B;
	border: 1px solid rgba(239, 68, 68, .2);
}

/* --- Success State --- */
.waiseo-success-state {
	padding: 24px 0;
}

.waiseo-success-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 60px;
	height: 60px;
	border-radius: 50%;
	background: var(--waiseo-green);
	color: #fff;
	font-size: 28px;
	font-weight: 700;
	margin-bottom: 16px;
	box-shadow: 0 4px 16px rgba(34, 197, 94, .3);
	animation: waiseo-pop-in 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}

@keyframes waiseo-pop-in {
	0% {
		transform: scale(0);
		opacity: 0;
	}

	100% {
		transform: scale(1);
		opacity: 1;
	}
}

.waiseo-success-state h3 {
	font-size: 20px;
	font-weight: 700;
	color: var(--waiseo-text);
	margin: 0 0 4px;
}

.waiseo-success-state p {
	font-size: 14px;
	color: var(--waiseo-text-secondary);
	margin: 0;
}

/* --- Wizard Navigation --- */
.waiseo-wizard-nav {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-top: 24px;
	padding-top: 24px;
	border-top: 1px solid var(--waiseo-border);
	gap: 16px;
}

/* --- Wizard Panel Transitions --- */
.waiseo-wizard-panel {
	animation: waiseo-fade-in 0.35s cubic-bezier(.4, 0, .2, 1);
}

@keyframes waiseo-fade-in {
	0% {
		opacity: 0;
		transform: translateY(12px);
	}

	100% {
		opacity: 1;
		transform: translateY(0);
	}
}

/* ============================================================
   PROVIDER CARDS (Wizard Step 2)
   ============================================================ */

.waiseo-provider-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
	margin-bottom: 8px;
	text-align: left;
}

.waiseo-provider-card {
	border: 2px solid var(--waiseo-border);
	border-radius: var(--waiseo-radius-lg);
	padding: 22px;
	transition: all var(--waiseo-transition);
	background: var(--waiseo-surface);
	position: relative;
	overflow: hidden;
}

.waiseo-provider-card:hover {
	border-color: var(--waiseo-primary);
	box-shadow: 0 4px 16px rgba(20, 110, 245, .1);
	transform: translateY(-2px);
}

.waiseo-provider-card.waiseo-provider-selected {
	border-color: var(--waiseo-primary);
	background: var(--waiseo-primary-light);
}

.waiseo-provider-header {
	margin-bottom: 12px;
}

.waiseo-provider-name {
	font-size: 15px;
	font-weight: 700;
	margin: 0 0 2px;
	color: var(--waiseo-text);
}

.waiseo-provider-models {
	font-size: 12px;
	color: var(--waiseo-text-muted);
}

.waiseo-provider-body .waiseo-input-group {
	margin-bottom: 10px;
}

.waiseo-provider-key {
	width: 100%;
	padding: 8px 12px;
	border: 1px solid var(--waiseo-border);
	border-radius: var(--waiseo-radius);
	font-family: var(--waiseo-font);
	font-size: 13px;
	color: var(--waiseo-text);
	background: var(--waiseo-surface);
	transition: border-color var(--waiseo-transition);
	outline: none;
}

.waiseo-provider-key:focus {
	border-color: var(--waiseo-primary);
	box-shadow: 0 0 0 2px var(--waiseo-primary-light);
}

.waiseo-provider-actions {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 8px;
}

.waiseo-provider-default {
	display: flex;
	align-items: center;
	gap: 4px;
	font-size: 12px;
	color: var(--waiseo-text-secondary);
	cursor: pointer;
}

.waiseo-provider-default input[type="radio"] {
	accent-color: var(--waiseo-primary);
}

.waiseo-provider-result {
	margin-top: 8px;
	padding: 6px 10px;
	border-radius: var(--waiseo-radius);
	font-size: 12px;
}

.waiseo-provider-result.waiseo-result-success {
	background: var(--waiseo-green-light);
	color: #166534;
}

.waiseo-provider-result.waiseo-result-error {
	background: var(--waiseo-red-light);
	color: #991B1B;
}

/* ============================================================
   SITE SCAN (Wizard Step 3)
   ============================================================ */

.waiseo-scan-section {
	padding: 16px 0;
}

.waiseo-progress-bar {
	width: 100%;
	height: 8px;
	background: var(--waiseo-border);
	border-radius: 4px;
	overflow: hidden;
	margin-bottom: 12px;
}

.waiseo-progress-fill {
	height: 100%;
	width: 0%;
	background: linear-gradient(90deg, var(--waiseo-primary), var(--waiseo-purple));
	border-radius: 4px;
	transition: width .5s cubic-bezier(.4, 0, .2, 1);
	box-shadow: 0 0 8px rgba(20, 110, 245, .25);
}

.waiseo-progress-text {
	font-size: 14px;
	color: var(--waiseo-text-secondary);
	margin: 0;
}

.waiseo-scan-stats {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	gap: 16px;
}

.waiseo-scan-stat {
	background: var(--waiseo-bg);
	border-radius: 12px;
	padding: 22px 16px;
	text-align: center;
	transition: transform var(--waiseo-transition), box-shadow var(--waiseo-transition);
}

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

.waiseo-scan-stat-number {
	display: block;
	font-size: 30px;
	font-weight: 800;
	color: var(--waiseo-primary);
	margin-bottom: 4px;
	letter-spacing: -.5px;
}

.waiseo-scan-stat-label {
	display: block;
	font-size: 12px;
	color: var(--waiseo-text-secondary);
	line-height: 1.3;
}

/* ============================================================
   LICENSE TAB IN SETTINGS (Phase 3C)
   ============================================================ */

.waiseo-license-status {
	display: flex;
	align-items: flex-start;
	gap: 24px;
	background: var(--waiseo-surface);
	border-radius: var(--waiseo-radius-xl);
	padding: 34px;
	box-shadow: var(--waiseo-shadow);
	border: 1px solid var(--waiseo-border);
	margin-bottom: 24px;
	transition: box-shadow var(--waiseo-transition-slow);
}

.waiseo-license-status:hover {
	box-shadow: var(--waiseo-shadow-md);
}

.waiseo-license-badge {
	flex-shrink: 0;
}

.waiseo-badge {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 7px 16px;
	border-radius: var(--waiseo-radius-pill, 99px);
	font-size: 13px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.waiseo-badge-none {
	background: #E5E7EB;
	color: #6B7280;
}

.waiseo-badge-basic {
	background: linear-gradient(135deg, #3B82F6, #146EF5);
	color: #fff;
}

.waiseo-badge-pro {
	background: linear-gradient(135deg, #8B5CF6, #7C3AED);
	color: #fff;
}

.waiseo-badge-agency {
	background: linear-gradient(135deg, #F59E0B, #D97706);
	color: #fff;
}

.waiseo-license-info {
	flex: 1;
}

.waiseo-license-info h3 {
	font-size: 18px;
	font-weight: 800;
	margin: 0 0 8px;
	color: var(--waiseo-text);
	letter-spacing: -.3px;
}

.waiseo-license-detail {
	font-size: 14px;
	color: var(--waiseo-text-secondary);
	margin: 0 0 4px;
}

.waiseo-license-detail strong {
	color: var(--waiseo-text);
}

.waiseo-license-actions {
	margin-top: 16px;
}

/* --- Upgrade CTA --- */
.waiseo-upgrade-cta {
	background: linear-gradient(135deg, var(--waiseo-primary-light), var(--waiseo-purple-light));
	border: 1px solid rgba(20, 110, 245, .15);
	border-radius: var(--waiseo-radius-xl);
	padding: 32px 36px;
	transition: box-shadow var(--waiseo-transition-slow);
}

.waiseo-upgrade-cta:hover {
	box-shadow: 0 8px 24px rgba(20, 110, 245, .08);
}

.waiseo-upgrade-cta h3 {
	font-size: 19px;
	font-weight: 800;
	margin: 0 0 8px;
	color: var(--waiseo-text);
	letter-spacing: -.3px;
}

.waiseo-upgrade-cta p {
	font-size: 14px;
	color: var(--waiseo-text-secondary);
	margin: 0 0 16px;
	line-height: 1.6;
}

.waiseo-upgrade-features {
	list-style: none;
	margin: 0 0 20px;
	padding: 0;
}

.waiseo-upgrade-features li {
	position: relative;
	padding-left: 24px;
	margin-bottom: 8px;
	font-size: 14px;
	color: var(--waiseo-text-secondary);
}

.waiseo-upgrade-features li::before {
	content: '✦';
	position: absolute;
	left: 0;
	color: var(--waiseo-purple);
}

.waiseo-upgrade-features li.waiseo-locked::before {
	content: '🔒';
}

/* --- Lock Icon for locked abilities --- */
.waiseo-lock-badge {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 3px 10px;
	border-radius: var(--waiseo-radius-pill, 99px);
	font-size: 11px;
	font-weight: 600;
	background: var(--waiseo-gold-light);
	color: #92400E;
}

.waiseo-lock-badge svg {
	width: 12px;
	height: 12px;
}

/* --- Spinner --- */
.waiseo-spinner {
	display: inline-block;
	width: 16px;
	height: 16px;
	border: 2px solid rgba(255, 255, 255, .3);
	border-top-color: #fff;
	border-radius: 50%;
	animation: waiseo-spin 0.6s linear infinite;
}

.waiseo-spinner-dark {
	border-color: rgba(0, 0, 0, .1);
	border-top-color: var(--waiseo-primary);
}

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

/* --- Loading State --- */
.waiseo-btn.is-loading {
	pointer-events: none;
	opacity: 0.7;
}

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

@media (max-width: 640px) {
	.waiseo-wizard-wrapper {
		padding: 16px 12px 48px;
	}

	.waiseo-card {
		padding: 24px 20px;
	}

	.waiseo-provider-grid {
		grid-template-columns: 1fr;
	}

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

	.waiseo-wizard-nav {
		flex-direction: column;
		align-items: stretch;
		text-align: center;
	}

	.waiseo-wizard-steps {
		gap: 0;
	}

	.waiseo-step-label {
		display: none;
	}

	.waiseo-step-connector {
		width: 32px;
		margin: 0 6px;
	}

	.waiseo-license-status {
		flex-direction: column;
	}
}

/* ================================================================
   LICENSE GATE — LOCK BADGES & LOCKED SECTIONS
   Used across AI Hub, AI Settings, and any gated feature UI.
   ================================================================ */

/* Small inline lock badge — "🔒 Pro" */
.waiseo-lock-badge {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-size: 11px;
	font-weight: 600;
	line-height: 1;
	padding: 3px 8px;
	border-radius: 99px;
	background: rgba(239, 68, 68, 0.1);
	color: #EF4444;
	vertical-align: middle;
	margin-left: 6px;
	white-space: nowrap;
	letter-spacing: 0.02em;
}

/* Locked button state */
.sp-ai-action-btn.waiseo-locked,
.sp-field-toggle.waiseo-locked {
	opacity: 0.55;
	pointer-events: auto;
	cursor: not-allowed;
	position: relative;
}

.sp-ai-action-btn.waiseo-locked::after {
	content: '';
	position: absolute;
	inset: 0;
	border-radius: inherit;
	background: repeating-linear-gradient(-45deg,
			transparent,
			transparent 6px,
			rgba(0, 0, 0, 0.03) 6px,
			rgba(0, 0, 0, 0.03) 12px);
	pointer-events: none;
}

/* Locked tool section (keyword research, content outline) */
.sp-ai-tool-section.waiseo-locked-section {
	position: relative;
	opacity: 0.75;
}

/* Overlay message shown inside locked sections */
.waiseo-locked-overlay {
	padding: 22px 28px;
	background: linear-gradient(135deg, #fef3c7 0%, #fef9c3 100%);
	border: 1px solid #f59e0b;
	border-radius: 12px;
	text-align: center;
	color: #92400e;
	font-size: 14px;
	line-height: 1.6;
}

.waiseo-locked-overlay p {
	margin: 0 0 12px;
}

.waiseo-locked-overlay .waiseo-btn {
	font-size: 13px;
}

/* Plan comparison table (license tab) */
.waiseo-plan-table {
	margin-top: 12px;
	table-layout: auto;
}

.waiseo-plan-table th,
.waiseo-plan-table td {
	text-align: center;
	padding: 12px 14px;
}

.waiseo-plan-table .waiseo-plan-col {
	width: 1%;
	min-width: 92px;
	white-space: nowrap;
}

.waiseo-plan-table thead th.waiseo-plan-col:last-child {
	min-width: 104px;
}

.waiseo-plan-table th:first-child,
.waiseo-plan-table td:first-child {
	text-align: left;
}

.waiseo-plan-cell .dashicons,
	.waiseo-plan-cell svg {
	font-size: 18px;
	width: 18px;
	height: 18px;
}

/* License status card (license tab) */
.waiseo-license-status-card {
	background: var(--waiseo-surface, #fff);
	border: 1px solid var(--waiseo-border, #e5e7eb);
	border-radius: var(--waiseo-radius-xl, 20px);
	padding: 28px;
	margin-bottom: 24px;
	transition: box-shadow var(--waiseo-transition, .2s ease);
}

.waiseo-license-status-card:hover {
	box-shadow: var(--waiseo-shadow, 0 1px 3px rgba(0, 0, 0, .04));
}

.waiseo-license-plan-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: 16px;
}

.waiseo-feature-count {
	font-size: 13px;
	color: var(--waiseo-text-muted, #6b7280);
	margin-left: 12px;
}

.waiseo-license-meta {
	display: flex;
	gap: 24px;
	flex-wrap: wrap;
}

.waiseo-license-detail {
	font-size: 13px;
	color: var(--waiseo-text-muted, #6b7280);
}

.waiseo-license-detail strong {
	color: var(--waiseo-text, #141415);
}

/* Capabilities list */
.waiseo-license-features {
	margin-bottom: 24px;
	background: var(--waiseo-surface-alt, #f8f9fb);
	border: 1px solid var(--waiseo-border, #e5e7eb);
	border-radius: var(--waiseo-radius-lg, 14px);
	padding: 22px 24px 20px;
}

.waiseo-license-features h3 {
	margin: 0 0 16px;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: .7px;
	text-transform: uppercase;
	color: var(--waiseo-text-muted, #6b7280);
}

.waiseo-caps-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.waiseo-caps-list li {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	font-size: 12px;
	font-weight: 600;
	color: var(--waiseo-primary, #146ef5);
	background: var(--waiseo-primary-light, rgba(20, 110, 245, 0.08));
	border: 1px solid rgba(20, 110, 245, 0.18);
	border-radius: 100px;
	padding: 4px 12px 4px 8px;
	line-height: 1.4;
	white-space: nowrap;
	transition: background .15s ease, border-color .15s ease;
}

.waiseo-caps-list li:hover {
	background: rgba(20, 110, 245, 0.14);
	border-color: rgba(20, 110, 245, 0.30);
}

.waiseo-caps-list .dashicons,
	.waiseo-caps-list svg {
	color: var(--waiseo-green, #10b981);
	font-size: 14px;
	width: 14px;
	height: 14px;
	line-height: 14px;
	flex-shrink: 0;
}

/* Deactivate section */
.waiseo-license-deactivate {
	margin-top: 24px;
	padding-top: 20px;
	border-top: 1px solid var(--waiseo-border, #e5e7eb);
}

.waiseo-license-deactivate .description {
	margin: 0 0 12px;
	font-size: 13px;
	color: var(--waiseo-text-muted, #6b7280);
}

/* Activate form (license tab) */
.waiseo-license-activate-form {
	margin-bottom: 32px;
}

.waiseo-license-activate-form h3 {
	margin: 0 0 8px;
	font-size: 15px;
	font-weight: 600;
}

.waiseo-license-activate-form .description {
	margin: 0 0 16px;
	font-size: 13px;
	color: var(--waiseo-text-muted, #6b7280);
}

/* Plan comparison section */
.waiseo-plan-comparison {
	margin-bottom: 32px;
}

.waiseo-plan-comparison h3 {
	margin: 0 0 12px;
	font-size: 15px;
	font-weight: 600;
}

/* Upgrade CTA */
.waiseo-upgrade-cta {
	margin-bottom: 24px;
}

.waiseo-cta-inner {
	text-align: center;
	padding: 44px 28px;
	background: linear-gradient(135deg, #eef2ff 0%, #e0e7ff 50%, #c7d2fe 100%);
	border-radius: var(--waiseo-radius-xl, 20px);
	border: 1px solid #a5b4fc;
}

.waiseo-cta-inner h3 {
	margin: 0 0 8px;
	font-size: 22px;
	font-weight: 800;
	color: #312e81;
	letter-spacing: -.4px;
}

.waiseo-cta-inner p {
	margin: 0 0 20px;
	font-size: 14px;
	color: #4338ca;
}

/* ============================================================
   PLAN-SPECIFIC DASHBOARD — Upgrade Banners & Feature Previews
   ============================================================ */

/* Upgrade banner (Free & Basic) */
.waiseo-dashboard-upgrade-banner {
	margin-bottom: 24px;
	border-radius: var(--waiseo-radius-xl, 20px);
	background: linear-gradient(135deg, #1e3a8a 0%, #3b82f6 100%);
	color: #fff;
	overflow: hidden;
	box-shadow: var(--waiseo-shadow-md);
	transition: box-shadow var(--waiseo-transition-slow, .35s ease);
}

.waiseo-dashboard-upgrade-banner:hover {
	box-shadow: var(--waiseo-shadow-lg);
}

.waiseo-dashboard-upgrade-banner.waiseo-upgrade-banner--basic {
	background: linear-gradient(135deg, #5b21b6 0%, #8b5cf6 100%);
}

.waiseo-upgrade-banner-inner {
	display: flex;
	align-items: center;
	gap: 20px;
	padding: 24px 28px;
}

.waiseo-upgrade-banner-inner>.dashicons,
	.waiseo-upgrade-banner-inner>svg {
	font-size: 36px;
	width: 36px;
	height: 36px;
	opacity: .85;
	flex-shrink: 0;
}

.waiseo-upgrade-banner-text {
	flex: 1;
}

.waiseo-upgrade-banner-text h3 {
	margin: 0 0 4px;
	font-size: 17px;
	font-weight: 800;
	color: #fff;
	letter-spacing: -.2px;
}

.waiseo-upgrade-banner-text p {
	margin: 0;
	font-size: 13.5px;
	opacity: .9;
	color: rgba(255, 255, 255, .92);
}

.waiseo-dashboard-upgrade-banner .waiseo-btn {
	flex-shrink: 0;
	background: #fff !important;
	color: #1e3a8a !important;
	border: none;
	font-weight: 600;
}

.waiseo-dashboard-upgrade-banner .waiseo-btn:hover {
	opacity: .92;
}

/* Feature preview grid (Free plan dashboard) */
.waiseo-feature-preview-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
	gap: 16px;
}

.waiseo-feature-preview-card {
	position: relative;
	padding: 22px 18px 18px;
	background: var(--waiseo-bg, #f0f0f0);
	border-radius: 12px;
	border: 1px solid var(--waiseo-border, #e5e7eb);
	text-align: center;
	transition: all var(--waiseo-transition, .2s ease);
}

.waiseo-feature-preview-card:hover {
	box-shadow: var(--waiseo-shadow-md);
	transform: translateY(-3px);
	border-color: rgba(20, 110, 245, .15);
}

.waiseo-feature-preview-card>.dashicons,
	.waiseo-feature-preview-card>svg {
	font-size: 28px;
	width: 28px;
	height: 28px;
	color: var(--waiseo-primary, #146EF5);
	margin-bottom: 12px;
}

.waiseo-feature-preview-card h4 {
	margin: 0 0 6px;
	font-size: 14px;
	font-weight: 600;
	color: var(--waiseo-text, #1D1F20);
}

.waiseo-feature-preview-card p {
	margin: 0;
	font-size: 12.5px;
	color: var(--waiseo-text-secondary, rgba(30, 30, 36, .7));
}

.waiseo-preview-plan-tag {
	display: inline-block;
	margin-top: 10px;
	padding: 2px 10px;
	font-size: 10.5px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .5px;
	border-radius: 100px;
	background: var(--waiseo-primary-light, rgba(20, 110, 245, .08));
	color: var(--waiseo-primary, #146EF5);
}

/* Plan badge inline in hero */
.sp-hero .waiseo-plan-badge {
	display: inline-block;
	vertical-align: middle;
	margin-left: 8px;
	padding: 3px 12px;
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .5px;
	border-radius: 100px;
}

/* Plan-specific badge colours (used in hero, license tab, and anywhere a plan badge appears) */
.waiseo-plan-badge {
	display: inline-block;
	padding: 3px 12px;
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .5px;
	border-radius: 100px;
}

.waiseo-plan-badge.waiseo-plan-none {
	background: var(--waiseo-bg, #f0f0f0);
	color: var(--waiseo-text-secondary, #6b7280);
	border: 1px solid var(--waiseo-border, #e5e7eb);
}

.waiseo-plan-badge.waiseo-plan-basic {
	background: var(--waiseo-primary-light, rgba(20, 110, 245, .08));
	color: var(--waiseo-primary, #146EF5);
	border: 1px solid rgba(20, 110, 245, .2);
}

.waiseo-plan-badge.waiseo-plan-pro {
	background: var(--waiseo-purple-light, rgba(124, 58, 237, .08));
	color: var(--waiseo-purple, #7C3AED);
	border: 1px solid rgba(124, 58, 237, .2);
}

.waiseo-plan-badge.waiseo-plan-agency {
	background: var(--waiseo-gold-light, rgba(245, 158, 11, .08));
	color: #b45309;
	border: 1px solid rgba(245, 158, 11, .25);
}

/* AI Hub quick action button style */
.sp-action-btn.sp-action-btn--ai {
	background: linear-gradient(135deg, #146EF5, #8B5CF6);
	color: #fff !important;
	border: none;
}

.sp-action-btn.sp-action-btn--ai:hover {
	opacity: .9;
}

/* Dashboard plan teaser panel */
.waiseo-dashboard-plan-teaser .sp-panel-body {
	padding: 24px;
}

@media (max-width: 782px) {
	.waiseo-upgrade-banner-inner {
		flex-direction: column;
		text-align: center;
		gap: 14px;
	}

	.waiseo-feature-preview-grid {
		grid-template-columns: 1fr 1fr;
	}
}

/* ============================================================
   DARK MODE OVERRIDES — License & Wizard
   ============================================================ */

/* --- Re-declare --waiseo-* tokens for dark mode --- */
[data-theme="dark"] {
	--waiseo-primary: #4d9aff;
	--waiseo-primary-hover: #6bacff;
	--waiseo-primary-light: rgba(77, 154, 255, .12);
	--waiseo-purple: #a78bfa;
	--waiseo-purple-light: rgba(167, 139, 250, .12);
	--waiseo-gold: #fbbf24;
	--waiseo-gold-light: rgba(251, 191, 36, .12);
	--waiseo-green: #34d399;
	--waiseo-green-light: rgba(52, 211, 153, .12);
	--waiseo-red: #f87171;
	--waiseo-red-light: rgba(248, 113, 113, .12);
	--waiseo-text: #e4e4e7;
	--waiseo-text-secondary: rgba(228, 228, 231, .7);
	--waiseo-text-muted: rgba(228, 228, 231, .45);
	--waiseo-surface: #1e1e2e;
	--waiseo-bg: #131a26;
	--waiseo-border: rgba(255, 255, 255, .08);
	--waiseo-shadow: 0 1px 3px rgba(0, 0, 0, .2), 0 1px 2px rgba(0, 0, 0, .15);
	--waiseo-shadow-md: 0 4px 16px rgba(0, 0, 0, .25);
	--waiseo-shadow-lg: 0 12px 40px rgba(0, 0, 0, .3);
	--waiseo-shadow-xl: 0 20px 60px rgba(0, 0, 0, .35);
}

[data-theme="dark"] .waiseo-license-status-card {
	background: var(--sp-bg-card, #1e1e2e);
	border-color: var(--sp-border, rgba(255, 255, 255, 0.06));
}

/* Bug 7: "Unlocked Capabilities" section dark mode */
[data-theme="dark"] .waiseo-license-features {
	background: rgba(20, 110, 245, 0.05);
	border-color: rgba(20, 110, 245, 0.15);
}

[data-theme="dark"] .waiseo-license-features h3 {
	color: var(--sp-text-muted, rgba(228, 228, 231, 0.5));
}

[data-theme="dark"] .waiseo-caps-list li {
	color: #7ab4ff;
	background: rgba(20, 110, 245, 0.12);
	border-color: rgba(77, 154, 255, 0.25);
}

[data-theme="dark"] .waiseo-caps-list li:hover {
	background: rgba(20, 110, 245, 0.20);
	border-color: rgba(77, 154, 255, 0.40);
}

[data-theme="dark"] .waiseo-caps-list .dashicons,
	[data-theme="dark"] .waiseo-caps-list svg {
	color: #34d399;
}

/* Bug 8: Deactivate button dark mode */
[data-theme="dark"] .waiseo-license-deactivate {
	background: transparent;
	border-color: var(--sp-border, rgba(255, 255, 255, 0.06));
}

[data-theme="dark"] .waiseo-license-deactivate .description {
	color: var(--sp-text-secondary, rgba(228, 228, 231, 0.7));
}

[data-theme="dark"] .waiseo-btn--danger,
[data-theme="dark"] .waiseo-btn-danger {
	background: rgba(239, 68, 68, 0.15);
	color: #f87171;
	border-color: rgba(239, 68, 68, 0.25);
}

[data-theme="dark"] .waiseo-btn--danger:hover,
[data-theme="dark"] .waiseo-btn-danger:hover {
	background: var(--sp-danger, #ef4444);
	color: #ffffff;
	border-color: transparent;
}

[data-theme="dark"] .waiseo-license-activate-form {
	color: var(--sp-text, #e4e4e7);
}

[data-theme="dark"] .waiseo-license-activate-form h3 {
	color: var(--sp-text, #e4e4e7);
}

[data-theme="dark"] .waiseo-license-activate-form .description {
	color: var(--sp-text-secondary, rgba(228, 228, 231, 0.7));
}

[data-theme="dark"] .waiseo-input {
	background: var(--sp-bg-input, #16161e);
	color: var(--sp-text, #e4e4e7);
	border-color: var(--sp-border-medium, rgba(255, 255, 255, 0.1));
}

[data-theme="dark"] .waiseo-input::placeholder,
[data-theme="dark"] .waiseo-input-large::placeholder {
	color: var(--sp-text-placeholder, #74839c);
}

[data-theme="dark"] .waiseo-input:focus {
	border-color: var(--sp-primary, #146EF5);
	box-shadow: 0 0 0 3px rgba(20, 110, 245, 0.15);
}

[data-theme="dark"] .waiseo-plan-comparison {
	color: var(--sp-text, #e4e4e7);
}

[data-theme="dark"] .waiseo-plan-comparison h3 {
	color: var(--sp-text, #e4e4e7);
}

[data-theme="dark"] .waiseo-plan-table {
	background: var(--sp-bg-card, #1e1e2e);
	border-color: var(--sp-border, rgba(255, 255, 255, 0.06));
}

[data-theme="dark"] .waiseo-plan-table thead th {
	background: rgba(255, 255, 255, 0.03);
	color: var(--sp-text-muted, #8b97a8);
	border-bottom-color: var(--sp-border, rgba(255, 255, 255, 0.06));
}

[data-theme="dark"] .waiseo-plan-table tbody td {
	color: var(--sp-text, #e4e4e7);
	border-bottom-color: var(--sp-border, rgba(255, 255, 255, 0.06));
}

/* Bug 5: fix WordPress .striped zebra rows in dark mode */
[data-theme="dark"] .waiseo-plan-table.striped>tbody> :nth-child(odd) {
	background-color: rgba(255, 255, 255, 0.03);
}

[data-theme="dark"] .waiseo-plan-table.striped>tbody> :nth-child(odd) td,
[data-theme="dark"] .waiseo-plan-table.striped>tbody> :nth-child(odd) th {
	background-color: transparent;
}

[data-theme="dark"] .waiseo-plan-table.striped>tbody> :nth-child(even) {
	background-color: transparent;
}

[data-theme="dark"] .waiseo-plan-table.striped>tbody> :nth-child(even) td,
[data-theme="dark"] .waiseo-plan-table.striped>tbody> :nth-child(even) th {
	background-color: transparent;
}

[data-theme="dark"] .waiseo-plan-table tbody tr:hover td {
	background: var(--sp-bg-card-hover, rgba(255, 255, 255, 0.04));
}

/* Bug 5: also override WordPress .widefat striped defaults */
[data-theme="dark"] .widefat.waiseo-plan-table {
	border-color: var(--sp-border, rgba(255, 255, 255, 0.06));
}

[data-theme="dark"] .waiseo-card {
	background: var(--sp-bg-card, #1e1e2e);
	border-color: var(--sp-border, rgba(255, 255, 255, 0.06));
	color: var(--sp-text, #e4e4e7);
}

/* Bug 6: keep upgrade banner gradient visible in dark mode */
[data-theme="dark"] .waiseo-dashboard-upgrade-banner {
	background: linear-gradient(135deg, #0f2557 0%, #1e40af 100%);
	border-color: rgba(59, 130, 246, 0.2);
}

[data-theme="dark"] .waiseo-dashboard-upgrade-banner.waiseo-upgrade-banner--basic {
	background: linear-gradient(135deg, #3b0f6e 0%, #6d28d9 100%);
	border-color: rgba(139, 92, 246, 0.2);
}

[data-theme="dark"] .waiseo-dashboard-upgrade-banner .waiseo-btn {
	background: rgba(255, 255, 255, 0.15) !important;
	color: #ffffff !important;
	border: 1px solid rgba(255, 255, 255, 0.2);
}

[data-theme="dark"] .waiseo-dashboard-upgrade-banner .waiseo-btn:hover {
	background: rgba(255, 255, 255, 0.25) !important;
}

[data-theme="dark"] .waiseo-upgrade-banner-text h3 {
	color: #ffffff;
}

[data-theme="dark"] .waiseo-upgrade-banner-text p {
	color: rgba(255, 255, 255, 0.85);
}

[data-theme="dark"] .waiseo-feature-preview-card {
	background: var(--sp-bg-card, #1e1e2e);
	border-color: var(--sp-border, rgba(255, 255, 255, 0.06));
	color: var(--sp-text, #e4e4e7);
}

[data-theme="dark"] .waiseo-feature-preview-card h4 {
	color: var(--sp-text, #e4e4e7);
}

[data-theme="dark"] .waiseo-feature-preview-card p {
	color: var(--sp-text-secondary, rgba(228, 228, 231, 0.7));
}

[data-theme="dark"] .waiseo-preview-plan-tag {
	background: rgba(20, 110, 245, 0.15);
	color: #6ba3f7;
}

/* Bug 9: "NO LICENSE" / Free plan badge dark mode */
[data-theme="dark"] .waiseo-plan-badge.waiseo-plan-none {
	background: rgba(255, 255, 255, 0.08);
	color: var(--sp-text-secondary, #8b97a8);
	border-color: rgba(255, 255, 255, 0.1);
}

[data-theme="dark"] .waiseo-plan-badge.waiseo-plan-basic {
	background: rgba(20, 110, 245, 0.15);
	color: #6ba3f7;
	border-color: rgba(20, 110, 245, 0.25);
}

[data-theme="dark"] .waiseo-plan-badge.waiseo-plan-pro {
	background: rgba(124, 58, 237, 0.15);
	color: #a78bfa;
	border-color: rgba(124, 58, 237, 0.25);
}

[data-theme="dark"] .waiseo-plan-badge.waiseo-plan-agency {
	background: rgba(245, 158, 11, 0.12);
	color: #fbbf24;
	border-color: rgba(245, 158, 11, 0.2);
}

/* Upgrade CTA dark mode */
[data-theme="dark"] .waiseo-cta-inner {
	background: linear-gradient(135deg, rgba(20, 110, 245, 0.1) 0%, rgba(124, 58, 237, 0.12) 50%, rgba(99, 102, 241, 0.1) 100%);
	border-color: rgba(124, 58, 237, 0.2);
}

[data-theme="dark"] .waiseo-cta-inner h3 {
	color: var(--sp-text, #e4e4e7);
}

[data-theme="dark"] .waiseo-cta-inner p {
	color: var(--sp-text-secondary, #8b97a8);
}

/* License detail meta dark mode */
[data-theme="dark"] .waiseo-feature-count {
	color: var(--sp-text-secondary, #8b97a8);
}

[data-theme="dark"] .waiseo-license-detail {
	color: var(--sp-text-secondary, #8b97a8);
}

[data-theme="dark"] .waiseo-license-detail strong {
	color: var(--sp-text, #e4e4e7);
}

[data-theme="dark"] .waiseo-result-box {
	background: var(--sp-bg-card, #1e1e2e);
	border-color: var(--sp-border, rgba(255, 255, 255, 0.06));
	color: var(--sp-text, #e4e4e7);
}

/* Plan-cell minus icon in dark mode */
[data-theme="dark"] .waiseo-plan-cell .dashicons-minus,
	[data-theme="dark"] .waiseo-plan-cell .svg-minus {
	color: rgba(255, 255, 255, 0.15) !important;
}