/**
 * Products System Styles
 *
 * Covers:
 *  - Product card (archive + related)
 *  - Products archive (filter bar, grid)
 *  - Single product (hero, features, use-cases, gallery, related)
 *  - Shared utilities (badges, btn sizes, breadcrumbs)
 *
 * Design tokens align with style.css CSS variables already
 * defined in the UnicaSuite theme (--color-primary, --color-bg, etc.)
 *
 * @package unicasuite
 */

/* =============================================================
   Shared Utilities
   ============================================================= */

.badge {
	display: inline-flex;
	align-items: center;
	font-size: 0.7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	padding: 2px 10px;
	border-radius: 999px;
	line-height: 1.6;
}

.badge--success  { background: #10B981; color: #fff; }
.badge--warning  { background: #F59E0B; color: #fff; }
.badge--primary  { background: var(--color-primary, #4F46E5); color: #fff; }

.btn--sm {
	font-size: 0.8rem;
	padding: 6px 14px;
}
.btn--lg {
	font-size: 1rem;
	padding: 14px 32px;
}
.btn--ghost {
	background: transparent;
	color: var(--color-primary, #4F46E5);
	border: 1px solid var(--color-primary, #4F46E5);
}
.btn--ghost:hover {
	background: var(--color-primary, #4F46E5);
	color: #fff;
}

.section-title {
	font-size: 1.6rem;
	font-weight: 700;
	margin-bottom: 2rem;
	text-align: center;
}

/* =============================================================
   Breadcrumbs
   ============================================================= */

.product-breadcrumbs {
	padding-top: 1.25rem;
	padding-bottom: 0.5rem;
}

.breadcrumb-list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 4px;
	list-style: none;
	margin: 0;
	padding: 0;
	font-size: 0.82rem;
	color: var(--color-muted, #64748b);
}

.breadcrumb-list a {
	color: var(--color-primary, #4F46E5);
	text-decoration: none;
}
.breadcrumb-list a:hover { text-decoration: underline; }

.breadcrumb-sep { color: var(--color-muted, #94a3b8); }

.breadcrumb-item--current {
	color: var(--color-text, #1e293b);
	font-weight: 600;
}

/* =============================================================
   Product Card — Compact Horizontal (pcard)
   ============================================================= */

.pcard {
	border-radius: var(--radius-lg, 0.75rem);
	border: 1px solid var(--color-border, #e2e8f0);
	background: var(--color-surface, #fff);
	transition: box-shadow 0.2s ease, border-color 0.2s ease;
}

.pcard:hover {
	box-shadow: var(--shadow-md, 0 4px 6px -1px rgba(0,0,0,.07));
	border-color: rgba(var(--color-primary-rgb, 79,70,229), .25);
}

.pcard__link {
	display: flex;
	align-items: center;
	gap: var(--space-4, 1rem);
	padding: var(--space-4, 1rem);
	text-decoration: none;
	color: inherit;
}

.pcard__icon {
	width: 48px;
	height: 48px;
	flex-shrink: 0;
	border-radius: var(--radius-lg, 0.75rem);
	background: var(--color-bg-alt, #f1f5f9);
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
}

.pcard__icon img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	padding: 4px;
}

.pcard__icon-fallback {
	color: var(--color-text-muted, #94a3b8);
}

.pcard__body {
	flex: 1;
	min-width: 0;
}

.pcard__top {
	display: flex;
	align-items: center;
	gap: var(--space-2, 0.5rem);
	margin-bottom: 2px;
}

.pcard__title {
	font-size: var(--text-sm, 0.875rem);
	font-weight: 700;
	margin: 0;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	color: var(--color-heading, #0f172a);
	line-height: 1.3;
}

.pcard__top .badge {
	flex-shrink: 0;
}

.pcard__desc {
	font-size: var(--text-xs, 0.75rem);
	color: var(--color-text-secondary, #475569);
	margin: 0 0 4px;
	line-height: 1.4;
	display: -webkit-box;
	-webkit-line-clamp: 1;
	line-clamp: 1;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.pcard__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	font-size: 0.68rem;
	color: var(--color-text-muted, #94a3b8);
}

.pcard__cat,
.pcard__ver,
.pcard__os {
	white-space: nowrap;
}

.pcard__cat::after,
.pcard__ver::after {
	content: "·";
	margin-left: 6px;
}

.pcard__meta > :last-child::after {
	content: none;
}

.pcard__arrow {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 28px;
	height: 28px;
	border-radius: var(--radius-full, 9999px);
	background: var(--color-bg-alt, #f1f5f9);
	color: var(--color-text-muted, #94a3b8);
	transition: all 0.2s ease;
}

.pcard__arrow svg {
	width: 14px;
	height: 14px;
}

.pcard:hover .pcard__arrow {
	background: var(--color-primary, #4F46E5);
	color: #fff;
	transform: translateX(2px);
}

/* =============================================================
   Products Grid (archive + related) — works with .pcard
   ============================================================= */

.products-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: var(--space-3, 0.75rem);
	padding-top: var(--space-4, 1rem);
	padding-bottom: var(--space-6, 1.5rem);
}

/* =============================================================
   Products Archive
   ============================================================= */

.products-archive__header {
	padding-top: 2.5rem;
	padding-bottom: 1rem;
}

.products-archive__title {
	font-size: 2rem;
	font-weight: 800;
	margin: 0.5rem 0 0.4rem;
}

.products-archive__tagline {
	color: var(--color-muted, #64748b);
	font-size: 1rem;
	margin-bottom: 0;
}

.products-archive__empty {
	grid-column: 1 / -1;
	text-align: center;
	padding: 3rem 1rem;
	color: var(--color-muted, #64748b);
}

/* Filter bar */
.products-filter {
	padding-top: 1rem;
	padding-bottom: 0.5rem;
}

.products-archive__dynamic {
	position: relative;
	transition: opacity 0.18s ease;
}

.products-filter__form {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	align-items: center;
}

.products-filter__select {
	padding: 8px 12px;
	border: 1px solid var(--color-border, #e2e8f0);
	border-radius: 8px;
	background: var(--color-bg, #fff);
	color: var(--color-text, #1e293b);
	font-size: 0.875rem;
	cursor: pointer;
}

.products-filter__count {
	margin: 0;
	font-size: 0.82rem;
	color: var(--color-muted, #64748b);
}

.products-filter__status {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
	margin: 0.5rem 0 0;
}

.products-filter__loading {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.82rem;
	color: var(--color-muted, #64748b);
	opacity: 0;
	visibility: hidden;
	transform: translateY(2px);
	transition: opacity 0.18s ease, transform 0.18s ease, visibility 0.18s ease;
}

.products-filter__loading-spinner {
	width: 16px;
	height: 16px;
	border: 2px solid var(--color-border, #e2e8f0);
	border-top-color: var(--color-primary, #4F46E5);
	border-radius: 50%;
	animation: products-spin 0.7s linear infinite;
}

.products-grid {
	position: relative;
	transition: opacity 0.18s ease;
}

.products-archive.is-loading .products-archive__dynamic {
	opacity: 0.62;
	pointer-events: none;
}

.products-archive.is-loading .products-filter__loading {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

@keyframes products-spin {
	to {
		transform: rotate(360deg);
	}
}

/* Pagination */
.products-pagination {
	display: flex;
	justify-content: center;
	padding: 1.5rem 1rem 3rem;
	gap: 4px;
	flex-wrap: wrap;
}

.products-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 36px;
	height: 36px;
	border: 1px solid var(--color-border, #e2e8f0);
	border-radius: 6px;
	padding: 0 10px;
	text-decoration: none;
	font-size: 0.875rem;
	color: var(--color-text, #1e293b);
	transition: background 0.15s;
}

.products-pagination .page-numbers:hover,
.products-pagination .page-numbers.current {
	background: var(--color-primary, #4F46E5);
	color: #fff;
	border-color: var(--color-primary, #4F46E5);
}

/* =============================================================
   Single Product — New Design (sp-* prefix)
   ============================================================= */

/* -- Breadcrumbs ------------------------------------------------ */

.sp-breadcrumbs {
	padding-top: var(--space-5, 1.25rem);
	padding-bottom: var(--space-2, 0.5rem);
}

/* -- Hero ------------------------------------------------------- */

.sp-hero {
	position: relative;
	overflow: hidden;
	padding: var(--space-12, 3rem) 0 var(--space-10, 2.5rem);
}

.sp-hero__bg {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(135deg,
			rgba(var(--color-primary-rgb, 79,70,229), .08) 0%,
			transparent 60%
		),
		linear-gradient(225deg,
			rgba(var(--color-primary-rgb, 79,70,229), .05) 0%,
			transparent 50%
		);
	z-index: 0;
}

.sp-hero__bg::after {
	content: "";
	position: absolute;
	inset: 0;
	background:
		radial-gradient(600px circle at 20% 60%, rgba(var(--color-primary-rgb, 79,70,229), .06), transparent 60%),
		radial-gradient(400px circle at 80% 30%, rgba(var(--color-primary-rgb, 79,70,229), .04), transparent 50%);
}

.sp-hero__inner {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: auto 1fr auto;
	gap: var(--space-8, 2rem);
	align-items: start;
}

/* Logo */
.sp-hero__logo-wrap {
	display: flex;
	align-items: flex-start;
}

.sp-hero__logo {
	width: 88px;
	height: 88px;
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: var(--radius-xl, 1rem);
	background: var(--color-surface, #fff);
	border: 1px solid var(--color-border, #e2e8f0);
	box-shadow: var(--shadow-md);
	overflow: hidden;
}

.sp-hero__logo img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	padding: 6px;
}

.sp-hero__logo--placeholder {
	color: var(--color-text-muted, #94a3b8);
}

/* Content */
.sp-hero__content {
	min-width: 0;
}

.sp-hero__badges {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-2, 0.5rem);
	margin-bottom: var(--space-3, 0.75rem);
}

.sp-hero__title {
	font-size: var(--text-4xl, 2.25rem);
	font-weight: 800;
	line-height: var(--leading-tight, 1.25);
	margin: 0 0 var(--space-3, 0.75rem);
	color: var(--color-heading, #0f172a);
}

.sp-hero__desc {
	font-size: var(--text-lg, 1.125rem);
	color: var(--color-text-secondary, #475569);
	margin: 0 0 var(--space-4, 1rem);
	line-height: var(--leading-relaxed, 1.75);
	max-width: 560px;
}

.sp-hero__meta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-2, 0.5rem);
	align-items: center;
}

/* Pill badge */
.sp-pill {
	display: inline-flex;
	align-items: center;
	font-size: var(--text-xs, 0.75rem);
	font-weight: 600;
	padding: 3px 10px;
	border-radius: var(--radius-full, 9999px);
	background: var(--color-bg-alt, #f1f5f9);
	color: var(--color-text-secondary, #475569);
	line-height: 1.4;
}

.sp-pill--link {
	color: var(--color-primary, #4F46E5);
	border: 1px solid rgba(var(--color-primary-rgb, 79,70,229), .25);
	background: rgba(var(--color-primary-rgb, 79,70,229), .06);
	text-decoration: none;
	transition: background var(--transition-fast, 150ms ease), color var(--transition-fast, 150ms ease);
}

.sp-pill--link:hover {
	background: var(--color-primary, #4F46E5);
	color: #fff;
}

/* Hero actions */
.sp-hero__actions {
	display: flex;
	flex-direction: column;
	gap: var(--space-4, 1rem);
	align-items: flex-end;
	flex-shrink: 0;
}

/* Download grid */
.sp-dl-grid {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-2, 0.5rem);
}

.sp-dl-btn {
	display: inline-flex;
	align-items: center;
	gap: var(--space-3, 0.75rem);
	padding: var(--space-3, 0.75rem) var(--space-5, 1.25rem);
	border-radius: var(--radius-lg, 0.75rem);
	background: var(--color-primary, #4F46E5);
	color: #fff;
	text-decoration: none;
	font-weight: 600;
	transition: all var(--transition-fast, 150ms ease);
	box-shadow: var(--shadow-sm);
	white-space: nowrap;
}

.sp-dl-btn:hover {
	background: var(--color-primary-hover, #4338CA);
	box-shadow: var(--shadow-md);
	transform: translateY(-1px);
}

.sp-dl-btn__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	opacity: 0.9;
}

.sp-dl-btn__icon svg {
	width: 24px;
	height: 24px;
}

.sp-dl-btn__text {
	display: flex;
	flex-direction: column;
	line-height: 1.2;
}

.sp-dl-btn__label {
	font-size: var(--text-sm, 0.875rem);
	font-weight: 700;
}

.sp-dl-btn__sub {
	font-size: var(--text-xs, 0.75rem);
	opacity: 0.8;
	font-weight: 400;
}

/* Visit website link  */
.sp-site-btn {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2, 0.5rem);
	padding: var(--space-2, 0.5rem) var(--space-4, 1rem);
	border-radius: var(--radius-lg, 0.75rem);
	font-size: var(--text-sm, 0.875rem);
	font-weight: 600;
	color: var(--color-primary, #4F46E5);
	border: 1px solid rgba(var(--color-primary-rgb, 79,70,229), .3);
	text-decoration: none;
	transition: all var(--transition-fast, 150ms ease);
	background: transparent;
}

.sp-site-btn:hover {
	background: var(--color-primary, #4F46E5);
	color: #fff;
	border-color: var(--color-primary, #4F46E5);
}

.sp-site-btn svg {
	width: 16px;
	height: 16px;
}

/* -- Sticky Section Nav ----------------------------------------- */

.sp-nav {
	position: sticky;
	top: var(--header-height, 72px);
	z-index: 90;
	background: var(--color-surface, #fff);
	border-bottom: 1px solid var(--color-border, #e2e8f0);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
}

.sp-nav__inner {
	display: flex;
	gap: var(--space-1, 0.25rem);
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
	padding: var(--space-2, 0.5rem) 0;
}

.sp-nav__inner::-webkit-scrollbar { display: none; }

.sp-nav__link {
	display: inline-flex;
	align-items: center;
	padding: var(--space-2, 0.5rem) var(--space-4, 1rem);
	font-size: var(--text-sm, 0.875rem);
	font-weight: 500;
	color: var(--color-text-secondary, #475569);
	text-decoration: none;
	border-radius: var(--radius-md, 0.5rem);
	white-space: nowrap;
	transition: all var(--transition-fast, 150ms ease);
}

.sp-nav__link:hover,
.sp-nav__link.is-active {
	color: var(--color-primary, #4F46E5);
	background: rgba(var(--color-primary-rgb, 79,70,229), .08);
}

/* -- Sections --------------------------------------------------- */

.sp-section {
	padding: var(--space-12, 3rem) 0;
}

.sp-section--alt {
	background: var(--color-bg-alt, #f8fafc);
}

.sp-section__head {
	display: flex;
	align-items: center;
	gap: var(--space-3, 0.75rem);
	margin-bottom: var(--space-8, 2rem);
}

.sp-section__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: var(--radius-lg, 0.75rem);
	background: rgba(var(--color-primary-rgb, 79,70,229), .1);
	color: var(--color-primary, #4F46E5);
	flex-shrink: 0;
}

.sp-section__icon svg {
	width: 22px;
	height: 22px;
}

.sp-section__title {
	font-size: var(--text-2xl, 1.5rem);
	font-weight: 800;
	margin: 0;
	color: var(--color-heading, #0f172a);
}

.sp-section__body {
	max-width: var(--container-narrow, 768px);
}

/* -- Resource Links ---------------------------------------------- */

.sp-resource-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: var(--space-5, 1.25rem);
}

.sp-resource-card {
	display: flex;
	flex-direction: column;
	gap: var(--space-3, 0.75rem);
	padding: var(--space-6, 1.5rem);
	background: var(--color-surface, #fff);
	border: 1px solid var(--color-border, #e2e8f0);
	border-radius: var(--radius-xl, 1rem);
	color: inherit;
	text-decoration: none;
	box-shadow: var(--shadow-sm);
	transition: transform var(--transition, 250ms ease), box-shadow var(--transition, 250ms ease), border-color var(--transition-fast, 150ms ease);
}

.sp-resource-card:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-md);
	border-color: rgba(var(--color-primary-rgb, 79,70,229), .25);
}

.sp-resource-card__type {
	display: inline-flex;
	align-items: center;
	width: fit-content;
	font-size: var(--text-xs, 0.75rem);
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--color-primary, #4F46E5);
}

.sp-resource-card__title {
	font-size: var(--text-lg, 1.125rem);
	font-weight: 700;
	line-height: 1.4;
	color: var(--color-heading, #0f172a);
}

.sp-resource-card__desc {
	font-size: var(--text-sm, 0.875rem);
	line-height: var(--leading-relaxed, 1.75);
	color: var(--color-text-secondary, #475569);
}

.sp-resource-card__cta {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2, 0.5rem);
	margin-top: auto;
	font-size: var(--text-sm, 0.875rem);
	font-weight: 600;
	color: var(--color-primary, #4F46E5);
}

.sp-resource-card__cta svg {
	width: 14px;
	height: 14px;
	transition: transform var(--transition-fast, 150ms ease);
}

.sp-resource-card:hover .sp-resource-card__cta svg {
	transform: translateX(2px);
}

/* -- Features Grid ---------------------------------------------- */

.sp-features {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: var(--space-5, 1.25rem);
}

.sp-feat {
	display: flex;
	flex-direction: column;
	gap: var(--space-3, 0.75rem);
	padding: var(--space-6, 1.5rem);
	background: var(--color-surface, #fff);
	border-radius: var(--radius-xl, 1rem);
	border: 1px solid var(--color-border, #e2e8f0);
	transition: box-shadow var(--transition, 250ms ease), transform var(--transition, 250ms ease);
}

.sp-feat:hover {
	box-shadow: var(--shadow-md);
	transform: translateY(-2px);
}

.sp-feat__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: var(--radius-lg, 0.75rem);
	background: rgba(var(--color-primary-rgb, 79,70,229), .1);
	color: var(--color-primary, #4F46E5);
	flex-shrink: 0;
}

.sp-feat__icon svg {
	width: 20px;
	height: 20px;
}

.sp-feat__title {
	font-size: var(--text-base, 1rem);
	font-weight: 700;
	margin: 0;
	color: var(--color-heading, #0f172a);
}

.sp-feat__desc {
	font-size: var(--text-sm, 0.875rem);
	color: var(--color-text-secondary, #475569);
	margin: 0;
	line-height: var(--leading-relaxed, 1.75);
}

/* Feature description list (pipe-separated items) */

.sp-feat__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-2, 0.5rem);
}

.sp-feat__list li {
	position: relative;
	padding-left: 1.25em;
	font-size: var(--text-sm, 0.875rem);
	color: var(--color-text-secondary, #475569);
	line-height: var(--leading-relaxed, 1.75);
}

.sp-feat__list li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0.65em;
	width: 6px;
	height: 6px;
	border-radius: var(--radius-full, 9999px);
	background: var(--color-primary, #4F46E5);
	opacity: 0.6;
}

/* -- Use Cases -------------------------------------------------- */

.sp-usecases {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: var(--space-5, 1.25rem);
}

.sp-uc {
	display: flex;
	gap: var(--space-4, 1rem);
	align-items: flex-start;
	padding: var(--space-6, 1.5rem);
	background: var(--color-surface, #fff);
	border-radius: var(--radius-xl, 1rem);
	border: 1px solid var(--color-border, #e2e8f0);
	transition: box-shadow var(--transition, 250ms ease);
}

.sp-uc:hover {
	box-shadow: var(--shadow-md);
}

.sp-uc__num {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: var(--radius-full, 9999px);
	background: var(--color-primary, #4F46E5);
	color: #fff;
	font-size: var(--text-sm, 0.875rem);
	font-weight: 700;
	flex-shrink: 0;
	line-height: 1;
}

.sp-uc__body {
	min-width: 0;
}

.sp-uc__title {
	font-size: var(--text-base, 1rem);
	font-weight: 700;
	margin: 0 0 var(--space-1, 0.25rem);
	color: var(--color-heading, #0f172a);
}

.sp-uc__desc {
	font-size: var(--text-sm, 0.875rem);
	color: var(--color-text-secondary, #475569);
	margin: 0;
	line-height: var(--leading-relaxed, 1.75);
}

/* -- Gallery ---------------------------------------------------- */

.sp-gallery {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	gap: var(--space-4, 1rem);
}

.sp-gallery__item {
	position: relative;
	display: block;
	border-radius: var(--radius-xl, 1rem);
	overflow: hidden;
	border: 1px solid var(--color-border, #e2e8f0);
	transition: box-shadow var(--transition, 250ms ease), transform var(--transition, 250ms ease);
}

.sp-gallery__item:hover {
	box-shadow: var(--shadow-lg);
	transform: translateY(-2px);
}

.sp-gallery__item img {
	width: 100%;
	aspect-ratio: 16 / 10;
	object-fit: cover;
	display: block;
	transition: transform var(--transition-slow, 400ms ease);
}

.sp-gallery__item:hover img {
	transform: scale(1.04);
}

.sp-gallery__hover {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(0, 0, 0, .4);
	color: #fff;
	opacity: 0;
	transition: opacity var(--transition, 250ms ease);
	pointer-events: none;
}

.sp-gallery__item:hover .sp-gallery__hover {
	opacity: 1;
}

.sp-gallery__hover svg {
	width: 28px;
	height: 28px;
}

/* -- Related ---------------------------------------------------- */

.products-grid--related {
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
}

/* -- CTA Section (Get Started) ---------------------------------- */

.sp-cta {
	position: relative;
	padding: var(--space-16, 4rem) 0;
	overflow: hidden;
}

.sp-cta__bg {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(
			135deg,
			rgba(var(--color-primary-rgb, 79,70,229), .06) 0%,
			rgba(var(--color-primary-rgb, 79,70,229), .02) 50%,
			transparent 100%
		);
	z-index: 0;
}

.sp-cta__bg::before {
	content: '';
	position: absolute;
	top: -40%;
	right: -10%;
	width: 500px;
	height: 500px;
	border-radius: 50%;
	background: radial-gradient(
		circle,
		rgba(var(--color-primary-rgb, 79,70,229), .08) 0%,
		transparent 70%
	);
	pointer-events: none;
}

.sp-cta__bg::after {
	content: '';
	position: absolute;
	bottom: -30%;
	left: -5%;
	width: 400px;
	height: 400px;
	border-radius: 50%;
	background: radial-gradient(
		circle,
		rgba(16, 185, 129, .06) 0%,
		transparent 70%
	);
	pointer-events: none;
}

.sp-cta__inner {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: 1fr auto;
	gap: var(--space-10, 2.5rem);
	align-items: center;
	padding: var(--space-10, 2.5rem) var(--space-10, 2.5rem);
	background: var(--color-surface, #fff);
	border-radius: var(--radius-2xl, 1.5rem);
	border: 1px solid var(--color-border, #e2e8f0);
	box-shadow:
		0 4px 24px rgba(0, 0, 0, .04),
		0 1px 4px rgba(0, 0, 0, .02);
}

.sp-cta__content {
	display: flex;
	flex-direction: column;
	gap: var(--space-4, 1rem);
}

.sp-cta__title {
	font-size: var(--text-3xl, 1.875rem);
	font-weight: 800;
	color: var(--color-heading, #0f172a);
	margin: 0;
	line-height: 1.2;
	letter-spacing: -0.01em;
}

.sp-cta__desc {
	font-size: var(--text-lg, 1.125rem);
	color: var(--color-text-secondary, #475569);
	line-height: var(--leading-relaxed, 1.75);
	margin: 0;
	max-width: 540px;
}

.sp-cta__actions {
	display: flex;
	align-items: center;
	gap: var(--space-4, 1rem);
	flex-wrap: wrap;
	margin-top: var(--space-2, 0.5rem);
}

.sp-cta__btn {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2, 0.5rem);
	padding: var(--space-3, 0.75rem) var(--space-7, 1.75rem);
	background: var(--color-primary, #4F46E5);
	color: #fff;
	font-size: var(--text-base, 1rem);
	font-weight: 700;
	border-radius: var(--radius-xl, 1rem);
	text-decoration: none;
	transition:
		background var(--transition, 250ms ease),
		box-shadow var(--transition, 250ms ease),
		transform var(--transition, 250ms ease);
	box-shadow:
		0 2px 8px rgba(var(--color-primary-rgb, 79,70,229), .25),
		0 1px 2px rgba(0, 0, 0, .06);
}

.sp-cta__btn:hover {
	background: var(--color-primary-hover, #4338CA);
	box-shadow:
		0 4px 16px rgba(var(--color-primary-rgb, 79,70,229), .35),
		0 2px 4px rgba(0, 0, 0, .08);
	transform: translateY(-1px);
}

.sp-cta__btn:active {
	transform: translateY(0);
}

.sp-cta__btn svg {
	width: 20px;
	height: 20px;
	flex-shrink: 0;
}

.sp-cta__link {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: var(--text-sm, 0.875rem);
	font-weight: 600;
	color: var(--color-primary, #4F46E5);
	text-decoration: none;
	transition: gap var(--transition, 250ms ease);
}

.sp-cta__link:hover {
	gap: 10px;
}

.sp-cta__link svg {
	width: 14px;
	height: 14px;
	transition: transform var(--transition, 250ms ease);
}

.sp-cta__link:hover svg {
	transform: translateX(2px);
}

/* Trust badges */

.sp-cta__trust {
	list-style: none;
	margin: var(--space-2, 0.5rem) 0 0;
	padding: 0;
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--space-4, 1rem) var(--space-5, 1.25rem);
}

.sp-cta__trust li {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: var(--text-sm, 0.875rem);
	color: var(--color-text-secondary, #475569);
}

.sp-cta__trust li svg {
	width: 14px;
	height: 14px;
	color: #10b981;
	flex-shrink: 0;
}

/* Product logo in CTA */

.sp-cta__visual {
	display: flex;
	align-items: center;
	justify-content: center;
}

.sp-cta__logo {
	width: 120px;
	height: 120px;
	border-radius: var(--radius-2xl, 1.5rem);
	overflow: hidden;
	background: var(--color-bg-alt, #f1f5f9);
	border: 1px solid var(--color-border, #e2e8f0);
	box-shadow: 0 4px 20px rgba(0, 0, 0, .06);
	transition: transform var(--transition-slow, 400ms ease);
}

.sp-cta:hover .sp-cta__logo {
	transform: scale(1.04) rotate(-1deg);
}

.sp-cta__logo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* =============================================================
   Admin meta box styles (loaded in wp-admin only)
   ============================================================= */

.unicasuite-repeater-list {
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin-bottom: 10px;
}

.unicasuite-repeater-item {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	align-items: flex-start;
	padding: 10px;
	background: #f9f9f9;
	border: 1px solid #ddd;
	border-radius: 4px;
}

.unicasuite-repeater-item input.regular-text {
	flex: 0 0 240px;
}

.unicasuite-repeater-item textarea.large-text {
	flex: 1;
	min-width: 200px;
}

/* =============================================================
   Product Tutorial Sections (Quick Help + Workflow Tutorials)
   ============================================================= */

/* -- Section subtitle (shared) ---------------------------------- */

.sp-section__subtitle {
	font-size: var(--text-sm, 0.875rem);
	color: var(--color-text-secondary, #475569);
	margin: var(--space-1, 0.25rem) 0 0;
	line-height: var(--leading-normal, 1.5);
}

/* -- Icon variants ---------------------------------------------- */

.sp-section__icon--help {
	background: rgba(59, 130, 246, .1);
	color: #3b82f6;
}

.sp-section__icon--tutorial {
	background: rgba(16, 185, 129, .1);
	color: #10b981;
}

/* -- Section Guides Grid ---------------------------------------- */

.sp-guides {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: var(--space-3, 0.75rem);
}

/* Tutorial Card — shared base (tcard) */

.tcard {
	display: flex;
	text-decoration: none;
	color: inherit;
	border-radius: var(--radius-xl, 1rem);
	transition:
		box-shadow var(--transition, 250ms ease),
		transform var(--transition, 250ms ease),
		border-color var(--transition, 250ms ease);
}

.tcard:focus-visible {
	outline: 2px solid var(--color-primary, #4F46E5);
	outline-offset: 2px;
}

/* -- Section Guide Card (tcard--section) -- */

.tcard--section {
	align-items: center;
	gap: var(--space-3, 0.75rem);
	padding: var(--space-4, 1rem) var(--space-5, 1.25rem);
	background: var(--color-surface, #fff);
	border: 1px solid var(--color-border, #e2e8f0);
}

.tcard--section:hover {
	box-shadow: var(--shadow-md, 0 4px 12px rgba(0,0,0,.08));
	border-color: rgba(59, 130, 246, .3);
	transform: translateY(-1px);
}

.tcard--section .tcard__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: var(--radius-lg, 0.75rem);
	background: rgba(59, 130, 246, .08);
	color: #3b82f6;
	flex-shrink: 0;
}

.tcard--section .tcard__body {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.tcard--section .tcard__title {
	font-size: var(--text-sm, 0.875rem);
	font-weight: 600;
	color: var(--color-heading, #0f172a);
	line-height: 1.4;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.tcard--section .tcard__subtitle {
	font-size: var(--text-xs, 0.75rem);
	color: var(--color-text-secondary, #475569);
	line-height: 1.5;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.tcard--section .tcard__arrow {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border-radius: var(--radius-full, 9999px);
	background: var(--color-bg-alt, #f1f5f9);
	color: var(--color-text-secondary, #475569);
	flex-shrink: 0;
	transition: background var(--transition, 250ms ease), color var(--transition, 250ms ease), transform var(--transition, 250ms ease);
}

.tcard--section:hover .tcard__arrow {
	background: rgba(59, 130, 246, .12);
	color: #3b82f6;
	transform: translateX(2px);
}

/* -- Workflow Tutorial Card (tcard--workflow) -- */

.sp-workflows {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
	gap: var(--space-5, 1.25rem);
}

.tcard--workflow {
	flex-direction: column;
	overflow: hidden;
	background: var(--color-surface, #fff);
	border: 1px solid var(--color-border, #e2e8f0);
}

.tcard--workflow:hover {
	box-shadow: var(--shadow-lg, 0 8px 24px rgba(0,0,0,.12));
	transform: translateY(-3px);
}

.tcard__thumb {
	position: relative;
	display: block;
	width: 100%;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: var(--color-bg-alt, #f1f5f9);
}

.tcard__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--transition-slow, 400ms ease);
}

.tcard--workflow:hover .tcard__thumb img {
	transform: scale(1.04);
}

.tcard__thumb--placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-text-secondary, #94a3b8);
}

.tcard__play {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(0, 0, 0, .25);
	color: #fff;
	opacity: 0;
	transition: opacity var(--transition, 250ms ease);
}

.tcard--workflow:hover .tcard__play {
	opacity: 1;
}

.tcard__content {
	display: flex;
	flex-direction: column;
	gap: var(--space-2, 0.5rem);
	padding: var(--space-5, 1.25rem);
}

.tcard__meta {
	display: flex;
	align-items: center;
	gap: var(--space-2, 0.5rem);
	flex-wrap: wrap;
}

.tcard__time,
.tcard__steps {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-size: var(--text-xs, 0.75rem);
	color: var(--color-text-secondary, #475569);
}

.tcard__time svg,
.tcard__steps svg {
	width: 14px;
	height: 14px;
}

.tcard--workflow .tcard__title {
	font-size: var(--text-base, 1rem);
	font-weight: 700;
	color: var(--color-heading, #0f172a);
	line-height: 1.4;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.tcard__goal {
	font-size: var(--text-sm, 0.875rem);
	color: var(--color-text-secondary, #475569);
	line-height: var(--leading-relaxed, 1.75);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.tcard__cta {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin-top: var(--space-1, 0.25rem);
	font-size: var(--text-sm, 0.875rem);
	font-weight: 600;
	color: var(--color-primary, #4F46E5);
	transition: gap var(--transition, 250ms ease);
}

.tcard--workflow:hover .tcard__cta {
	gap: 10px;
}

.tcard__cta svg {
	width: 14px;
	height: 14px;
	transition: transform var(--transition, 250ms ease);
}

.tcard--workflow:hover .tcard__cta svg {
	transform: translateX(2px);
}

/* -- Badge sizes -- */

.badge--sm {
	font-size: var(--text-xs, 0.75rem);
	padding: 2px 8px;
	border-radius: var(--radius-full, 9999px);
	font-weight: 600;
	line-height: 1.4;
}

.badge--danger {
	background: rgba(239, 68, 68, .1);
	color: #ef4444;
}

/* -- Show more toggle -- */

.sp-tutorials__more {
	text-align: center;
	margin-top: var(--space-5, 1.25rem);
}

.sp-tutorials__toggle {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2, 0.5rem);
	padding: var(--space-2, 0.5rem) var(--space-5, 1.25rem);
	background: var(--color-surface, #fff);
	border: 1px solid var(--color-border, #e2e8f0);
	border-radius: var(--radius-full, 9999px);
	font-size: var(--text-sm, 0.875rem);
	font-weight: 600;
	color: var(--color-heading, #0f172a);
	cursor: pointer;
	transition: box-shadow var(--transition, 250ms ease), border-color var(--transition, 250ms ease);
}

.sp-tutorials__toggle:hover {
	box-shadow: var(--shadow-sm, 0 1px 4px rgba(0,0,0,.06));
	border-color: var(--color-primary, #4F46E5);
}

.sp-tutorials__toggle[aria-expanded="true"] svg {
	transform: rotate(180deg);
}

/* When collapsed, hide overflow items (JS toggles this) */
.sp-guides[data-collapsed="true"] .tcard--section:nth-child(n+9) {
	display: none;
}

/* =============================================================
   Dark mode overrides
   Uses [data-theme="dark"] to match the theme toggle system.
   ============================================================= */

/* -- Cards (pcard) -- */
[data-theme="dark"] .pcard {
	background: var(--color-surface, #252526);
	border-color: var(--color-border, #3e3e42);
}

[data-theme="dark"] .pcard__icon {
	background: var(--color-surface-alt, #2d2d2d);
}

[data-theme="dark"] .pcard:hover {
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
	border-color: rgba(var(--color-primary-rgb, 129,140,248), .3);
}

[data-theme="dark"] .pcard__arrow {
	background: var(--color-surface-alt, #2d2d2d);
}

[data-theme="dark"] .products-filter__select {
	background: var(--color-surface, #252526);
	border-color: var(--color-border, #3e3e42);
	color: var(--color-text, #d4d4d4);
}

/* -- Single Product (sp-*) Dark Overrides -- */

[data-theme="dark"] .sp-hero__bg {
	background:
		linear-gradient(135deg,
			rgba(var(--color-primary-rgb, 129,140,248), .1) 0%,
			transparent 60%
		),
		linear-gradient(225deg,
			rgba(var(--color-primary-rgb, 129,140,248), .06) 0%,
			transparent 50%
		);
}

[data-theme="dark"] .sp-hero__bg::after {
	background:
		radial-gradient(600px circle at 20% 60%, rgba(var(--color-primary-rgb, 129,140,248), .08), transparent 60%),
		radial-gradient(400px circle at 80% 30%, rgba(var(--color-primary-rgb, 129,140,248), .05), transparent 50%);
}

[data-theme="dark"] .sp-hero__logo {
	background: var(--color-surface, #252526);
	border-color: var(--color-border, #3e3e42);
}

[data-theme="dark"] .sp-pill {
	background: var(--color-surface-alt, #2d2d2d);
	color: var(--color-text-secondary, #9d9d9d);
}

[data-theme="dark"] .sp-pill--link {
	background: rgba(var(--color-primary-rgb, 129,140,248), .12);
	border-color: rgba(var(--color-primary-rgb, 129,140,248), .25);
}

[data-theme="dark"] .sp-dl-btn {
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.4);
}

[data-theme="dark"] .sp-site-btn {
	border-color: rgba(var(--color-primary-rgb, 129,140,248), .35);
}

[data-theme="dark"] .sp-nav {
	background: rgba(30, 30, 30, .92);
	border-color: var(--color-border, #3e3e42);
}

[data-theme="dark"] .sp-section--alt {
	background: var(--color-bg-alt, #252526);
}

[data-theme="dark"] .sp-section__icon {
	background: rgba(var(--color-primary-rgb, 129,140,248), .15);
}

[data-theme="dark"] .sp-feat {
	background: var(--color-surface, #252526);
	border-color: var(--color-border, #3e3e42);
}

[data-theme="dark"] .sp-feat:hover {
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.4);
}

[data-theme="dark"] .sp-feat__icon {
	background: rgba(var(--color-primary-rgb, 129,140,248), .15);
}

[data-theme="dark"] .sp-uc {
	background: var(--color-surface, #252526);
	border-color: var(--color-border, #3e3e42);
}

[data-theme="dark"] .sp-uc:hover {
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.4);
}

[data-theme="dark"] .sp-gallery__item {
	border-color: var(--color-border, #3e3e42);
}

[data-theme="dark"] .sp-gallery__item:hover {
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5);
}

[data-theme="dark"] .sp-gallery__hover {
	background: rgba(0, 0, 0, .55);
}

/* -- Tutorial sections dark -- */

[data-theme="dark"] .sp-section__subtitle {
	color: var(--color-text-secondary, #9d9d9d);
}

[data-theme="dark"] .sp-section__icon--help {
	background: rgba(59, 130, 246, .15);
}

[data-theme="dark"] .sp-section__icon--tutorial {
	background: rgba(16, 185, 129, .15);
}

[data-theme="dark"] .tcard--section {
	background: var(--color-surface, #252526);
	border-color: var(--color-border, #3e3e42);
}

[data-theme="dark"] .tcard--section:hover {
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
	border-color: rgba(59, 130, 246, .35);
}

[data-theme="dark"] .tcard--section .tcard__icon {
	background: rgba(59, 130, 246, .15);
}

[data-theme="dark"] .tcard--section .tcard__title {
	color: var(--color-heading, #e4e4e4);
}

[data-theme="dark"] .tcard--section .tcard__arrow {
	background: var(--color-surface-alt, #2d2d2d);
}

[data-theme="dark"] .tcard--section:hover .tcard__arrow {
	background: rgba(59, 130, 246, .2);
}

[data-theme="dark"] .tcard--workflow {
	background: var(--color-surface, #252526);
	border-color: var(--color-border, #3e3e42);
}

[data-theme="dark"] .tcard--workflow:hover {
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.5);
}

[data-theme="dark"] .tcard__thumb {
	background: var(--color-surface-alt, #2d2d2d);
}

[data-theme="dark"] .tcard--workflow .tcard__title {
	color: var(--color-heading, #e4e4e4);
}

[data-theme="dark"] .tcard__goal {
	color: var(--color-text-secondary, #9d9d9d);
}

[data-theme="dark"] .sp-tutorials__toggle {
	background: var(--color-surface, #252526);
	border-color: var(--color-border, #3e3e42);
	color: var(--color-heading, #e4e4e4);
}

/* -- CTA section dark -- */

[data-theme="dark"] .sp-cta__bg {
	background:
		linear-gradient(
			135deg,
			rgba(var(--color-primary-rgb, 129,140,248), .08) 0%,
			transparent 60%
		);
}

[data-theme="dark"] .sp-cta__bg::before {
	background: radial-gradient(
		circle,
		rgba(var(--color-primary-rgb, 129,140,248), .1) 0%,
		transparent 70%
	);
}

[data-theme="dark"] .sp-cta__bg::after {
	background: radial-gradient(
		circle,
		rgba(16, 185, 129, .08) 0%,
		transparent 70%
	);
}

[data-theme="dark"] .sp-cta__inner {
	background: var(--color-surface, #252526);
	border-color: var(--color-border, #3e3e42);
	box-shadow:
		0 4px 24px rgba(0, 0, 0, .3),
		0 1px 4px rgba(0, 0, 0, .15);
}

[data-theme="dark"] .sp-cta__title {
	color: var(--color-heading, #e4e4e4);
}

[data-theme="dark"] .sp-cta__desc {
	color: var(--color-text-secondary, #9d9d9d);
}

[data-theme="dark"] .sp-cta__btn {
	box-shadow:
		0 2px 12px rgba(var(--color-primary-rgb, 129,140,248), .3),
		0 1px 4px rgba(0, 0, 0, .2);
}

[data-theme="dark"] .sp-cta__btn:hover {
	box-shadow:
		0 4px 20px rgba(var(--color-primary-rgb, 129,140,248), .4),
		0 2px 8px rgba(0, 0, 0, .3);
}

[data-theme="dark"] .sp-cta__trust li {
	color: var(--color-text-secondary, #9d9d9d);
}

[data-theme="dark"] .sp-cta__logo {
	background: var(--color-surface-alt, #2d2d2d);
	border-color: var(--color-border, #3e3e42);
	box-shadow: 0 4px 20px rgba(0, 0, 0, .3);
}

/* =============================================================
   Homepage Products Section (hp-products)
   ============================================================= */

.hp-products {
	padding: var(--space-10, 2.5rem) 0 var(--space-8, 2rem);
}

.hp-products__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: var(--space-4, 1rem);
}

.hp-products__head-left {
	display: flex;
	align-items: center;
	gap: var(--space-2, 0.5rem);
}

.hp-products__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border-radius: var(--radius-md, 0.5rem);
	background: rgba(var(--color-primary-rgb, 79,70,229), .1);
	color: var(--color-primary, #4F46E5);
}

.hp-products__icon svg {
	width: 18px;
	height: 18px;
}

.hp-products__title {
	font-size: var(--text-lg, 1.125rem);
	font-weight: 700;
	margin: 0;
	color: var(--color-heading, #0f172a);
}

.hp-products__viewall {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-size: var(--text-sm, 0.875rem);
	font-weight: 600;
	color: var(--color-primary, #4F46E5);
	text-decoration: none;
	transition: gap 0.2s ease;
}

.hp-products__viewall:hover {
	gap: 8px;
	text-decoration: underline;
}

.hp-products__viewall svg {
	width: 14px;
	height: 14px;
}

.hp-products__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: var(--space-3, 0.75rem);
}

/* =============================================================
   Homepage Blog Section (hp-blog)
   ============================================================= */

.hp-blog {
	padding: var(--space-10, 2.5rem) 0 var(--space-12, 3rem);
}

.hp-blog__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: var(--space-6, 1.5rem);
}

.hp-blog__head-left {
	display: flex;
	align-items: center;
	gap: var(--space-2, 0.5rem);
}

.hp-blog__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border-radius: var(--radius-md, 0.5rem);
	background: rgba(var(--color-primary-rgb, 79,70,229), .1);
	color: var(--color-primary, #4F46E5);
}

.hp-blog__icon svg {
	width: 18px;
	height: 18px;
}

.hp-blog__title {
	font-size: var(--text-lg, 1.125rem);
	font-weight: 700;
	margin: 0;
	color: var(--color-heading, #0f172a);
}

/* =============================================================
   Hero Search Bar (legacy overrides — now in style.css)
   ============================================================= */

/* =============================================================
   Products Archive — Sort & View Toggle
   ============================================================= */

.products-toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 0.75rem;
	padding: 0.75rem 0;
}

.products-sort {
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

.products-sort__label {
	font-size: 0.82rem;
	color: var(--color-muted, #64748b);
	white-space: nowrap;
}

.products-sort__select {
	padding: 6px 10px;
	border: 1px solid var(--color-border, #e2e8f0);
	border-radius: 8px;
	background: var(--color-bg, #fff);
	color: var(--color-text, #1e293b);
	font-size: 0.82rem;
	cursor: pointer;
}

.products-view-toggle {
	display: flex;
	gap: 4px;
}

.products-view-toggle__btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border: 1px solid var(--color-border, #e2e8f0);
	border-radius: 8px;
	background: var(--color-bg, #fff);
	color: var(--color-muted, #64748b);
	cursor: pointer;
	transition: all 0.15s;
}

.products-view-toggle__btn:hover,
.products-view-toggle__btn.is-active {
	background: var(--color-primary, #4F46E5);
	color: #fff;
	border-color: var(--color-primary, #4F46E5);
}

/* List view variant */
.products-grid--list {
	grid-template-columns: 1fr !important;
}

/* =============================================================
   Lightbox
   ============================================================= */

.us-lightbox {
	position: fixed;
	inset: 0;
	z-index: 10000;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(0, 0, 0, 0.92);
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.25s ease, visibility 0.25s ease;
}

.us-lightbox.is-open {
	opacity: 1;
	visibility: visible;
}

.us-lightbox__stage {
	display: flex;
	align-items: center;
	justify-content: center;
	max-width: 90vw;
	max-height: 85vh;
	flex: 1;
}

.us-lightbox__img {
	max-width: 100%;
	max-height: 85vh;
	object-fit: contain;
	border-radius: 8px;
	box-shadow: 0 16px 64px rgba(0, 0, 0, 0.5);
	transition: opacity 0.2s ease;
}

.us-lightbox__img.is-loading {
	opacity: 0.3;
}

.us-lightbox__close {
	position: absolute;
	top: 1rem;
	right: 1rem;
	z-index: 10;
	width: 44px;
	height: 44px;
	display: flex;
	align-items: center;
	justify-content: center;
	border: none;
	background: rgba(255, 255, 255, 0.1);
	color: #fff;
	font-size: 1.75rem;
	border-radius: 50%;
	cursor: pointer;
	transition: background 0.15s;
}

.us-lightbox__close:hover {
	background: rgba(255, 255, 255, 0.25);
}

.us-lightbox__prev,
.us-lightbox__next {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 10;
	width: 44px;
	height: 44px;
	display: flex;
	align-items: center;
	justify-content: center;
	border: none;
	background: rgba(255, 255, 255, 0.1);
	color: #fff;
	border-radius: 50%;
	cursor: pointer;
	transition: background 0.15s;
}

.us-lightbox__prev { left: 1rem; }
.us-lightbox__next { right: 1rem; }

.us-lightbox__prev:hover,
.us-lightbox__next:hover {
	background: rgba(255, 255, 255, 0.25);
}

.us-lightbox__counter {
	position: absolute;
	bottom: 1.25rem;
	left: 50%;
	transform: translateX(-50%);
	color: rgba(255, 255, 255, 0.7);
	font-size: 0.875rem;
	font-variant-numeric: tabular-nums;
}

/* =============================================================
   Responsive
   ============================================================= */

/* ---- Tablet --------------------------------------------------- */
@media (max-width: 900px) {
	.sp-hero__inner {
		grid-template-columns: auto 1fr;
	}

	.sp-hero__actions {
		grid-column: 1 / -1;
		flex-direction: row;
		flex-wrap: wrap;
		align-items: center;
	}

	.sp-guides {
		grid-template-columns: 1fr 1fr;
	}

	.sp-workflows {
		grid-template-columns: 1fr 1fr;
	}

	.sp-cta__inner {
		grid-template-columns: 1fr;
		text-align: center;
		padding: var(--space-8, 2rem);
	}

	.sp-cta__content {
		align-items: center;
	}

	.sp-cta__actions {
		justify-content: center;
	}

	.sp-cta__trust {
		justify-content: center;
	}

	.sp-cta__desc {
		max-width: none;
	}
}

/* ---- Mobile --------------------------------------------------- */
@media (max-width: 640px) {
	/* Single product hero */
	.sp-hero {
		padding: var(--space-8, 2rem) 0 var(--space-6, 1.5rem);
	}

	.sp-hero__inner {
		grid-template-columns: 1fr;
		gap: var(--space-5, 1.25rem);
	}

	.sp-hero__logo-wrap {
		justify-content: center;
	}

	.sp-hero__logo {
		width: 72px;
		height: 72px;
	}

	.sp-hero__content {
		text-align: center;
	}

	.sp-hero__badges {
		justify-content: center;
	}

	.sp-hero__title {
		font-size: var(--text-2xl, 1.5rem);
	}

	.sp-hero__desc {
		font-size: var(--text-base, 1rem);
		max-width: none;
	}

	.sp-hero__meta {
		justify-content: center;
	}

	.sp-hero__actions {
		align-items: stretch;
	}

	.sp-dl-grid {
		flex-direction: column;
	}

	.sp-dl-btn {
		justify-content: center;
	}

	.sp-site-btn {
		justify-content: center;
	}

	/* Sticky nav */
	.sp-nav__link {
		padding: var(--space-2, 0.5rem) var(--space-3, 0.75rem);
		font-size: var(--text-xs, 0.75rem);
	}

	/* Feature cards */
	.sp-features {
		grid-template-columns: 1fr;
	}

	.sp-usecases {
		grid-template-columns: 1fr;
	}

	/* Gallery */
	.sp-gallery {
		grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
		gap: var(--space-3, 0.75rem);
	}

	/* Tutorial grids */
	.sp-guides {
		grid-template-columns: 1fr;
	}

	.sp-workflows {
		grid-template-columns: 1fr;
	}

	/* CTA mobile */
	.sp-cta {
		padding: var(--space-10, 2.5rem) 0;
	}

	.sp-cta__inner {
		grid-template-columns: 1fr;
		text-align: center;
		padding: var(--space-6, 1.5rem);
		gap: var(--space-6, 1.5rem);
	}

	.sp-cta__content {
		align-items: center;
	}

	.sp-cta__title {
		font-size: var(--text-2xl, 1.5rem);
	}

	.sp-cta__desc {
		font-size: var(--text-base, 1rem);
		max-width: none;
	}

	.sp-cta__actions {
		justify-content: center;
		flex-direction: column;
		align-items: stretch;
	}

	.sp-cta__btn {
		justify-content: center;
	}

	.sp-cta__link {
		justify-content: center;
	}

	.sp-cta__trust {
		justify-content: center;
	}

	.sp-cta__visual {
		display: none;
	}

	/* Section padding */
	.sp-section {
		padding: var(--space-8, 2rem) 0;
	}

	.sp-section__title {
		font-size: var(--text-xl, 1.25rem);
	}

	/* Products grid */
	.products-grid,
	.hp-products__grid {
		grid-template-columns: 1fr;
	}

	.products-filter__form {
		flex-direction: column;
		align-items: stretch;
	}

	.products-filter__select {
		width: 100%;
	}

	.us-lightbox__prev,
	.us-lightbox__next {
		display: none;
	}
}
