/* WP Super Docs — standalone layout */

:root {
	--wpsd-bg: #ffffff;
	--wpsd-text: #1f2328;
	--wpsd-muted: #6e7781;
	--wpsd-border: #e5e7eb;
	--wpsd-accent: #d97706;
	--wpsd-accent-hover: #b45309;
	--wpsd-accent-bg: #fef3c7;
	--wpsd-content-max: 820px;
	--wpsd-sidebar-width: 280px;
	--wpsd-shell-max: 1600px;
	--wpsd-topbar-height: 64px;
	--wpsd-radius: 8px;
	--wpsd-sidebar-bg: #ffffff;
	--wpsd-card-bg: #ffffff;
	--wpsd-code-bg: #f3f4f6;
	--wpsd-pre-bg: #1f2328;
	--wpsd-pre-text: #f3f4f6;
	--wpsd-input-bg: #f9fafb;
	--wpsd-hover-bg: #f9fafb;
	--wpsd-footer-bg: #f9fafb;
	--wpsd-font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

/* ============ Dark theme ============ */
html[data-wpsd-theme="dark"] {
	--wpsd-bg: #0b1220;
	--wpsd-text: #e6edf3;
	--wpsd-muted: #8b97a8;
	--wpsd-border: #2a3548;
	--wpsd-accent: #fbbf24;
	--wpsd-accent-hover: #fcd34d;
	--wpsd-accent-bg: rgba(251, 191, 36, .12);
	--wpsd-sidebar-bg: #0b1220;
	--wpsd-card-bg: #131c2e;
	--wpsd-code-bg: #1b2538;
	--wpsd-pre-bg: #050a16;
	--wpsd-pre-text: #e6edf3;
	--wpsd-input-bg: #131c2e;
	--wpsd-hover-bg: #1b2538;
	--wpsd-footer-bg: #070d19;
}

.wpsd-body {
	margin: 0;
	background: var(--wpsd-bg);
	color: var(--wpsd-text);
	font-family: var(--wpsd-font);
	font-size: 16px;
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
}
.wpsd-body * { box-sizing: border-box; }

/* ============ Topbar ============ */
.wpsd-topbar {
	position: sticky;
	top: 0;
	z-index: 100;
	background: var(--wpsd-card-bg);
	border-bottom: 1px solid var(--wpsd-border);
	height: var(--wpsd-topbar-height);
	display: flex;
	align-items: center;
}
.wpsd-topbar-inner {
	width: 100%;
	margin: 0;
	padding: 0;
	display: flex;
	align-items: center;
	gap: 32px;
}
.wpsd-brand {
	display: flex;
	align-items: center;
	gap: 10px;
	text-decoration: none;
	color: var(--wpsd-text);
	font-weight: 600;
	font-size: 18px;
	flex-shrink: 0;
}
.wpsd-brand img { height: 32px; width: auto; display: block; }
.wpsd-brand-mark {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	background: var(--wpsd-accent);
	color: #fff;
	border-radius: 6px;
	font-weight: 700;
	text-transform: uppercase;
}

/* ============ Product switcher button ============ */
.wpsd-product-switcher-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 8px 14px;
	background: var(--wpsd-accent-bg);
	color: var(--wpsd-accent);
	border: 1px solid transparent;
	border-radius: 8px;
	font: inherit;
	font-size: 14px;
	font-weight: 600;
	cursor: pointer;
	transition: background-color .15s ease, border-color .15s ease;
}
.wpsd-product-switcher-btn:hover {
	background: var(--wpsd-accent-bg);
	border-color: var(--wpsd-accent);
}
.wpsd-product-switcher-btn .wpsd-chevron { transition: transform .15s ease; }
.wpsd-product-switcher-btn[aria-expanded="true"] .wpsd-chevron { transform: rotate(180deg); }

.wpsd-current-product { white-space: nowrap; }
.wpsd-current-product-static {
	padding: 8px 14px;
	color: var(--wpsd-text);
	font-size: 14px;
	font-weight: 600;
}

/* ============ Modal ============ */
.wpsd-modal {
	position: fixed;
	inset: 0;
	z-index: 1000;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 24px;
}
.wpsd-modal[hidden] { display: none; }
.wpsd-modal-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(15, 23, 42, .55);
	backdrop-filter: blur(2px);
	animation: wpsd-fade-in .15s ease;
}
.wpsd-modal-panel {
	position: relative;
	background: var(--wpsd-card-bg);
	border-radius: 14px;
	box-shadow: 0 20px 60px rgba(0, 0, 0, .3);
	width: 100%;
	max-width: 720px;
	max-height: 85vh;
	display: flex;
	flex-direction: column;
	animation: wpsd-pop-in .18s ease;
}
@keyframes wpsd-fade-in { from { opacity: 0; } to { opacity: 1; } }
@keyframes wpsd-pop-in {
	from { opacity: 0; transform: scale(.96) translateY(8px); }
	to   { opacity: 1; transform: scale(1) translateY(0); }
}
.wpsd-modal-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 20px 24px;
	border-bottom: 1px solid var(--wpsd-border);
}
.wpsd-modal-header h2 {
	margin: 0;
	font-size: 18px;
	font-weight: 600;
	color: var(--wpsd-text);
}
.wpsd-modal-close {
	background: transparent;
	border: 0;
	padding: 6px;
	cursor: pointer;
	color: var(--wpsd-muted);
	border-radius: 6px;
	display: inline-flex;
}
.wpsd-modal-close:hover { color: var(--wpsd-text); background: var(--wpsd-code-bg); }
.wpsd-modal-body { padding: 24px; overflow-y: auto; }

.wpsd-product-grid-modal {
	display: grid;
	gap: 14px;
}
.wpsd-product-grid-modal.wpsd-cols-2 { grid-template-columns: repeat(2, 1fr); }
.wpsd-product-grid-modal.wpsd-cols-3 { grid-template-columns: repeat(3, 1fr); }

.wpsd-product-card-modal {
	display: flex;
	flex-direction: column;
	gap: 6px;
	padding: 20px;
	border: 1px solid var(--wpsd-border);
	border-radius: 10px;
	text-decoration: none;
	color: var(--wpsd-text);
	transition: border-color .15s ease, transform .15s ease, box-shadow .15s ease;
}
.wpsd-product-card-modal.has-image {
	flex-direction: row;
	align-items: flex-start;
	gap: 14px;
}
.wpsd-product-card-modal-image {
	width: 48px;
	height: 48px;
	border-radius: 8px;
	object-fit: cover;
	flex-shrink: 0;
	background: var(--wpsd-hover-bg);
	border: 1px solid var(--wpsd-border);
}
.wpsd-product-card-modal-text {
	display: flex;
	flex-direction: column;
	gap: 4px;
	min-width: 0;
}
.wpsd-product-card-modal:hover {
	border-color: var(--wpsd-accent);
	transform: translateY(-2px);
	box-shadow: 0 6px 18px rgba(217, 119, 6, .12);
}
.wpsd-product-card-modal.is-active {
	border-color: var(--wpsd-accent);
	background: var(--wpsd-accent-bg);
}
.wpsd-product-card-name { font-weight: 600; font-size: 16px; }
.wpsd-product-card-desc { font-size: 13px; color: var(--wpsd-muted); line-height: 1.5; }

.wpsd-topbar-right { margin-left: auto; display: flex; align-items: center; gap: 16px; }
.wpsd-back-site {
	color: var(--wpsd-muted);
	text-decoration: none;
	font-size: 14px;
}
.wpsd-back-site:hover { color: var(--wpsd-text); }

/* ============ Theme toggle ============ */
.wpsd-theme-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	background: transparent;
	border: 1px solid var(--wpsd-border);
	border-radius: 8px;
	color: var(--wpsd-text);
	cursor: pointer;
	transition: background-color .15s, border-color .15s;
}
.wpsd-theme-toggle:hover {
	background: var(--wpsd-hover-bg);
	border-color: var(--wpsd-accent);
}
.wpsd-theme-toggle .wpsd-icon-moon { display: none; }
html[data-wpsd-theme="dark"] .wpsd-theme-toggle .wpsd-icon-sun  { display: none; }
html[data-wpsd-theme="dark"] .wpsd-theme-toggle .wpsd-icon-moon { display: block; }

/* ============ Search ============ */
.wpsd-search { position: relative; display: flex; align-items: center; gap: 6px; }
.wpsd-search-input {
	width: 240px;
	padding: 7px 70px 7px 12px;
	border: 1px solid var(--wpsd-border);
	border-radius: 6px;
	font-size: 14px;
	background: var(--wpsd-hover-bg);
	color: var(--wpsd-text);
	font-family: inherit;
}
.wpsd-search-input:focus {
	outline: none;
	border-color: var(--wpsd-accent);
	background: var(--wpsd-card-bg);
	box-shadow: 0 0 0 3px rgba(217, 119, 6, .15);
}
/* Keyboard shortcut hint inside the search box */
.wpsd-search-input-wrap {
	position: relative;
	display: flex;
	align-items: center;
}
.wpsd-search-kbd {
	position: absolute;
	right: 8px;
	top: 50%;
	transform: translateY(-50%);
	display: flex;
	align-items: center;
	gap: 2px;
	pointer-events: none;
	transition: opacity .15s;
}
.wpsd-search-kbd kbd {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 1px 5px;
	border: 1px solid var(--wpsd-border);
	border-radius: 4px;
	font-size: 11px;
	font-family: inherit;
	line-height: 16px;
	color: var(--wpsd-muted);
	background: var(--wpsd-card-bg);
	box-shadow: 0 1px 0 var(--wpsd-border);
	white-space: nowrap;
}
.wpsd-search-input:focus ~ .wpsd-search-kbd,
.wpsd-search-input:not(:placeholder-shown) ~ .wpsd-search-kbd {
	opacity: 0;
}
.wpsd-search-scope {
	padding: 6px 8px;
	border: 1px solid var(--wpsd-border);
	border-radius: 6px;
	background: var(--wpsd-card-bg);
	font-size: 13px;
	color: var(--wpsd-text);
	cursor: pointer;
}
.wpsd-search-results {
	position: absolute;
	top: calc(100% + 8px);
	right: 0;
	width: 420px;
	max-width: calc(100vw - 48px);
	max-height: 70vh;
	overflow-y: auto;
	background: var(--wpsd-card-bg);
	border: 1px solid var(--wpsd-border);
	border-radius: var(--wpsd-radius);
	box-shadow: 0 12px 40px rgba(0, 0, 0, .12);
	z-index: 200;
}
.wpsd-search-list { list-style: none; margin: 0; padding: 6px; }
.wpsd-search-list li { margin: 0; }
.wpsd-search-list a {
	display: block;
	padding: 12px 14px;
	border-radius: 6px;
	text-decoration: none;
	color: var(--wpsd-text);
}
.wpsd-search-list a:hover { background: var(--wpsd-hover-bg); }
.wpsd-search-title { font-weight: 600; font-size: 14px; margin-bottom: 3px; }
.wpsd-search-meta {
	font-size: 11px;
	color: var(--wpsd-accent);
	text-transform: uppercase;
	letter-spacing: .04em;
	margin-bottom: 4px;
}
.wpsd-search-excerpt { font-size: 13px; color: var(--wpsd-muted); line-height: 1.5; }
.wpsd-search-results mark {
	background: var(--wpsd-accent-bg);
	color: var(--wpsd-accent-hover);
	padding: 0 2px;
	border-radius: 2px;
}
.wpsd-search-empty,
.wpsd-search-loading {
	padding: 16px;
	color: var(--wpsd-muted);
	font-size: 14px;
	text-align: center;
}

/* ============ Shell ============ */
.wpsd-shell {
	width: 100%;
	margin: 0;
	padding: 0 48px;
	display: grid;
	grid-template-columns: var(--wpsd-sidebar-width) 1fr;
	gap: 48px;
	align-items: start;
}

/* ============ Sidebar ============ */
.wpsd-sidebar {
	position: sticky;
	top: calc(var(--wpsd-topbar-height) + 24px);
	max-height: calc(100vh - var(--wpsd-topbar-height) - 48px);
	overflow-y: auto;
	padding: 32px 0;
}
.wpsd-nav-group { margin-bottom: 28px; }
.wpsd-nav-heading {
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .06em;
	color: var(--wpsd-accent);
	margin: 0 0 10px;
	padding: 0 8px;
	background: white;
}
.wpsd-nav-list { list-style: none; margin: 0; padding: 0; }
.wpsd-nav-list li { margin: 0; }
.wpsd-nav-link {
	display: block;
	padding: 7px 12px;
	color: var(--wpsd-muted);
	text-decoration: none;
	font-size: 14px;
	border-radius: 6px;
	border-left: 2px solid transparent;
	margin-left: 6px;
}
.wpsd-nav-link:hover { color: var(--wpsd-text); background: var(--wpsd-hover-bg); }
.wpsd-nav-link.is-current {
	color: var(--wpsd-accent);
	font-weight: 600;
	background: var(--wpsd-accent-bg);
	border-left-color: var(--wpsd-accent);
}
.wpsd-empty { color: var(--wpsd-muted); padding: 16px 8px; font-size: 14px; }

/* ============ Main ============ */
.wpsd-main { padding: 40px 0 80px; min-width: 0; }
.wpsd-main-inner { max-width: none; width: 100%; }

.wpsd-main-inner h1 {
	font-size: 36px;
	font-weight: 700;
	margin: 0 0 24px;
	line-height: 1.2;
	color: var(--wpsd-text);
}
.wpsd-main-inner h2 { font-size: 24px; font-weight: 600; margin: 40px 0 16px; color: var(--wpsd-text); }
.wpsd-main-inner h3 { font-size: 19px; font-weight: 600; margin: 32px 0 12px; color: var(--wpsd-text); }
.wpsd-main-inner h4, .wpsd-main-inner h5, .wpsd-main-inner h6 { color: var(--wpsd-text); }
.wpsd-main-inner p { margin: 0 0 16px; color: var(--wpsd-text); }
.wpsd-main-inner ul, .wpsd-main-inner ol { margin: 0 0 16px; padding-left: 24px; }
.wpsd-main-inner li { margin-bottom: 6px; }
.wpsd-main-inner a { color: var(--wpsd-accent); text-decoration: underline; text-underline-offset: 2px; }
.wpsd-main-inner a:hover { color: var(--wpsd-accent-hover); }
/* Cards are full-block links — underline looks wrong on titles and excerpts */
.wpsd-main-inner .wpsd-popular-card,
.wpsd-main-inner .wpsd-popular-card * { text-decoration: none; color: inherit; }
.wpsd-main-inner .wpsd-popular-card:hover { border-color: var(--wpsd-accent); }
.wpsd-main-inner code {
	background: var(--wpsd-code-bg);
	padding: 2px 6px;
	border-radius: 4px;
	font-size: .9em;
	font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
}
.wpsd-main-inner pre {
	background: var(--wpsd-pre-bg);
	color: var(--wpsd-pre-text);
	padding: 16px 20px;
	border-radius: var(--wpsd-radius);
	overflow-x: auto;
	font-size: 14px;
	margin: 0 0 20px;
}
.wpsd-main-inner pre code { background: transparent; padding: 0; color: inherit; }
.wpsd-main-inner blockquote {
	border-left: 3px solid var(--wpsd-accent);
	padding: 4px 16px;
	margin: 0 0 20px;
	color: var(--wpsd-muted);
	background: var(--wpsd-accent-bg);
}
.wpsd-main-inner img { max-width: 100%; height: auto; border-radius: var(--wpsd-radius); }
.wpsd-main-inner table {
	width: 100%;
	border-collapse: collapse;
	margin: 0 0 20px;
	font-size: 14px;
}
.wpsd-main-inner th, .wpsd-main-inner td {
	border: 1px solid var(--wpsd-border);
	padding: 10px 12px;
	text-align: left;
}
.wpsd-main-inner th { background: var(--wpsd-hover-bg); font-weight: 600; }

.wpsd-lead { font-size: 18px; color: var(--wpsd-muted); margin-bottom: 24px; }

/* ============ Mobile menu ============ */
.wpsd-mobile-toggle {
	display: none;
	background: transparent;
	border: 0;
	padding: 6px;
	color: var(--wpsd-text);
	cursor: pointer;
	border-radius: 6px;
	margin-right: 4px;
}
.wpsd-mobile-toggle:hover { background: var(--wpsd-code-bg); }

.wpsd-drawer {
	position: fixed;
	inset: 0;
	z-index: 1100;
}
.wpsd-drawer[hidden] { display: none; }
.wpsd-drawer-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(15, 23, 42, .55);
	animation: wpsd-fade-in .15s ease;
}
.wpsd-drawer-panel {
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	width: min(86vw, 340px);
	background: var(--wpsd-bg);
	box-shadow: 0 0 60px rgba(0, 0, 0, .25);
	display: flex;
	flex-direction: column;
	overflow: hidden;
	animation: wpsd-slide-in .2s ease;
}
@keyframes wpsd-slide-in {
	from { transform: translateX(-100%); }
	to   { transform: translateX(0); }
}
.wpsd-drawer-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 14px 16px;
	border-bottom: 1px solid var(--wpsd-border);
	flex-shrink: 0;
}
.wpsd-drawer-close {
	background: transparent;
	border: 0;
	padding: 4px;
	color: var(--wpsd-muted);
	cursor: pointer;
	border-radius: 6px;
	display: inline-flex;
}
.wpsd-drawer-close:hover { color: var(--wpsd-text); background: var(--wpsd-code-bg); }

.wpsd-drawer-products {
	padding: 14px 16px 8px;
	border-bottom: 1px solid var(--wpsd-border);
	flex-shrink: 0;
}
.wpsd-drawer-section-label {
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .06em;
	color: var(--wpsd-muted);
	margin-bottom: 8px;
}
.wpsd-drawer-product {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 8px 12px;
	margin-bottom: 4px;
	color: var(--wpsd-text);
	text-decoration: none;
	font-size: 14px;
	font-weight: 500;
	border-radius: 6px;
}
.wpsd-drawer-product:hover { background: var(--wpsd-hover-bg); }
.wpsd-drawer-product.is-active {
	background: var(--wpsd-accent-bg);
	color: var(--wpsd-accent);
	font-weight: 600;
}
.wpsd-drawer-product-image {
	width: 28px;
	height: 28px;
	border-radius: 6px;
	object-fit: cover;
	flex-shrink: 0;
	background: var(--wpsd-hover-bg);
}

/* Drawer product dropdown toggle (mobile, scales to many products) */
.wpsd-drawer-product-toggle {
	display: flex;
	align-items: center;
	gap: 10px;
	width: 100%;
	padding: 10px 12px;
	background: var(--wpsd-hover-bg);
	border: 1px solid var(--wpsd-border);
	border-radius: 8px;
	color: var(--wpsd-text);
	font: inherit;
	font-size: 14px;
	font-weight: 600;
	cursor: pointer;
	text-align: left;
}
.wpsd-drawer-product-toggle:hover { border-color: var(--wpsd-accent); }
.wpsd-drawer-product-current {
	flex: 1;
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.wpsd-drawer-product-chevron {
	flex-shrink: 0;
	color: var(--wpsd-muted);
	transition: transform .15s ease;
}
.wpsd-drawer-product-toggle[aria-expanded="true"] .wpsd-drawer-product-chevron {
	transform: rotate(180deg);
}
.wpsd-drawer-product-list {
	margin-top: 6px;
	padding: 6px;
	max-height: 280px;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	background: var(--wpsd-card-bg);
	border: 1px solid var(--wpsd-border);
	border-radius: 8px;
}
.wpsd-drawer-product-list[hidden] { display: none; }

/* Mobile search toggle button (shown only on mobile) */
.wpsd-mobile-search-toggle {
	display: none;
	background: transparent;
	border: 1px solid var(--wpsd-border);
	border-radius: 8px;
	width: 36px;
	height: 36px;
	align-items: center;
	justify-content: center;
	color: var(--wpsd-text);
	cursor: pointer;
}
.wpsd-mobile-search-toggle:hover {
	background: var(--wpsd-hover-bg);
	border-color: var(--wpsd-accent);
}

.wpsd-drawer-nav {
	flex: 1;
	overflow-y: auto;
	padding: 16px;
	-webkit-overflow-scrolling: touch;
}
.wpsd-drawer-nav .wpsd-nav-group { margin-bottom: 24px; }
.wpsd-drawer-nav .wpsd-nav-heading {
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .06em;
	color: var(--wpsd-accent);
	margin: 0 0 8px;
	padding: 0 8px;
}
.wpsd-drawer-nav .wpsd-nav-list { list-style: none; margin: 0; padding: 0; }
.wpsd-drawer-nav .wpsd-nav-link {
	display: block;
	padding: 9px 12px;
	color: var(--wpsd-muted);
	text-decoration: none;
	font-size: 15px;
	border-radius: 6px;
	border-left: 2px solid transparent;
	margin-left: 6px;
}
.wpsd-drawer-nav .wpsd-nav-link:hover { color: var(--wpsd-text); background: var(--wpsd-hover-bg); }
.wpsd-drawer-nav .wpsd-nav-link.is-current {
	color: var(--wpsd-accent);
	font-weight: 600;
	background: var(--wpsd-accent-bg);
	border-left-color: var(--wpsd-accent);
}

/* ============ Breadcrumbs ============ */
.wpsd-breadcrumbs {
	margin: 0 0 16px;
	font-size: 13px;
	color: var(--wpsd-muted);
}
.wpsd-breadcrumbs ol {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 6px;
	list-style: none;
	margin: 0;
	padding: 0;
}
.wpsd-breadcrumbs li {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin: 0;
}
.wpsd-breadcrumbs a {
	color: var(--wpsd-muted);
	text-decoration: none;
	transition: color .15s;
}
.wpsd-breadcrumbs a:hover { color: var(--wpsd-accent); }
.wpsd-breadcrumbs [aria-current="page"] {
	color: var(--wpsd-text);
	font-weight: 500;
}
.wpsd-crumb-sep { color: var(--wpsd-border); user-select: none; }

/* Product index grid */
.wpsd-product-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: 16px;
	margin-top: 24px;
}
.wpsd-product-card {
	display: flex;
	gap: 16px;
	align-items: flex-start;
	padding: 20px;
	border: 1px solid var(--wpsd-border);
	border-radius: var(--wpsd-radius);
	text-decoration: none;
	color: var(--wpsd-text);
	transition: border-color .15s, transform .15s;
}
.wpsd-product-card:hover {
	border-color: var(--wpsd-accent);
	transform: translateY(-2px);
}
.wpsd-product-card-image {
	width: 56px;
	height: 56px;
	border-radius: 8px;
	object-fit: cover;
	flex-shrink: 0;
	background: var(--wpsd-hover-bg);
	border: 1px solid var(--wpsd-border);
}
.wpsd-product-card-text { min-width: 0; flex: 1; }
.wpsd-product-card h3 { margin: 0 0 8px; font-size: 18px; }
.wpsd-product-card p { margin: 0; color: var(--wpsd-muted); font-size: 14px; }

.wpsd-doc-list { list-style: none; padding: 0; }
.wpsd-doc-list li { padding: 12px 0; border-bottom: 1px solid var(--wpsd-border); }
.wpsd-doc-list a { color: var(--wpsd-text); text-decoration: none; font-weight: 500; }
.wpsd-doc-list a:hover { color: var(--wpsd-accent); }

/* Prev / next */
.wpsd-prev-next {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
	margin-top: 64px;
	padding-top: 32px;
	border-top: 1px solid var(--wpsd-border);
}
.wpsd-prev-next a {
	display: block;
	padding: 16px 20px;
	border: 1px solid var(--wpsd-border);
	border-radius: var(--wpsd-radius);
	text-decoration: none;
	color: var(--wpsd-text);
	transition: border-color .15s;
}
.wpsd-prev-next a:hover { border-color: var(--wpsd-accent); }
.wpsd-prev-next span {
	display: block;
	font-size: 12px;
	color: var(--wpsd-muted);
	text-transform: uppercase;
	letter-spacing: .05em;
	margin-bottom: 4px;
}
.wpsd-prev-next strong { font-weight: 600; font-size: 15px; }
.wpsd-next { text-align: right; }

/* ============ Mobile ============ */
@media (max-width: 900px) {
	.wpsd-mobile-toggle { display: inline-flex; }
	.wpsd-mobile-search-toggle { display: inline-flex; }
	.wpsd-search-desktop { display: none !important; }
	.wpsd-shell { grid-template-columns: 1fr; gap: 0; padding: 0 16px; }
	.wpsd-sidebar { display: none; }
	.wpsd-product-switcher { gap: 2px; flex-wrap: wrap; }
	.wpsd-product-tab { padding: 6px 10px; font-size: 13px; }
	.wpsd-topbar-inner { gap: 12px; padding: 0; flex-wrap: wrap; }
	.wpsd-back-site { display: none; }
	.wpsd-product-switcher-btn { padding: 6px 10px; font-size: 13px; }
	.wpsd-product-grid-modal.wpsd-cols-2,
	.wpsd-product-grid-modal.wpsd-cols-3 { grid-template-columns: 1fr; }
	.wpsd-modal { padding: 12px; }
	.wpsd-modal-panel { max-height: 90vh; }
	.wpsd-main { padding: 24px 0 60px; }
	.wpsd-main-inner h1 { font-size: 28px; }
	.wpsd-prev-next { grid-template-columns: 1fr; }
	.wpsd-topbar-right { gap: 8px; }
	.wpsd-footer-inner { padding: 18px 16px 14px; }
}

/* ============ Footer ============ */
.wpsd-footer {
	margin-top: 40px;
	background: var(--wpsd-footer-bg);
	border-top: 1px solid var(--wpsd-border);
	color: var(--wpsd-muted);
	font-size: 14px;
}
.wpsd-footer-inner {
	width: 100%;
	margin: 0;
	padding: 18px 48px 14px;
}
.wpsd-footer-top {
	display: grid;
	grid-template-columns: minmax(0, 1.2fr) minmax(0, 2fr);
	gap: 48px;
	padding-bottom: 14px;
}
.wpsd-footer-brand { max-width: 320px; }
.wpsd-footer-logo { max-height: 40px; width: auto; display: block; margin-bottom: 14px; }
.wpsd-footer-tagline {
	margin: 0;
	color: var(--wpsd-muted);
	font-size: 14px;
	line-height: 1.6;
}
.wpsd-footer-columns {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
	gap: 32px;
}
.wpsd-footer-col-heading {
	margin: 0 0 14px;
	font-size: 12px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .06em;
	color: var(--wpsd-text);
}
.wpsd-footer-col-links {
	list-style: none;
	margin: 0;
	padding: 0;
}
.wpsd-footer-col-links li { margin-bottom: 8px; }
.wpsd-footer-col-links a {
	color: var(--wpsd-muted);
	text-decoration: none;
	transition: color .15s;
}
.wpsd-footer-col-links a:hover { color: var(--wpsd-accent); }

.wpsd-footer-bottom {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	padding-top: 12px;
	border-top: 1px solid var(--wpsd-border);
	flex-wrap: wrap;
}
.wpsd-footer-bottom-left {
	display: flex;
	align-items: center;
	gap: 16px;
	flex-wrap: wrap;
}
.wpsd-footer-powered-by {
	font-size: 13px;
	color: var(--wpsd-muted);
}
.wpsd-footer-powered-by a {
	color: var(--wpsd-accent);
	text-decoration: none;
	font-weight: 500;
}
.wpsd-footer-powered-by a:hover { text-decoration: underline; }
.wpsd-footer-copyright {
	color: var(--wpsd-muted);
	font-size: 13px;
}
.wpsd-footer-copyright a { color: var(--wpsd-accent); text-decoration: none; }
.wpsd-footer-copyright a:hover { text-decoration: underline; }

.wpsd-footer-socials {
	display: flex;
	gap: 8px;
	list-style: none;
	margin: 0;
	padding: 0;
}
.wpsd-social {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: 8px;
	color: var(--wpsd-muted);
	border: 1px solid var(--wpsd-border);
	background: transparent;
	transition: all .15s;
}
.wpsd-social:hover {
	color: var(--wpsd-accent);
	border-color: var(--wpsd-accent);
	background: var(--wpsd-accent-bg);
}

@media (max-width: 760px) {
	.wpsd-footer-top { grid-template-columns: 1fr; gap: 22px; padding-bottom: 14px; }
	.wpsd-footer-bottom { flex-direction: column; align-items: flex-start; gap: 10px; }
	.wpsd-footer-inner { padding: 18px 16px 14px; }
}

/* ============ Mobile search modal ============ */
.wpsd-search-modal {
	position: fixed;
	inset: 0;
	z-index: 1200;
}
.wpsd-search-modal[hidden] { display: none; }
.wpsd-search-modal-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(15, 23, 42, .55);
	backdrop-filter: blur(2px);
	animation: wpsd-fade-in .15s ease;
}
.wpsd-search-modal-panel {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	background: var(--wpsd-bg);
	border-bottom: 1px solid var(--wpsd-border);
	box-shadow: 0 12px 40px rgba(0, 0, 0, .25);
	max-height: 100vh;
	display: flex;
	flex-direction: column;
	animation: wpsd-search-slide-down .2s ease;
}
@keyframes wpsd-search-slide-down {
	from { transform: translateY(-100%); }
	to   { transform: translateY(0); }
}
.wpsd-search-modal-header {
	padding: 14px 16px;
	border-bottom: 1px solid var(--wpsd-border);
	display: flex;
	flex-direction: column;
	gap: 10px;
	flex-shrink: 0;
}
.wpsd-search-mobile {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px 14px;
	background: var(--wpsd-hover-bg);
	border: 1px solid var(--wpsd-border);
	border-radius: 10px;
}
.wpsd-search-modal-icon { color: var(--wpsd-muted); flex-shrink: 0; }
.wpsd-search-input-mobile {
	flex: 1;
	width: auto;
	border: 0;
	background: transparent;
	padding: 4px 0;
	font-size: 16px; /* Prevents iOS zoom on focus */
	color: var(--wpsd-text);
	font-family: inherit;
	outline: none;
	min-width: 0;
}
.wpsd-search-modal-close {
	background: transparent;
	border: 0;
	padding: 4px;
	color: var(--wpsd-muted);
	cursor: pointer;
	border-radius: 6px;
	display: inline-flex;
	flex-shrink: 0;
}
.wpsd-search-modal-close:hover { color: var(--wpsd-text); background: var(--wpsd-code-bg); }
.wpsd-search-scope-mobile {
	padding: 8px 12px;
	border: 1px solid var(--wpsd-border);
	border-radius: 8px;
	background: var(--wpsd-bg);
	font-size: 14px;
	color: var(--wpsd-text);
	cursor: pointer;
}
.wpsd-search-modal-results {
	flex: 1;
	overflow-y: auto;
	padding: 6px;
	-webkit-overflow-scrolling: touch;
	background: var(--wpsd-bg);
	max-height: calc(100vh - 130px);
}
.wpsd-search-modal-results[hidden] { display: none; }
.wpsd-search-modal-results .wpsd-search-list { list-style: none; margin: 0; padding: 6px; }
.wpsd-search-modal-results .wpsd-search-list a {
	display: block;
	padding: 14px 16px;
	border-radius: 8px;
	text-decoration: none;
	color: var(--wpsd-text);
	border-bottom: 1px solid var(--wpsd-border);
}
.wpsd-search-modal-results .wpsd-search-list a:hover { background: var(--wpsd-hover-bg); }
.wpsd-search-modal-results .wpsd-search-title { font-weight: 600; font-size: 15px; margin-bottom: 4px; }
.wpsd-search-modal-results .wpsd-search-meta {
	font-size: 11px;
	color: var(--wpsd-accent);
	text-transform: uppercase;
	letter-spacing: .04em;
	margin-bottom: 4px;
}
.wpsd-search-modal-results .wpsd-search-excerpt { font-size: 13px; color: var(--wpsd-muted); line-height: 1.5; }
.wpsd-search-modal-results mark {
	background: var(--wpsd-accent-bg);
	color: var(--wpsd-accent-hover);
	padding: 0 2px;
	border-radius: 2px;
}
.wpsd-search-modal-results .wpsd-search-empty,
.wpsd-search-modal-results .wpsd-search-loading {
	padding: 24px 16px;
	color: var(--wpsd-muted);
	font-size: 14px;
	text-align: center;
}

/* ============ Doc page features ============ */

/* Doc meta strip (reading time + last updated) */
.wpsd-doc-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 18px;
	margin: -8px 0 24px;
	padding-bottom: 16px;
	border-bottom: 1px solid var(--wpsd-border);
	color: var(--wpsd-muted);
	font-size: 13px;
}
.wpsd-doc-meta-item {
	display: inline-flex;
	align-items: center;
	gap: 6px;
}
.wpsd-doc-meta-item svg {
	flex-shrink: 0;
	color: var(--wpsd-muted);
}

/* Doc body — content + TOC two-column layout.
   Content column flexes between a min readable width and a max comfortable
   reading width; TOC is fixed at 200px on the right. */
.wpsd-doc-has-toc .wpsd-doc-body {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 220px;
	gap: 56px;
	align-items: start;
}
.wpsd-doc-body .wpsd-doc-content { min-width: 0; }
/* Cap the actual prose at a comfortable reading width so wide screens
   don't produce 200-character lines. Applies whether or not a TOC is present. */
.wpsd-doc-content > * { max-width: 820px; }

/* Table of contents sidebar */
.wpsd-toc {
	position: sticky;
	top: calc(var(--wpsd-topbar-height) + 24px);
	max-height: calc(100vh - var(--wpsd-topbar-height) - 48px);
	overflow-y: auto;
	font-size: 13px;
	padding: 4px 0;
}
.wpsd-toc-title {
	margin: 0 0 12px;
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .06em;
	color: var(--wpsd-muted);
}
.wpsd-toc-list {
	list-style: none;
	margin: 0;
	padding: 0;
	border-left: 2px solid var(--wpsd-border);
}
.wpsd-toc-list li { margin: 0; }
.wpsd-toc-link {
	display: block;
	padding: 5px 0 5px 12px;
	margin-left: -2px;
	border-left: 2px solid transparent;
	color: var(--wpsd-muted);
	text-decoration: none;
	line-height: 1.4;
	transition: color .15s, border-color .15s;
}
.wpsd-toc-link:hover { color: var(--wpsd-text); }
.wpsd-toc-link.is-active {
	color: var(--wpsd-accent);
	border-left-color: var(--wpsd-accent);
	font-weight: 600;
}
.wpsd-toc-h3 { padding-left: 24px; font-size: 12px; }

/* Sharing buttons */
.wpsd-sharing {
	display: flex;
	align-items: center;
	gap: 12px;
	margin: 40px 0 0;
	padding: 16px 0;
	border-top: 1px solid var(--wpsd-border);
	flex-wrap: wrap;
}
.wpsd-sharing-label {
	font-size: 13px;
	font-weight: 600;
	color: var(--wpsd-muted);
	text-transform: uppercase;
	letter-spacing: .04em;
}
.wpsd-sharing-list {
	display: flex;
	gap: 8px;
	list-style: none;
	margin: 0;
	padding: 0;
}
/* Reset the prose <ul> rules from .wpsd-main-inner that would otherwise
   add padding-left: 24px and bottom margin to the share button list,
   which pushes the icons out of vertical alignment with the SHARE: label. */
.wpsd-main-inner .wpsd-sharing-list { padding-left: 0; padding-right: 0; margin: 0; }
.wpsd-main-inner .wpsd-sharing-list li { margin: 0; }
.wpsd-share-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: 8px;
	color: var(--wpsd-muted);
	border: 1px solid var(--wpsd-border);
	background: transparent;
	cursor: pointer;
	transition: all .15s;
	text-decoration: none;
	position: relative;
}
.wpsd-share-btn:hover {
	color: var(--wpsd-accent);
	border-color: var(--wpsd-accent);
	background: var(--wpsd-accent-bg);
}
.wpsd-share-copy-feedback {
	position: absolute;
	top: -28px;
	left: 50%;
	transform: translateX(-50%);
	background: var(--wpsd-text);
	color: var(--wpsd-bg);
	padding: 3px 8px;
	border-radius: 4px;
	font-size: 11px;
	font-weight: 600;
	white-space: nowrap;
	pointer-events: none;
}

/* Feedback widget */
.wpsd-feedback {
	margin: 32px 0 0;
	padding: 24px;
	background: var(--wpsd-hover-bg);
	border: 1px solid var(--wpsd-border);
	border-radius: var(--wpsd-radius);
	text-align: center;
}
.wpsd-feedback-question {
	margin: 0 0 14px;
	font-size: 16px;
	font-weight: 600;
	color: var(--wpsd-text);
}
.wpsd-feedback-buttons {
	display: flex;
	gap: 10px;
	justify-content: center;
}
.wpsd-feedback-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 8px 18px;
	background: var(--wpsd-card-bg);
	border: 1px solid var(--wpsd-border);
	border-radius: 8px;
	color: var(--wpsd-text);
	font: inherit;
	font-size: 14px;
	font-weight: 600;
	cursor: pointer;
	transition: all .15s;
}
.wpsd-feedback-btn:hover {
	border-color: var(--wpsd-accent);
	color: var(--wpsd-accent);
}
.wpsd-feedback-btn.is-selected {
	background: var(--wpsd-accent-bg);
	border-color: var(--wpsd-accent);
	color: var(--wpsd-accent);
}
.wpsd-feedback-followup { margin-top: 14px; }
.wpsd-feedback-thanks {
	margin: 0 0 12px;
	font-size: 14px;
	color: var(--wpsd-text);
	font-weight: 500;
}
.wpsd-feedback-comment-label {
	display: block;
	font-size: 13px;
	color: var(--wpsd-muted);
	margin-bottom: 6px;
	text-align: left;
}
.wpsd-feedback-comment {
	width: 100%;
	padding: 10px 12px;
	border: 1px solid var(--wpsd-border);
	border-radius: 6px;
	background: var(--wpsd-card-bg);
	color: var(--wpsd-text);
	font: inherit;
	font-size: 14px;
	resize: vertical;
}
.wpsd-feedback-comment:focus {
	outline: none;
	border-color: var(--wpsd-accent);
	box-shadow: 0 0 0 3px rgba(217, 119, 6, .15);
}
.wpsd-feedback-submit {
	margin-top: 10px;
	padding: 8px 18px;
	background: var(--wpsd-accent);
	color: #fff;
	border: 0;
	border-radius: 6px;
	font: inherit;
	font-size: 14px;
	font-weight: 600;
	cursor: pointer;
	transition: background-color .15s;
}
.wpsd-feedback-submit:hover { background: var(--wpsd-accent-hover); }
.wpsd-feedback-done p {
	margin: 0;
	color: #10b981;
	font-weight: 600;
	font-size: 14px;
}

/* Related docs */
.wpsd-related-docs {
	margin: 48px 0 0;
	padding-top: 32px;
	border-top: 1px solid var(--wpsd-border);
}
.wpsd-related-title {
	margin: 0 0 16px;
	font-size: 18px;
	font-weight: 600;
	color: var(--wpsd-text);
}
.wpsd-related-list {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
	gap: 12px;
	list-style: none;
	margin: 0;
	padding: 0;
}
.wpsd-related-link {
	display: block;
	padding: 14px 16px;
	border: 1px solid var(--wpsd-border);
	border-radius: var(--wpsd-radius);
	text-decoration: none;
	color: var(--wpsd-text);
	transition: border-color .15s, transform .15s;
}
.wpsd-related-link:hover {
	border-color: var(--wpsd-accent);
	transform: translateY(-2px);
}
.wpsd-related-link-title {
	display: block;
	font-weight: 600;
	font-size: 14px;
	margin-bottom: 4px;
}
.wpsd-related-link-desc {
	display: block;
	font-size: 12px;
	color: var(--wpsd-muted);
	line-height: 1.5;
}

/* Mobile: collapse TOC into a static block above content */
@media (max-width: 1100px) {
	.wpsd-doc-has-toc .wpsd-doc-body {
		grid-template-columns: 1fr;
		gap: 0;
	}
	.wpsd-toc {
		position: static;
		max-height: none;
		margin: 0 0 32px;
		padding: 16px 18px;
		background: var(--wpsd-hover-bg);
		border: 1px solid var(--wpsd-border);
		border-radius: var(--wpsd-radius);
		order: -1;
	}
}
@media (max-width: 760px) {
	.wpsd-feedback { padding: 18px; }
	/* Keep Yes/No side by side — stacking them looks awkward on a 2-button group. */
	.wpsd-feedback-buttons { flex-direction: row; flex-wrap: wrap; gap: 8px; }
	.wpsd-feedback-btn { flex: 1 1 auto; min-width: 90px; padding: 10px 14px; }
	.wpsd-related-list { grid-template-columns: 1fr; }
	.wpsd-sharing { flex-direction: column; align-items: flex-start; }
}

/* ============ Language switcher ============ */
.wpsd-lang-toggle {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 0 10px;
	height: 36px;
	background: transparent;
	border: 1px solid var(--wpsd-border);
	border-radius: 8px;
	color: var(--wpsd-text);
	cursor: pointer;
	font: inherit;
	transition: background-color .15s, border-color .15s;
}
.wpsd-lang-toggle:hover {
	background: var(--wpsd-hover-bg);
	border-color: var(--wpsd-accent);
}
.wpsd-lang-current-code {
	font-size: 12px;
	font-weight: 600;
	letter-spacing: .03em;
}

.wpsd-lang-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 8px;
}
.wpsd-lang-item {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 12px 14px;
	border: 1px solid var(--wpsd-border);
	border-radius: 8px;
	text-decoration: none;
	color: var(--wpsd-text);
	transition: border-color .15s, background-color .15s, transform .15s;
}
.wpsd-lang-item:hover {
	border-color: var(--wpsd-accent);
	background: var(--wpsd-hover-bg);
	transform: translateY(-1px);
}
.wpsd-lang-item.is-current {
	border-color: var(--wpsd-accent);
	background: var(--wpsd-accent-bg);
}
.wpsd-lang-flag {
	width: 24px;
	height: auto;
	border-radius: 3px;
	flex-shrink: 0;
}
.wpsd-lang-code-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 24px;
	background: var(--wpsd-hover-bg);
	border: 1px solid var(--wpsd-border);
	border-radius: 4px;
	font-size: 11px;
	font-weight: 700;
	color: var(--wpsd-muted);
	flex-shrink: 0;
}
.wpsd-lang-names {
	display: flex;
	align-items: baseline;
	gap: 8px;
	min-width: 0;
	flex: 1;
	flex-wrap: wrap;
}
.wpsd-lang-native-name {
	font-size: 14px;
	font-weight: 600;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.wpsd-lang-english-name {
	font-size: 12px;
	color: var(--wpsd-muted);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.wpsd-lang-english-name::before {
	content: "·";
	margin-right: 8px;
	color: var(--wpsd-border);
}
.wpsd-lang-check {
	color: var(--wpsd-accent);
	flex-shrink: 0;
}
@media (max-width: 760px) {
	.wpsd-lang-list { grid-template-columns: 1fr; }
}

/* ============ Popular answers (homepage section) ============ */
.wpsd-popular-section {
	margin: 24px 0 48px;
	padding: 0;
}
.wpsd-popular-title {
	font-size: 22px;
	font-weight: 700;
	margin: 0 0 6px;
	color: var(--wpsd-text);
}
.wpsd-popular-intro {
	margin: 0 0 20px;
	color: var(--wpsd-muted);
	font-size: 15px;
}
.wpsd-popular-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 16px;
}
.wpsd-popular-card {
	position: relative;
	display: block;
	background: var(--wpsd-card-bg);
	border: 1px solid var(--wpsd-border);
	border-radius: 10px;
	padding: 18px 20px 44px;
	text-decoration: none;
	color: var(--wpsd-text);
	transition: border-color .15s ease, transform .15s ease, box-shadow .15s ease;
	min-height: 110px;
}
.wpsd-popular-card:hover {
	border-color: var(--wpsd-accent);
	transform: translateY(-1px);
	box-shadow: 0 4px 14px rgba(0,0,0,.04);
}
.wpsd-popular-card-product {
	display: inline-block;
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: .05em;
	color: var(--wpsd-accent);
	font-weight: 600;
	margin-bottom: 6px;
}
.wpsd-popular-card-title {
	font-size: 17px;
	font-weight: 600;
	margin: 0 0 8px;
	line-height: 1.35;
	color: var(--wpsd-text);
}
.wpsd-popular-card-excerpt {
	font-size: 14px;
	color: var(--wpsd-muted);
	margin: 0;
	line-height: 1.55;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.wpsd-popular-card-arrow {
	position: absolute;
	right: 18px;
	bottom: 14px;
	color: var(--wpsd-accent);
	font-size: 18px;
	font-weight: 700;
	transition: transform .15s ease;
}
.wpsd-popular-card:hover .wpsd-popular-card-arrow {
	transform: translateX(3px);
}
.wpsd-index-products-heading {
	font-size: 18px;
	font-weight: 600;
	margin: 32px 0 6px;
	color: var(--wpsd-text);
}

/* ============================================================
   RTL support
   ------------------------------------------------------------
   The layout template adds class="wpsd-rtl" on <html> when the
   current language reads right-to-left. We use a class hook
   instead of the [dir="rtl"] attribute selector because it's
   higher specificity, not affected by WordPress locale quirks,
   and guaranteed to be present when we say so.
   ============================================================ */

/* -------- RTL grid mirroring via native `direction: rtl` --------
   We use multiple selectors so the rule matches regardless of which
   DOM hook is present: <html class="wpsd-rtl">, <body class="wpsd-rtl">,
   <div class="wpsd-shell wpsd-rtl">, or <div class="wpsd-shell" dir="rtl">.
   The last two are self-hooks emitted directly on the shell, so they
   match even if the ancestor hooks fail.

   `direction: rtl` on a grid container is the NATIVE CSS way to mirror
   track order: the first DOM child fills the rightmost track, the second
   child fills the leftmost. DOM order stays sidebar → main, but visually
   the sidebar moves to the right and main to the left. No `order:` needed,
   no `grid-template-columns` swap needed. */
html.wpsd-rtl .wpsd-shell,
body.wpsd-rtl .wpsd-shell,
.wpsd-shell.wpsd-rtl,
.wpsd-shell[dir="rtl"] {
	direction: rtl;
	/* Keep the track sizes identical to LTR — only the visual order flips. */
	grid-template-columns: var(--wpsd-sidebar-width) 1fr;
}

/* TOC grid: same trick. DOM order is content → TOC, grid is 1fr 220px.
   With direction: rtl, content fills the rightmost 1fr track and TOC
   fills the leftmost 220px track. Perfect mirror. */
html.wpsd-rtl .wpsd-doc-has-toc .wpsd-doc-body,
body.wpsd-rtl .wpsd-doc-has-toc .wpsd-doc-body,
.wpsd-rtl .wpsd-doc-has-toc .wpsd-doc-body,
[dir="rtl"] .wpsd-doc-has-toc .wpsd-doc-body {
	direction: rtl;
	grid-template-columns: minmax(0, 1fr) 220px;
}

/* Sidebar nav active-item accent bar flips to the right edge. */
.wpsd-rtl .wpsd-nav-link {
	border-left: 0;
	border-right: 2px solid transparent;
	margin-left: 0;
	margin-right: 6px;
}
.wpsd-rtl .wpsd-nav-link.is-current {
	border-right-color: var(--wpsd-accent);
}

/* Section headings inside the nav */
.wpsd-rtl .wpsd-nav-section-title {
	padding: 0 8px 0 0;
}

/* Doc prose: list indent flips */
.wpsd-rtl .wpsd-main-inner ul,
.wpsd-rtl .wpsd-main-inner ol {
	padding-left: 0;
	padding-right: 24px;
}

/* Blockquote border flips */
.wpsd-rtl .wpsd-main-inner blockquote {
	border-left: 0;
	border-right: 3px solid var(--wpsd-accent);
	padding-left: 0;
	padding-right: 16px;
}

/* Table cells — text-align:left becomes right */
.wpsd-rtl .wpsd-main-inner th,
.wpsd-rtl .wpsd-main-inner td {
	text-align: right;
}

/* TOC moves to the LEFT side of the content column in RTL via the
   direction: rtl flip above. The left border on TOC items becomes a right border. */
.wpsd-rtl .wpsd-toc {
	border-left: 0;
	border-right: 2px solid var(--wpsd-border);
}
.wpsd-rtl .wpsd-toc-link {
	border-left: 0;
	border-right: 2px solid transparent;
	margin-left: 0;
	margin-right: -2px;
	padding-left: 0;
	padding-right: 12px;
}
.wpsd-rtl .wpsd-toc-link.is-current {
	border-right-color: var(--wpsd-accent);
}
.wpsd-rtl .wpsd-toc-h3 {
	padding-left: 0;
	padding-right: 24px;
}

/* Topbar right group should sit on the left in RTL */
.wpsd-rtl .wpsd-topbar-right {
	margin-left: 0;
	margin-right: auto;
}

/* "Back to site" arrow — the textual "←" is a physical LTR arrow.
   Replace the content with a right-pointing arrow via pseudo-element. */
.wpsd-rtl .wpsd-back-site {
	direction: rtl;
}

/* Prev/next footer nav: the next arrow on the right should swap with prev */
.wpsd-rtl .wpsd-next { text-align: left; }
.wpsd-rtl .wpsd-prev { text-align: right; }

/* Search — the scope select that sits inside the search box */
.wpsd-rtl .wpsd-search-desktop {
	direction: rtl;
}
.wpsd-rtl .wpsd-search-input {
	text-align: right;
}

/* Modals: close button flips side */
.wpsd-rtl .wpsd-modal-close {
	right: auto;
	left: 16px;
}

/* Breadcrumb: the chevron glyph "›" points the wrong way in RTL, use "‹" instead. */
.wpsd-rtl .wpsd-crumb-sep {
	transform: scaleX(-1);
	display: inline-block;
}

/* Feedback widget: the big blockquote-style comment area */
.wpsd-rtl .wpsd-feedback-comment-box {
	text-align: right;
}

/* Language switcher button: current code badge flips from the right of the icon to the left */
.wpsd-rtl .wpsd-lang-toggle {
	flex-direction: row-reverse;
}

/* Language modal items: flag sits on the right, text on the left */
.wpsd-rtl .wpsd-lang-item {
	flex-direction: row-reverse;
}

/* Doc meta row (reading time + updated date) */
.wpsd-rtl .wpsd-doc-meta {
	direction: rtl;
}

/* Mobile drawer panel — slides from the right instead of the left */
.wpsd-rtl .wpsd-drawer-panel {
	left: auto;
	right: 0;
}

/* Popular answers cards: arrow flips from bottom-right to bottom-left and
   points the other way in RTL. */
.wpsd-rtl .wpsd-popular-card {
	padding: 18px 20px 44px;
}
.wpsd-rtl .wpsd-popular-card-arrow {
	right: auto;
	left: 18px;
	transform: scaleX(-1);
}
.wpsd-rtl .wpsd-popular-card:hover .wpsd-popular-card-arrow {
	transform: scaleX(-1) translateX(3px);
}

/* ============================================================
   RTL responsive overrides — MUST be the last rules in the RTL
   block. The unconditional RTL rules above use selectors like
   `html.wpsd-rtl .wpsd-shell` (specificity 0,2,1) which win over
   the default LTR mobile rules at the same breakpoint. To keep
   the mobile layout sane on RTL we re-declare the relevant grid
   collapses with the SAME high-specificity selectors so cascade
   order alone decides the winner. Source order matters here:
   these blocks must come AFTER every unconditional RTL rule
   that targets the same selector / property pair.
   ============================================================ */

/* Collapse the doc-body TOC grid in RTL at the same 1100px breakpoint
   the LTR rule uses. Without this the unconditional 1fr 220px RTL grid
   above keeps a phantom 220px column reserved between 901–1100px,
   which squeezes the doc text into a narrow band. */
@media (max-width: 1100px) {
	html.wpsd-rtl .wpsd-doc-has-toc .wpsd-doc-body,
	body.wpsd-rtl .wpsd-doc-has-toc .wpsd-doc-body,
	.wpsd-rtl .wpsd-doc-has-toc .wpsd-doc-body,
	[dir="rtl"] .wpsd-doc-has-toc .wpsd-doc-body {
		grid-template-columns: 1fr;
		gap: 0;
	}
	/* The collapsed TOC becomes a card with its own background — the
	   right-side accent border the unconditional RTL rule adds is left
	   over from sidebar-mode and looks wrong on the inline card. */
	.wpsd-rtl .wpsd-toc {
		border-right: 0;
	}
}

/* Collapse the main shell sidebar grid in RTL at the same 900px
   breakpoint the LTR rule uses. Without this the unconditional
   sidebar-width 1fr RTL grid leaves an empty sidebar track on
   mobile because the `.wpsd-sidebar` element is display:none. */
@media (max-width: 900px) {
	html.wpsd-rtl .wpsd-shell,
	body.wpsd-rtl .wpsd-shell,
	.wpsd-shell.wpsd-rtl,
	.wpsd-shell[dir="rtl"] {
		grid-template-columns: 1fr;
		gap: 0;
		padding: 0 16px;
	}
}

/* Dashboard-admin and feedback-admin pages: nothing to flip because they
   live inside the WP admin which already handles its own RTL via the core
   admin stylesheet. We intentionally leave those alone. */

/* ============================================================
   v1.25: Feature batch — status badges, announcement bar,
   category icons, anchor header-links, keyboard shortcuts
   overlay, 404 page.
   ============================================================ */

/* ---- Status badges ---- */
.wpsd-status-badge {
	display: inline-block;
	padding: 2px 8px;
	margin-left: 8px;
	font-size: 10px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .04em;
	border-radius: 999px;
	vertical-align: middle;
	line-height: 1.6;
	white-space: nowrap;
}
.wpsd-status-new        { background: #dcfce7; color: #166534; }
.wpsd-status-updated    { background: #dbeafe; color: #1e40af; }
.wpsd-status-beta       { background: #ede9fe; color: #5b21b6; }
.wpsd-status-deprecated { background: #fee2e2; color: #991b1b; }
html[data-wpsd-theme="dark"] .wpsd-status-new        { background: rgba(22,101,52,.25);  color: #86efac; }
html[data-wpsd-theme="dark"] .wpsd-status-updated    { background: rgba(30,64,175,.25);  color: #93c5fd; }
html[data-wpsd-theme="dark"] .wpsd-status-beta       { background: rgba(91,33,182,.25);  color: #c4b5fd; }
html[data-wpsd-theme="dark"] .wpsd-status-deprecated { background: rgba(153,27,27,.25);  color: #fca5a5; }

/* Sidebar nav: push the badge to the right edge of the link. */
.wpsd-nav-link { display: flex; align-items: center; gap: 6px; }
.wpsd-nav-link .wpsd-nav-link-text { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; }
.wpsd-nav-link .wpsd-status-badge { margin-left: auto; flex-shrink: 0; font-size: 9px; padding: 1px 6px; }

/* Single-doc title: badge sits beside the h1 at a slightly bigger size. */
.wpsd-doc-title .wpsd-status-badge { font-size: 12px; padding: 3px 10px; }

/* ---- Category icons in sidebar ---- */
.wpsd-nav-heading { display: flex; align-items: center; gap: 8px; }
.wpsd-cat-icon { display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.wpsd-cat-icon-emoji { font-size: 16px; line-height: 1; }
.wpsd-cat-icon-img img { height: 18px; width: auto; display: block; }

/* ---- Anchor header-links (# button inside h2/h3) ---- */
.wpsd-headerlink {
	display: inline-block;
	margin-left: 8px;
	color: var(--wpsd-muted);
	text-decoration: none;
	font-weight: 400;
	opacity: 0;
	transition: opacity .15s;
}
.wpsd-main-inner h2:hover .wpsd-headerlink,
.wpsd-main-inner h3:hover .wpsd-headerlink,
.wpsd-headerlink:focus { opacity: 1; }
.wpsd-headerlink:hover { color: var(--wpsd-accent); }

/* ---- Announcement bar ---- */
.wpsd-announcement {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 10px 48px 10px 20px;
	font-size: 14px;
	line-height: 1.4;
	text-align: center;
	background: var(--wpsd-ann-bg, #111827);
	color: var(--wpsd-ann-fg, #ffffff);
}
html[data-wpsd-theme="dark"] .wpsd-announcement {
	background: var(--wpsd-ann-bg-dark, #1f2937);
	color: var(--wpsd-ann-fg-dark, #f9fafb);
}
.wpsd-announcement-inner { max-width: 1100px; }
.wpsd-announcement-link { text-decoration: underline; }
.wpsd-announcement-link:hover { text-decoration: none; }
.wpsd-announcement-close {
	position: absolute;
	right: 12px;
	top: 50%;
	transform: translateY(-50%);
	background: transparent;
	border: 0;
	cursor: pointer;
	padding: 6px;
	opacity: .8;
	display: inline-flex;
}
.wpsd-announcement-close:hover { opacity: 1; }
.wpsd-rtl .wpsd-announcement { padding: 10px 20px 10px 48px; }
.wpsd-rtl .wpsd-announcement-close { right: auto; left: 12px; }

/* ---- Keyboard shortcuts overlay ---- */
.wpsd-shortcuts-modal {
	position: fixed;
	inset: 0;
	z-index: 300;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 20px;
}
.wpsd-shortcuts-modal[hidden] { display: none; }
.wpsd-shortcuts-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, .5);
}
.wpsd-shortcuts-panel {
	position: relative;
	background: var(--wpsd-card-bg);
	border: 1px solid var(--wpsd-border);
	border-radius: var(--wpsd-radius);
	max-width: 480px;
	width: 100%;
	padding: 24px 28px;
	box-shadow: 0 20px 60px rgba(0, 0, 0, .25);
}
.wpsd-shortcuts-panel h2 {
	margin: 0 0 16px;
	font-size: 18px;
	color: var(--wpsd-text);
}
.wpsd-shortcuts-list { list-style: none; margin: 0; padding: 0; }
.wpsd-shortcuts-list li {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 10px 0;
	border-bottom: 1px solid var(--wpsd-border);
	color: var(--wpsd-text);
	font-size: 14px;
}
.wpsd-shortcuts-list li:last-child { border-bottom: 0; }
.wpsd-kbd {
	display: inline-block;
	padding: 3px 8px;
	border: 1px solid var(--wpsd-border);
	border-radius: 4px;
	background: var(--wpsd-hover-bg);
	font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
	font-size: 12px;
	color: var(--wpsd-text);
	min-width: 22px;
	text-align: center;
}
.wpsd-kbd + .wpsd-kbd { margin-left: 4px; }

/* ---- 404 page ---- */
.wpsd-404 {
	text-align: center;
	padding: 60px 20px;
	max-width: 680px;
	margin: 0 auto;
}
.wpsd-404 h2 {
	font-size: 32px;
	margin: 0 0 16px;
	color: var(--wpsd-text);
}
.wpsd-404 p {
	color: var(--wpsd-muted);
	font-size: 16px;
	line-height: 1.6;
}

/* ---- Light/Dark mode logos ---- */
/* The template emits both <img> tags; CSS shows the matching one. When only
   one logo is configured the renderer falls back to the same src for both. */
.wpsd-logo-dark { display: none; }
html[data-wpsd-theme="dark"] .wpsd-logo-light { display: none; }
html[data-wpsd-theme="dark"] .wpsd-logo-dark  { display: inline-block; }

/* ---- Hide product switcher button on mobile (drawer has its own) ---- */
@media (max-width: 900px) {
	.wpsd-product-switcher-btn { display: none !important; }
}

/* ---- Light/Dark mode footer logos ---- */
/* Same pattern as the topbar dual logo: emit both, hide the inactive one. */
.wpsd-footer-logo-dark { display: none; }
html[data-wpsd-theme="dark"] .wpsd-footer-logo-light { display: none; }
html[data-wpsd-theme="dark"] .wpsd-footer-logo-dark  { display: inline-block; }

/* ============================================================
   v1.31: Code blocks, callouts, mermaid, katex, versioning
   ============================================================ */

/* ---- Callouts (admonitions) ---- */
.wpsd-callout {
	display: flex;
	gap: 14px;
	margin: 24px 0;
	padding: 16px 20px;
	border-radius: var(--wpsd-radius);
	border-left: 4px solid;
	background: var(--wpsd-hover-bg);
}
.wpsd-rtl .wpsd-callout { border-left: 0; border-right: 4px solid; }
.wpsd-callout-icon {
	flex-shrink: 0;
	width: 22px;
	height: 22px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.wpsd-callout-icon svg { width: 22px; height: 22px; }
.wpsd-callout-body { flex: 1; min-width: 0; }
.wpsd-callout-title {
	font-weight: 700;
	font-size: 14px;
	margin-bottom: 6px;
	color: var(--wpsd-text);
	text-transform: uppercase;
	letter-spacing: .04em;
}
.wpsd-callout-content { color: var(--wpsd-text); font-size: 15px; line-height: 1.6; }
.wpsd-callout-content p:first-child { margin-top: 0; }
.wpsd-callout-content p:last-child  { margin-bottom: 0; }

/* Type colors */
.wpsd-callout-info    { border-color: #3b82f6; background: rgba(59, 130, 246, .08); }
.wpsd-callout-info    .wpsd-callout-icon, .wpsd-callout-info    .wpsd-callout-title { color: #1e40af; }
.wpsd-callout-tip     { border-color: #10b981; background: rgba(16, 185, 129, .08); }
.wpsd-callout-tip     .wpsd-callout-icon, .wpsd-callout-tip     .wpsd-callout-title { color: #047857; }
.wpsd-callout-warning { border-color: #f59e0b; background: rgba(245, 158, 11, .08); }
.wpsd-callout-warning .wpsd-callout-icon, .wpsd-callout-warning .wpsd-callout-title { color: #b45309; }
.wpsd-callout-danger  { border-color: #ef4444; background: rgba(239, 68, 68, .08); }
.wpsd-callout-danger  .wpsd-callout-icon, .wpsd-callout-danger  .wpsd-callout-title { color: #b91c1c; }
.wpsd-callout-note    { border-color: #6b7280; background: rgba(107, 114, 128, .08); }
.wpsd-callout-note    .wpsd-callout-icon, .wpsd-callout-note    .wpsd-callout-title { color: #374151; }

html[data-wpsd-theme="dark"] .wpsd-callout-info    .wpsd-callout-icon, html[data-wpsd-theme="dark"] .wpsd-callout-info    .wpsd-callout-title { color: #93c5fd; }
html[data-wpsd-theme="dark"] .wpsd-callout-tip     .wpsd-callout-icon, html[data-wpsd-theme="dark"] .wpsd-callout-tip     .wpsd-callout-title { color: #6ee7b7; }
html[data-wpsd-theme="dark"] .wpsd-callout-warning .wpsd-callout-icon, html[data-wpsd-theme="dark"] .wpsd-callout-warning .wpsd-callout-title { color: #fcd34d; }
html[data-wpsd-theme="dark"] .wpsd-callout-danger  .wpsd-callout-icon, html[data-wpsd-theme="dark"] .wpsd-callout-danger  .wpsd-callout-title { color: #fca5a5; }
html[data-wpsd-theme="dark"] .wpsd-callout-note    .wpsd-callout-icon, html[data-wpsd-theme="dark"] .wpsd-callout-note    .wpsd-callout-title { color: #d1d5db; }

/* ---- Enhanced code blocks ---- */
.wpsd-doc-content pre[class*="language-"],
.wpsd-doc-content .wp-block-code,
.wpsd-doc-content pre {
	position: relative;
	padding-top: 36px !important;
	border-radius: var(--wpsd-radius);
	overflow-x: auto;
}
.wpsd-code-frame {
	position: relative;
	margin: 20px 0;
}
.wpsd-code-lang-label {
	position: absolute;
	top: 8px;
	left: 14px;
	font-size: 11px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .06em;
	color: #94a3b8;
	font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
	pointer-events: none;
	z-index: 2;
}
.wpsd-rtl .wpsd-code-lang-label { left: auto; right: 14px; }
.wpsd-code-copy-btn {
	position: absolute;
	top: 6px;
	right: 8px;
	z-index: 2;
	padding: 4px 10px;
	font-size: 11px;
	font-weight: 600;
	color: #cbd5e1;
	background: rgba(255, 255, 255, .08);
	border: 1px solid rgba(255, 255, 255, .12);
	border-radius: 4px;
	cursor: pointer;
	transition: all .15s;
	font-family: inherit;
}
.wpsd-rtl .wpsd-code-copy-btn { right: auto; left: 8px; }
.wpsd-code-copy-btn:hover {
	background: rgba(255, 255, 255, .16);
	color: #fff;
}
.wpsd-code-copy-btn.is-copied {
	background: #10b981;
	color: #fff;
	border-color: #10b981;
}

/* Multi-language tabs */
.wpsd-code-tabs { margin: 20px 0; }
.wpsd-code-tabs-nav {
	display: flex;
	gap: 2px;
	border-bottom: 1px solid var(--wpsd-border);
	margin-bottom: 0;
	overflow-x: auto;
}
.wpsd-code-tabs-btn {
	padding: 10px 18px;
	font-size: 13px;
	font-weight: 600;
	color: var(--wpsd-muted);
	background: transparent;
	border: 0;
	border-bottom: 2px solid transparent;
	cursor: pointer;
	font-family: inherit;
	white-space: nowrap;
	transition: all .15s;
}
.wpsd-code-tabs-btn:hover { color: var(--wpsd-text); }
.wpsd-code-tabs-btn.is-active {
	color: var(--wpsd-accent);
	border-bottom-color: var(--wpsd-accent);
}
.wpsd-code-tabs-panel { display: none; }
.wpsd-code-tabs-panel.is-active { display: block; }
.wpsd-code-tabs-panel pre { margin-top: 0; border-top-left-radius: 0; border-top-right-radius: 0; }

/* ---- Mermaid diagrams ---- */
.wpsd-mermaid-diagram {
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 24px 0;
	padding: 24px;
	background: var(--wpsd-hover-bg);
	border: 1px solid var(--wpsd-border);
	border-radius: var(--wpsd-radius);
	overflow-x: auto;
}
.wpsd-mermaid-diagram svg { max-width: 100%; height: auto; }

/* ---- KaTeX math ---- */
.wpsd-doc-content .katex-display {
	margin: 20px 0;
	overflow-x: auto;
	overflow-y: hidden;
	padding: 8px 0;
}
.wpsd-doc-content .katex { font-size: 1.05em; }

/* ---- Version switcher button (desktop topbar) ---- */
.wpsd-version-toggle {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 10px 12px 10px 12px;
	font-size: 13px;
	font-weight: 600;
	color: var(--wpsd-text);
	background: var(--wpsd-card-bg);
	border: 1px solid var(--wpsd-border);
	border-radius: 6px;
	cursor: pointer;
	font-family: inherit;
	transition: all .15s;
}
.wpsd-version-toggle:hover { border-color: var(--wpsd-accent); color: var(--wpsd-accent); }
.wpsd-version-toggle svg { flex-shrink: 0; }
.wpsd-version-toggle .wpsd-version-current { white-space: nowrap; }
/* Hide the desktop topbar version button on mobile — the mobile drawer
   has its own version button so this would be a duplicate. Same 900px
   breakpoint the rest of the desktop topbar collapses at. */
@media (max-width: 900px) {
	.wpsd-version-toggle { display: none !important; }
}

/* Modals opened from inside the mobile drawer (z 1100) need to sit above
   it. Without this they render BEHIND the drawer panel and are invisible. */
.wpsd-version-modal { z-index: 1300; }
#wpsd-product-modal  { z-index: 1300; }

/* ---- Mobile drawer version section ---- */
.wpsd-drawer-versions {
	padding: 14px 20px 14px;
	border-bottom: 1px solid var(--wpsd-border);
	margin-bottom: 10px;
}
.wpsd-drawer-section-label {
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .06em;
	color: var(--wpsd-muted);
	margin-bottom: 8px;
}
.wpsd-drawer-version-toggle {
	display: flex;
	align-items: center;
	gap: 10px;
	width: 100%;
	padding: 12px 14px;
	font-size: 14px;
	font-weight: 600;
	color: var(--wpsd-text);
	background: var(--wpsd-card-bg);
	border: 1px solid var(--wpsd-border);
	border-radius: 8px;
	cursor: pointer;
	font-family: inherit;
	text-align: left;
}
.wpsd-rtl .wpsd-drawer-version-toggle { text-align: right; }
.wpsd-drawer-version-toggle svg { flex-shrink: 0; }
.wpsd-drawer-version-toggle span { flex: 1; }
.wpsd-drawer-version-toggle .wpsd-chevron { color: var(--wpsd-muted); }

/* ---- Version modal items (reuses .wpsd-modal shell from language modal) ---- */
.wpsd-version-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 4px;
}
.wpsd-version-item {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 14px 16px;
	border-radius: 10px;
	text-decoration: none;
	color: var(--wpsd-text);
	border: 1px solid transparent;
	transition: all .12s;
}
.wpsd-version-item:hover {
	background: var(--wpsd-hover-bg);
	border-color: var(--wpsd-border);
}
.wpsd-version-item.is-current {
	background: var(--wpsd-accent-bg);
	border-color: var(--wpsd-accent);
}
.wpsd-version-item-name {
	flex: 1;
	font-size: 15px;
	font-weight: 600;
}
.wpsd-version-item-desc {
	font-size: 13px;
	color: var(--wpsd-muted);
	font-weight: 400;
	margin-left: 8px;
}
.wpsd-rtl .wpsd-version-item-desc { margin-left: 0; margin-right: 8px; }
.wpsd-version-check { color: var(--wpsd-accent); flex-shrink: 0; }

/* ---- Product index page enrichment: category cards + popular ---- */
.wpsd-product-cats {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 16px;
	margin: 32px 0;
}
.wpsd-product-cat-card {
	display: flex;
	align-items: center;
	gap: 20px;
	padding: 22px 24px;
	background: var(--wpsd-card-bg);
	border: 1px solid var(--wpsd-border);
	border-radius: var(--wpsd-radius);
	text-decoration: none;
	color: var(--wpsd-text);
	transition: all .15s;
}
.wpsd-product-cat-card:hover {
	border-color: var(--wpsd-accent);
	transform: translateY(-1px);
	box-shadow: 0 4px 16px rgba(0, 0, 0, .06);
}
.wpsd-product-cat-card-icon {
	flex-shrink: 0;
	font-size: 28px;
	line-height: 1;
	display: flex;
	align-items: center;
	justify-content: center;
}
.wpsd-product-cat-card-icon img { height: 50px; width: auto; display: block; }
.wpsd-product-cat-card-body {
	flex: 1;
	min-width: 0;
}
.wpsd-product-cat-card-title {
	font-size: 17px;
	font-weight: 700;
	color: var(--wpsd-accent);
	text-decoration: underline;
	text-underline-offset: 2px;
	margin: 0 0 6px;
}
.wpsd-product-cat-card-desc {
	font-size: 14px;
	color: var(--wpsd-muted);
	margin: 0 0 8px;
	line-height: 1.5;
}
.wpsd-product-cat-card-count {
	font-size: 12px;
	color: var(--wpsd-accent);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .04em;
	text-decoration: none;
}
.wpsd-main-inner h3 { margin-top: 0; }

.wpsd-product-section-heading {
	font-size: 14px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .06em;
	color: var(--wpsd-muted);
	margin: 40px 0 16px;
}

/* ─── AI Summary block (v1.2.0) ─────────────────────────────────────────── */
.wpsd-ai-summary {
	display: flex;
	gap: 10px;
	align-items: flex-start;
	background: var(--wpsd-surface-alt, #f6f8fa);
	border-left: 3px solid var(--wpsd-accent, #0073aa);
	border-radius: 6px;
	padding: 12px 16px;
	margin: 0 0 24px;
}
[data-wpsd-theme="dark"] .wpsd-ai-summary {
	background: rgba(255,255,255,.05);
	border-left-color: var(--wpsd-accent, #5badff);
}
.wpsd-ai-summary__icon {
	font-size: 16px;
	line-height: 1.6;
	color: var(--wpsd-accent, #0073aa);
	flex-shrink: 0;
}
[data-wpsd-theme="dark"] .wpsd-ai-summary__icon {
	color: var(--wpsd-accent, #5badff);
}
.wpsd-ai-summary__text {
	margin: 0;
	font-size: 14px;
	line-height: 1.65;
	color: var(--wpsd-muted);
}

/* ─── Ask AI button (desktop topbar) ─────────────────────────────────────── */
.wpsd-ask-btn-desktop {
	display: none; /* shown at ≥769px via media query below */
	align-items: center;
	gap: 6px;
	padding: 0 10px;
	height: 36px;
	background: transparent;
	border: 1px solid var(--wpsd-border);
	border-radius: 8px;
	color: var(--wpsd-text);
	cursor: pointer;
	font: inherit;
	font-size: 13px;
	white-space: nowrap;
	transition: background-color .15s, border-color .15s;
	flex-shrink: 0;
}
.wpsd-ask-btn-desktop:hover {
	background: var(--wpsd-hover-bg);
	border-color: var(--wpsd-accent);
	color: var(--wpsd-text); /* keep text colour — border shifts, not text */
}
@media (min-width: 769px) {
	.wpsd-ask-btn-desktop { display: inline-flex; }
}

/* ─── Ask AI icon (mobile topbar) ────────────────────────────────────────── */
.wpsd-mobile-ask-toggle {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 36px;
	padding: 0 10px;
	background: transparent;
	border: 1px solid var(--wpsd-border);
	border-radius: 8px;
	color: var(--wpsd-text);
	cursor: pointer;
	font: inherit;
	font-size: 13px;
	white-space: nowrap;
	transition: background-color .15s, border-color .15s;
}
.wpsd-mobile-ask-toggle:hover {
	background: var(--wpsd-hover-bg);
	border-color: var(--wpsd-accent);
	color: var(--wpsd-text);
}
@media (min-width: 769px) {
	.wpsd-mobile-ask-toggle { display: none; }
}

/* ─── Ask AI modal ───────────────────────────────────────────────────────── */
/* IMPORTANT: explicit [hidden] rule prevents display:flex from overriding
   the hidden attribute — without this the modal shows on every page load. */
.wpsd-ask-modal[hidden] { display: none !important; }

.wpsd-ask-modal {
	position: fixed;
	inset: 0;
	z-index: 9998;
	display: flex;
	align-items: flex-end; /* bottom sheet on mobile */
	justify-content: center;
}
@media (min-width: 640px) {
	.wpsd-ask-modal {
		align-items: center; /* centered dialog on desktop */
	}
}
.wpsd-ask-modal-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(0,0,0,.45);
	backdrop-filter: blur(2px);
}
.wpsd-ask-modal-panel {
	position: relative;
	z-index: 1;
	width: 100%;
	max-width: 640px;
	max-height: 90vh;
	background: var(--wpsd-surface, #fff);
	border-radius: 16px 16px 0 0;
	display: flex;
	flex-direction: column;
	overflow: hidden;
	box-shadow: 0 -4px 32px rgba(0,0,0,.15);
}
@media (min-width: 640px) {
	.wpsd-ask-modal-panel {
		border-radius: 16px;
		box-shadow: 0 8px 48px rgba(0,0,0,.18);
	}
}
[data-wpsd-theme="dark"] .wpsd-ask-modal-panel {
	background: var(--wpsd-surface, #1e2028);
}

/* Header */
.wpsd-ask-modal-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 16px 18px 14px;
	border-bottom: 1px solid var(--wpsd-border, #e5e7eb);
	flex-shrink: 0;
}
.wpsd-ask-modal-title-row {
	display: flex;
	align-items: center;
	gap: 8px;
}
.wpsd-ask-modal-sparkle {
	color: var(--wpsd-accent, #0073aa);
}
[data-wpsd-theme="dark"] .wpsd-ask-modal-sparkle {
	color: var(--wpsd-accent, #5badff);
}
.wpsd-ask-modal-header h2 {
	font-size: 16px;
	font-weight: 700;
	margin: 0;
	color: var(--wpsd-text, #111);
}
[data-wpsd-theme="dark"] .wpsd-ask-modal-header h2 {
	color: var(--wpsd-text, #e5e7eb);
}
.wpsd-ask-modal-close {
	width: 32px;
	height: 32px;
	border-radius: 6px;
	border: none;
	background: none;
	cursor: pointer;
	color: var(--wpsd-muted, #6b7280);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	transition: background .15s;
	flex-shrink: 0;
}
.wpsd-ask-modal-close:hover {
	background: var(--wpsd-surface-alt, #f3f4f6);
	color: var(--wpsd-text, #111);
}

/* Body */
.wpsd-ask-modal-body {
	padding: 16px 18px 20px;
	display: flex;
	flex-direction: column;
	gap: 16px;
	overflow-y: auto;
	flex: 1;
}

/* Input row */
.wpsd-ask-input-row {
	display: flex;
	gap: 8px;
}
.wpsd-ask-input {
	flex: 1;
	height: 42px;
	padding: 0 14px;
	border: 1.5px solid var(--wpsd-border, #d1d5db);
	border-radius: 10px;
	font-size: 14px;
	background: var(--wpsd-surface, #fff);
	color: var(--wpsd-text, #111);
	outline: none;
	transition: border-color .15s;
}
.wpsd-ask-input:focus {
	border-color: var(--wpsd-accent, #0073aa);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--wpsd-accent, #0073aa) 15%, transparent);
}
[data-wpsd-theme="dark"] .wpsd-ask-input {
	background: var(--wpsd-surface-alt, #2a2d36);
	border-color: var(--wpsd-border, #3d4048);
	color: var(--wpsd-text, #e5e7eb);
}
.wpsd-ask-submit {
	height: 42px;
	padding: 0 16px;
	border-radius: 10px;
	border: none;
	background: var(--wpsd-accent, #0073aa);
	color: #fff;
	font-size: 14px;
	font-weight: 600;
	cursor: pointer;
	display: flex;
	align-items: center;
	gap: 6px;
	white-space: nowrap;
	transition: opacity .15s;
	flex-shrink: 0;
}
.wpsd-ask-submit:hover { opacity: .88; }
.wpsd-ask-submit:disabled { opacity: .5; cursor: not-allowed; }

/* Empty state */
.wpsd-ask-empty-state {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 12px;
	padding: 28px 0;
	color: var(--wpsd-muted, #9ca3af);
	text-align: center;
}
.wpsd-ask-empty-state p {
	font-size: 14px;
	line-height: 1.55;
	margin: 0;
}

/* Loading */
.wpsd-ask-loading {
	display: flex;
	align-items: center;
	gap: 10px;
	color: var(--wpsd-muted, #6b7280);
	font-size: 14px;
	padding: 12px 0;
}
.wpsd-ask-spinner {
	width: 18px;
	height: 18px;
	border: 2px solid var(--wpsd-border, #e5e7eb);
	border-top-color: var(--wpsd-accent, #0073aa);
	border-radius: 50%;
	animation: wpsd-spin .7s linear infinite;
	flex-shrink: 0;
}
@keyframes wpsd-spin { to { transform: rotate(360deg); } }

/* Answer */
.wpsd-ask-answer {
	font-size: 14px;
	line-height: 1.65;
	color: var(--wpsd-text, #1a1a1a);
}
[data-wpsd-theme="dark"] .wpsd-ask-answer {
	color: var(--wpsd-text, #e5e7eb);
}
.wpsd-ask-answer p {
	margin: 0 0 10px;
}
.wpsd-ask-answer p:last-child { margin-bottom: 0; }

/* Citations */
.wpsd-ask-citations {
	display: flex;
	flex-direction: column;
	gap: 8px;
	padding-top: 4px;
}
.wpsd-ask-citations-label {
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .06em;
	color: var(--wpsd-muted, #9ca3af);
}
.wpsd-ask-citations-chips {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}
.wpsd-ask-citation-chip {
	display: inline-flex;
	align-items: center;
	padding: 4px 10px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 500;
	background: var(--wpsd-surface-alt, #f3f4f6);
	color: var(--wpsd-accent, #0073aa);
	text-decoration: none;
	border: 1px solid transparent;
	transition: background .15s, border-color .15s;
}
.wpsd-ask-citation-chip:hover {
	background: color-mix(in srgb, var(--wpsd-accent, #0073aa) 10%, transparent);
	border-color: var(--wpsd-accent, #0073aa);
}
[data-wpsd-theme="dark"] .wpsd-ask-citation-chip {
	background: rgba(255,255,255,.07);
	color: var(--wpsd-accent, #5badff);
}
[data-wpsd-theme="dark"] .wpsd-ask-citation-chip:hover {
	background: rgba(255,255,255,.12);
}

/* Error */
.wpsd-ask-error {
	font-size: 13px;
	color: #d63638;
	padding: 10px 0;
}

/* Cached note */
.wpsd-ask-cached-note {
	font-size: 11px;
	color: var(--wpsd-muted, #9ca3af);
	padding-top: 4px;
}

/* ─── Version notices (v1.4.0) ───────────────────────────────────────────── */
.wpsd-vnotice {
	display: flex;
	align-items: flex-start;
	gap: 8px;
	padding: 10px 14px;
	border-radius: 6px;
	font-size: 13px;
	line-height: 1.5;
	margin: 0 0 16px;
}
.wpsd-vnotice svg { flex-shrink: 0; margin-top: 1px; }
.wpsd-vnotice a { color: inherit; font-weight: 600; }

.wpsd-vnotice--old {
	background: #fff8e1;
	border: 1px solid #f0c040;
	color: #5c4a00;
}
[data-wpsd-theme="dark"] .wpsd-vnotice--old {
	background: rgba(240,192,64,.12);
	border-color: rgba(240,192,64,.35);
	color: #f0c040;
}

.wpsd-vnotice--siblings {
	background: var(--wpsd-surface-alt, #f6f8fa);
	border: 1px solid var(--wpsd-border, #e5e7eb);
	color: var(--wpsd-muted);
	flex-wrap: wrap;
}
[data-wpsd-theme="dark"] .wpsd-vnotice--siblings {
	background: rgba(255,255,255,.04);
}

.wpsd-vnotice__label {
	font-weight: 600;
	white-space: nowrap;
}
.wpsd-vnotice__chips {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}
.wpsd-vnotice__chip {
	display: inline-flex;
	align-items: center;
	padding: 2px 10px;
	border-radius: 999px;
	background: var(--wpsd-accent, #0073aa);
	color: #fff !important;
	font-size: 12px;
	font-weight: 600;
	text-decoration: none !important;
	transition: opacity .15s;
}
.wpsd-vnotice__chip:hover { opacity: .85; }
