/* ======================================================
   Armenius PC Builder — storefront styles.
   Mounted by the [armenius_pc_builder] shortcode, scoped
   under `.armenius-pcbuilder`.
   ====================================================== */

.armenius-pcbuilder {
	--armenius-pcb-accent: #FFD300;
	--armenius-pcb-accent-dk: #e6be00;
	--armenius-pcb-accent-lt: rgba(255, 211, 0, 0.12);
	--armenius-pcb-bg: #FFFFFF;
	--armenius-pcb-bg-alt: #FFFFFF;
	--armenius-pcb-border: #EBEBEB;
	--armenius-pcb-text: #1A1A1A;
	--armenius-pcb-text-dim: #767676;
	--armenius-pcb-text-muted: #AAAAAA;
	--armenius-pcb-trans: 0.18s ease;
	--armenius-pcb-shadow-md: 0 4px 20px rgba(0, 0, 0, 0.09);

	font-family: 'Open Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	background: var(--armenius-pcb-bg);
	color: var(--armenius-pcb-text);
	width: 100%;

	display: grid;
	grid-template-columns: 33% 1fr;
	grid-template-rows: 1fr;
	grid-template-areas: "sidebar main";
	min-height: 540px;
}

/* ── Sidebar (left, vertical steps) ──────────────────── */
.armenius-pcb-sidebar {
	grid-area: sidebar;
	background: var(--armenius-pcb-bg-alt);
	overflow-y: auto;
	padding: 0;
	display: flex;
	flex-direction: column;
	align-self: start;
}

.armenius-pcb-steps {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
}

/* ── Step item ───────────────────────────────────────── */
.armenius-pcb-step-item {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	padding: 14px 18px;
	cursor: pointer;
	border-left: 3px solid transparent;
	transition: background var(--armenius-pcb-trans), border-color var(--armenius-pcb-trans);
	user-select: none;
}

.armenius-pcb-step-item:hover {
	background: rgba(255, 211, 0, 0.07);
}

.armenius-pcb-step-item.active {
	border-left-color: var(--armenius-pcb-accent);
	background: var(--armenius-pcb-accent-lt);
}

.armenius-pcb-step-item .step-info {
	display: flex;
	flex-direction: column;
	gap: 3px;
	min-width: 0;
	width: 100%;
}

.armenius-pcb-step-item .step-label {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 2px;
	line-height: 1.25;
	min-width: 0;
}

.armenius-pcb-step-item .step-line {
	display: block;
	max-width: 100%;
}

.armenius-pcb-step-item .step-line--index {
	font-size: 0.72rem;
	font-weight: 600;
	color: var(--armenius-pcb-text-muted);
	text-transform: uppercase;
	letter-spacing: 0.02em;
}

.armenius-pcb-step-item .step-line--name {
	font-size: 0.82rem;
	font-weight: 600;
	color: var(--armenius-pcb-text);
}

.armenius-pcb-step-item.active .step-line--index {
	color: var(--armenius-pcb-accent-dk);
}

/* Selected product preview in sidebar */
.armenius-pcb-step-item .step-selected-preview {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-top: 8px;
	padding: 8px;
	background: #fff;
	border: 1.5px solid var(--armenius-pcb-accent);
}

.armenius-pcb-step-item .step-selected-preview img {
	width: 44px;
	height: 44px;
	object-fit: contain;
	flex-shrink: 0;
	background: #f5f5f5;
	padding: 3px;
}

.armenius-pcb-step-item .preview-details {
	display: flex;
	flex-direction: column;
	gap: 3px;
	min-width: 0;
}

.armenius-pcb-step-item .preview-name {
	font-size: 0.74rem;
	font-weight: 600;
	color: var(--armenius-pcb-text);
	line-height: 1.35;
	word-break: break-word;
}

.armenius-pcb-step-item .preview-price {
	font-size: 0.75rem;
	font-weight: 700;
	color: var(--armenius-pcb-accent-dk);
}

/* ── Main Content ────────────────────────────────────── */
.armenius-pcb-main {
	grid-area: main;
	padding: 0 28px;
	overflow-y: auto;
	background: var(--armenius-pcb-bg);
	position: relative;
}

/* AJAX refresh: match category archive (opacity dim, no blur overlay) */
.armenius-pcb-main.is-loading .armenius-pcb-toolbar,
.armenius-pcb-main.is-loading .armenius-pcb-filters,
.armenius-pcb-main.is-loading .armenius-pcb-grid {
	opacity: 0.55;
	pointer-events: none;
	transition: opacity 0.2s ease;
	user-select: none;
}

.armenius-pcb-catalog-overlay {
	position: absolute;
	inset: 0;
	z-index: 7;
	background: rgb(255 255 255 / 0.62);
	display: flex;
	align-items: center;
	justify-content: center;
	pointer-events: all;
}

.armenius-pcb-catalog-overlay[hidden] {
	display: none;
}

/* ── Loader ──────────────────────────────────────────── */
.armenius-pcb-loader {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: 64px 24px;
	color: var(--armenius-pcb-text-muted);
	font-size: 0.85rem;
	gap: 16px;
}

.armenius-pcb-loader[hidden] {
	display: none;
}

.armenius-pcb-loader__msg {
	margin: 0;
	text-align: center;
	max-width: 28rem;
	line-height: 1.45;
}

.armenius-pcb-spinner {
	width: 36px;
	height: 36px;
	border: 3px solid var(--armenius-pcb-border);
	border-top-color: var(--armenius-pcb-accent);
	border-radius: 50%;
	animation: armenius-pcb-spin 0.7s linear infinite;
}

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

/* ── Product Grid ────────────────────────────────────── */
.armenius-pcb-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 10px;
}

/* ── Product Card ────────────────────────────────────── */
.armenius-pcb-product-card {
	background: #fff;
	border: 1px solid #e7e7e7;
	box-shadow: 0 0 10px 0 rgb(0 0 0 / 0.08);
	cursor: pointer;
	transition: border-color var(--armenius-pcb-trans), box-shadow var(--armenius-pcb-trans);
	display: flex;
	flex-direction: column;
	position: relative;
	overflow: visible;
	padding: 10px;
}

.armenius-pcb-product-card:hover,
.armenius-pcb-product-card:focus-within {
	border-color: #e7e7e7;
	box-shadow: 0 0 10px 0 rgb(0 0 0 / 0.22);
}

.armenius-pcb-product-card.selected {
	border-color: var(--armenius-pcb-accent);
	box-shadow: 0 0 0 2px rgba(255, 211, 0, 0.45), 0 0 10px 0 rgb(0 0 0 / 0.18);
}

.armenius-pcb-product-card .card-img-wrap {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	aspect-ratio: 1 / 1;
	padding: 14px;
	background: #fff;
	overflow: hidden;
	box-sizing: border-box;
}

.armenius-pcb-product-card img {
	display: block;
	max-height: 100%;
	max-width: 100%;
	width: auto;
	height: auto;
	object-fit: contain;
}

.armenius-pcb-card-body {
	padding: 10px 4px 4px;
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.armenius-pcb-card-name {
	font-size: 0.85rem;
	font-weight: 600;
	color: var(--color-dark-2, #2e2e2e);
	margin: 0;
	line-height: 1.4;
	min-height: 2.8em;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.armenius-pcb-card-price {
	font-size: 0.95rem;
	font-weight: 700;
	color: var(--color-dark-2, #1a1a1a);
	margin: 0;
	line-height: 1.2;
}

.armenius-pcb-card-price--free {
	color: var(--armenius-pcb-text-dim);
	font-weight: 600;
}

.armenius-pcb-card-price--no-price {
	min-height: 1.2em;
	margin: 0;
}

.armenius-pcb-step-item .preview-price--no-display {
	display: inline-block;
	min-height: 1em;
	min-width: 1em;
}

.armenius-pcb-card-actions {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-top: auto;
}

.armenius-pcb-card-btn {
	flex: 1;
	padding: 10px 12px;
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.02em;
	text-align: center;
	background: #fff;
	color: var(--color-dark-2, #2e2e2e);
	border: 1.5px solid #e7e7e7;
	cursor: pointer;
	transition: background var(--armenius-pcb-trans), border-color var(--armenius-pcb-trans), color var(--armenius-pcb-trans);
	min-height: 40px;
}

.armenius-pcb-card-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 40px;
	width: 40px;
	height: 40px;
	font-size: 1rem;
	text-decoration: none;
	color: var(--color-dark-2, #2e2e2e);
	background: #fff;
	border: 1.5px solid #e7e7e7;
	transition: color var(--armenius-pcb-trans), border-color var(--armenius-pcb-trans), background var(--armenius-pcb-trans);
}

.armenius-pcb-card-link:hover {
	color: var(--color-dark-2, #2e2e2e);
	border-color: var(--armenius-pcb-accent);
	background: var(--armenius-pcb-accent-lt);
}

.armenius-pcb-product-card:hover .armenius-pcb-card-btn,
.armenius-pcb-product-card:focus-within .armenius-pcb-card-btn {
	border-color: var(--armenius-pcb-accent);
	background: var(--armenius-pcb-accent-lt);
	color: var(--color-dark-2, #2e2e2e);
}

.armenius-pcb-product-card.selected .armenius-pcb-card-btn {
	background: var(--armenius-pcb-accent);
	border-color: var(--armenius-pcb-accent);
	color: var(--color-dark-2, #1a1a1a);
}

/* ── Sidebar Footer (total + cart) ───────────────────── */
.armenius-pcb-sidebar-footer {
	margin-top: auto;
	padding: 16px 18px;
	border-top: 1px solid var(--armenius-pcb-border);
	display: flex;
	flex-direction: column;
	gap: 10px;
}

/* Consolidated picks (mobile only; hidden on wide — see min-width rule below). */
.armenius-pcb-selection-summary {
	margin: 0;
	padding: 12px 16px 14px;
	border-bottom: 1px solid var(--armenius-pcb-border);
	background: #fafafa;
}

.armenius-pcb-selection-summary[hidden] {
	display: none;
}

.armenius-pcb-selection-summary__title {
	margin: 0 0 10px;
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--armenius-pcb-text-muted);
}

.armenius-pcb-selection-summary__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.armenius-pcb-selection-summary__item {
	display: flex;
	flex-direction: column;
	gap: 4px;
	padding: 8px 10px;
	background: #fff;
	border: 1px solid var(--armenius-pcb-border);
	border-radius: var(--radius, 5px);
}

.armenius-pcb-selection-summary__step {
	font-size: 0.68rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.03em;
	color: var(--armenius-pcb-text-dim);
}

.armenius-pcb-selection-summary__row {
	display: flex;
	align-items: center;
	gap: 10px;
	min-width: 0;
}

.armenius-pcb-selection-summary__thumb {
	width: 40px;
	height: 40px;
	object-fit: contain;
	flex-shrink: 0;
	background: #f5f5f5;
	padding: 3px;
	border-radius: 4px;
}

.armenius-pcb-selection-summary__meta {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 4px;
	min-width: 0;
	flex: 1;
}

.armenius-pcb-selection-summary__name {
	font-size: 0.78rem;
	font-weight: 600;
	color: var(--armenius-pcb-text);
	line-height: 1.35;
	word-break: break-word;
}

.armenius-pcb-selection-summary__qty {
	font-weight: 700;
	color: var(--armenius-pcb-text-dim);
}

.armenius-pcb-selection-summary__price {
	font-size: 0.76rem;
	font-weight: 700;
	color: var(--armenius-pcb-accent-dk);
}

.armenius-pcb-selection-summary__price--muted {
	min-height: 1em;
	min-width: 1em;
}

@media (min-width: 1025px) {
	.armenius-pcb-selection-summary {
		display: none !important;
	}
}

.armenius-pcb-total-block {
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-size: 0.85rem;
	color: var(--armenius-pcb-text-dim);
}

.armenius-pcb-total-block strong {
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--armenius-pcb-text);
}

.armenius-pcb-btn-cart {
	position: relative;
	width: 100%;
	min-height: 44px;
	padding: 12px;
	font-size: 0.8rem;
	font-weight: 700;
	text-transform: uppercase;
	background: var(--armenius-pcb-accent);
	color: #1a1a1a;
	border: none;
	cursor: pointer;
	transition: background var(--armenius-pcb-trans), opacity var(--armenius-pcb-trans), color var(--armenius-pcb-trans);
}

.armenius-pcb-btn-cart__feedback,
.armenius-pcb-btn-cart__spinner {
	display: none;
}

.armenius-pcb-btn-cart__icon--added,
.armenius-pcb-btn-cart__icon--error {
	display: none;
}

.armenius-pcb-btn-cart__spinner {
	position: absolute;
	inset: 0;
	margin: auto;
	width: 28px;
	height: 28px;
	border: 3px solid rgb(26 26 26 / 0.2);
	border-top-color: #1a1a1a;
	border-radius: 50%;
	animation: armeniusCartSpin 0.7s linear infinite;
}

.armenius-pcb-btn-cart.is-loading {
	pointer-events: none;
}

.armenius-pcb-btn-cart.is-loading .armenius-pcb-btn-cart__slot {
	visibility: hidden;
}

.armenius-pcb-btn-cart.is-loading .armenius-pcb-btn-cart__spinner {
	display: block;
}

.armenius-pcb-btn-cart.is-added,
.armenius-pcb-btn-cart.is-error {
	pointer-events: none;
}

.armenius-pcb-btn-cart.is-added .armenius-pcb-btn-cart__slot,
.armenius-pcb-btn-cart.is-error .armenius-pcb-btn-cart__slot {
	visibility: hidden;
}

.armenius-pcb-btn-cart.is-added .armenius-pcb-btn-cart__feedback,
.armenius-pcb-btn-cart.is-error .armenius-pcb-btn-cart__feedback {
	display: flex;
	align-items: center;
	justify-content: center;
	position: absolute;
	inset: 0;
}

.armenius-pcb-btn-cart.is-added .armenius-pcb-btn-cart__icon--added {
	display: block;
	color: #fff;
}

.armenius-pcb-btn-cart.is-error .armenius-pcb-btn-cart__icon--error {
	display: block;
	color: #fff;
}

.armenius-pcb-btn-cart.is-added {
	background: #1f8f46;
	color: #fff;
}

.armenius-pcb-btn-cart.is-error {
	background: #c53131;
	color: #fff;
}

.armenius-pcb-btn-cart:hover:not(:disabled):not(.is-loading):not(.is-added):not(.is-error) {
	background: var(--armenius-pcb-accent-dk);
}

.armenius-pcb-btn-cart:disabled:not(.is-loading):not(.is-added):not(.is-error) {
	opacity: 0.35;
	cursor: not-allowed;
}

/* No Assembly sidebar preview */
.step-no-assembly {
	border-color: var(--armenius-pcb-border) !important;
	background: var(--armenius-pcb-bg-alt) !important;
}

/* ── Load more (client-side pagination) ──────────────── */
.armenius-pcb-load-more {
	grid-column: 1 / -1;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 10px;
	padding: 24px 0 8px;
}

.armenius-pcb-load-more__count {
	margin: 0;
	font-size: 0.85rem;
	color: var(--armenius-pcb-text-dim);
}

.armenius-pcb-load-more-btn {
	min-height: 44px;
	padding: 11px 22px;
	font-size: 0.78rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	background: #fff;
	color: var(--color-dark-2, #2e2e2e);
	border: 1.5px solid var(--armenius-pcb-border);
	cursor: pointer;
	transition: background var(--armenius-pcb-trans), border-color var(--armenius-pcb-trans), color var(--armenius-pcb-trans);
}

.armenius-pcb-load-more-btn:hover,
.armenius-pcb-load-more-btn:focus-visible {
	border-color: var(--armenius-pcb-accent);
	background: var(--armenius-pcb-accent-lt);
	outline: none;
}

.armenius-pcb-load-more-btn:active {
	background: var(--armenius-pcb-accent);
	border-color: var(--armenius-pcb-accent);
	color: var(--color-dark-2, #1a1a1a);
}

/* ── Empty / Error States ────────────────────────────── */
.armenius-pcb-state-msg {
	grid-column: 1 / -1;
	text-align: center;
	padding: 60px 24px;
	color: var(--armenius-pcb-text-muted);
	font-size: 0.9rem;
}

.armenius-pcb-state-msg .state-icon {
	font-size: 2.5rem;
	margin-bottom: 12px;
	opacity: 0.35;
}

/* ── Toolbar ─────────────────────────────────────────── */
.armenius-pcb-toolbar {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 0;
}

.armenius-pcb-toolbar[hidden] {
	display: none;
}

.armenius-pcb-filters {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	padding-top: 10px;
	margin-bottom: 18px;
	border-top: 1px solid var(--armenius-pcb-border);
	margin-top: 8px;
}

.armenius-pcb-filters:empty {
	display: none;
}

/* Toolbar search uses the theme-wide `.armenius-infield` floating-label
   pattern (tokens + base in `wp-content/themes/armenius/assets/css/global.css`).
   We only own the wrap's flex sizing here; visual chrome (border, padding,
   focus state) is fully driven by the shared infield rules so the storefront
   reads as one design system. */
.armenius-pcb-search-wrap.armenius-infield {
	flex: 1 1 0;
	min-width: 0;
}

.armenius-pcb-sort-select {
	flex: 0 0 auto;
	width: auto;
	min-width: 0;
	max-width: 220px;
	padding: 11px 14px;
	font-size: 0.95rem;
	min-height: 46px;
	font-family: inherit;
	border: 1.5px solid var(--armenius-pcb-border);
	background: var(--armenius-pcb-bg);
	color: var(--armenius-pcb-text);
	outline: none;
	cursor: pointer;
	transition: border-color var(--armenius-pcb-trans);
	white-space: nowrap;
	box-sizing: border-box;
}

.armenius-pcb-sort-select:focus {
	border-color: var(--armenius-pcb-accent);
}

/* Feature filters: auto-fit content width, never full row. */
.armenius-pcb-feature-select {
	flex: 0 0 auto;
	width: auto;
	min-width: 0;
	max-width: 240px;
	padding: 11px 14px;
	font-size: 0.9rem;
	min-height: 42px;
	box-sizing: border-box;
}

.armenius-pcb-error-msg {
	grid-column: 1 / -1;
	padding: 14px 18px;
	background: rgba(210, 50, 50, 0.06);
	border-left: 3px solid #d43232;
	color: #c03232;
	font-size: 0.85rem;
}

/* ── Responsive ──────────────────────────────────────── */
@media (max-width: 1024px) {
	.armenius-pcbuilder {
		grid-template-columns: 1fr;
		grid-template-areas:
			"sidebar"
			"main";
	}

	.armenius-pcb-sidebar {
		border-bottom: 1px solid var(--armenius-pcb-border);
		overflow: visible;
	}

	.armenius-pcb-sidebar-footer {
		margin-top: 0;
	}

	.armenius-pcb-steps {
		flex-direction: row;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
	}

	.armenius-pcb-step-item {
		flex-direction: column;
		align-items: center;
		text-align: center;
		border-left: none;
		border-bottom: 3px solid transparent;
		padding: 10px 14px;
		gap: 6px;
		flex-shrink: 0;
		max-width: 120px;
	}

	.armenius-pcb-step-item .step-info {
		align-items: center;
	}

	.armenius-pcb-step-item .step-label {
		align-items: center;
		text-align: center;
	}

	.armenius-pcb-step-item .step-line--name {
		display: -webkit-box;
		-webkit-line-clamp: 2;
		-webkit-box-orient: vertical;
		overflow: hidden;
		word-break: break-word;
	}

	.armenius-pcb-step-item .step-selected-preview {
		display: none !important;
	}

	.armenius-pcb-step-item.active {
		border-left-color: transparent;
		border-bottom-color: var(--armenius-pcb-accent);
	}

	/* Category-archive–style toolbar (shortcode pages do not load archive-products.css). */
	.armenius-pcb-toolbar {
		flex-direction: column;
		align-items: stretch;
		gap: 10px;
		margin-bottom: 4px;
	}

	.armenius-pcb-search-wrap.armenius-infield {
		flex: 1 1 auto;
		width: 100%;
		max-width: none;
		min-width: 0;
	}

	.armenius-pcb-search-input {
		font-family: var(--font-body, 'Open Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif);
		font-size: var(--armenius-infield-input-fs, 1rem);
		line-height: var(--armenius-infield-input-lh, 1.35);
		color: #454444;
		background: #eceeef;
		border: 1px solid #ddd;
		border-radius: var(--radius, 5px);
		box-shadow: none;
		box-sizing: border-box;
		width: 100%;
	}

	.armenius-pcb-search-input::placeholder {
		color: #767676;
		opacity: 1;
	}

	/*
	 * ZWSP placeholder: mirror archive infield :placeholder-shown padding when the shopper types.
	 */
	.armenius-pcb-search-wrap.armenius-infield:has(.armenius-pcb-search-input:not(:placeholder-shown)) .armenius-infield__input {
		padding: var(--armenius-infield-pad-y-start-focus) var(--armenius-infield-pad-x-focus) var(--armenius-infield-pad-y-end-focus);
	}

	.armenius-pcb-search-wrap.armenius-infield:has(.armenius-pcb-search-input:not(:placeholder-shown)) .armenius-infield__label {
		inset-inline-start: var(--armenius-infield-pad-x-focus);
		max-width: calc(100% - 2 * var(--armenius-infield-pad-x-focus));
		top: var(--armenius-infield-label-top-focus);
		color: var(--armenius-infield-label-color-focus);
		transform: translateY(0) scale(var(--armenius-infield-label-scale-focus));
	}

	.armenius-pcb-sort-select {
		flex: 1 1 auto;
		width: 100%;
		max-width: none;
		height: 52px;
		margin: 0;
		padding: 0 34px 0 10px;
		font-family: var(--font-body, 'Open Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif);
		font-size: 1rem;
		line-height: normal;
		color: #454444;
		background: #eceeef;
		border: 1px solid #ddd;
		border-radius: var(--radius, 5px);
		box-shadow: none;
		appearance: none;
		-webkit-appearance: none;
		background-image:
			linear-gradient(45deg, transparent 50%, #666 50%),
			linear-gradient(135deg, #666 50%, transparent 50%);
		background-position:
			calc(100% - 15px) 52%,
			calc(100% - 9px) 52%;
		background-size: 6px 6px, 6px 6px;
		background-repeat: no-repeat;
		box-sizing: border-box;
	}

	.armenius-pcb-sort-select:focus {
		border-color: var(--armenius-pcb-accent);
		outline: none;
	}

	.armenius-pcb-instock-label {
		margin-left: 0;
		width: 100%;
		justify-content: flex-start;
		padding: 4px 0;
		min-height: 44px;
		box-sizing: border-box;
	}

	.armenius-pcb-filters {
		flex-direction: column;
		align-items: stretch;
		flex-wrap: nowrap;
		gap: 10px;
		padding-top: 12px;
		margin-top: 6px;
		margin-bottom: 16px;
	}

	.armenius-pcb-feature-select {
		width: 100%;
		max-width: none;
		min-height: 48px;
	}

	.armenius-pcb-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 640px) {
	.armenius-pcb-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 12px;
	}

	.armenius-pcb-main {
		padding: 16px;
	}
}

.armenius-pcb-instock-label {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 0.8rem;
	font-weight: 600;
	color: var(--armenius-pcb-text-dim);
	cursor: pointer;
	white-space: nowrap;
	margin-left: 10px;
}

.armenius-pcb-instock-label input {
	margin: 0;
	cursor: pointer;
}

.armenius-pcb-delivery-badge {
	position: absolute;
	z-index: 2;
	top: 10px;
	inset-inline-start: 10px;
	max-width: min(60%, 9.75rem);
	padding: 4px 7px;
	font-size: 0.6875rem;
	font-weight: 700;
	line-height: 1.25;
	color: #fff;
	background: var(--color-dark-2, #2e2e2e);
	border-radius: var(--radius, 5px);
	box-shadow: 0 1px 6px rgb(0 0 0 / 0.18);
	pointer-events: none;
	text-transform: none;
	text-align: start;
	text-wrap: balance;
}

.armenius-pcb-delivery-badge.wh1 {
	background: #1f8f46;
	color: #fff;
}

.armenius-pcb-delivery-badge.alt {
	background: var(--color-dark-2, #2e2e2e);
	color: #fff;
}

.armenius-pcb-product-card.wh1-stock {
	border-color: #e7e7e7;
}

.armenius-pcb-product-card.wh1-stock.selected {
	border-color: var(--armenius-pcb-accent);
}

.armenius-pcb-build-time {
	font-size: 0.72rem;
	color: var(--armenius-pcb-text-dim);
	margin-bottom: 12px;
	padding: 8px 10px;
	background: #fdfdfd;
	border: 1px solid var(--armenius-pcb-border);
	border-left: 3.5px solid var(--armenius-pcb-accent);
	line-height: 1.4;
}

.armenius-pcb-build-time[hidden] {
	display: none;
}

.armenius-pcb-build-time span {
	display: block;
	font-size: 0.68rem;
	text-transform: uppercase;
	margin-bottom: 2px;
	color: var(--armenius-pcb-text-muted);
}

.armenius-pcb-build-time strong {
	color: var(--armenius-pcb-text);
	font-size: 0.82rem;
	font-weight: 700;
}

/* Sidebar Qty Controls */
.preview-price-row {
	display: flex;
	justify-content: left;
	gap: 5px;
	align-items: center;
}

.step-qty-controls {
	display: flex;
	align-items: center;
	gap: 8px;
	background: #f8f8f8;
	padding: 2px 4px;
	border-radius: 4px;
	border: 1px solid #eee;
}

.qty-btn {
	appearance: none;
	-webkit-appearance: none;
	background: #fff;
	border: 1px solid #ddd;
	width: 20px;
	height: 20px;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	font-size: 14px;
	line-height: 1;
	padding: 0;
	border-radius: 3px;
	color: #333;
	transition: all 0.2s;
}

.qty-btn:hover {
	background: #eee;
	border-color: #ccc;
}

.qty-val {
	font-size: 0.75rem;
	font-weight: 600;
	min-width: 14px;
	text-align: center;
	color: var(--armenius-pcb-text);
}

.remove-product-btn {
	appearance: none;
	-webkit-appearance: none;
	background: transparent;
	border: none;
	padding: 0;
	margin: 0;
	cursor: pointer;
	color: #cc6060;
	font-size: 16px;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: color 0.2s;
}

.remove-product-btn:hover {
	color: #cc0000;
}

/* ── AI Build Wizard Modal ───────────────────────────── */
.armenius-pcb-ai-overlay {
	display: none;
	position: fixed;
	inset: 0;
	background: rgba(0, 0, 0, 0.55);
	z-index: 99999;
	align-items: center;
	justify-content: center;
}

.armenius-pcb-ai-overlay.visible {
	display: flex;
}

.armenius-pcb-ai-modal {
	background: #fff;
	width: 100%;
	max-width: 440px;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.25);
	overflow: hidden;
	animation: armenius-pcb-modal-in 0.22s ease;
}

@keyframes armenius-pcb-modal-in {
	from { transform: translateY(10px) scale(0.97); opacity: 0; }
	to   { transform: translateY(0) scale(1); opacity: 1; }
}

.armenius-pcb-ai-modal-header {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 18px 20px;
	background: #FFD300;
	border-bottom: 2px solid rgba(0, 0, 0, 0.07);
}

.armenius-pcb-ai-modal-icon { font-size: 1.3rem; }

.armenius-pcb-ai-modal-header h3 {
	flex: 1;
	margin: 0;
	font-size: 1rem;
	font-weight: 700;
	color: #1a1a1a;
}

.armenius-pcb-ai-modal-close {
	background: transparent;
	border: none;
	font-size: 1.1rem;
	cursor: pointer;
	color: #1a1a1a;
	padding: 2px 6px;
	opacity: 0.6;
	transition: opacity 0.2s;
}

.armenius-pcb-ai-modal-close:hover { opacity: 1; }

.armenius-pcb-ai-modal-body {
	padding: 24px 20px;
	display: flex;
	flex-direction: column;
	gap: 18px;
}

.armenius-pcb-ai-form-group {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.armenius-pcb-ai-form-group label {
	font-size: 0.78rem;
	font-weight: 600;
	text-transform: uppercase;
	color: #555;
	text-align: left;
}

.armenius-pcb-ai-select,
.armenius-pcb-ai-input {
	width: 100%;
	padding: 10px 12px;
	font-size: 0.88rem;
	font-family: inherit;
	border: 1.5px solid #ddd;
	background: #fafafa;
	color: #1a1a1a;
	outline: none;
	transition: border-color 0.18s;
	box-sizing: border-box;
}

.armenius-pcb-ai-select:focus,
.armenius-pcb-ai-input:focus {
	border-color: #FFD300;
}

.armenius-pcb-ai-submit-btn {
	width: 100%;
	padding: 13px;
	background: #1a1a1a;
	color: #FFD300;
	border: none;
	font-size: 0.9rem;
	font-weight: 700;
	text-transform: uppercase;
	cursor: pointer;
	transition: background 0.2s, opacity 0.2s;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	min-height: 46px;
}

.armenius-pcb-ai-submit-btn:hover:not(:disabled) { background: #333; }
.armenius-pcb-ai-submit-btn:disabled { opacity: 0.6; cursor: wait; }

.armenius-pcb-ai-spinner {
	width: 18px;
	height: 18px;
	border: 2.5px solid rgba(255, 211, 0, 0.3);
	border-top-color: #FFD300;
	border-radius: 50%;
	animation: armenius-pcb-spin 0.7s linear infinite;
}

.armenius-pcb-ai-disclaimer {
	font-size: 0.68rem;
	color: #aaa;
	text-align: center;
	margin: 0;
}

/* ── AI Result Message Panel ─────────────────────────── */
.armenius-pcb-ai-message {
	background: #fffef4;
	border: 1.5px solid #FFD300;
	border-left: 4px solid #FFD300;
	padding: 14px 16px;
	margin-bottom: 20px;
	animation: armenius-pcb-modal-in 0.3s ease;
}

.armenius-pcb-ai-message-header {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 8px;
}

.armenius-pcb-ai-message-icon { font-size: 1rem; }

.armenius-pcb-ai-message-header strong {
	flex: 1;
	font-size: 0.82rem;
	font-weight: 700;
	color: #1a1a1a;
}

.armenius-pcb-ai-message-meta {
	font-size: 0.72rem;
	color: #888;
	font-style: italic;
}

.armenius-pcb-ai-message-close {
	background: transparent;
	border: none;
	cursor: pointer;
	font-size: 0.9rem;
	color: #aaa;
	line-height: 1;
	padding: 0 2px;
}

.armenius-pcb-ai-message-close:hover { color: #333; }

.armenius-pcb-ai-message-text {
	font-size: 0.82rem;
	color: #444;
	line-height: 1.6;
	margin: 0;
}

@keyframes armenius-pcb-shake {
	0%, 100% { transform: translateX(0); }
	20%, 60% { transform: translateX(-6px); }
	40%, 80% { transform: translateX(6px); }
}

.armenius-pcb-ai-input-shake {
	animation: armenius-pcb-shake 0.4s ease;
	border-color: #d43232 !important;
}

.armenius-pcb-ai-progress-msg {
	margin: 10px 0 0 0;
	font-size: 13px;
	color: #666;
	text-align: center;
	min-height: 20px;
	transition: opacity 0.3s ease;
}

.armenius-pcb-spinner-small {
	width: 14px;
	height: 14px;
	border: 2px solid rgba(0, 0, 0, 0.2);
	border-top-color: currentColor;
	border-radius: 50%;
	animation: armenius-pcb-spin 0.7s linear infinite;
	display: inline-block;
}

.armenius-pcb-share-actions {
	display: flex;
	gap: 8px;
	margin-top: 10px;
}

.armenius-pcb-share-btn.ai-checker {
	background: var(--armenius-pcb-accent);
	color: #1a1a1a;
	border: 1px solid var(--armenius-pcb-accent-dk);
}

.armenius-pcb-share-btn.ai-checker:hover {
	background: var(--armenius-pcb-accent-dk);
}

.armenius-pcb-share-btn.ai-checker:disabled {
	opacity: 0.35;
	cursor: not-allowed;
}

.armenius-pcb-share-btn {
	flex: 1;
	padding: 10px;
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	background: #f4f4f4;
	color: #333;
	border: 1px solid #ddd;
	cursor: pointer;
	transition: all var(--armenius-pcb-trans);
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
}

.armenius-pcb-share-btn:hover {
	background: #eee;
	border-color: #ccc;
}

.armenius-pcb-share-btn.copy:active {
	background: #e8e8e8;
}
